@charset "utf-8";

:root {
	--pcv: / 1280 * 100vw;
	
	--spv: / 640 * 100vw;
	--spp: / 640 * 100%;
}

/* -------------------------------------------------
	font (M PLUS 1p / Google Fonts)
------------------------------------------------- */

@font-face {
	font-family: 'M PLUS 1p';
	font-weight: 400;
	font-style: normal;
	src: url('../font/M_PLUS_1p/MPLUS1p-Regular.ttf') format('truetype');
}
@font-face {
	font-family: 'M PLUS 1p';
	font-weight: 500;
	font-style: normal;
	src: url('../font/M_PLUS_1p/MPLUS1p-Medium.ttf') format('truetype');
}
@font-face {
	font-family: 'M PLUS 1p';
	font-weight: 700;
	font-style: normal;
	src: url('../font/M_PLUS_1p/MPLUS1p-Bold.ttf') format('truetype');
}

/* -------------------------------------------------
	reset
------------------------------------------------- */

* {
	margin: 0;
	padding: 0;
	vertical-align: top;
	box-sizing: border-box;
}

html {
}

body {
	line-height: 1;
	-webkit-text-size-adjust: 100%;
	position: relative;
	font-family: 'M PLUS 1p', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	font-weight: 400;
	text-align: center;
	color: #333;
}

p, h1, h2, h3, h4, th, td, li, dt, dd, figcaption, input, select, textarea {
	font-weight: 400;
}

img {
	border: none;
	max-width: 100%;
	height: auto;
}

iframe {
	border: none;
}

a {
	text-decoration: none;
	color: #333;
}
a:hover {
	
}

ul, ol {
	list-style-type: none;
}

main {
	width: 100%;
	display: block;
	overflow: hidden;
}

@media print, screen and (min-width:641px) {
	a[href^="tel:"] {
		cursor: default;
	}
}

@media screen and (max-width:640px) {
	
}

/* -------------------------------------------------
	bg
------------------------------------------------- */

.bg-paleblue {
	background: #ddf4ff;
}
.bg-palegreen {
	background: #d6f7f1;
}
.bg-check {
	background: url("../img/bg_check.png") repeat center top;
}

@media screen and (max-width:640px) {
	.bg-check {
		background-size: calc(16 var(--spv)) auto;
	}
}

/* -------------------------------------------------
	box
------------------------------------------------- */

.box640 {
	max-width: 640px;
	margin: 0 auto;
	position: relative;
}

@media screen and (max-width:640px) {
	.box640 {
		width: auto;
	}
	.box-sp {
		width: calc(600 var(--spp));
		margin: 0 auto;
		position: relative;
	}
	.box-sp-narrow {
		width: calc(580 var(--spp));
		margin: 0 auto;
		position: relative;
	}
	.box-sp-narrow2 {
		width: calc(540 var(--spp));
		margin: 0 auto;
		position: relative;
	}
	.box-sp-narrow3 {
		width: calc(516 var(--spp));
		margin: 0 auto;
		position: relative;
	}
}

/* -------------------------------------------------
	h
------------------------------------------------- */

.h-normal {
	margin-bottom: 55px;
	color: #fff;
	font-family: 'Baloo_Bhaina';
	font-size: 38px;
	letter-spacing: 1px;
	text-align: center;
	font-weight: normal;
}

@media screen and (max-width:640px) {
	.h-normal {
		margin-bottom: 30px;
		font-size: 30px;
	}
}

/* -------------------------------------------------
	note
------------------------------------------------- */

.note-style1.white {
	color: #fff;
}
.note-style1 p,
.note-style1 li {
	font-size: 12px;
	line-height: calc(18 / 12);
	text-align: left;
}
.note-style1.center p,
.note-style1.center li {
	text-align: center;
}
.note-style1 .mt {
	margin-top: 1em;
}

@media screen and (max-width:640px) {
	.note-style1 p,
	.note-style1 li {
		font-size: calc(15 var(--spv));
		line-height: calc(25 / 15);
	}
	.note-style1.sp-center p,
	.note-style1.sp-center li {
		text-align: center;
	}
}

/* -------------------------------------------------
	responsive
------------------------------------------------- */

@media print, screen and (min-width:641px) {
	.pc-none {
		display: none !important;
	}
}

@media screen and (max-width:640px) {
	.sp-none {
		display: none !important;
	}
}

/* -------------------------------------------------
	print
------------------------------------------------- */

