@charset "UTF-8";

/* リセット
---------------------------------------------------------- */
html, body, div, dl, dt, dd, ul, ol, li, h1, h2, h2, h3, h4, h5, h6,
pre, form, fieldset, input, textarea, p, table, th, td, button, a, span {
	margin: 0;
	padding: 0;
	font-size: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
ol ,
ul {
	list-style: none;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
	display: block;
	margin: 0;
	padding: 0;
	font-size: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
}
address {
	font-style: normal;
}

/* レイアウト
----------------------------------------*/
html {
	font-size: 1rem;
	font-size: 10px;
	height: 100%;
}
body {
	color: #1d1d1d;
	font-family: "Noto Sans JP", sans-serif;
	background: #fff;
	font-size: 1.4rem;
	line-height: 1.5;
	height: 100%;
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt";
}
body.open,
body.modal_open {
	width: 100%;
	height: 100%;
	position: fixed;
	overflow-y: scroll;
}
img {
	image-rendering: -webkit-optimize-contrast;
	display: block;
}
.wrapper {
	overflow: clip;
}
a {
	text-decoration: none;
	color: inherit;
	transition: opacity .3s;
}
table,
tbody,
thead,
tr,
th,
td {
	position: static;
}
@media (hover: hover) {
	a:hover {
		opacity: .6;
	}
}
@media only screen and (min-width: 835px) {
	a[href^="tel:"] {
		pointer-events: none;
	}
}
@media only screen and (max-width: 834px) {
	img {
		width: 100%;
	}
	html {
		font-size: 1.3334vw;
	}
}

/* img
----------------------------------------*/
img {
	max-width: 100%;
	height: auto;
}

/*font
----------------------------------------*/
.en {
	font-family: "Noto Sans", sans-serif;
}
.yugothic {
	font-family: "游ゴシック体", YuGothic, "游ゴシック体", "Yu Gothic", "Noto Sans JP", sans-serif;
}

/*表示
----------------------------------------*/
@media only screen and (min-width: 835px) {
	.sp {
		display: none !important;
	}
}

@media only screen and (max-width: 834px) {
	.pc {
		display: none !important;
	}
}

/*header
----------------------------------------*/
.header {
	padding: 1rem 1rem .9rem;
}
.header_logo {
	width: 38.4rem;
	margin: 0 auto;
}
@media only screen and (max-width: 834px) {
	.header {
		padding: 2.1rem 1rem 1.9rem;
	}
	.header_logo {
		width: 59.8rem;
	}
}

/*mv
----------------------------------------*/
.mv {
	background: #eaf8f4 url(../img/mv_bg_01.png) no-repeat center 2.6rem / 98.2rem auto;
	margin-bottom: 2.4rem;
}
.mv_inner {
	max-width: 96rem;
	margin: 0 auto;
	padding: 2.9rem 0;
}
.mv_ttl {
	width: 48.0031rem;
	margin: 0 0 13.7rem .9rem;
}
.mv_navi {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.3rem;
}
.mv_navi a {
	display: block;
	border: .2rem solid #108761;
	background: #fff;
	color: #108761;
	border-radius: .8rem;
	text-align: center;
	font-size: 1.676rem;
	font-weight: 700;
	letter-spacing: .05em;
	padding: .9rem 0;
	box-shadow: .5rem .5rem .6rem rgba(35, 50, 45, .2);
}
.mv_navi a::before {
	content: '';
	display: block;
	width: 2.2rem;
	height: 2.2rem;
	border-radius: 50%;
	background: #108761;
	position: absolute;
	top: 0;
	bottom: 0;
	right: .7rem;
	margin: auto 0;
}
.mv_navi a::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: .6rem .45rem 0;
	border-color: #fff transparent transparent;
	position: absolute;
	top: .1rem;
	bottom: 0;
	right: 1.4rem;
	margin: auto 0;
}
@media only screen and (max-width: 834px) {
	.mv {
		background: #eaf8f4 url(../img/mv_bg_01-sp.png) no-repeat left top / 100% auto;
		margin-bottom: 7.7rem;
	}
	.mv_inner {
		padding: 4.2rem 0 5.6rem;
	}
	.mv_ttl {
		width: 62.8rem;
		margin: 0 0 50.3rem 4.1rem;
	}
	.mv_navi {
		width: 67rem;
		margin: 0 auto;
		grid-template-columns: repeat(2, 1fr);
		gap: 1.8rem 1.9rem;
	}
	.mv_navi a {
		font-size: 2.4rem;
		padding: 1.25rem 0 1.3rem;
	}
	.mv_navi a::before {
		width: 3.2rem;
		height: 3.2rem;
		right: 1rem;
	}
	.mv_navi a::after {
		border-width: .9rem .8rem 0;
		top: .2rem;
		right: 1.8rem;
	}
}