@media print {
	body {
		width: 980px !important;
	}
}

/* -------------------------------------------------
	header
------------------------------------------------- */

header .col2 {
	height: 78px;
	max-width: 990px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
header .col2 .logo1 {
	padding: 18px 0 0 21px;
}
header .col2 .logo1 img {
	width: 184px;
}
header .col2 .logo2 {
	padding: 27px 21px 0 0;
}
header .col2 .logo2 img {
	width: 269px;
}

@media screen and (max-width:640px) {
	header .col2 {
		height: calc(78 var(--spv));
	}
	header .col2 .logo1 {
		padding: calc(16 var(--spv)) 0 0 calc(20 var(--spv));
	}
	header .col2 .logo1 img {
		width: calc(184 var(--spv));
	}
	header .col2 .logo2 {
		padding: calc(28 var(--spv)) calc(20 var(--spv)) 0 0;
	}
	header .col2 .logo2 img {
		width: calc(269 var(--spv));
	}
}

/* -------------------------------------------------
	.cta-area
------------------------------------------------- */

.cta-area {
	padding: 17px 0 30px;
	background: #29abe1;
}
.cta-area .copy {
	display: block;
	margin: 0 auto;
}
.cta-area .btn {
	margin-top: 12px;
	display: inline-block;
	position: relative;
}
.cta-area .btn::before {
	width: 100%;
	height: 100%;
	display: block;
	content: "";
	border-radius: 34px;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	box-shadow: 5px -3px 20px 0 rgba(0,50,100,0.3);
}
.cta-area .btn img {
	position: relative;
	z-index: 4;
}
.cta-area .note {
	margin-top: 18px;
	color: #fff;
	font-size: 12px;
	letter-spacing: 0.08em;
}

/* fv直下 */
.cta-area.fv {
	background: #ffec94;
}

@media print, screen and (min-width:641px) {
	/* fv直下 */
	.cta-area.fv {
		position: relative;
		z-index: 2;
	}
}

@media screen and (max-width:640px) {
	.cta-area {
		padding: calc(17 var(--spv)) 0 calc(26 var(--spv));
	}
	.cta-area .copy {
		width: calc(329 var(--spv));
	}
	.cta-area .btn {
		margin-top: calc(9 var(--spv));
	}
	.cta-area .btn::before {
		border-radius: calc(34 var(--spv));
		box-shadow: 0.8vw -0.6vw 1.8vw 0 rgba(0,0,0,0.2);
	}
	.cta-area .btn img {
		width: calc(516 var(--spv));
	}
	.cta-area .note {
		margin-top: calc(17 var(--spv));
		font-size: calc(15 var(--spv));
	}
	
	/* fv直下 */
	.cta-area.fv {
		margin-top: -2.9vw;
		position: relative;
		z-index: 2;
	}
}

@media print, screen and (min-width:641px) and (max-width:910px) {
	/* fv直下 */
	.cta-area.fv .copy,
	.cta-area.fv .btn {
		transform: translateX(-84px);
	}
}

/* -------------------------------------------------
	.cta-recommend
------------------------------------------------- */

.cta-recommend {
	padding-top: 33px;
	background: #29abe1;
}
.cta-recommend p {
	height: 90px;
	padding-top: 16px;
	font-size: 20px;
	line-height: 1.5;
	letter-spacing: 0.08em;
	font-weight: 700;
	background: #fff;
	position: relative;
}
.cta-recommend p::before {
	width: 28px;
	height: 55px;
	content: "";
	display: block;
	background: url("../img/fig_light.svg") no-repeat 0 0 / 100% auto;
	position: absolute;
	left: calc(50% - 228px);
	top: -18px;
}

@media screen and (max-width:640px) {
	.cta-recommend {
		padding-top: calc(33 var(--spv));
	}
	.cta-recommend p {
		height: calc(90 var(--spv));
		padding-top: calc(16 var(--spv));
		font-size: calc(20 var(--spv));
	}
	.cta-recommend p::before {
		width: calc(28 var(--spv));
		height: calc(55 var(--spv));
		left: calc(92 var(--spv));
		top: calc(-18 var(--spv));
	}
}

/* -------------------------------------------------
	#fv
------------------------------------------------- */

@media print, screen and (min-width:641px) {
	#fv {
		height: 314px;
		background: #0f99d3;
		position: relative;
		z-index: 12;
	}
	#fv h1 {
		width: 641px;
		position: absolute;
		top: 25px;
		left: calc(50% - 428px);
		z-index: 4;
	}
	#fv .bg {
		max-width: none;
		position: absolute;
		left: 50%;
		bottom: 0;
		z-index: 2;
		transform: translateX(-50%);
	}
	#fv .note-style1 {
		position: absolute;
		z-index: 4;
		left: calc(50% - 428px);
		top: 265px;
	}
	#fv::after {
		width: 249px;
		height: 494px;
		background: url(../img/fig_fv_02.png) no-repeat 0 0 / contain;
		content: "";
		display: block;
		position: absolute;
		left: calc(50% + 228px);
		top: 22px;
	}
}