/*cta
----------------------------------------*/
.cta a {
	display: flex;
	align-items: center;
	gap: 3rem;
	width: 80rem;
	background: linear-gradient(to right, #f43b4c 10%,#f1894c 100%);
	color: #fff;
	margin: 0 auto .5rem;
	border-radius: 3.8rem;
	font-weight: 700;
	padding: 1.5rem 1.5rem 1.6rem 7.5rem;
	box-shadow: .8rem .8rem 1.5rem rgba(88, 88, 88, .2);
}
.cta a::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 1.15rem 0 1.15rem 1.6rem;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 3.1rem;
	margin: auto 0;
	transition: transform .3s;
}
.cta_balloon {
	width: 22.2rem;
	font-size: 2.156rem;
	color: #e5004c;
	text-align: center;
	background: #fffcbc;
	border-radius: .5rem;
	padding: .55rem .55rem .55rem .9rem;
	letter-spacing: .025em;
}
.cta_balloon::before {
	content: '';
	display: block;
	width: 1.3rem;
	height: 1.3rem;
	border-radius: 0 .3rem 0 0;
	background: #fffcbc;
	position: absolute;
	top: 0;
	bottom: 0;
	right: -.7rem;
	transform: scaleY(.7) rotate(45deg);
	margin: auto 0;
}
.cta_balloon span {
	font-size: 3.019rem;
	line-height: 1;
	vertical-align: -.2rem;
}
.cta_txt {
	font-size: 3.2rem;
	line-height: 1;
	letter-spacing: .025em;
	margin-bottom: .3rem;
}
.cta_note {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 700;
}
.cta_float {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	opacity: 0;
	pointer-events: none;
	transition: opacity .3s;
}
.cta_float.show {
	opacity: 1;
	pointer-events: all;
}
.cta_float a {
	margin-bottom: 0;
	border-radius: 5rem;
	padding: 1.3rem 1.5rem 1.3rem 6.6rem;
	gap: 3.5rem;
}
.cta_float .cta_txt {
	padding-top: .5rem;
}
.cta_float .cta_txt span {
	font-size: 2rem;
	font-weight: 400;
	display: block;
	margin-top: 1.2rem;
	letter-spacing: 0;
}
.cta_float .cta_balloon {
	width: 12.6rem;
	font-size: 2.135rem;
	border-radius: 1rem;
	padding: .55rem .5rem .55rem .9rem;
	line-height: 1.1;
}
.cta_float .cta_balloon::before {
	width: 1.6rem;
	height: 1.6rem;
	right: -.9rem;
}
.cta_float .cta_balloon > span {
	font-size: 2.615rem;
	line-height: 1;
	margin-left: 1rem;
}
.cta_float .cta_balloon > span span {
	font-size: 4rem;
	line-height: 1;
}
@media (hover:hover) {
	.cta a:hover::after {
		transform: translateX(.5rem);
	}
}
@media only screen and (min-width: 835px) {
	.cta .cta_large {
		justify-content: center;
		padding: 3.25rem 1.5rem;
		border-radius: 5rem;
	}
	.cta_large .cta_balloon {
		width: 27.5rem;
		position: absolute;
		left: 0;
		right: 0;
		top: -4rem;
		margin: 0 auto;
		font-size: 2.4rem;
		border: .3rem solid #f34a4c;
		border-radius: 1.5rem;
		padding: .6rem .55rem .7rem;
	}
	.cta_large .cta_balloon::before {
		width: 1.4rem;
		height: 1.4rem;
		top: auto;
		bottom: -.7rem;
		left: 0;
		right: 0;
		transform: scaleX(.6) rotate(135deg);
		margin: 0 auto;
	}
	.cta_large .cta_balloon span {
		font-size: 3.36rem;
	}
}
@media only screen and (max-width: 834px) {
	.cta a {
		width: 70rem;
		margin: 0 auto 1.5rem;
		border-radius: 8rem;
		padding: 5.8rem 1.5rem;
		justify-content: center;
	}
	.cta a::after {
		border-width: 1.5rem 0 1.5rem 2.1rem;
	}
	.cta_balloon:not(.cta_float .cta_balloon) {
		width: 34.5rem;
		font-size: 3rem;
		border-radius: 1rem;
		padding: .8rem 1rem;
		position: absolute;
		left: 0;
		right: 0;
		top: -4.8rem;
		margin: 0 auto;
		border: .2rem solid #f34a4c;
	}
	.cta_balloon:not(.cta_float .cta_balloon)::before {
		width: 1.6rem;
		height: 1.6rem;
		top: auto;
		bottom: -.8rem;
		left: 0;
		right: 0;
		transform: scaleX(.8) rotate(135deg);
		margin: 0 auto;
	}
	.cta_balloon span {
		font-size: 4.2rem;
	}
	.cta_txt {
		font-size: 4rem;
	}
	.cta_note {
		font-size: 2.8rem;
	}
	.cta_float {
		bottom: 2rem;
	}
	.cta_float a {
		width: 100%;
		border-radius: 7rem;
		padding: 2.6rem 1.5rem 2rem 4rem;
		margin-bottom: 0;
		justify-content: flex-start;
		gap: 3rem;
	}
	.cta_float a::after {
		right: 4.5rem;
		border-width: 1.3rem 0 1.3rem 1.7rem;
	}
	.cta_float .cta_txt {
		padding-top: 0;
		font-size: 3.6rem;
	}
	.cta_float .cta_txt span {
		font-size: 2.4rem;
		margin-top: 1.6rem;
	}
	.cta_float .cta_balloon {
		width: 14.3rem;
		font-size: 2.361rem;
		padding: 1rem .5rem 1.2rem .9rem;
	}
	.cta_float .cta_balloon > span {
		font-size: 2.892rem;
	}
	.cta_float .cta_balloon > span span {
		font-size: 4.459rem;
	}
}

/*ttl_h2
----------------------------------------*/
.ttl_h2 {
	background: url(../img/ttl_h2_bg.svg) no-repeat center bottom / 100% auto;
	width: 96.1rem;
	margin: 0 auto;
	font-size: 4.4rem;
	padding-bottom: 4.5rem;
	color: #108761;
	letter-spacing: .05em;
	text-align: center;
}
.ttl_h2 span {
	display: block;
	font-size: 2.8rem;
	letter-spacing: .05em;
	color: #1d1d1d;
	margin-bottom: .5rem;
}
@media only screen and (max-width: 834px) {
	.ttl_h2 {
		background-image: url(../img/ttl_h2_bg-sp.svg);
		width: 67.2rem;
		font-size: 5.4rem;
		line-height: 1.3333;
		padding-bottom: 5.8rem;
	}
	.ttl_h2 span {
		font-size: 4rem;
		margin-bottom: 1.7rem;
	}
}