@media print, screen and (min-width:641px) and (max-width:910px) {
	#fv {
		height: calc(314px * 0.7);
	}
	#fv h1 {
		width: calc(641px * 0.7);
		left: 5%;
		top: calc(25px * 0.7);
	}
	#fv .note-style1 {
		width: calc(641px * 0.7);
		left: 5%;
		top: calc(265px * 0.68);
	}
	#fv .note-style1 br {
		display: none;
	}
	#fv::after {
		width: calc(249px * 0.7);
		height: calc(494px * 0.7);
		left: auto;
		right: -2%;
		top: calc(22px * 0.7);
	}
}

@media screen and (max-width:640px) {
	#fv {
		position: relative;
		z-index: 4;
	}
	#fv h1 {
		width: 100%;
		position: relative;
		left: 0;
		top: 0;
		z-index: 2;
	}
	#fv .note-style1 {
		width: 55%;
		position: absolute;
		z-index: 4;
		left: 10%;
		top: 84%;
		letter-spacing: -0.03em;
	}
	#fv .note-style1 p {
		line-height: calc(17 / 12);
	}
}

/* -------------------------------------------------
	.pamphlet
------------------------------------------------- */

.pamphlet.green {
	background: #d6f7f1;
}

@media print, screen and (min-width:641px) {
	.pamphlet.blue {
		padding-top: 12px;
		background: #ddf4ff;
	}
}

@media screen and (max-width:640px) {
	.pamphlet.blue {
		margin-top: -3vw;
		position: relative;
	}
	.pamphlet.blue::before {
		width: 100%;
		height: calc(234 var(--spv));
		content: "";
		display: block;
		background: #ddf4ff;
		position: absolute;
		left: 0;
		bottom: 0;
		z-index: 2;
	}
	.pamphlet.blue img {
		position: relative;
		z-index: 4;
	}
}

/* -------------------------------------------------
	#points
------------------------------------------------- */

@media print, screen and (min-width:641px) {
	#points .bg-paleblue {
		padding-bottom: 60px;
	}
}

@media screen and (max-width:640px) {
	#points .bg-paleblue {
		padding-bottom: calc(35 var(--spv));
	}
}

/* -------------------------------------------------
	#point1
------------------------------------------------- */

#point1 {
	position: relative;
	z-index: 10;
}

#point1 .bg-check {
	padding: 55px 0 320px;
}

#point1 .lead {
	margin-top: 1.2em;
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 0.08em;
}

#point1 .move {
	width: 100%;
	height: 107px;
	margin-top: 21px;
	overflow: hidden;
}
#point1 .move .bg {
	width: calc(864px * 10);
	height: 100%;
	background: url("../img/bg_01.png") repeat-x 0 0;
	animation: under-fv 16s linear 0s infinite;
}

#point1 .border {
	margin-top: 60px;
	padding-bottom: 14px;
	border-radius: 34px;
	border: solid 3px #333;
	background: #fff;
}
#point1 .border .and1 {
	transform: translateY(-26px);
}
#point1 .border .note {
	margin-top: -18px;
	font-size: 12px;
}
#point1 .border .desc {
	margin-top: 0.8em;
	font-size: 20px;
	line-height: 1.5;
	letter-spacing: 0.06em;
	font-weight: 700;
}
#point1 .and2 {
	margin-top: 36px;
}

@media screen and (max-width:640px) {
	#point1 .bg-check {
		margin-top: 0;
		padding: calc(58 var(--spv)) 0 calc(226 var(--spv));
	}

	#point1 .title img {
		width: calc(428 var(--spv));
	}
	#point1 .lead {
		margin-top: 1em;
		font-size: calc(20 var(--spv));
		line-height: 1.5;
	}

	#point1 .move {
		height: calc(107 var(--spv));
		margin-top: 1vw;
	}
	#point1 .move .bg {
		width: calc(864 * 10 var(--spv));
		background-size: auto 100%;
		animation: under-fv-sp 16s linear 0s infinite;
	}

	#point1 .border {
		margin-top: calc(60 var(--spv));
		padding-bottom: calc(23 var(--spv));
		border-radius: calc(34 var(--spv));
		border-width: calc(3 var(--spv));
	}
	#point1 .border .and1 {
		width: calc(381 var(--spv));
		transform: translateY( calc(-25 var(--spv)) );
	}
	#point1 .border .note {
		margin-top: 0;
		font-size: calc(15 var(--spv));
	}
	#point1 .border .desc {
		margin-top: 0.8em;
		font-size: calc(20 var(--spv));
		line-height: calc(35 / 20);
	}
	#point1 .and2 {
		width: calc(573 var(--spv));
		margin-top: calc(36 var(--spv));
	}
}

@keyframes under-fv {
	0% { transform: translateX(0); }
	100% { transform: translateX(-864px); }
}

@keyframes under-fv-sp {
	0% { transform: translateX(0); }
	100% { transform: translateX( calc(-864 var(--spv)) ); }
}

/* -------------------------------------------------
	#point2
------------------------------------------------- */

#point2 {
	position: relative;
	z-index: 20;
}
#point2 .copy1 {
	max-width: none;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	top: -247px;
	z-index: 2;
}
#point2 .title {
	margin-bottom: -198px;
	transform: translateY(-198px);
	position: relative;
	z-index: 4;
}
#point2 .copy2 {
	margin-top: 31px;
	position: relative;
	z-index: 4;
}
#point2 .texts {
	margin-top: 29px;
}

#point2 .acc-parent.mb {
	margin-bottom: 30px;
}
#point2 .acc-cont .inner {
	padding-top: 10px;
}
#point2 .acc-cont .note-style1 {
	width: 457px;
	margin: 13px auto 0;
}

@media screen and (max-width:640px) {
	#point2 .copy1 {
		width: 100%;
		top: calc(-169 var(--spv));
	}
	#point2 .title {
		margin-bottom: calc(-62 var(--spv));
		transform: translateY( calc(-62 var(--spv)) );
	}
	#point2 .title img {
		width: calc(428 var(--spv));
	}
	#point2 .copy2 {
		width: calc(577 var(--spv));
		margin-top: calc(31 var(--spv));
	}
	#point2 .texts {
		margin-top: calc(32 var(--spv));
	}

	#point2 .acc-parent.mb {
		margin-bottom: calc(25 var(--spv));
	}
	#point2 .acc-cont .inner {
		padding-top: 0;
	}
	#point2 .acc-cont img {
		width: calc(460 var(--spv));
	}
	#point2 .acc-cont .note-style1 {
		width: calc(460 var(--spv));
		margin: calc(9 var(--spv)) auto 0;
	}
}

/* -------------------------------------------------
	#points .hr
------------------------------------------------- */

#points .hr {
	margin-top: 56px;
	padding-top: 60px;
	position: relative;
}
#points .hr::before {
	max-width: 640px;
	width: 100%;
	height: 0;
	margin: 0 auto;
	content: "";
	display: block;
	position: absolute;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
	border-top: dotted 4px #889399;
}

@media screen and (max-width:640px) {
	#points .hr {
		margin-top: calc(52 var(--spv));
		padding-top: calc(56 var(--spv));
	}
	#points .hr::before {
		width: calc(600 var(--spp));
		border-width: calc(4 var(--spv));
	}
}

/* -------------------------------------------------
	#points .acc
------------------------------------------------- */