/*nisa
----------------------------------------*/
.nisa {
	padding: 2.3rem 0 8.3rem .1em;
}
.nisa_inner {
	max-width: 96rem;
	margin: 0 auto;
}
.nisa_list {
	width: 91rem;
	display: flex;
	justify-content: center;
	margin: 3rem auto 0;
}
.nisa_list li {
	width: 33.3333%;
	text-align: center;
}
.nisa_list figure {
	width: 8.1rem;
	height: 7.8rem;
	display: flex;
	align-items: flex-end;
	margin: 0 auto 2.7rem;
}
.nisa_list li:nth-child(2) figure {
	width: 7.8rem;
}
.nisa_list li:nth-child(3) figure {
	width: 9.5rem;
}
.nisa_list h3 {
	font-size: 2.8rem;
	color: #108761;
	letter-spacing: .075em;
	margin-bottom: 1.2rem;
}
.nisa_list p {
	font-size: 1.8rem;
	line-height: 1.7778;
	letter-spacing: .025em;
}
.nisa_note {
	font-size: 1.2rem;
	margin-top: 3.5rem;
	letter-spacing: .01em;
}
.nisa_simulation + .nisa_note {
	padding: 0 .5rem;
}
.nisa_note li {
	padding-left: 1.75rem;
}
.nisa_note li span:first-child {
	position: absolute;
	left: -.2rem;
	top: 0;
}
.nisa_note a {
	text-decoration: underline;
	text-underline-offset: .2rem;
	color: #108761;
}
.nisa_simulation {
	padding: 7.8rem 0 .1rem;
	overflow: hidden;
}
.nisa_simulation h3 {
	text-align: center;
	font-size: 3.2rem;
	color: #108761;
	letter-spacing: .05em;
	margin-bottom: 3.8rem;
}
.nisa_simulation h3::after {
	content: '';
	display: block;
	width: 14rem;
	height: .4rem;
	border-radius: .25rem;
	background: #108761;
	margin: 2.2rem auto 0;
}
.nisa_simulation h4 {
	text-align: center;
	font-size: 2.3rem;
	letter-spacing: .05em;
	margin-bottom: 3.2rem;
}
.nisa_simulation_slider {
	width: 66rem;
	margin: 0 auto;
}
.nisa_simulation_slider::after,
.nisa_simulation_slider .slick-list::after {
	content: '';
	display: block;
	clear: both;
}
.nisa_simulation_slider .slick-prev,
.nisa_simulation_slider .slick-next {
	appearance: none;
	display: block;
	width: 5.7rem;
	height: 5.7rem;
	border-radius: 50%;
	background: #bababa url(../img/icon_arrow_01.svg) no-repeat 55% center / 1.9rem auto;
	position: absolute;
	top: 29.3rem;
	right: -2.5rem;
	border: 0;
	padding: 0;
	margin: 0;
	overflow: hidden;
	text-indent: -99rem;
	cursor: pointer;
	outline: none;
	z-index: 10;
}
.nisa_simulation_slider .slick-prev {
	left: -2.5rem;
	right: auto;
	transform: scale(-1, 1);
}
.nisa_simulation_slider .slick-disabled {
	display: none !important;
}
.nisa_simulation_slider .slick-dots {
	display: flex;
	justify-content: center;
	gap: 2.1rem;
	margin-top: 5rem;
}
.nisa_simulation_slider .slick-dots button {
	appearance: none;
	padding: 0;
	width: 1.4rem;
	height: 1.4rem;
	border-radius: 50%;
	background: #bababa;
	border: 0;
	overflow: hidden;
	text-indent: -99rem;
}
.nisa_simulation_slider .slick-dots .slick-active  button {
	background: #e1f041;
}
.nisa_simulation_item {
	width: 60rem;
	float: left;
	margin: 0 3rem;
}
.nisa_simulation_case {
	background: #f3ffcc;
	text-align: center;
	color: #108761;
	font-size: 2.676rem;
	font-weight: 700;
	letter-spacing: .05em;
	line-height: 1.32;
	padding: 1.7rem 0 1.5rem;
	margin-bottom: 1.5rem;
}
.nisa_simulation_case span {
	font-size: 2.203rem;
}
.nisa_simulation_box {
	background: #f2f2f2;
	display: flex;
	gap: 4.5rem;
	padding: 2.1rem 0 2.5rem 9.7rem;
	margin-bottom: 1.3rem;
}
.nisa_simulation_box dl:first-child {
	width: 21.5rem;
	padding-top: .9rem;
}
.nisa_simulation_box dl:first-child dt {
	background: #108761;
	color: #fff;
	font-size: 1.731rem;
	text-align: center;
	border-radius: 1.4rem;
	padding: .1rem;
	font-weight: 700;
	margin-bottom: 1rem;
}
.nisa_simulation_box dl:first-child dt span {
	font-size: 2.251rem;
	line-height: 1;
	vertical-align: -.1rem;
}
.nisa_simulation_box dl:first-child dd {
	font-weight: 700;
	font-size: 2.25rem;
	margin: 0 -1rem;
	text-align: center;
}
.nisa_simulation_box dl:first-child dd > span {
	color: #f75a30;
	display: block;
	margin-top: .2rem;
}
.nisa_simulation_box dl:first-child dd > span span {
	font-size: 3.981rem;
	line-height: 1;
	vertical-align: -.2rem;
}
.nisa_simulation_box dl:last-child dt {
	font-size: 1.785rem;
	font-weight: 700;
	padding-left: 2.5rem;
	margin-bottom: .2rem;
}
.nisa_simulation_box dl:last-child dd + dt {
	margin-top: 1.5rem;
}
.nisa_simulation_box dl:last-child dt::before {
	content: '';
	display: block;
	width: 2rem;
	height: 2rem;
	position: absolute;
	left: .2rem;
	top: .4rem;
	background: #c3d600;
}
.nisa_simulation_box dl:last-child dt:nth-of-type(2):before {
	background: #f75a30;
}
.nisa_simulation_box dl:last-child dd {
	font-size: 1.575rem;
	font-weight: 700;
}
.nisa_simulation_box dl:last-child dd span {
	font-size: 2.787rem;
	line-height: 1;
	vertical-align: -.2rem;
}
.nisa_disclaimer {
	background: #f2f2f2;
	max-width: 84rem;
	padding: 3rem 3.5rem;
	margin: 6rem auto 0;
}
.nisa_disclaimer h3 {
	text-align: center;
	font-size: 2rem;
	letter-spacing: .05em;
	cursor: pointer;
}
.nisa_disclaimer h3::after {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 .75rem 1.2rem;
	border-color: transparent transparent #1d1d1d;
	margin: 0 -2.2rem 0 .7rem;
	vertical-align: .3rem;
}
.nisa_disclaimer h3:not(.open)::after {
	transform: scale(1, -1);
}
.nisa_disclaimer p {
	font-size: 1.4rem;
	line-height: 1.7857;
	display: none;
	padding-top: 1.5rem;
}
@media only screen and (max-width: 834px) {
	.nisa {
		padding: 9.5rem 0 8.3rem .1em;
	}
	.nisa_list {
		width: 67rem;
		display: block;
		margin: 4.5rem auto 0;
	}
	.nisa_list li {
		width: auto;
		text-align: left;
		display: flex;
		align-items: flex-end;
	}
	.nisa_list li + li {
		margin-top: 7.2rem;
	}
	.nisa_list figure,
	.nisa_list li:nth-child(2) figure,
	.nisa_list li:nth-child(3) figure {
		width: 17.6rem;
		height: auto;
		margin: 0;
	}
	.nisa_list li:nth-child(1) figure img {
		width: 11.5rem;
		margin-left: 1.4rem;
	}
	.nisa_list li:nth-child(2) figure img {
		width: 11rem;
		margin-left: 1.7rem;
		top: 1rem;
		position: relative;
	}
	.nisa_list li:nth-child(3) figure img {
		width: 12rem;
		margin-left: .2rem;
		position: relative;
		top: .4rem;
	}
	.nisa_list h3 {
		font-size: 4rem;
		margin-bottom: .6rem;
	}
	.nisa_list p {
		font-size: 2.6rem;
	}
	.nisa_list_txt {
		margin-bottom: -1.2rem;
	}
	.nisa_note {
		width: 67rem;
		font-size: 2rem;
		margin: 5.8rem auto 0;
	}
	.nisa_note li {
		padding-left: 2.5rem;
	}
	.nisa_simulation {
		padding: 11.5rem 0 .1rem;
	}
	.nisa_simulation h3 {
		font-size: 4.6rem;
		margin-bottom: 5.3rem;
	}
	.nisa_simulation h3::after {
		width: 20rem;
		height: .6rem;
		border-radius: .3rem;
		margin: 3rem auto 0;
	}
	.nisa_simulation h4 {
		font-size: 3.4rem;
		margin-bottom: 1.5rem;
	}
	.nisa_simulation_slider {
		width: 67.5rem;
	}
	.nisa_simulation_slider .slick-prev,
	.nisa_simulation_slider .slick-next {
		width: 8.2rem;
		height: 8.2rem;
		background: #bababa url(../img/icon_arrow_01.svg) no-repeat 55% center / 2.7rem auto;
		top: 36.1rem;
		right: .6rem;
	}
	.nisa_simulation_slider .slick-dots {
		gap: 3rem;
	}
	.nisa_simulation_slider .slick-dots button {
		width: 2rem;
		height: 2rem;
	}
	.nisa_simulation_item {
		margin: 0 3.75rem;
	}
	.nisa_simulation_item figure {
		width: 55.4rem;
		margin: 0 auto;
	}
	.nisa_simulation_case {
		font-size: 3.4rem;
		line-height: 1.35;
		padding: 1.9rem 0;
		margin-bottom: 2rem;
	}
	.nisa_simulation_case span {
		font-size: 2.8rem;
	}
	.nisa_simulation_box {
		width: 54rem;
		margin: 0 auto;
		gap: 3.2rem;
		padding: 2.1rem 0 2.7rem 2.3rem;
	}
	.simulation_02 .nisa_simulation_box,
	.simulation_03 .nisa_simulation_box {
		gap: 2.4rem;
	}
	.nisa_simulation_box dl:first-child {
		width: 27.5rem;
		padding-top: 1.5rem;
	}
	.nisa_simulation_box dl:first-child dt {
		font-size: 2.2rem;
		border-radius: 1.8rem;
		margin-bottom: 1.4rem;
	}
	.nisa_simulation_box dl:first-child dt span {
		font-size: 2.86rem;
		vertical-align: -.2rem;
	}
	.nisa_simulation_box dl:first-child dd {
		font-size: 2.86rem;
	}
	.nisa_simulation_box dl:first-child dd > span {
		margin-top: .5rem;
	}
	.nisa_simulation_box dl:first-child dd > span span {
		font-size: 5.059rem;
	}
	.simulation_02 .nisa_simulation_box dl:first-child dd > span span,
	.simulation_03 .nisa_simulation_box dl:first-child dd > span span {
		letter-spacing: -.02em;
	}
	.nisa_simulation_box dl:last-child {
		padding-top: .4rem;
	}
	.nisa_simulation_box dl:last-child dt {
		font-size: 2.268rem;
		padding-left: 3.2rem;
		margin-bottom: .4rem;
	}
	.nisa_simulation_box dl:last-child dd + dt {
		margin-top: 2rem;
	}
	.nisa_simulation_box dl:last-child dt::before {
		width: 2.5rem;
		height: 2.5rem;
	}
	.nisa_simulation_box dl:last-child dd {
		font-size: 2rem;
	}
	.nisa_simulation_box dl:last-child dd span {
		font-size: 3.541rem;
	}
	.nisa_simulation + .nisa_note {
		margin-top: 3rem;
	}
	.nisa_disclaimer {
		max-width: 67rem;
		padding: 3.7rem 3.3rem;
		margin: 6.2rem auto 0;
	}
	.nisa_disclaimer h3 {
		font-size: 3.2rem;
	}
	.nisa_disclaimer h3::after {
		border-width: 0 1.1rem 1.8rem;
		margin: 0 -.6rem 0 3.4rem;
	}
	.nisa_disclaimer p {
		font-size: 2.4rem;
		line-height: 1.6667;
		padding: 1.9rem 0 1.8rem;
	}
}