#points .acc {
	width: 534px;
	margin: 30px auto 0;
	background: #29abe1;
	border: solid 3px #333;
	border-radius: 34px;
	color: #fff;
	box-shadow: 10px -5px 21px 0 rgba(0, 50, 100, 0.27);
	position: relative;
}
#points .acc::after {
	width: 6px;
	height: 3px;
	background: #29abe1;
	border-bottom: solid 1px #bdd9e6;
	content: "";
	display: block;
	position: absolute;
	bottom: -3px;
	right: 154px;
}
#points .acc .acc-title {
	padding: 21px 0;
	cursor: pointer;
	position: relative;
}
#points .acc .acc-title p {
	color: #fff;
	font-weight: 700;
	font-size: 20px;
	letter-spacing: 0.12em;
}
#points .acc .acc-title .ico {
	width: 34px;
	height: 34px;
	background: #fcc800;
	border-radius: 50%;
	box-shadow: 10px -5px 35px 0 rgba(0, 0, 0, 0.4);
	position: absolute;
	right: 21px;
	top: 50%;
	transform: translateY(-50%);
}
#points .acc .acc-title .ico div {
	width: 28px;
	height: 6px;
	border-radius: 3px;
	background: #333;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease-out;
}
#points .acc .acc-title:not(.active) .ico div:last-child {
	transform: translate(-50%,-50%) rotate(-90deg);
}
#points .acc .acc-cont {
	display: none;
}
#points .acc .acc-cont .inner {
	padding-bottom: 30px;
}

@media screen and (max-width:640px) {
	#points .acc {
		width: 100%;
		margin: calc(30 var(--spv)) auto 0;
		border: solid calc(3 var(--spv)) #333;
		border-radius: calc(34 var(--spv));
		box-shadow: calc(10 var(--spv)) calc(-5 var(--spv)) calc(21 var(--spv)) 0 rgba(0,50,100,0.27);
	}
	#points .acc::after {
		width: calc(6 var(--spv));
		height: calc(3 var(--spv));
		bottom: calc(-3 var(--spv));
		right: calc(57 var(--spv));
	}
	#points .acc .acc-title {
		padding: calc(26 var(--spv)) 0;
	}
	#points .acc .acc-title p {
		font-size: calc(25 var(--spv));
	}
	#points .acc .acc-title .ico {
		width: calc(41 var(--spv));
		height: calc(41 var(--spv));
		box-shadow: calc(10 var(--spv)) calc(-5 var(--spv)) calc(35 var(--spv)) 0 rgba(0, 0, 0, 0.4);
		right: calc(32 var(--spv));
	}
	#points .acc .acc-title .ico div {
		width: calc(33 var(--spv));
		height: calc(6 var(--spv));
		border-radius: calc(3 var(--spv));
	}
	#points .acc .acc-cont .inner {
		padding-bottom: calc(35 var(--spv));
	}
}

/* -------------------------------------------------
	#point3
------------------------------------------------- */

#point3 .tokuyaku {
	margin-top: 34px;
}

#point3 .text1 {
	height: 29px;
	padding: 0 1em;
	font-weight: 700;
	color: #29abe1;
	font-size: 20px;
	letter-spacing: 0.08em;
	display: inline-flex;
	align-items: center;
	background: #ffec94;
	border-radius: 15px;
}
#point3 .text2 {
	margin-top: 0.6em;
	font-size: 20px;
	line-height: 1.5;
	letter-spacing: 0.08em;
	font-weight: 700;
}
#point3 .white-box {
	width: 457px;
	margin: 25px auto 0;
	padding: 27px 0 22px;
	background: #fff;
	position: relative;
	color: #333;
}
#point3 .ex {
	width: 36px;
	height: 36px;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
	font-size: 20px;
	font-weight: 500;
	position: absolute;
	left: 50%;
	top: 0;
	transform: translate(-50%,-50%);
	background: #ffec94;
}
#point3 .text3 {
	margin-bottom: 0.3em;
	font-size: 20px;
	line-height: 1.5;
	letter-spacing: 0.08em;
	font-weight: 700;
	color: #28a7e1;
}
#point3 .text4 {
	margin-top: 0.9em;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.08em;
}

@media screen and (max-width:640px) {
	#point3 .title img {
		width: calc(428 var(--spv));
	}

	#point3 .tokuyaku {
		margin-top: calc(34 var(--spv));
	}

	#point3 .text1 {
		height: calc(29 var(--spv));
		padding: 0 0.8em;
		font-size: calc(25 var(--spv));
		border-radius: calc(15 var(--spv));
	}
	#point3 .text2 {
		margin-top: 0.6em;
		font-size: calc(25 var(--spv));
		line-height: calc(38 / 25);
	}
	#point3 .white-box {
		width: calc(460 var(--spv));
		margin: calc(25 var(--spv)) auto 0;
		padding: calc(22 var(--spv)) 0 calc(15 var(--spv));
	}
	#point3 .ex {
		width: calc(29 var(--spv));
		height: calc(29 var(--spv));
		font-size: calc(17 var(--spv));
	}
	#point3 .text3 {
		font-size: calc(15 var(--spv));
		line-height: calc(21 / 15);
	}
	#point3 .fig {
		width: calc(443 var(--spv));
	}
	#point3 .text4 {
		margin-top: 0.9em;
		font-size: calc(20 var(--spv));
	}
}

/* -------------------------------------------------
	#point4
------------------------------------------------- */

#point4 .tokuyaku {
	margin-top: 35px;
}
#point4 .or {
	margin-top: 22px;
	font-size: 35px;
	font-weight: 700;
	letter-spacing: 0.08em;
}
#point4 .or + .acc {
	margin-top: 22px;
}
#point4 .acc .acc-title p {
	letter-spacing: 0.04em;
}
#point4 .note-style1 {
	width: 457px;
	margin: 13px auto 0;
}

.note-under-point4 {
	margin-top: 1.8em;
	color: #f76696;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
}

@media screen and (max-width:640px) {
	#point4 .title img {
		width: calc(436 var(--spv));
	}
	#point4 .tokuyaku {
		margin-top: calc(35 var(--spv));
	}
	#point4 .or {
		margin-top: calc(22 var(--spv));
		font-size: calc(35 var(--spv));
		}
	#point4 .or + .acc {
		margin-top: calc(22 var(--spv));
	}
	#point4 .acc .acc-title p.pos-fix1 {
		text-align: left;
		margin-left: calc(28 var(--spv));
	}
	#point4 .acc .acc-title p.lh {
		line-height: calc(40 / 25);
	}
	#point4 .fig {
		width: calc(460 var(--spv));
	}
	#point4 .note-style1 {
		width: calc(460 var(--spv));
		margin: calc(8 var(--spv)) auto 0;
	}
	
	.note-under-point4 {
		width: calc(450 var(--spv));
		margin: 1.5em auto 0;
		color: #fc5300;
		font-size: calc(15 var(--spv));
		line-height: calc(25 / 15);
		text-align: left;
	}
}

/* -------------------------------------------------
	#points-fig
------------------------------------------------- */

@media print, screen and (min-width:641px) {
	#points-fig {
		background: linear-gradient(180deg, #ddf4ff 0%, #fff 100%);
	}
}

/* -------------------------------------------------
	#courage
------------------------------------------------- */

#courage {
	width: 100%;
	padding: 60px 0 0;
	overflow: hidden;
	position: relative;
}

#courage .on {
	position: relative;
	z-index: 4;
}

#courage .lead {
	padding-bottom: 250px;
	background: url("../img/fig_courage_01.png") no-repeat center bottom;
}
#courage .lead p {
	margin-top: 30px;
	padding-bottom: 0.2em;
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 0.08em;
	display: inline-block;
	border-bottom: solid 2px #8c8c8c;
}
#courage .fig1 {
	padding-top: 63px;
}
#courage .text1 {
	margin-top: 1em;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: calc(25 / 20);
}
#courage .fig2 {
	padding-top: 58px;
}
#courage .double {
	margin-top: 20px;
}

@media print, screen and (min-width:641px) {
	#courage {
		padding-bottom: 30px;
	}
	#courage .note-style1 {
		width: 637px;
		margin: 22px auto 0;
	}
	#courage .note-style1 p {
		text-align: center;
		white-space: nowrap;
	}
	
	#courage::before,
	#courage::after {
		content: "";
		display: block;
		width: 8000px;
		height: 1000px;
		position: absolute;
		left: 50%;
		top: 100%;
		z-index: 2;
		background: #d6f7f1;
	}
	#courage::before {
		transform: translateX(-50%) rotate(-11.6deg);
	}
	#courage::after {
		transform: translateX(-50%) rotate(11.6deg);
	}
}

@media screen and (max-width:640px) {
	#courage {
		padding: calc(60 var(--spv)) 0 0;
	}
	#courage .title img {
		width: calc(518 var(--spv));
	}
	#courage .lead {
		padding-bottom: calc(230 var(--spv));
		background-size: calc(587 var(--spv)) auto;
	}
	#courage .lead p {
		margin-top: calc(34 var(--spv));
		padding-bottom: 0.2em;
		font-size: calc(20 var(--spv));
		border-width: 1px;
	}
	#courage .fig1 {
		padding-top: calc(63 var(--spv));
	}
	#courage .text1 {
		font-size: calc(20 var(--spv));
	}
	#courage .fig2 {
		padding-top: calc(58 var(--spv));
	}
	#courage .note-style1 {
		margin-top: calc(20 var(--spv));
	}
	#courage .double {
		margin-top: calc(43 var(--spv));
	}
}