/*topics
----------------------------------------*/
.vpoint {
	padding: 3.2rem 0 10.7rem;
}
.vpoint_inner {
	max-width: 96rem;
	margin: 0 auto;
}
.vpoint h3 {
	text-align: center;
	font-size: 2.4rem;
	margin: 3.3rem 0 2.9rem;
	letter-spacing: .05em;
}
.vpoint h3 span:nth-of-type(1),
.vpoint h3 span:nth-child(2) {
	background: linear-gradient(transparent 60%, #fcffa0 60%);
}
.vpoint h3 span:nth-of-type(3) {
	font-size: 3.6rem;
	color: #108761;
	background: linear-gradient(transparent 70%, #fcffa0 70%);
}
.vpoint_txt {
	text-align: center;
	font-size: 1.8rem;
	line-height: 1.7778;
	letter-spacing: .025em;
	margin-bottom: 4rem;
}
.vpoint_note {
	max-width: 72rem;
	margin: 3.2rem auto 0;
	font-size: 1.2rem;
}
.vpoint_note li {
	padding-left: 3rem;
}
.vpoint_note li span {
	position: absolute;
	left: 0;
	top: 0;
}
.vpoint_note a {
	text-decoration: underline;
	text-underline-offset: .2rem;
	color: #108761;
}
.vpoint_sbi {
	background: #f7ffde;
	margin: 4.8rem 0 0;
	padding: 5.5rem 0 4.5rem;
}
.vpoint_sbi h4 {
	text-align: center;
	font-size: 3.2rem;
	letter-spacing: .05em;
	color: #108761;
	margin-bottom: 2.5rem;
}
.vpoint_sbi h4 span {
	display: block;
	font-size: 2.6rem;
	letter-spacing: .05em;
	color: #1d1d1d;
	margin-bottom: .7rem;
}
.vpoint_sbi h4::after {
	content: '';
	display: block;
	width: 14rem;
	height: .4rem;
	border-radius: .2rem;
	background: #108761;
	margin: 2rem auto 0;
}
.vpoint_sbi_txt {
	font-size: 2.4rem;
	font-weight: 700;
	text-align: center;
	line-height: 1.75;
}
.vpoint_sbi_txt + .vpoint_sbi_txt {
	letter-spacing: .04em;
}
.vpoint_sbi_txt span {
	color: #108761;
}
.vpoint_sbi figure {
	max-width: 36.8rem;
	margin: 2.3rem auto 0;
}
.vpoint_sbi_note {
	max-width: 73.5rem;
	margin: 1.5rem auto 0;
	font-size: 1.2rem;
}
@media only screen and (max-width: 834px) {
	.vpoint {
		padding: 3.2rem 0 12rem;
	}
	.vpoint .ttl_h2 {
		padding-bottom: 6.5rem;
	}
	.vpoint h3 {
		font-size: 3.4rem;
		line-height: 1.58;
	}
	.vpoint h3 span:nth-of-type(3) {
		font-size: 5rem;
	}
	.vpoint_txt {
		font-size: 2.6rem;
		margin-bottom: 2rem;
	}
	.vpoint_inner > figure {
		width: 67rem;
		margin: 0 auto;
	}
	.vpoint_note {
		max-width: 67rem;
		font-size: 2rem;
	}
	.vpoint_note li {
		padding-left: 4rem;
	}
	.vpoint_sbi {
		margin: 9.5rem 0 0;
		padding: 6rem 0 5.8rem;
	}
	.vpoint_sbi h4 {
		font-size: 4.6rem;
		margin-bottom: 5rem;
	}
	.vpoint_sbi h4 span {
		font-size: 4rem;
	}
	.vpoint_sbi h4::after {
		width: 20rem;
		height: .6rem;
		border-radius: .3rem;
		margin: 2.8rem auto 0;
	}
	.vpoint_sbi_txt {
		font-size: 3rem;
		line-height: 1.6867;
	}
	.vpoint_sbi figure {
		max-width: 58.5rem;
		margin: 5rem auto 0;
	}
	.vpoint_sbi_note {
		max-width: 61.4rem;
		margin: 3rem auto 0;
		font-size: 2rem;
	}
}

/*sbi
----------------------------------------*/
.sbi {
	margin-bottom: 10.8rem;
}
.sbi .ttl_h2 {
	margin-bottom: 1.8rem;
}
.sbi h3 {
	text-align: center;
	font-size: 3.2rem;
	color: #108761;
	letter-spacing: .04em;
}
.sbi_no1 {
	max-width: 64.8rem;
	margin: 2.1rem auto 6.5rem;
}
.sbi_no1_box {
	background: #329777;
	border-radius: 4rem 0;
	color: #fff;
	text-align: center;
	padding: 2.9rem 0 2.5rem;
	margin-bottom: 1.2rem;
}
.sbi_no1 h4 {
	text-align: center;
	font-size: 2.8rem;
	font-weight: 500;
	letter-spacing: .05em;
	margin-bottom: -.2rem;
}
.sbi_no1 figure {
	max-width: 27.9rem;
	margin: 0 auto 2.3rem;
}
.sbi_no1_box p {
	font-size: 1.82rem;
	letter-spacing: .07em;
	padding-left: .3em;
}
.sbi_note {
	font-size: 1.2rem;
}
.sbi_note li {
	padding-left: 2rem;
}
.sbi_note li span:first-child {
	position: absolute;
	left: .5rem;
	top: 0;
}
.sbi_commission {
	max-width: 78rem;
	margin: 2rem auto 6.8rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 7.1rem;
}
.sbi_commission figure {
	margin-bottom: 1rem;
}
.sbi_trust_txt_01 {
	font-size: 2.38rem;
	text-align: center;
	font-weight: 700;
	margin: 1.8rem 0 3.4rem;
	letter-spacing: .05em;
}
.sbi_trust_txt_01 span {
	color: #108761;
	background: linear-gradient(transparent 60%, #fcffa0 60%);
}
.sbi_trust_box {
	max-width: 66rem;
	margin: 0 auto 3.1rem;
	background: #f3ffcc;
	padding: 3.8rem 0 4rem 8.3rem;
}
.sbi_trust_box ul {
	font-size: 2.1rem;
	font-weight: 700;
	letter-spacing: .05em;
}
.sbi_trust_box ul li {
	padding-left: 5.7rem;
}
.sbi_trust_box ul li + li {
	margin-top: 2.83rem;
}
.sbi_trust_box ul li::before {
	content: '';
	display: block;
	background: url(../img/icon_check.svg) no-repeat left top / 100% auto;
	width: 3.945rem;
	height: 3.593rem;
	position: absolute;
	top: -.3rem;
	left: 0;
}
.sbi_trust_etc {
	width: 12.4721rem;
	height: 4.984rem;
	margin: 0 auto -1rem;
	text-align: center;
	font-size: 1.96rem;
	color: #fff;
	font-weight: 500;
	padding-top: .4rem;
	background: url(../img/sbi_trust_etc_bg.svg) no-repeat left top / 100% auto;
}
.sbi_trust_txt_02 {
	text-align: center;
	color: #108761;
	font-weight: 700;
	margin-bottom: 1.9rem;
}
.sbi_trust_txt_02 > span:nth-child(1) {
	font-size: 3.345rem;
	vertical-align: -.4rem;
}
.sbi_trust_txt_02 > span:nth-child(1) > span {
	font-size: 6.298rem;
	line-height: 1;
}
.sbi_trust_txt_02 > span:nth-child(1) > span span {
	font-size: 4rem;
	vertical-align: .5rem;
}
.sbi_trust_txt_02 > span:nth-child(2) {
	background: linear-gradient(transparent 78%, #fcffa0 78%);
	margin-left: .7rem;
	display: inline-block;
}
.sbi_trust_txt_02 > span:nth-child(2) span:nth-child(1) {
	font-size: 2.52rem;
	line-height: 1.3054;
	display: inline-block;
	vertical-align: -.4rem;
}
.sbi_trust_txt_02 > span:nth-child(2) span:nth-child(2) {
	font-size: 3.903rem;
	letter-spacing: .05em;
}
.sbi_trust_txt_02 > span:nth-child(2) span:nth-child(2) span {
	font-size: 12.363rem;
	line-height: 1;
	vertical-align: -.7rem;
}
.sbi_trust_note {
	text-align: center;
	font-size: 1.2rem;
	letter-spacing: .025em;
}
.sbi_trust_txt_03 {
	text-align: center;
	font-size: 2.8rem;
	color: #108761;
	font-weight: 700;
	letter-spacing: .05em;
	margin: 1.8rem 0 1rem;
}
.sbi_trust_txt_03 span {
	background: linear-gradient(transparent 60%, #fcffa0 60%);
}
@media only screen and (max-width: 834px) {
	.sbi {
		margin-bottom: 11.6rem;
	}
	.sbi .ttl_h2 {
		margin-bottom: 2.5rem;
	}
	.sbi h3 {
		font-size: 4.6rem;
	}
	.sbi_no1 {
		max-width: 53rem;
		margin: 3rem auto 10rem;
	}
	.sbi_no1_box {
		padding: 4rem 0 3.1rem;
		margin-bottom: 2.7rem;
	}
	.sbi_no1 h4 {
		font-size: 4rem;
		margin-bottom: 1rem;
	}
	.sbi_no1 figure {
		max-width: 38.6376rem;
		margin: 0 auto 3.5rem;
	}
	.sbi_no1_box p {
		font-size: 2.6rem;
		line-height: 1.7692;
	}
	.sbi_note {
		font-size: 2rem;
	}
	.sbi_no1 .sbi_note {
		margin: 0 -5rem;
	}
	.sbi_note li {
		padding-left: 2.5rem;
	}
	.sbi_note li span:first-child {
		left: 0;
	}
	.sbi_commission {
		margin: 2.7rem auto 8rem;
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		gap: 2rem 2.5rem;
	}
	.sbi_commission > li {
		width: 30.2rem;
	}
	.sbi_commission figure {
		margin-bottom: 1.5rem;
	}
	.sbi_commission li:last-child .sbi_note {
		margin: 0 -15rem;
	}
	.sbi_trust_txt_01 {
		font-size: 3.4rem;
		margin: 2.3rem 0 4rem;
		line-height: 1.6471;
	}
	.sbi_trust_box {
		max-width: 61rem;
		margin: 0 auto 4.4rem;
		padding: 3.8rem 5rem 5rem 5.7rem;
	}
	.sbi_trust_box ul {
		font-size: 3rem;
	}
	.sbi_trust_box ul li {
		padding-left: 8rem;
	}
	.sbi_trust_box ul li + li {
		margin-top: 2.8rem;
	}
	.sbi_trust_box ul li + li:last-child {
		margin-top: 5.5rem;
	}
	.sbi_trust_box ul li::before {
		width: 5.6rem;
		height: 5.2rem;
	}
	.sbi_trust_etc {
		width: 19.5rem;
		height: 7.2rem;
		margin: 0 auto 2rem;
		font-size: 2.8rem;
		background-size: 100% 100%;
	}
	.sbi_trust_txt_02 {
		margin-bottom: 1rem;
	}
	.sbi_trust_txt_02 > span:nth-child(1) {
		font-size: 4.78rem;
		display: block;
		margin-bottom: -2rem;
	}
	.sbi_trust_txt_02 > span:nth-child(1) > span {
		font-size: 8.998rem;
	}
	.sbi_trust_txt_02 > span:nth-child(1) > span span {
		font-size: 5.84rem;
	}
	.sbi_trust_txt_02 > span:nth-child(2) span:nth-child(1) {
		font-size: 3.6rem;
	}
	.sbi_trust_txt_02 > span:nth-child(2) span:nth-child(2) {
		font-size: 5.577rem;
	}
	.sbi_trust_txt_02 > span:nth-child(2) span:nth-child(2) span {
		font-size: 17.664rem;
	}
	.sbi_trust_note {
		font-size: 2rem;
	}
	.sbi_trust_txt_03 {
		font-size: 4rem;
		letter-spacing: 0;
		margin: 2rem 0 1rem;
	}
}

/*info
----------------------------------------*/
.info {
	margin-bottom: 10.2rem;
}
.info_inner {
	max-width: 96rem;
	margin: 0 auto;
}
.info .ttl_h2 {
	margin-bottom: 4.8rem;
}
.info a {
	display: block;
	max-width: 88rem;
	margin: 0 auto;
}
.info_bnr + .info_bnr {
	margin-top: 3rem;
}
.info_bnr > h2 {
	font-size: 3.12rem;
	font-feature-settings: "palt";
	letter-spacing: .07em;
	width: fit-content;
	padding: 0 5rem;
	margin: 0 auto 1.5rem;
	color: #060606;
}
.info_bnr > h2::before,
.info_bnr > h2::after {
	content: '';
	display: block;
	width: 2px;
	height: 35px;
	background: #000;
	transform: rotate(23deg);
	margin: 0 25px;
	position: absolute;
	right: 0;
	bottom: .5rem;
}
.info_bnr > h2::before {
	transform: rotate(-25deg);
	right: auto;
	left: 0;
}
@media only screen and (max-width: 834px) {
	.info .ttl_h2 {
		margin-bottom: 3.3rem;
	}
	.info a {
		max-width: 67.5rem;
	}
	.info_bnr + .info_bnr {
		margin-top: 2rem;
	}
	.info_bnr > h2 {
		font-size: 4vw !important;
		padding: 0 8.5rem;
		margin-bottom: 7px;
		width: fit-content !important;
		text-align: center;
	}
	.info_bnr > h2::before,
	.info_bnr > h2::after {
		width: 0.5333vw;
		height: 4.5333vw;
		bottom: 0;
	}
}

/*start
----------------------------------------*/
.start {
	background: #f7ffde;
	margin: 7.3rem 0 0;
	padding: 11rem 0 12.3rem;
}
.start_inner {
	max-width: 96rem;
	margin: 0 auto;
}
.start .ttl_h2 {
	margin-bottom: 7rem;
}
.start_step {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2.7rem;
	margin-bottom: 8.5rem;
}
.start_step .start_step_item {
	background: #fff;
	border-radius: 1.5rem;
	box-shadow: 1rem 1rem 1rem rgba(24, 64, 51, .1);
	padding: 7.7rem 0 3rem;
}
.start_step .start_step_item.start_step_get {
	background: url(../img/start_step_bg_01.png) no-repeat center center / cover;
	padding-top: 2.5rem;
}
.start_step_ttl {
	position: absolute;
	left: 0;
	right: 0;
	top: -2rem;
	width: 14.8406rem;
	margin: 0 auto;
}
.start_step h3 {
	text-align: center;
	font-size: 2.2rem;
	line-height: 1.4091;
	color: #108761;
	min-height: 9.3rem;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 3.1rem 0 1.4rem;
}
.start_step .start_step_item.start_step_get h3 {
	font-size: 2.7rem;
	line-height: 1.3704;
}
.start_step_txt {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 500;
}
.start_step .start_step_item:nth-child(1) h3,
.start_step .start_step_item:nth-child(1) .start_step_txt {
	letter-spacing: .05em;
}
.start_step_cta {
	display: block;
	width: 17.4rem;
	margin: 1.8rem auto 0;
	border-radius: 3rem;
	font-size: 2rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.15;
	background: linear-gradient(to right, #f43b4c 10%,#f1894c 100%);
	color: #fff;
	padding: .7rem 1rem .7rem 0;
	letter-spacing: .03em;
	left: -.3rem;
	box-shadow: .8rem .8rem 1.5rem rgba(88, 88, 88, .2);
}
.start_step_cta::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: .75rem 0 .75rem 1rem;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 1.5rem;
	margin: auto 0;
	transition: transform .3s;
}
.start_btn + .start_btn {
	margin-top: 6.5rem;
}
.start_btn h3 {
	text-align: center;
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: .05em;
	width: fit-content;
	padding: 0 2.9rem;
	margin: 0 auto 1.3rem;
}
.start_btn h3::before,
.start_btn h3::after {
	content: '';
	display: block;
	width: .2rem;
	height: 3.2rem;
	background: #1d1d1d;
	position: absolute;
	right: 0;
	bottom: .3rem;
	transform: rotate(23deg);
}
.start_btn h3::before {
	right: auto;
	left: 0;
	transform: rotate(-23deg);
}
.start_btn a {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #108761;
	color: #fff;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: .05em;
	max-width: 90rem;
	margin: 0 auto;
	height: 10.6rem;
	border-radius: 5.3rem;
}
.start_btn a::after {
	content: '';
	display: block;
	background: url(../img/icon_arrow_02.svg) no-repeat left top / 100% auto;
	width: 1.191rem;
	height: 2.426rem;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 3.7rem;
	margin: auto 0;
	transition: transform .3s;
}
@media (hover:hover) {
	.start_step_cta:hover::after,
	.start_btn a:hover::after {
		transform: translateX(.5rem);
	}
}
@media only screen and (min-width: 835px) {
	.start_step .start_step_item + .start_step_item::before {
		content: '';
		display: block;
		width: 4.5rem;
		height: 4.5rem;
		border-radius: 50%;
		background: #108761;
		position: absolute;
		top: 20.4rem;
		left: -3.7rem;
	}
	.start_step .start_step_item + .start_step_item::after {
		content: '';
		display: block;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 1.05rem 0 1.05rem 1.5rem;
		border-color: transparent transparent transparent #fff;
		position: absolute;
		top: 21.7rem;
		left: -2rem;
	}
}
@media only screen and (max-width: 834px) {
	.start {
		margin: 5rem 0 0;
		padding: 11rem 0 11.8rem;
		overflow: hidden;
	}
	.start_step {
		width: 51.4rem;
		display: block;
		margin-left: 4rem;
		margin-bottom: 9.8rem;
	}
	.start_step::after,
	.start_step .slick-list::after {
		content: '';
		display: block;
		clear: both;
	}
	.start_step .slick-track {
		display: flex;
	}
	.start_step .slick-prev,
	.start_step .slick-next {
		appearance: none;
		display: block;
		width: 8.2rem;
		height: 8.2rem;
		background: #bababa url(../img/icon_arrow_01.svg) no-repeat 55% center / 2.7rem auto;
		border-radius: 50%;
		position: absolute;
		top: 23.8rem;
		right: -2rem;
		border: 0;
		padding: 0;
		margin: 0;
		overflow: hidden;
		text-indent: -99rem;
		cursor: pointer;
		outline: none;
	}
	.start_step .slick-prev {
		display: none !important;
	}
	.start_step .slick-dots {
		display: flex;
		justify-content: center;
		gap: 3rem;
		margin: 5.5rem -16rem 0 0;
	}
	.start_step .slick-dots button {
		appearance: none;
		padding: 0;
		width: 2rem;
		height: 2rem;
		border-radius: 50%;
		background: #bababa;
		border: 0;
		overflow: hidden;
		text-indent: -99rem;
	}
	.start_step .slick-dots .slick-active  button {
		background: #108761;
	}
	.start_step .start_step_item {
		width: 47rem;
		float: left;
		margin-right: 4.4rem;
		border-radius: 2rem;
		padding: 9.5rem 0 3.4rem;
	}
	.start_step .start_step_item.start_step_get {
		background-image: url(../img/start_step_bg_01-sp.png);
		padding-top: 9.5rem;
	}
	.start_step_ttl {
		top: -3.5rem;
		width: 23.2rem;
	}
	.start_step h3 {
		font-size: 4rem;
		min-height: 0;
		line-height: 1.35;
		margin: 3.4rem 0 2.5rem;
	}
	.start_step figure {
		width: 75%;
		height: 12.2rem;
		margin: 0 auto;
	}
	.start_step_02 figure {
		width: 80%;
		top: -.5rem;
	}
	.start_step_03 figure {
		top: -.5rem;
	}
	.start_step .start_step_item.start_step_get h3 {
		font-size: 4rem;
	}
	.start_step_txt {
		font-size: 2.6rem;
		line-height: 1.6923;
	}
	.start_step_cta {
		width: 30.7rem;
		margin: 2.8rem auto 0;
		border-radius: 3.1rem;
		font-size: 2.6rem;
		padding: 1.7rem 1rem 1.7rem 0;
		left: auto;
	}
	.start_step_cta::after {
		border-width: .9rem 0 .9rem 1.3rem;
		right: 1.5rem;
	}
	.start_btn + .start_btn {
		margin-top: 3rem;
	}
	.start_btn h3 {
		font-size: 3rem;
		line-height: 1.3333;
		padding: 0 3.2rem;
		margin: 0 auto 1.6rem;
	}
	.start_btn h3::before,
	.start_btn h3::after {
		width: .4rem;
		height: 3.6rem;
		bottom: 0;
	}
	.start_btn a {
		max-width: 67rem;
	}
}

/*faq
----------------------------------------*/
.faq {
	background: #f0f3ef;
	padding: 11.1rem 0 12rem;
}
.faq_inner {
	max-width: 96rem;
	margin: 0 auto;
}
.faq_list {
	margin: 4.5rem 1.2rem 0;
}
.faq_list dt {
	font-size: 2.6rem;
	color: #108761;
	font-weight: 700;
	line-height: 1.5385;
	padding: 0 0 .3rem 8.4rem;
	margin-bottom: 1.6rem;
	letter-spacing: .05em;
	min-height: 7rem;
	display: flex;
	align-items: center;
}
.faq_list dt:not(:first-child) {
	margin-top: 6.5rem;
}
.faq_list dt::before {
	content: '';
	display: block;
	background: url(../img/faq_icon_01.svg) no-repeat left top / 100% auto;
	width: 6.4rem;
	height: 6.4rem;
	position: absolute;
	left: .4rem;
	top: 0;
}
.faq_list dd {
	font-size: 1.8rem;
	line-height: 1.7778;
	letter-spacing: .04em;
}
.faq_list dd a {
	text-decoration: underline;
	text-underline-offset: 1rem;
}
.faq_list dd p + p {
	margin-top: 3.2rem;
}
@media only screen and (max-width: 834px) {
	.faq {
		padding: 10.6rem 0 10rem;
	}
	.faq_inner {
		max-width: 68.8rem;
	}
	.faq_list {
		margin: 6.4rem 1.2rem 0;
	}
	.faq_list dt {
		font-size: 3.4rem;
		line-height: 1.4706;
		padding: 0 0 .3rem 10rem;
		margin-bottom: 3rem;
		margin-right: -1rem;
		min-height: 8rem;
	}
	.faq_list dt:not(:first-child) {
		margin-top: 8.2rem;
	}
	.faq_list dt::before {
		width: 7.9rem;
		height: 7.9rem;
		left: 0;
	}
	.faq_list dd {
		font-size: 2.6rem;
	}
	.faq_list dd p + p {
		margin-top: 4.5rem;
	}
}

/*btn_pagetop
----------------------------------------*/
.btn_pagetop {
	width: 6.3rem;
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	z-index: 9999;
	display: none;
}
.btn_pagetop a {
	display: block;
	transition: opacity .3s;
}
.btn_pagetop a:hover {
	opacity: .6;
}
.btn_pagetop img {
	display: block;
}
@media screen and (max-width: 834px) {
	.btn_pagetop {
		width: 9.8rem;
		bottom: 16rem;
		right: 0;
	}
}

/*footer
----------------------------------------*/
.footer {
	padding-bottom: 15rem;
}
.footer_pagetop {
	display: block;
	background: #333;
	padding: 1.4rem 0;
}
.footer_pagetop img {
	width: 2.5rem;
	margin: 0 auto;
}
.footer_inner {
	max-width: 96rem;
	margin: 0 auto;
	padding: 4.5rem 0 0;
	color: #2b2b2b;
}
.footer_inner h2 {
	font-size: 1.7rem;
	font-weight: 500;
	margin-bottom: .3rem;
}
.footer_item {
	font-size: 1.5rem;
	letter-spacing: .01em;
	line-height: 1.6667;
}
.footer_item + .footer_item {
	margin-top: 3.9rem;
}
.footer_list li {
	margin-left: 2.5rem;
	text-indent: -2.5rem;
}
.footer_list li::before {
	content: '●';
	margin-right: 1rem;
}
.footer_item p + p,
.footer_item ul + p {
	margin-top: .9rem;
}
.footer_item a::before {
	content: '';
	display: inline-block;
	width: .7rem;
	height: .7rem;
	border-top: .1rem solid #2b2b2b;
	border-right: .1rem solid #2b2b2b;
	transform: rotate(45deg);
	vertical-align: .2rem;
	margin-right: .5rem;
}
.footer_item a[target="_blank"]::after {
	content: '';
	display: inline-block;
	width: 1.3rem;
	height: 1.3rem;
	background: url(../img/icon_external.png) no-repeat left top / 100% auto;
	margin-left: .4rem;
	vertical-align: -.1rem;
}
.footer_item .footer_broker {
	margin-top: 3.2rem;
}
.footer_item .footer_link {
	display: flex;
	gap: 4.8rem;
	margin-bottom: 3.5rem;
}
.footer_item .footer_link a::before {
	margin-right: 1.6rem;
}
.footer .copyright {
	display: block;
	text-align: center;
	font-size: 1.3rem;
	margin-top: 7.3rem;
}
@media only screen and (max-width: 834px) {
	.footer {
		padding-bottom: 30rem;
	}
	.footer_pagetop {
		padding: 4.4rem 0 4.9rem;
	}
	.footer_pagetop img {
		width: 4rem;
	}
	.footer_inner h2 {
		font-size: 3.4rem;
		margin-bottom: .4rem;
	}
	.footer_item {
		margin-left: 4rem;
		margin-right: 3rem;
		font-size: 3rem;
		letter-spacing: 0;
	}
	.footer_item + .footer_item {
		margin-top: 8.4rem;
	}
	.footer_list li {
		margin-left: 5rem;
		text-indent: -5rem;
	}
	.footer_list li::before {
		margin-right: 2rem;
	}
	.footer_item p + p,
	.footer_item ul + p {
		margin-top: 3.5rem;
	}
	.footer_item a::before {
		width: 1.4rem;
		height: 1.4rem;
		border-top-width: .2rem;
		border-right-width: .2rem;
		vertical-align: .4rem;
		margin-right: 1rem;
	}
	.footer_item a[target="_blank"]::after {
		width: 2.6rem;
		height: 2.6rem;
		margin-left: .8rem;
		vertical-align: -.2rem;
	}
	.footer_item .footer_broker {
		margin-top: 5rem;
	}
	.footer_item .footer_link {
		flex-direction: column;
		gap: 2rem;
		margin: 3rem 0 6.8rem;
	}
	.footer_item .footer_link a::before {
		margin-right: 3rem;
	}
	.footer .copyright {
		font-size: 2.6rem;
		margin-top: 8rem;
	}
}