/* -------------------------------------------------
	#lump-sum
------------------------------------------------- */

#lump-sum {
	padding: 55px 0 20px;
}
#lump-sum .text1 {
	display: block;
	margin: 39px auto 0;
}
#lump-sum .fig {
	margin-top: 23px;
}

@media screen and (max-width:640px) {
	#lump-sum {
		padding: calc(65 var(--spv)) 0 calc(18 var(--spv));
	}
	#lump-sum .title img {
		width: calc(484 var(--spv));
	}
	#lump-sum .text1 {
		width: calc(293 var(--spv));
		margin-top: calc(37 var(--spv));
	}
	#lump-sum .fig {
		width: 100%;
		margin-top: calc(27 var(--spv));
	}
}

/* -------------------------------------------------
	#faq
------------------------------------------------- */

#faq {
	padding: 62px 0 60px;
}

#faq .qa-list {
	width: 534px;
	margin: 35px auto 0;
	text-align: left;
}
#faq .qa-list li {
	background: #29abe1;
	border: solid 3px #333;
	border-radius: 34px;
	color: #fff;
	box-shadow: 10px -5px 21px 0 rgba(0,50,100,0.27);
	position: relative;
}
#faq .qa-list li::after {
	width: 6px;
	height: 3px;
	background: #29abe1;
	border-bottom: solid 1px #fff;
	content: "";
	display: block;
	position: absolute;
	bottom: -3px;
	right: 154px;
}
#faq .qa-list li + li {
	margin-top: 23px;
}
#faq .qa-list .q-box {
	padding: 30px 0;
	display: flex;
	align-items: center;
	cursor: pointer;
	position: relative;
}
#faq .qa-list .a-box {
	display: none;
}
#faq .qa-list .a-inner {
	margin: 0 21px;
	padding: 35px 0 29px;
	display: flex;
	border-top: dotted 3px #333;
}
#faq .qa-list .label {
	width: 49px;
	height: 67px;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
	border-radius: 10px;
}
#faq .qa-list .q-box .label {
	margin-left: 21px;
}
#faq .qa-list .q-box .ico {
	width: 34px;
	height: 34px;
	background: #fcc800;
	border-radius: 50%;
	box-shadow: 10px -5px 35px 0 rgba(0,0,0,0.4);
	position: absolute;
	right: 21px;
	top: 50%;
	transform: translateY(-50%);
}
#faq .qa-list .q-box .ico div {
	width: 28px;
	height: 6px;
	border-radius: 3px;
	background: #333;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	transition: transform 0.2s ease-out;
}
#faq .qa-list .q-box:not(.active) .ico div:last-child {
	transform: translate(-50%,-50%) rotate(-90deg);
}
#faq .qa-list .q-box .desc {
	width: 380px;
	margin-left: 13px;
	font-size: 25px;
	line-height: calc(37 / 25);
	font-weight: 700;
	letter-spacing: 0.03em;
}
#faq .qa-list .a-box .desc {
	width: 420px;
	margin-left: 12px;
	font-size: 20px;
	line-height: 1.5;
	font-weight: 700;
	letter-spacing: 0.04em;
}

@media print, screen and (min-width:641px) {
	#faq .qa-list .a-inner.pc-alcenter {
		align-items: center;
	}
	#faq .qa-list .desc.pc-nowrap {
		white-space: nowrap;
	}
}

@media screen and (max-width:640px) {
	#faq {
		padding: calc(60 var(--spv)) 0;
	}
	
	#faq .headline img {
		width: calc(325 var(--spv));
	}

	#faq .qa-list {
		width: 100%;
		margin: calc(34 var(--spv)) auto 0;
	}
	#faq .qa-list li {
		border: solid calc(3 var(--spv)) #333;
		border-radius: calc(34 var(--spv));
		box-shadow: calc(10 var(--spv)) calc(-5 var(--spv)) calc(21 var(--spv)) 0 rgba(0,50,100,0.27);
	}
	#faq .qa-list li::after {
		width: calc(6 var(--spv));
		height: calc(3 var(--spv));
		bottom: calc(-3 var(--spv));
		right: calc(57 var(--spv));
	}
	#faq .qa-list li + li {
		margin-top: calc(23 var(--spv));
	}
	#faq .qa-list .q-box {
		padding: calc(30 var(--spv)) 0;
	}
	#faq .qa-list .a-inner {
		margin: 0 calc(27 var(--spv));
		padding: calc(30 var(--spv)) 0;
		border-width: calc(3 var(--spv));
	}
	#faq .qa-list .label {
		width: calc(49 var(--spv));
		height: calc(67 var(--spv));
		border-radius: calc(10 var(--spv));
	}
	#faq .qa-list .q-box .label {
		margin-left: calc(39 var(--spv));
	}
	#faq .qa-list .a-box .label {
		margin-left: calc(12 var(--spv));
	}
	#faq .qa-list .q-box .label img {
		width: calc(30 var(--spv));
	}
	#faq .qa-list .a-box .label img {
		width: calc(28 var(--spv));
	}
	#faq .qa-list .q-box .ico {
		width: calc(41 var(--spv));
		height: calc(41 var(--spv));
		box-shadow: calc(10 var(--spv)) calc(-5 var(--spv)) calc(35 var(--spv)) 0 rgba(0,0,0,0.4);
		right: calc(32 var(--spv));
	}
	#faq .qa-list .q-box .ico div {
		width: calc(33 var(--spv));
		height: calc(6 var(--spv));
		border-radius: calc(3 var(--spv));
	}
	#faq .qa-list .q-box .desc {
		width: calc(394 var(--spv));
		margin-left: calc(16 var(--spv));
		font-size: calc(30 var(--spv));
		line-height: calc(42 / 30);
		letter-spacing: 0;
	}
	#faq .qa-list .a-box .desc {
		width: calc(460 var(--spv));
		margin-left: calc(16 var(--spv));
		font-size: calc(24 var(--spv));
		line-height: calc(39 / 24);
		letter-spacing: 0;
	}
	#faq .qa-list .desc.sp-nowrap {
		white-space: nowrap;
	}
}

/* -------------------------------------------------
	footer
------------------------------------------------- */

footer {
	padding: 28px 0 33px;
	text-align: left;
}
footer .text1 {
	font-size: 12px;
	line-height: calc(18 / 12);
	letter-spacing: 0.06em;
}
footer .num {
	margin-top: 2em;
	text-align: right;
	font-size: 11px;
}
footer .links {
	margin-top: 19px;
}
footer .links li {
	font-size: 12px;
	line-height: calc(18 / 12);
	letter-spacing: 0.08em;
}
footer .links li::before {
	width: 0;
	height: 0;
	margin-right: 0.2em;
	content: "";
	display: inline-block;
	border-width: 6px 0 6px 10px;
	border-color: transparent transparent transparent #29abe1;
	border-style: solid;
	vertical-align: -0.1em;
}
footer .copyright {
	margin-top: 4em;
	text-align: center;
	font-size: 11px;
}

@media print, screen and (min-width:641px) {
	footer a:hover {
		text-decoration: underline;
	}
}

@media screen and (max-width:640px) {
	footer {
		padding: calc(25 var(--spv)) 0 calc(30 var(--spv));
	}
	footer .text1 {
		font-size: calc(20 var(--spv));
		line-height: calc(35 / 20);
	}
	footer .num {
		margin-top: 2.5em;
		font-size: calc(16 var(--spv));
	}
	footer .links {
		margin-top: calc(48 var(--spv));
	}
	footer .links li {
		font-size: calc(20 var(--spv));
		line-height: calc(35 / 20);
	}
	footer .links li::before {
		width: 0;
		height: 0;
		margin-right: 0.2em;
		content: "";
		display: inline-block;
		border-width: 6px 0 6px 10px;
		border-color: transparent transparent transparent #29abe1;
		border-style: solid;
		vertical-align: -0.1em;
	}
	footer .copyright {
		margin-top: 2em;
		font-size: calc(16 var(--spv));
	}
}

/* -------------------------------------------------
	#fix-banner 追従バナー
------------------------------------------------- */

#fix-banner {
	width: 100%;
	padding: 15px 0;
	position: fixed;
	left: 0;
	bottom: 0;
	z-index: 50;
	background: rgba(255,255,255,0.76);
	transform: translateY(100%);
	transition: transform 0.2s ease-out;
}
#fix-banner.active {
	transform: translateY(0);
}

@media screen and (max-width:640px) {
	#fix-banner {
		padding: 3vw 0;
	}
	#fix-banner img {
		width: calc(516 var(--spv));
	}
}