@charset "utf-8";
:root {
	--c_bk:#000000;
	--c_wh:#ffffff;
	--c_bu:#007CE2;
	--c_bu2:#3FA9F5;
	--c_lb:#D9EEFD;
	--c_lb2:#EAF6FD;
	--c_or:#FF931E;
	--c_ye: #FFF100;
	--c_rd:#FF1D25;
	--c_lr:#fde6e8;
	--c_lr2:#fdf2f3;
	--c_dr:#C1272D;
	--c_pu:#8F409B;
	--c_gr:#00B050;
	--c_gr2:#22B573;
	--c_lg3:#E9F8F1;
	--c_gy:#F2F2F2;
	--cb: cubic-bezier(.38,.07,0,.98);
}
.clr-bk {color: var(--c_bk)!important;}
.clr-wh {color: var(--c_wh)!important;}
.clr-bu {color: var(--c_bu)!important;}
.clr-lb {color: var(--c_lb)!important;}
.clr-lb2 {color: var(--c_lb2)!important;}
.clr-or {color: var(--c_or)!important;}
.clryer {color: var(--c_ye)!important;}
.clr-rd {color: var(--c_rd)!important;}
.clr-lr {color: var(--c_lr)!important;}
.clr-lr2 {color: var(--c_lr2)!important;}
.clr-dr {color: var(--c_dr)!important;}
.clr-ry {color: var(--c_gr)!important;}
.clr-gr {color: var(--c_gr)!important;}
.clr-gr2 {color: var(--c_gr2)!important;}
.clr-lg {color: var(--c_lg3)!important;}
.clr-gy {color: var(--c_gy)!important;}
.bg-bk {background-color: var(--c_bk)!important;}
.bg-wh {background-color: var(--c_wh)!important;}
.bg-bu {background-color: var(--c_bu)!important;}
.bg-lb {background-color: var(--c_lb)!important;}
.bg-lb2 {background-color: var(--c_lb2)!important;}
.bg-or {background-color: var(--c_or)!important;}
.bg-ye {background-color: var(--c_ye)!important;}
.bg-rd {background-color: var(--c_rd)!important;}
.bg-lr {background-color: var(--c_lr)!important;}
.bg-lr2 {background-color: var(--c_lr2)!important;}
.bg-dr {background-color: var(--c_dr)!important;}
.bg-gr {background-color: var(--c_gr)!important;}
.bg-gr2 {background-color: var(--c_gr2)!important;}
.bg-lg3 {background-color: var(--c_lg3)!important;}
.bg-gy {background-color: var(--c_gy)!important;}

.fo-futura {
	font-family: "futura-pt", sans-serif;
	font-weight: 700;
	font-style: normal;
	line-height: 1;
}
.fo-din {
	font-family: "din-2014-narrow", sans-serif;
	font-weight: 600;
	font-style: normal;
	line-height: 1;
}
body {
	padding-top: 11.4rem;
}
.spClick {
	pointer-events: none;
}
.pageTtl {
	background: url(../img/page_ttl_bg.jpg) center center no-repeat;
	background-size: cover;
	height: 20rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	color: #fff;
	font-size: 1.7rem;
}
.pageTtl._bl {
	background-image: url(../img/page_ttl_bg_bl.jpg);
}
.pageTtl h1 {
	font-size: 6.2rem;
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: 0.05em;
}
.btnBox + .btnBox {
	margin-top: 8rem;
}
.btnBox .ttl {
	font-size: 4.2rem;
	font-weight: 600;
	letter-spacing: .1em;
	margin-bottom: 1rem;
}
.btnBox .sub {
	font-size: 3rem;
	font-weight: 600;
	display: inline-block;
	position: relative;
	margin-bottom: 2rem;
	line-height: 1.4;
	letter-spacing: .1em;
	padding: 0 1em;
}
.btnBox .sub::before,
.btnBox .sub::after {
	content: "";
	display: block;
	width: 2.5px;
	height: 1.2em;
	background: #000;
	position: absolute;
	bottom: 0;
	right: 0;
	transform: skew(-30deg);
}
.btnBox .sub::after {
	right: auto;
	left: 0;
	transform: skew(30deg);
}
.appBtn a {
	display: flex;
	justify-content: center;
	align-items: center;
	background: var(--c_rd);
	text-align: center;
	position: relative;
	color: #fff;
	border: .5rem solid #fff;
	line-height: 1;
	padding: 2.5rem 1rem 3rem;
	font-size: 6.4rem;
	font-weight: 700;
	gap: 4rem;
	letter-spacing: 0.05em;
	border-radius: 10rem;
	margin-bottom: 1rem;
	box-shadow: 1rem 1rem 0 rgba(0,0,0,.15);
}
.appBtn a::before {
	content: "";
	display: block;
	background: url(../img/top/icon_card.svg) center center no-repeat;
	background-size: contain;
	aspect-ratio: 84/52;
	width: 8.4rem;
}
.appBtn a::after {
	content: "";
	display: block;
	background: url(../img/arrow_wh.svg) center center no-repeat;
	background-size: contain;
	aspect-ratio: 1;
	width: 3rem;
	position: absolute;
	right: 5rem;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}
.appBtn a:hover {
	background-color: var(--c_bu)!important;
}
.appBtn._increase a {
	background-color: var(--c_gr);
}
.appBtn._increase a::before {
	display: none;
}
.appBtn._sm a {
	max-width: 60rem;
	margin: 3rem auto 0;
	font-size: 4.5rem;
	gap: 1.5rem;
}
.appBtn._sm a::after {
	width: 2rem;
	right: 2rem;
}
.appBtn._sm a::before {
	width: 6rem;
}
.appBtn._noIcon a::before {
	display: none;
}
.appBtn._arrow {
	background: url(../img/btm_bk.svg) center top no-repeat;
	background-size: auto 3.1rem;
	padding-top: 4rem;
	margin-top: 3rem;
}
.appBtnWrap .appBtn {
	background: url(../img/btm_bl.svg) center top no-repeat;
	background-size: auto 2.6rem;
	padding-top: 4.5rem;
	margin-top: 2rem;
}
.appBtnWrap .appBtn a {
	margin: 0 auto;
	font-size: 5rem;
	gap: 1.5rem;
	max-width: 73rem;
}
.appBtnWrap .appBtn a::before {
	width: 6.7rem;
}
.btnArea  {
	padding: 5rem 0;
}
.btnArea h2 {
	font-size: 4.2rem;
	margin-bottom: 2rem;
}
.btnArea h2 span {
	color: var(--c_bu);
}
.btnArea.bg-bu {
	color: #fff;
}
.btnArea.bg-bu h2 span {
	color: #FFF100;
}

/*appフォーム
---------------------------------------------------------*/
@media screen and (max-width: 780px) {
	body.appPage {
		padding-bottom: 0;
	}
	body#apply {
		padding-bottom: 4rem;
	}
}
.appPage._apply .hBtn a._01,
.appPage._apply .navBtn li._01,
.appPage._apply .spBtn a._01,
.appPage._increase .hBtn a._02,
.appPage._increase .navBtn li._02,
.appPage._increase .spBtn a._02 
{
	display: none!important;
}

/*header
---------------------------------------------------------*/
#header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background: #fff;
	z-index: 9990;
	transition: .2s;
}
#header.scl {
	box-shadow: 0 -1px 5px #ddd;
}
.hWrap {
	padding: 2rem 7rem 2rem 0;
	width: 90%;
	max-width: 110rem;
	margin: 0 auto;
	position: relative;
	gap: 1rem;
}
.hLogo {
	text-align: left;
	display: flex;
	align-items: center;
	gap: 2rem;
}
.logo img {
	display: block;
	max-height: 6.7rem;
}
.hLogo .ttl {
	font-size: 2.3rem;
	font-weight: 800;
	line-height: 1.1;
	color: var(--c_bu);
}
.hLogo .ttl strong {
	display: block;
	font-size: 140%;
}
.hBtn {
	display: flex;
	gap: 1.2rem;
}
.hBtn a {
	width: 27.5rem;
	height: 7.4rem;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	color: #fff;
	background: var(--c_rd);
	text-align: center;
	font-size: 3.7rem;
	font-weight: 800;
	border-radius: 10rem;
	padding: .5rem 0 .5rem;
	line-height: 1.2;
	position: relative;
}
.hBtn a._01 small {
	display: block;
	font-size: 43%;
}
.hBtn a._02 {
	width: 17.5rem;
	font-size: 2.2rem;
	font-weight: 700;
	color: #000;
	background: #fff;
	border-radius: .6rem;
	border: 1px solid #000;
	line-height: 1.2;
	padding-right: 2rem;
}
.hBtn a::after {
	content: "";
	display: block;
	width: 2.2rem;
	aspect-ratio: 1;
	background: url(../img/arrow_wh.svg) center center no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 1.6rem;
	transform: translateY(-50%);
}
.hBtn a._02::after {
	right: 1rem;
	background-image: url(../img/arrow.svg);
}
.hBtn a:hover {
	background-color: var(--c_bu);
}
.hBtn a._02:hover {
	background-color: var(--c_lb);
}

/*nav
----------------------------------------------------------*/
.menuIcon {
	position: absolute;
	bottom: 2.2rem;
	right: 0;
	width: 5.4rem;
	height: 3.6rem;
	z-index: 99999;
	cursor: pointer;
	display: block;
}
.menuIcon::after {
	content: "メニュー";
	font-size: 1.4rem;
	color: #4d4d4d;
	font-weight: 600;
	display: block;
	white-space: nowrap;
	position: absolute;
	top: -2.5rem;
	left: 0;
	right: 0;
	margin: 0 auto;
}
.menuIcon.active {
	top: 4.5rem;
	bottom: auto;
}
.menuIcon.active::after {
	content: "閉じる";
}
.menuIcon span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background:#4d4d4d;
	z-index: 10;
/*	transition: .2s;*/
}
.menuIcon span:nth-of-type(1) {top: 0px;}
.menuIcon span:nth-of-type(2) {top: 1.6rem;	}
.menuIcon span:nth-of-type(3) {bottom: 0px;	}
.menuIcon.active span {
	/* background-color: #fff; */
}
.menuIcon.active span:nth-of-type(1) {
	-webkit-transform: translateY(2.2rem) rotate(45deg);
	transform: translateY(2.2rem) rotate(45deg);
}
.menuIcon.active span:nth-of-type(2) {
	opacity: 0;
}
.menuIcon.active span:nth-of-type(3) {
	-webkit-transform: translateY(-1rem) rotate(-45deg);
	transform: translateY(-1rem) rotate(-45deg);
}
#nav {
	position: fixed;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	z-index: 10;
	transition: all 0.3s ease-in-out;
	overflow: auto;
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
	display: block;
	background: var(--c_bu);
	color: #fff;
	text-align: left;
	font-weight: 600;
	visibility: hidden;
	pointer-events: none;
	opacity: 0;
}
#nav.active {
	opacity: 1;
	visibility: visible;
	pointer-events: all;
	z-index: 9990;
}
.navHeader {
	padding: 2.5rem 0;
	position: relative;
	background: #F5F5F5;
	margin-bottom: 3rem;
}
.navHeader .navBtn {
	display: none;
}
.navTel {
	display: flex;
	align-items: flex-end;
}
.navTel a {
	color: #fff;
	font-size: 7.5rem;
}
.navTel small {
	display: block;
	font-size: 1.6rem;
	font-weight: 500;
}
.navLogo {
	display: flex;
	align-items: flex-end;
	gap: 2rem;
}
.navLogo::after {
	content: "";
	display: block;
	position: absolute;
	left: -100vw;
	right: -100vw;
	bottom: 0;
	height: 2px;
	background: #fff;
}
.navLogo {
	width: 90%;
	max-width: 110rem;
	margin: 0 auto;
	gap: 1rem 5rem;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}
.navLogo .logo._01 img {
	max-height: 8.1rem;
}
.navLogo .logo._02 img {
	max-height: 5.7rem;
}
.navCont {
	max-width: 110rem;
}
.nav {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	text-align: left;
	margin-bottom: 6rem;
}
.nav a {
	display: flex;
	align-items: center;
	gap: 1.2rem;
	font-size: 1.8rem;
	color: #fff;
	line-height: 1;
	font-weight: 500;
}
.nav a::before {
	content: "";
	display: block;
	width: 1.2rem;
	aspect-ratio: 1;
	background: url(../img/arrow_wh.svg) left center no-repeat;
	background-size: contain;
	margin-bottom: -0.3rem;
}
.nav a:hover {
	color: var(--c_ye);
}
a[target="-1"] {
	pointer-events: none;
}
.nav li + li {
	margin-top: 1.5rem;
}
.nav .child,.nav .son {
	margin-top: 1.5rem;
}
.nav .child a {
	font-size: 1.6rem;
	font-weight: 400;
}
.nav .child a::before {
	visibility: hidden;
}
.nav .son a {
	line-height: 1.4;
	padding-left: .3em;
	text-indent: -.3em;
}
.navBtn {
	display: flex;
	justify-content: center;
	gap: 2rem;
	margin-bottom: 5rem;
}
.navBtn li {
	width: 100%;
	max-width: 49rem;
}
.navBtn a {
	display: block;
	text-align: center;
	background: var(--c_rd);
	color: #fff;
	border-radius: 10rem;
	padding: 1rem;
	font-size: 3.6rem;
	font-weight: 800;
	line-height: 1.2;
	position: relative;
}
.navBtn a small {
	display: block;
	font-weight: 600;
	font-size: 50%;
}
.navBtn li._02 a {
	background: #fff;
	color: #000;
	border-radius: .6rem;
}
.navBtn li a::after {
	content: "";
	display: block;
	width: 2rem;
	aspect-ratio: 1;
	background: url(../img/arrow_wh.svg) center center no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 2rem;
	transform: translateY(-50%);
}
.navBtn li:nth-of-type(2) a::after {
	background-image: url(../img/arrow.svg);
}
.navBtn a:hover {
	background: var(--c_bu2);
	color: #fff;
}
.navBtn li:nth-of-type(2) a:hover {
	color: #fff;
	background-color: var(--c_gr2);
}
.navBtn li:nth-of-type(2) a:hover:after {
	background-image: url(../img/arrow_wh.svg);
}
.toLoan a {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background: #fff;
	border-radius: .6rem;
	max-width: 36rem;
	margin: 0 auto;
	font-size: 1.6rem;
	font-weight: 600;
	padding: 1.5rem 1rem;
	line-height: 1.1;
	margin-bottom: 2rem;
}
.toLoan .logo img {
	max-height: 4.8rem;
}
.toLoan a span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	letter-spacing: 0.1em;
	gap: 1rem;
	margin-top: 1rem;
}
.toLoan a span::after {
	content: "";
	display: block;
	aspect-ratio: 1;
	background: url(../img/blank_bl.svg) center center no-repeat;
	background-size: contain;
	width: 1.3rem;
}
.spBtn {
	display: none;
}

/*footer-----------------------------------------------*/
#footer {
	background: var(--c_bu);
	color: #fff;
	overflow: hidden;
	border-top: 1px solid #ccc;
}
.footArea {
	width: 90%;
	max-width: 110rem;
	margin: 0 auto;
	padding: 3rem 0;
}
.fTop {
	padding: 2.5rem 0;
	position: relative;
	background: #F5F5F5;
}
.fLogo {
	width: 90%;
	max-width: 110rem;
	margin: 0 auto;
	gap: 1rem 5rem;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}
.fLogo .logo._01 img {
	max-height: 8.1rem;
}
.fLogo .logo._02 img {
	max-height: 5.7rem;
}
.fLogo .ttl {
	font-size: 4.7rem;
	font-weight: 800;
}
.footArea .hBtn a {
	font-size: 3.5rem;
	width: 38rem;
	height: auto;
}
.fNav {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	text-align: left;
}
.fNav a {
	display: flex;
	align-items: center;
	gap: 1.2rem;
	font-size: 1.8rem;
	color: #fff;
	line-height: 1;
	font-weight: 500;
}
.fNav a::before {
	content: "";
	display: block;
	width: 1.2rem;
	aspect-ratio: 1;
	background: url(../img/arrow_wh.svg) left center no-repeat;
	background-size: contain;
	margin-bottom: -0.3rem;
}
.fNav a:hover {
	color: var(--c_ye);
}
.fNav li + li {
	margin-top: 1.5rem;
}
.fNav .child,.fNav .son {
	margin-top: 1.5rem;
}
.fNav .child a {
	font-size: 1.6rem;
	font-weight: 400;
}
.fNav .child a::before {
	visibility: hidden;
}
.fBtn {
	margin-top: 4rem;
	gap: 1rem;
}
.fBtn li {
	width: 100%;
	max-width: 39.5rem;
}
.fNav .son a {
	line-height: 1.4;
	padding-left: .3em;
	text-indent: -.3em;
}
.fBtn a {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: 1rem;
	background: #fff;
	border-radius: .3rem;
	border: .2rem solid var(--c_dr);
	padding: 1rem;
	font-weight: 600;
}
.fBtn a b {
	display: block;
	font-size: 87.5%;
	border-radius: 10rem;
	background: var(--c_dr);
	color: #fff;
	line-height: 1;
	padding: 0.8rem;
	width: 16rem;
}
.fBtn a::after {
	content: "";
	display: block;
	background: url(../img/arrow_rd.svg) center center no-repeat;
	background-size: contain;
	width: 1.4rem;
	aspect-ratio: 1;
}
.fBtn ._02 a {
	border-color: #C9CACA;
}
.fBtn ._02 a b {
	background: var(--c_bu);
}
.fBtn ._02 a::after {
	background-image: url(../img/blank_bl.svg);
}
.fBtm {
	padding-top: 3rem;
	margin-top: 3rem;
	position: relative;
}
.fBtm::after {
	content: "";
	display: block;
	position: absolute;
	left: -100vw;
	right: -100vw;
	top: 0;
	height: 2px;
	background: #003CC8;
}
.fAdd {
	font-size: 87.5%;
}
.fixBtn {
	display: none;
}

/*contents
---------------------------------------------------------*/
.h1 {
	opacity: 0;
	visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -9999;
	width: 0;
	height: 0;
}
.mainArea {
	text-align: center;
	overflow: hidden;
}
.mainSlider {
	transition: .6s;
	opacity: 0;
}
.mainSlider.slick-initialized {
	opacity: 1;
}
.sliderBox {
	width: 90%;
	max-width: 115rem;
	margin: 0 auto;
	font-size: 3rem;
	font-weight: 700;
	height: 60.5rem;
}
.slick-arrow {
	display: block;
	width: 3rem;
	aspect-ratio: 1;
	background: url(../img/arrow_gy.svg) center center no-repeat;
	background-size: contain;
	position: absolute;
	top: 50%;
	right: 15%;
	transform: translateY(-50%);
	z-index: 5;
	cursor: pointer;
	transition: .2s;
}
.slick-arrow.prev {
	right: auto;
	left: 15%;
	transform: translateY(-50%) rotate(180deg);
}
@media screen and (max-width: 1600px) {
	.slick-arrow.next {
		right: 5%;
	}
	.slick-arrow.prev {
		left: 5%;
	}
}
.slick-arrow:hover {
	opacity: .8;
}
.mainArea .slick-dots {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 1rem;
	z-index: 5;
	margin: 0 auto;
}
.mainArea .slick-dots button::before {
	content: "";
	width: 1rem;
	aspect-ratio: 1;
	background: transparent;
	border-radius: 50%;
	border: 1px solid #808080;
}
.slick-dots li.slick-active button::before {
	background: #808080;
}
.sliderWrap {
	background: url(../img/top/mv/mv01_bg.jpg) center center no-repeat;
	background-size: cover;
}
.sliderBox {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.sliderBox figure {
	max-width: 38rem;
	margin-top: auto;
}
.mvBtn {
	margin: 2.5rem auto 0;
	max-width: 53.3rem;
}
.sliderBox dl {
	flex: 1;
	max-width: 54rem;
	text-align: left;
	padding-bottom: 2rem;
}
.slider01Box {
	max-width: 100rem;
}
.slider01Box figure {
	max-width: 35.8rem;
	margin-left: -5rem;
}
.slider01Box dl {
	max-width: 66rem;
}
.slider01Box h2 {
	font-size: 3.9rem;
	font-weight: 800;
	letter-spacing: 0.05em;
	margin-bottom: 2rem;
}
.slider01Box ul {
	display: grid;
	display: flex;
	justify-content: space-between;
	gap: 1rem 2.5rem;
	margin-top: 2rem;
}
.slider01Box ul img {
	max-height: 14.7rem;
}
.sliderWrap._02 {
	background-image: url(../img/top/mv/mv02_bg.jpg);
}
.slider02Box {
	max-width: 99rem;
	position: relative;
}
.slider02Box figure {
	max-width: 40.5rem;
	position: absolute;
	left: 0;
	bottom: 0;
}
.slider02Box dl {
	flex: auto;
	max-width: 54rem;
	margin-left: auto;
}
.slider02Box .sub {
	margin-bottom: .5rem;
	letter-spacing: 0.05em;
	font-size: 3.3rem;
	font-weight: 800;
}
.slider02Box h2 {
	max-width: 56.4rem;
	font-size: 6rem;
	white-space: nowrap;
	font-weight: 800;
	letter-spacing: 0.02em;
}
.slider02Box h2 .se {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	line-height: 1.8;
}
.slider02Box h2 .se p {
	background: #fff;
	padding: 0 4rem;
	border-radius: 10rem;
	margin: 0 1.2rem;
}
.slider02Box h2 .se img {
	display: block;
	margin: 0 auto;
	height: 9rem;
}
.slider02Box dt {
	margin-bottom: 2.5rem;
	text-align: right;
}
.sliderWrap._03 {
	background-image: url(../img/top/mv/mv03_bg.jpg);
}
.slider03Box {
	max-width: 104rem;
	display: block;
	padding-top: 2rem;
}
.slider03Box dl {
	text-align: center;
	width: 100%;
	max-width: 100%;
	flex: auto;
}
.slider03Box h2 {
	margin-bottom: 1rem;
}
.slider03Box h2 img {
	display: block;
	max-height: 6.4rem;
	margin: 0 auto;
}
.slider03Box h3 {
	font-size: 3.8rem;
	font-weight: 700;
}
.slider03Box dt {
	position: relative;
	padding-bottom: 2rem;
}
.slider03Box dt figure {
	max-width: 12.9rem;
	position: absolute;
	left: 1.2rem;
	bottom: 0;
}
.slider03Box dt figure._02 {
	max-width: 10.5rem;
	left: auto;
	right: 1.2rem;
	bottom: 0;
}
.slider03Box ul {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 1rem 2.5rem;
	margin-top: 2rem;
}
.slider03Box ul {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-template-rows: repeat(2, 1fr);
	gap: 2rem;
	margin-top: 0;
}
.slider03Box ul li:nth-of-type(1) { grid-area: 1 / 1 / 3 / 2; }
.slider03Box ul li:nth-of-type(2) { grid-area: 1 / 2 / 2 / 3; }
.slider03Box ul li:nth-of-type(3) { grid-area: 2 / 2 / 3 / 3; }

.anm {
	opacity: 0;
	transform: translateY(5rem) scale(0);
	transition: .5s 1s;
}
.slick-active .anm {
	animation: anm .45s .8s forwards var(--cb);
}
.slick-active .anm._02 {
	animation-delay: .95s;
}
.slick-active .anm._03 {
	animation-delay: 1.1s;
}
.slick-active .anm._04 {
	animation-delay: 1.25s;
}
.slick-active .anm._05 {
	animation-delay: 1.4s;
}
@keyframes anm {
	0% {
		transform: translateY(5rem) scale(0);
		opacity: 0;
	}
	60% {
		transform: translateY(-2rem) scale(1.175);
		opacity: 1;
	}
	100% {
		transform: translateY(0) scale(1);
		opacity: 1;
	}
}






#topNews {
	padding: 3rem 0 4rem;
}
.termsLink a {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	margin-bottom: 3rem;
}
.termsLink a::after {
	content: "";
	display: block;
	background: url(../img/arrow02.svg) center center no-repeat;
	background-size: contain;
	width: 1.4rem;
	aspect-ratio: 1;
}
.termsLink a:hover {
	color: var(--c_bu);
}
.warningLink a {
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: 0.05em;
	margin-bottom: 4rem;
}
.warningLink a::before {
	content: "!";
	font-size: 75%;
	display: block;
	text-align: center;
	line-height: 1.8rem;
	width: 1.8rem;
	height: 1.8rem;
	min-width: 1.8rem;
	min-height: 1.8rem;
	color: #fff;
	background: #000;
	border-radius: 50%;
	margin-right: .7rem;
}
.warningLink a:hover {
	text-decoration: none;
	color: var(--c_bu);
}
.joukenImg {
	margin-bottom: 4rem;
}
#topNews .appBtn a {
	box-shadow: none;
}
#topNews .appBtn,
.btnArea .appBtn {
	background: url(../img/btm_bl.svg) center top no-repeat;
	background-size: auto 3.1rem;
	padding-top: 5.5rem;
}
.btnArea.bg-bu .appBtn {
	background-image: url(../img/btm_wh.svg);
}
.topNav {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 1.5rem;
	margin-top: 5rem;
}
.topNav a {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2rem;
	letter-spacing: 0.05em;
	font-size: 2.4rem;
	font-weight: 600;
	color: #333;
	position: relative;
	border: .2rem solid var(--c_dr);
	border-radius: .5rem;
	padding: 3rem 1rem 2rem;
}
.topNav a:hover {
	color: var(--c_dr);
	background: #FFF2F3;
}
.topNav h3 {
	font-size: 1.8rem;
	position: absolute;
	left: 0;
	right: 0;
	top: -2rem;
	margin: 0 auto;
	max-width: 25.5rem;
	border-radius: 10rem;
	background: var(--c_dr);
	color: #fff;
	padding: 0.6rem;
	z-index: 1;
}
.topNav a::after {
	content: "";
	display: block;
	background: url(../img/arrow_rd.svg) center center no-repeat;
	background-size: contain;
	width: 1.5rem;
	aspect-ratio: 1;
	margin-bottom: -0.5rem;
}
.topNav ._02 a {
	border-color: var(--c_bu);
}
.topNav ._02 a:hover {
	background: var(--c_lb);
	color: var(--c_bu);
}
.topNav ._02 h3 {
	background: var(--c_bu);
}
.topNav ._02 a::after {
	background-image: url(../img/blank_bl.svg);
	width: 2rem;
	aspect-ratio: 20/19;
}
.toCrease {
	margin-top: 3rem;
}
.toCrease a {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: .5rem 5rem;
	border: .2rem solid #333;
	border-radius: .6rem;
	padding: 1rem;
	text-align: center;
	color: #333;
	font-size: 4.65rem;
	font-weight: 700;
	background: #fff;
	letter-spacing: 0.075em;
}
.toCrease a::after {
	content: "";
	display: block;
	background: url(../img/arrow.svg) center center no-repeat;
	background-size: contain;
	width: 2rem;
	aspect-ratio: 1;
}
.toCrease a p {
	display: flex;
	align-items: center;
	line-height: 1.1;
	padding-bottom: 0.15em;
}
.toCrease a small {
	font-size: 66%;
	display: block;
	margin-left: 0.3em;
}
.toCrease a .ttl {
	display: inline-block;
	background: #333;
	font-size: 2rem;
	font-weight: 700;
	color: #fff;
	border-radius: 10rem;
	padding: 1rem;
	padding-bottom: 1.2rem;
	letter-spacing: 0.05em;
	line-height: 1.2;
	width: 28rem;
}
.toCrease a:hover {
	background: var(--c_gy);
}
#topThing {
	padding: 0 0 4rem;
}
.thingTtl {
	position: relative;
	z-index: 1;
	padding: 3rem 13.5rem 0;
	margin-bottom: 3rem;
}
.thingTtl figure {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}
.thingTtl figure._02 {
	right: 0;
	left: auto;
}
.thingTtl figure img {
	max-height: 12.5rem;
}
.thingTtl .sub {
	font-size: 2.6rem;
	font-weight: 800;
	line-height: 1;
	margin-bottom: 1rem;
	display: inline-block;
	position: relative;
	margin-bottom: .5rem;
	line-height: 1.4;
	letter-spacing: .1em;
	padding: 0 1em;
}
.thingTtl .sub::before,
.thingTtl .sub::after {
	content: "";
	display: block;
	width: 2.5px;
	height: 1.2em;
	background: #000;
	position: absolute;
	bottom: 0;
	right: 0;
	transform: skew(-30deg);
}
.thingTtl .sub::after {
	right: auto;
	left: 0;
	transform: skew(30deg);
}
.thingTtl h2 {
	font-size: 3.6rem;
	font-weight: 800;
	border-bottom: .4rem dotted var(--c_bu);
}
.tgl {
	position: relative;
	position: relative;
	cursor: pointer;
	transition: .2s;
}
.thingArea .tgl {
	background: var(--c_bu);
	color: #fff;
	border-radius: 10rem;
	font-size: 2.6rem;
	font-weight: 600;
	padding: 2rem;
	margin-bottom: 3rem;
}
.thingArea .tgl:hover {
	background-color: var(--c_bu2);
}
.tglIcon {
  display: inline-block;
  vertical-align: middle;
  color: #333;
  line-height: 1;
  height: .3rem;
  width: 1.6rem;
  background: #fff;
  position: absolute;
	top: 50%;
	right: 4rem;
	transform: translateY(-50%);
	z-index: 1;
}
.tglIcon::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  transition: .2s;
  transform: rotate(90deg);
}
.act .tglIcon::before {
	transform: rotate(0deg);
}
.tglIcon._bk,
.tglIcon._bk::before {
	background-color: #000;
}
.thingWrap {
	display: none;
}
.thingWrap > .txt {
	font-size: 2rem;
	margin-bottom: 3rem;
}
.thingBox {
	background: #fff;
	border-radius: 3rem;
	overflow: hidden;
	border: 2px solid var(--c_bu);
}
.thingBox h3 {
	font-size: 2.8rem;
	font-weight: 700;
	background: var(--c_bu);
	color: #fff;
	padding: 2rem;
}
.thingBox .cont {
	padding: 4rem 2rem;
}
#diagnosis {
	padding: 0;
	margin-bottom: 2rem;
	border-radius: .6rem ;
}
.diagnosisArea {
	border-top: 1px solid var(--c_bu);
	padding-bottom: 5rem;
}
.diagnosisTtlImg {
	padding: 0 4.5rem;
}
.diagnosisTtlImg img {
	max-height: 18.1rem;
}
.diagnosisTtl {
	margin-top: -4rem;
}
.diagnosisTtl h2 {
	color: #fff;
	font-size: 6.6rem;
	letter-spacing: 0.05em;
	padding-top: .8em;
	padding-right: .9em;
	position: relative;
	margin-bottom: 2rem;
}
.diagnosisTtl h2 .fo-futura {
	font-size: 133%;
	transform: scale(1.9, 1.92);
	display: inline-block;
	margin: 0 .5em;
	position: relative;
}
.diagnosisTtl h2::before {
	content: "";
	display: block;
	width: 21rem;
	aspect-ratio: 1;
	border-radius: 50%;
	background: var(--c_bu);
	z-index: -1;
	position: absolute;
	top: -2rem;
	left: 50%;
	transform: translateX(-50%);
	margin: 0 auto;
}
.diagnosisTtl .sub {
	max-width: 27.3rem;
	margin: 0 auto 1rem;
}
.diagnosisTtl02 {
	font-size: 3.2rem;
	color: #fff;
	letter-spacing: 0.05em;
	font-weight: 700;
	margin-bottom: 4rem;
}
.diagnosisBox {
	border-radius: 2rem;
	background: #fff;
	padding: 4rem 7rem;
	margin-bottom: 2rem;
	text-align: left;
}
.diagForm {
	display: grid;
	grid-template-columns: 23rem 1fr;
	gap: .8rem 2.5rem;
	font-weight: 500;
}
.diagForm dt {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--c_lb);
	font-size: 2.8rem;
	font-weight: 600;
}
.diagForm dd {
	padding: 1.5rem 0;
}
.diagForm input,.diagForm select {
	padding: 1.5rem;
	font-size: 2.4rem;
	border-radius: .5rem;
	border: 1px solid #666;
	width: 32.5rem;
}
.diagForm dd b {
	font-size: 2.8rem;
	font-weight: 600;
	margin-left: 1rem;
}
.diagForm dd .note {
	margin-top: 1rem;
}
.diagBtn button {
	width: 32.5rem;
	border-radius: 10rem;
	background: var(--c_or) url(../img/arrow_wh.svg) right 3rem center no-repeat;
	background-size: 1.6rem auto;
	font-size: 3.4rem;
	color: #fff;
	padding: 1.5rem;
	line-height: 1.2;
	letter-spacing: 0.05em;
}
.diagBtn button:hover {
	background-color: var(--c_rd);
}
.diagBtn {
	text-align: center;
	margin-top: 3rem;
}
#reason {
	padding-bottom: 0;
}
.reasonTopWrap {
	position: relative;
	padding: 1.5rem 20rem;
}
.reasonTopWrap figure img {
	max-height: 22.2rem;
}
.reasonTopWrap figure {
	position: absolute;
	top: 0;
	left: 0;
}
.reasonTopWrap figure._02 {
	right: 0;
	left: auto;
}
.reasonTop .sub {
	font-size: 4rem;
	color: var(--c_bu);
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 1.5rem;
}
.reasonTop .logo {
	text-align: center;
	margin-bottom: 2rem;
}
.reasonTop .logo img {
	margin: 0 auto;
	height: 6.3rem;
}
.reasonTop h2 {
	font-size: 5.4rem;
	letter-spacing: 0.05em;
	color: var(--c_bu);
	display: flex;
	align-items: flex-end;
	justify-content: center;
	background: url(../img/wave.svg) left bottom repeat-x;
	background-size: auto .9rem;
	padding-bottom: 1.2rem;
	text-indent: .075em;
	white-space: nowrap;
}
.reasonTop h2 .fo-futura {
	font-size: 240%;
	display: inline-block;
	line-height: .85;
}
.reasonArea {
	padding: 6rem 0;
	position: relative;
}
.reasonArea::before {
	content: "";
	display: block;
	z-index: -99;
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc(-50vw + 50%);
	right: calc(-50vw + 50%)
}
.reasonArea:nth-of-type(even)::before {
	background: var(--c_lb);
}
.reasonBox {
	border: .3rem solid var(--c_bu);
	background: #fff;
	position: relative;
	border-radius: 1.7rem;
	margin-top: 9rem;
}
.reasonTtl {
	background: var(--c_bu);
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 2rem 1rem;
	border-radius: 1.2rem 1.2rem 0 0;
	color: #fff;
	letter-spacing: 0.05em;
}
.reasonTtl .num {
	width: 10rem;
	aspect-ratio: 1;
	padding-top: 1.2rem;
	background: var(--c_bu);
	color: #fff;
	font-size: 5.6rem;
	line-height: 0.8;
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
	top: -6.3rem;
	border-radius: 50%;
	z-index: -1;
}
.reasonTtl .num .img {
	position: absolute;
	top: -3rem;
	left: 50%;
	margin: 0 auto;
	transform: translateX(-50%);
	font-size: 2.2rem;
	font-weight: 700;
	white-space: nowrap;
	color: #000;
}
.reasonTtl .num .img img {
	display: block;
}
.reasonTtl h2 {
	font-size: 3.4rem;
	font-weight: 800;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1.5rem;
}
.sevenlogo {
	display: inline-block;
	border-radius: 10rem;
	padding: .2rem 1.5rem;
	background: #fff;
	border-radius: 10rem;
}
.sevenlogo img {
	display: block;
	max-height: 5rem;
}
.reasonCont {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-direction: row-reverse;
	gap: 3rem;
	padding: 3rem 4rem;
}
#reason03 .reasonCont,
#reason04 .reasonCont,
#reason06 .reasonCont {
	flex-direction: row;
}
.reasonCont figure {
	flex: 1;
	text-align: center;
	margin: 0 0 -3rem;
}
img[src*="/reason_img01"] {
	max-height: 25.2rem;
}
img[src*="/reason_img02"] {
	max-height: 25.2rem;
}
img[src*="/reason_img03"] {
	max-height: 25.9rem;
}
img[src*="/reason_img04"] {
	max-height: 24.1rem;
}
img[src*="/reason_img06"] {
	max-height: 24.3rem;
}
.reasonCont dl {
	max-width: 51rem;
	text-align: left;
}
.reasonCont dt {
	font-size: 3.4rem;
	font-weight: 800;
	border-bottom: .2rem dotted #CCC;
	padding-bottom: 1rem;
	margin-bottom: 1rem;
}
.reasonCont dd {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.6;
}
.reasonCont dt .tag {
	background: var(--c_or);
	display: inline-block;
	font-size: 55%;
	color: #fff;
	border-radius: 10rem;
	padding: .2rem 2rem;
	margin-right: 1rem;
	vertical-align: .5rem;
}
.reasonBtm {
	margin-top: 2rem;
}
.btn02  {
	margin-top: 1.5rem;
}
.btn02 a {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 2rem;
	border-radius: 10rem;
	background: #fff;
	border: 1px solid #000;
	font-size: 1.9rem;
	padding: .5rem 3rem .5rem 4rem;
}
.btn02 a::after {
	content: "";
	display: block;
	background: url(../img/arrow.svg) center center no-repeat;
	background-size: contain;
	width: 1.5rem;
	aspect-ratio: 1;
}
.btn02 a:hover {
	border-color: #fff!important;
	background-color: var(--c_rd)!important;
	color: #fff;
}
.btn02 a:hover::after {
	background-image: url(../img/arrow_wh.svg);
}
.btn02._or a {
	background-color: var(--c_or);
	border-width: .2rem;
	color: #fff;
	border-color: #fff;
}
.btn02._or a::after {
	background-image: url(../img/arrow_wh.svg);
}
.btn02._bk a {
	background-color: #333;
	color: #fff;
	border-color: #333;
}
.btn02._bk a::after {
	background-image: url(../img/arrow_wh.svg);
}
.btn02._bl a {
	background-color: var(--c_bu);
	color: #fff;
	border-color: var(--c_bu);
}
.btn02._bl a::after {
	background-image: url(../img/arrow_wh.svg);
}
.appBtn02 a {
	font-weight: 700;
	display: flex;
	justify-content: center;
	align-items: center;
	background: var(--c_rd) url(../img/arrow_wh.svg) right 1rem center no-repeat;
	background-size: 1.6rem auto;
	color: #fff;
	font-size: 2.4rem;
	border-radius: 10rem;
	border: .3rem solid #fff;
	min-width: 28rem;
	padding: .5rem;
	padding-bottom: 0.8rem;
	box-shadow: .5rem .5rem 0 rgba(0,0,0,.15);
}
.appBtn02 a:hover {
	background-color: var(--c_bu);
}
.reason05Cont figure img {
	max-height: 14rem;
}
.reason05Cont figure {
	position: absolute;
	left: 1.5rem;
	bottom: 0;
	margin: 0;
}
.reason05Cont figure:nth-of-type(2) {
	right: 1.5rem;
	left: auto;
}
.reason05Cont ul {
	margin: -2rem auto 0;
	text-align: left;
}
.reason05Cont li {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	background: url(../img/top/icon_check.svg) left center no-repeat;
	background-size: 3.4rem auto;
	padding: 2rem 0 2rem 4.5rem;
	font-size: 3.4rem;
	font-weight: 700;
	gap: 0 1.2rem;
	line-height: 1;
}
.reason05Cont li span {
	position: relative;
}
.reason05Cont li img[src*="logo_nbc"] {
	max-height: 4rem;
}
.reason05Cont li:not(:first-of-type) {
	border-top: .2rem dotted #CCC;
}
.reason05Cont li small {
	font-size: 70%;
}
.reason05Cont li .note {
	font-size: 1.6rem;
	position: absolute;
	bottom: -2rem;
	right: 0;
	font-weight: 500;
}
#howto .container {
	max-width: 98rem;
}
.howtoTtl {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	gap: .1em;
	font-size: 4.2rem;
	font-weight: 500;
	margin-bottom: 4rem;
}
.howtoTtl img {
	max-height: 7.5rem;
}
.howtoTtl strong {
	display: block;
	font-size: 100%;
	letter-spacing: 0.075em;
}
.howtoWrap {
	gap: 7rem 3%;
}
.howtoWrap li {
	width: 48.5%;
	border-radius: 1.7rem;
	border: .3rem solid var(--c_bu);
	position: relative;
}
.howtoWrap li h3 {
	border-radius: 1rem 1rem 0 0;
	background: var(--c_bu);
	padding: .5rem;
	font-size: 3.2rem;
	color: #fff;
}
.howtoWrap li._02 {
	--c_bu:var(--c_bu2);
}
.howtoWrap li._03 {
	--c_bu:var(--c_rd);
}
.howtoWrap li._03 .appBtn02 a {
	background-color: var(--c_rd);
}
.howtoWrap li._03 .appBtn02 a:hover {
	background-color: #007CE2;
}
.howtoBox {
	padding: 2.5rem 2rem 4.5rem;
}
.howtoCont {
	margin: 0 auto;
	width: fit-content;
	text-align: left;
	font-weight: 800;
}
.howtoCont dt {
	display: flex;
	justify-content: center;
	align-items: center;
}
.howtoCont dd {
	line-height: 1.3;
	text-align: center;
}
.howtoCont dd._tel {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
}
.howtoCont dd._tel .fo-din {
	font-size: 115%;
}
.stel {
	display: block;
	margin-top: 0.5rem;
	font-size: 1.6rem;
	font-weight: 500;
}
.stel a {
	display: inline-block;
	font-size: 115%;
}
.howtoCont img[src*="logo_sevenginkou"] {
	width: 100%;
	max-height: 6rem;
}
.orTxt {
	font-size: 2.6rem;
	font-weight: 800;
	line-height: 1;
	margin: 1.5rem 0;
}
.howtoCont .txt {
	font-size: 3.2rem;
	white-space: nowrap;
}
.howtoCont .ttl {
	font-size: 2.6rem;
	font-weight: 800;
	margin-bottom: 0.1em;
}
.howtoCont .ttl small {
	display: block;
	font-size: 1.8rem;
}
.btn {
	margin-top: 2rem;
}
.btn a {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	min-width: 27.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	background: var(--c_or) url(../img/arrow_wh.svg) right 1rem center no-repeat;
	background-size: 1.6rem auto;
	color: #fff;
	font-size: 2.4rem;
	border-radius: 10rem;
	border: .3rem solid #fff;
	min-width: 28rem;
	padding: .5rem 5rem;
	padding-bottom: 0.8rem;
	box-shadow: .5rem .5rem 0 rgba(0,0,0,.15);
}
.btn._aq a {
	background-color: var(--c_bu2);
}
.btn a:hover {
	background-color: var(--c_rd)!important;
}
.howtoWrap .btn {
	position: absolute;
	left: 0;
	right: 0;
	bottom: -2.5rem;
	margin: 0 auto;
	max-width: 27.5rem;
}
.howtoWrap .appBtn02 a {
	font-size: 2.4rem;
	max-width: 34rem;
	margin: 0 auto 1rem;
}
.cap {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
}
#flow h2 {
	font-size: 5.8rem;
	margin-bottom: 5rem;
	color: #fff;
	line-height: 1;
}
.flow li {
	position: relative;
	z-index: 1;
}
.flowWrap {
	border-radius: 10rem;
	background: #fff;
	padding: 3rem;
	position: relative;
	display: flex;
	align-items: center;
	gap: 1rem 6.5rem;
}
.flow-arw {
	position: relative;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 1.6rem solid transparent;
  border-left: 1.6rem solid transparent;
  border-top: 2.1rem solid #fff;
  border-bottom: 0;
	position: relative;
	margin: 1.5rem auto 2.5rem;
}
.flow-arw::before {
	content: "";
	display: block;
  width: 3.3rem;
	aspect-ratio: 33/21;
	background-color: #005CD5;
	clip-path: polygon(50% 100%, 0% 0%, 100% 0%);
	z-index: -1;
	position: absolute;
	top: -1rem;
	left: 50%;
	transform: translateX(-50%);
}
.flowWrap .num {
	width: 13.5rem;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	border-radius: 50%;
	aspect-ratio: 1;
	line-height: 1;
	background: var(--c_or);
	color: #fff;
	font-size: 2rem;
}
.flowWrap .num strong {
	display: block;
	font-size: 450%;
	line-height: 1;
}
.flowWrap figure {
	position: absolute;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	top: 0;
	bottom: 0;
	right: 9.5rem;
}
._03 .flowWrap figure,
._05 .flowWrap figure {
	align-items: center;
}
img[src*="/flow_img01"] {
	max-height: 18.8rem;
}
img[src*="/flow_img02"] {
	max-height: 18.1rem;
}
img[src*="/flow_img03"] {
	max-height: 12.8rem;
}
img[src*="/flow_img04"] {
	max-height: 17.1rem;
}
 ._05 .flowWrap figure {
	width: 15rem;
 }
img[src*="/flow_img05"] {
	display: block;
	max-height: 21.6rem;
	margin: -4rem auto 2rem;
}
.flowWrap dl {
	text-align: left;
	font-size: 2.2rem;
}
.flowWrap dt {
	font-size: 3.4rem;
	font-weight: 800;
	display: flex;
	align-items: center;
	gap: 2rem;
}
.contTel {
	max-width: 55rem;
	margin: 5rem auto 0;
	color: #fff;
	font-size: 2.2rem;
}
.contTel a {
	color: #fff;
}
.contTel .ttl {
	font-weight: 600;
	margin-bottom: .5rem;
}
.telTxt {
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 500;
	white-space: nowrap;
	line-height: 1.3;
}
.telTxt .fo-din {
	font-size: 115%;
}
#product h2 {
	font-size: 5rem;
	margin-bottom: 2rem;
}
.contWrap {
	background: #fff;
	border: 1px solid #333;
	padding: 8rem;
}
.tlbWrap {
	display: grid;
	grid-template-columns: 26.5rem 1fr;
	text-align: left;
	font-size: 2.6rem;
	font-weight: 600;
	font-feature-settings: "palt";
}
.tlbWrap dt,.tlbWrap dd {
	padding: 2rem 3.5rem;
	border-top: .2rem dotted #5E5E5E;
}
.tlbWrap dt:last-of-type,.tlbWrap dd:last-of-type {
	border-bottom: .2rem dotted #5E5E5E;
}
.tlbWrap dt {
	background: var(--c_lb);
}
.productArea .note {
	font-size: 2rem;
	color: #231815;
	margin-top: 3rem;
}
.productArea .btn02 a {
	min-width: 45.5rem;
}
#simuBtn {
	padding: 5rem 0;
}
#simuBtn h2 {
	display: inline-block;
	position: relative;
	line-height: 1.2;
	margin-bottom: 1rem;
	font-size: 2.4rem;
}
#simuBtn h2::before,
#simuBtn h2::after {
	content: "";
	display: block;
	width: 0.3rem;
	height: 95%;
	border-radius: 10rem;
	position: absolute;
	bottom: 0;
	left: -3rem;
	background: #000;
	transform: skew(35deg);
}
#simuBtn h2::after {
	left: auto;
	right: -2rem;
	transform: skew(-35deg);
}
#simuBtn .appBtn a {
	max-width: 64rem;
	margin: 0 auto;
	font-size: 4.8rem;
	font-feature-settings: "palt";
	background-color: var(--c_bu2);
}
#simuBtn .appBtn a::before {
	display: none;
}
#simuBtn .appBtn a::after {
	right: 3rem;
}
.infoArea h2 {
	font-size: 4.6rem;
	margin-bottom: 5rem;
}
.infoWrap:first-of-type {
	margin-top: 0;
}
.infoWrap + .infoWrap {
	margin-top: 6rem;
}
.infoWrap h3 {
	font-size: 3.4rem;
	font-weight: 600;
	margin-bottom: 1rem;
}
.infoArea .note {
	margin-top: 1rem;
	font-size: 1.8rem;
	font-weight: 500;
}
.topBnr {
	margin-top: 4rem;
	gap: 1rem 2rem;
}
.infoWrap dl {
	display: grid;
	grid-template-columns: 41rem 1fr;
	border-radius: 2rem;
	border: .3rem solid #ccc;
	position: relative;
	overflow: hidden;
}
.infoWrap dl + dl {
	margin-top: 2rem;
}
.infoWrap dt {
	display: flex;
	flex-direction: column;
	justify-content: center;
	background: var(--c_lb);
	padding-left: 4rem;
}
.infoWrap dt li {
	text-align: left;
	font-size: 2.2rem;
	font-weight: 700;
	padding-left: .5em;
	text-indent: -.5em;
}
.infoWrap dt li + li {
	margin-top: 0.5rem;
}
.infoWrap dt li::before {
	content: "・";
}
.infoWrap h4 {
	font-size: 2.6rem;
	font-weight: 700;
}
.infoWrap h4 small {
	display: block;
}
.infoWrap dd {
	padding: 3rem 2rem;
}
.telnum a {
	pointer-events: none;
	color: var(--c_bu);
	white-space: nowrap;
	font-size: 9.2rem;
	line-height: 0.8;
}
.telnum small {
	display: block;
	font-size: 1.6rem;
	font-weight: 500;
	margin-top: 1rem;
}

#topInfo h2 {
	font-size: 5.4rem;
	font-weight: 800;
	margin-bottom: 4rem;
}
.topInfo li + li {
	margin-top: 1.5rem;
}
.topInfo a {
	display: block;
	border-radius: 10rem;
	text-align: center;
	color: #fff;
	font-weight: 700;
	font-size: 3rem;
	padding: 1rem;
	background: var(--c_bu);
	position: relative;
}
.topInfo a::after {
	content: "";
	display: block;
	background: url(../img/arrow_wh.svg) center center no-repeat;
	background-size: contain;
	aspect-ratio: 1;
	width: 2.6rem;
	position: absolute;
	right: 3rem;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}
.topInfo a:hover {
	background-color: var(--c_rd);
}




/*form
---------------------------------------------------------*/
.formTopArea {
	padding: 4rem 0;
	text-align: left;
}
.formTopTxt {
	text-align: center;
}
.formTopTxt h2 {
	font-size: 3.2rem;
}
.formTopTxt p {
	display: inline-block;
	text-align: left;
}
.formTopTxt a {
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 800;
	background: #D31833;
	color: #fff;
	max-width: 41rem;
	margin: 1rem auto 0;
	position: relative;
	padding: .5rem 0 1rem;
	line-height: 1;
}
.formTopTxt a:hover {
	background: #000;
}
.formTopTxt a::after {
	content: "";
	display: inline-block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 6px 0 6px 10px;
	border-color: transparent transparent transparent #ffffff;
	margin-left: 2rem;
}
.formTopArea h3 {
	font-size: 1.8rem;
	font-weight: 800;
	margin: 3rem 0 1rem;
	position: relative;
	padding-right: 21rem;
}
.pdfdl {
	position: absolute;
	top: 0;
	right: 0;
	display: inline-block;
	background: #4d4d4d;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 500;
	padding: .5rem 1rem;
	line-height: 1;
	display: flex;
	justify-content: center;
	align-items: center;
}
.pdfdl::after {
	content: "";
	display: inline-block;
	background: url(../img/icon_pdf.svg) center center no-repeat;
	background-size: contain;
	width: 1rem;
	height: 1.3rem;
	margin-left: .5rem;
}
.policyBox {
	border: 1px solid #000;
	height: 10rem;
	overflow: auto;
	padding: 1rem 2rem;
}
.policyBox h4 {
	font-size: 118%;
}
.policyBox h4:not(:first-of-type) {
	margin-top: 1.5rem;
}
.policyBox ol {
	list-style: decimal;
	padding-left: 1em;
}
.formSelect {
	text-align: center;
	margin-top: 8rem;
	font-size: 3.2rem;
	font-weight: 700;
}
.formSelect .box01 {
	width: 51%;
	background: url("../img/arrow_btm.svg") bottom center no-repeat;
	background-size: auto 3.4rem;
	padding-bottom: 5rem;
}
.formSelect .box02 {
	width: 46%;
	font-size: 2.6rem;
}
.formSelect dt a {
	height: 12rem;
	color: #fff;
	font-weight: 800;
	font-size: 6.2rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: #D31833;
	line-height: 1.2;
	padding-bottom: .5rem;
}
.formSelect .box02 dt a {
	background: #e4f3d9;
	font-size: 2.6rem;
	color: #00A73C;
}
.formSelect .box02 dt big {
	font-size: 150%;
	line-height: 1.1;
	white-space: nowrap;
}
.formSelect a::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: .6rem 0 .6rem 1rem;
	border-color: transparent transparent transparent #ffffff;
	position: absolute;
	right: 2rem;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	display: none;
}
.formSelect a:hover {
	background: #000!important;
	color: #fff!important
}
.loginArea {
	margin-top: 7rem;
	text-align: left;
	font-size: 2.2rem
}
.loginArea > dt {
	padding: 0 3rem 1rem;
	border-bottom: 1px solid #000;
	margin-bottom: 1.5rem;
	font-size: 108%;
	letter-spacing: -.05em;
}
.loginArea > dd {
	padding: 0 3.5rem;
}
.loginArea .txt {
	color: #D31833;
	margin-bottom: 2rem;
}
.loginForm {
	text-align: center;
}
.loginFormBox {
	max-width: 75rem;
	font-size: 118%;
	margin: 0 auto;
	text-align: left;
}
.loginFormBox dt {
	width: 28%;
	padding: .5rem;
}
.loginFormBox dd {
	width: 72%;
	padding: .5rem;
}
.loginFormBox input {
	width: 100%;
	padding: 1rem	
}
.loginForm button {
	display: block;
	max-width: 26rem;
	margin: 3rem auto;
	line-height: 1;
	border-radius: 90px;
	width: 100%;
	position: relative;
	background: #000;
	color: #fff;
	font-size: 2.6rem;
	font-family: 'Noto Sans JP', sans-serif ,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana;
	font-weight: 500;
	padding: .5rem 0 1rem;
	transition: .1s;
}
.loginForm button:hover {
	background: #D31833;
}
.loginForm button::after {
	content: "";
	display: inline-block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 6px 0 6px 10px;
	border-color: transparent transparent transparent #ffffff;
	position: absolute;
	right: 2rem;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
.passLink {
	color: #D31833;
	font-size: 2.6rem;
	text-decoration: underline;
}
.passLink:hover {
	color: #000;
	text-decoration: none;
}
#subscribeForm {
	background: #EDEDED;
}
.formArea {
	max-width: 120rem;
	padding: 4rem 10rem;
	text-align: left;
	background: #fff;
}
.formWrap h2 {
	font-size: 112.5%;
	border-bottom: 2px solid var(--c_bu);
	margin-bottom: 2rem;
}
.formWrap h2:not(:first-of-type) {
	margin-top: 7rem;
}
.formWrap dt {
	font-weight: 700;
	margin-top: 4rem;
}
.formWrap h2 + dl dt {
	margin-top: 0;
}
.formWrap dd {
	margin-top: .5rem;
}
.req dt::after {
	content: "必須";
	display: inline-block;
	font-size: 87.5%;
	color: #fff;
	background: var(--c_rd);
	padding: 0 .5rem;
	margin-left: 1rem;
	vertical-align: 0.2rem;
}
.formWrap input[type="text"],
.formWrap input[type="tel"],
.formWrap input[type="email"],
.formWrap input[type="password"],
.formWrap select,
.formWrap textarea {
	width: 100%;
	padding: .575em;
	border: 1px solid #ccc;
	border-radius: 3px;
	font-size: 2rem;
}
.formWrap input[type="text"]:focus,
.formWrap input[type="text"]:focus,
.formWrap input[type="tel"]:focus,
.formWrap input[type="email"]:focus,
.formWrap input[type="password"]:focus,
.formWrap select:focus,
.formWrap textarea:focus {
	outline: 2px solid #F3A500;
}
.formWrap .size-m {
	max-width: 49%;
}
.formWrap .size-s {
	max-width: 24%;
}
.formWrap input[type="text"] + span {
	margin-left: .5rem;
}
.formWrap select {
	background: #fff;
	color: #000
}
.formWrap textarea {
	height: 190px;
}
.formWrap .inputinput[type="text"] + span {
	padding-top: 0.75rem;
}
.zipBtn {
	background: #e6e6e6;
	font-size: 110%;
	margin-left: 1rem;
	padding: 1.1rem ;
	cursor: pointer;
	line-height: 1.1;
	border: 1px solid #949494;
	color: #231815;
	font-family: 'Noto Sans JP', sans-serif ,"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", Verdana;
	font-weight: 500;
	white-space: nowrap;
}
.zipBtn:hover {
	background: #ccc
}
.form-name .box {
	width: 49.5%;
}
.formWrap dd p {
	margin-top: 1rem;
}
.formWrap dd h3 {
	font-weight: 600
}
.formWrap dd h3:not(:first-of-type) {
	margin-top: 1.5rem;
}
.formWrap .note {
	margin-bottom: 1.5rem;
}
.form-birth select {
	width: 15rem;
	margin-top: .5rem;
}
.form-birth select:first-of-type {
	width: auto;
}
.form-birth select + span {
	margin: 0 .5rem
}
.radioWrap label {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	padding: 1rem .5rem 1.5rem;
	line-height: 1.1;
	text-align: center;
	width: 32.5%;
	border: 1px solid #949494;
	border-radius: 5px;
	background: #EDEDED;
	background: -webkit-gradient(linear,left bottom, left top,from(#EDEDED),to(#fff));
	background: -o-linear-gradient(bottom,#EDEDED 0%,#fff 100%);
	background: linear-gradient(to top,#EDEDED 0%,#fff 100%);
	font-size: 115%;
	cursor: pointer;
	transition: .1s;
	margin: .416666666%
}
.radioWrap.col-2 label {
	width: 49.1666666%;
}
.radioWrap label:hover {
	background: #ddd
}
.radioWrap label small {
	display: block;
	width: 100%;
	margin-top: .5rem;
	font-size: 90%;
}
.radioWrap input[type="radio"] {
	display: none;
}
.radioWrap input[type="radio"]:checked + label {
	background: var(--c_bu);
	border-color: var(--c_bu);
	color: #fff;
}
.req input[type="text"],
.req input[type="tel"],
.req input[type="email"],
.req input[type="password"],
.req select,
.req textarea {
	background: var(--c_lb2);
	border-color: var(--c_bu);
}
.radioWrap .errorTxt {
	width: 100%!important;
}
.req .radioWrap {
	background-color: var(--c_lb2);
	padding: .5rem 0;
}
.req option:disabled {
	color: var(--c_bu)!important;
}
.form-koza .box {
	width: 49.5%;
}
.magagizeCheck {
	text-align: center;
	font-size: 115%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.magagizeCheck label {
	margin: 0;
}
.magagizeCheck input {
	display: inline-block;
	-webkit-transform: scale(2);
	-ms-transform: scale(2);
	transform: scale(2);
	margin-right: 2rem;
}
.errorTxt {
	margin-top: .5rem;
	font-size: 90%;
	color: red;
}
.errorTxt a {
	text-decoration: underline;
	color: #137ED7
}
#email_error {
	font-size: 115%;
}
.errorTop .errorTxt:last-of-type {
	margin-bottom: 3rem;
}
.confTxt {
	font-size: 1.8rem;
	margin-top: 6rem;
	margin-bottom: 2.5rem;
	border: 1px solid #4d4d4d;
	padding: 1em;
}
.submitBtnWrap {
	margin-top: 3rem;
}
.formWrap .submitBtn {
	background: var(--c_bu);
	border-radius: 90px;
	color: #fff;
	font-size: 4.2rem;
	font-weight: 800;
	display: block;
	width: 48rem;
	margin: 1rem;
	line-height: 1;
	padding: 2rem 1rem;
	position: relative;
	transition: .1s;
}
.formWrap .submitBtn::after {
	content: "";
	display: block;
	background: url("../img/arrow_wh.svg") center center no-repeat;
	background-size: 100% auto;
	width: 2.4rem;
	height: 2.4rem;
	position: absolute;
	right: 3rem;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}
.formWrap .submitBtn._back {
	background: #aaa
}
#deleteForm .formWrap .submitBtn {
	background-color: var(--c_rd);
}
.formWrap .submitBtn:hover {
	background-color: #000!important;
}
.formWrap .submitBtn._back::after {
	right: auto;
	left: 3rem;
	-webkit-transform: translateY(-50%) rotate(180deg);
	-ms-transform: translateY(-50%) rotate(180deg);
	transform: translateY(-50%) rotate(180deg);
}
.hidden {
	display: none;
}
.kyojyu2 {
	background: url("../img/arrow03.svg") top 1rem center no-repeat;
	background-size: 4.5rem auto;
	padding-top: 6rem!important;
}
.formTxt {
	font-size: 3rem;
	font-weight: 800;
	text-align: center;
	color: #D31833;
	margin-bottom: 2rem;
}
.kyojyu2 input[type="text"] {
	background: #fff;
}
.shorui select {
	width: auto;
	background: #fff;
	border-color: #949494;
}
.fileCont {
	line-height: 1;
	border: 1px solid #949494;
	border-radius: 5px;
	padding: 1rem;
	margin-bottom: 2rem;
	max-width: 500px;
}
.thxBox {
	text-align: center;
	font-size: 2.2rem;
}
.thxBox .txt {
	margin-bottom: 2rem;
}
.seal {
	text-align: center;
	margin-top: 1.5rem;
}
.changeForm-address-close,
.changeForm-job-close {
	display: none;
	margin-top: 0!important;
}
.no-chenge {
	background: var(--c_lb);
	color: var(--c_bu);
	text-align: center;
	font-size: 112.5%;
	font-weight: 600;
	padding: 1.5rem;
	border-radius: 1rem;
}
#increaseForm {
	--c_bu:var(--c_rd);
	--c_lb:var(--c_lr);
	--c_lb2:var(--c_lr2);
}
.formTerms .box + .box {
	margin-top: 2rem;
}
.formTerms h3 {
	font-size: 1.8rem;
	position: relative;
	cursor: pointer;
	background: var(--c_gy);
	padding: 2rem;
}
.formTerms h3 span {
	display: block;
	width: 1.6rem;
	aspect-ratio: 1;
	position: absolute;
	right: 3rem;
	top: 50%;
	transform: translateY(-50%);
}
.formTerms h3 span::after,
.formTerms h3 span::before {
	content: "";
	width: 1.6rem;
	height: .3rem;
	background: #000;
	position: absolute;
	left: auto;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	transform: none;
	transition: .2s;
}
.formTerms h3 span::before {
	width: .3rem;
	height: 1.6rem;
	right: .65rem;
	opacity: 1;
}
.formTerms h3.act span::before {
	-webkit-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	transform: rotate(90deg);
	opacity: 0;
}
.formTerms .cont {
	display: none;
	height: 20rem;
	padding: 0 2rem;
	padding-right: 1em;
	overflow: auto;
	position: relative;
	font-size: 1.4rem;
	line-height: 1.6;
	margin-top: 2rem;
}
.formTerms .cont h4 {
	font-size: 112.5%;
	margin: 0.8rem 0;
}
.formTerms .cont h5 {
	font-size: 100%;
	margin: 1rem 0 .2rem;
}
.formTerms ol {
	list-style: decimal;
	padding-left: 1em;
}
.termsTbl {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 1rem;
}
.termsTbl th,
.termsTbl td {
	text-align: center;
	font-weight: 400;
	border: 1px solid #333;
	padding: .3rem 1rem;
	font-size: 90%;
}
.termsTbl thead th {
	color: #fff;
	background: #333;
}
.termsTbl thead th:first-of-type {
	border-right-color: #fff;
}
.termsTbl tbody tr:nth-of-type(even) {
	background: var(--c_gy);
}
.termsTbl tbody th span {
	display: inline-block;
	margin: 0 .5em;
}
.deleteFormTop {
	padding: 3rem 0 4rem;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.8;
}
.deleteFormTop h2 {
	font-size: 2.4rem;
	font-weight: 500;
	margin-bottom: 1rem;
}
.deleteFormTop .txt strong {
	display: inline-block;
	font-size: 122%;
	color: var(--c_rd);
	font-weight: 700;
	margin-top: 0.5rem;
}

/*appli
---------------------------------------------------------*/
#appliTop {
	padding: 4rem 0 0;
}
.appliTop {
	display: flex;
	flex-direction: row-reverse;
	gap: 2rem 4rem;
	text-align: left;
}
.appliTop figure img {
	max-height: 24.5rem;
}
.appliTop .box {
	text-align: left;
	font-size: 2.6rem;
	font-weight: 600;
	flex: 1;
	font-feature-settings: "palt";
}
.appliTop .box h2 {
	color: var(--c_bu);
	font-size: 4.8rem;
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: 0.05em;
	margin-bottom: 1rem;
}
.appliTop .box h2 strong {
	font-size: 175%;
}
.appliArea h2 {
	font-size: 3.8rem;
	font-weight: 800;
	margin-bottom: 4rem;
}
.appliWrap {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 3rem 4.5rem;
}
.appliWrap dl {
	background: #fff;
	overflow: hidden;
	border-radius: 2rem;
	border: 2px solid var(--c_bu);
}
.appliWrap dt {
	background: var(--c_bu);
	padding: 1rem;
	color: #fff;
	font-size: 2.8rem;
	font-weight: 800;
}
.appliWrap dd {
	padding: 2rem 2rem 3rem;
}
.appliWrap .bnr img {
	margin-top: 1rem;
	max-height: 6.05rem;
}
.appliWrap .txt {
	text-align: left;
	margin-top: 1rem;
}
.appliArea .note {
	margin-top: 2em;
	text-align: left;
	padding-left: 1em;
	text-indent: -1em;
}
.pageBtmTel {
	padding-top: 5rem;
}
.pageBtmTel h2 {
	font-size: 3.4rem;
	font-weight: 700;
	margin-bottom: 3rem;
}
.telBox {
	width: fit-content;
	margin: 0 auto;
	border-radius: 2rem;
	border: .3rem solid #ccc;
	position: relative;
	overflow: hidden;
	padding: 2rem 7rem;
}
.telBox .ttl {
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 1rem;
}
.telBox .telnum small {
	font-size: 1.8rem;
}

/*jouken
---------------------------------------------------------*/
.joukenArea h2 {
	text-align: left;
	color: var(--c_bu);
	margin-bottom: 2rem;
}
.joukenArea h2:not(:first-of-type) {
	margin-top: 8rem;
}
.joukenCont {
	display: grid;
	grid-template-columns: 35rem 1fr;
	text-align: left;
	font-size: 1.8rem;
}
.joukenCont dt,
.joukenCont dd {
	padding: 2rem 4rem;
	border-bottom: 1.5px dotted #5e5e5e;
}
.joukenCont dt:last-of-type,
.joukenCont dd:last-of-type {
	border-bottom: none;
}
.joukenCont dt {
	display: flex;
	flex-direction: column;
	align-items: start;
	justify-content: center;
	background: var(--c_gy);
	font-size: 112.5%;
	font-weight: 700;
}

/*shiryou
---------------------------------------------------------*/
.txtSec {
	padding: 3rem 0;
	font-size: 3.2rem;
	font-weight: 700;
}
.shiryouArea {
	background: #fff;
	padding: 3rem 2rem;
	border-radius: 2rem;
}
.shiryouArea h2 {
	font-size: 3.2rem;
	font-weight: 700;
	margin-bottom: 2rem;
}
.pdfBtn a {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1.5rem;
	font-size: 3.3rem;
	font-weight: 800;
	color: #fff;
	line-height: 1.4;
	position: relative;
	padding: 1.5rem 1rem 1.7rem;
	text-align: center;
	background: var(--c_bu);
	max-width: 71.5rem;
	margin: 0 auto 4rem;
	letter-spacing: 0.05em;
	border: .4rem solid #fff;
	border-radius: 10rem;
	box-shadow: .8rem .8rem 0 rgba(0, 0, 0, .15);
}
.pdfBtn a::before {
	content: "";
	display: inline-block;
	background: url("../img/icon_pdf02.svg") center center no-repeat;
	background-size: contain;
	width: 3.1rem;
	aspect-ratio: 31/37;
}
.pdfBtn a::after {
	content: "";
	display: inline-block;
	background: url("../img/icon_dl.svg") center center no-repeat;
	background-size: contain;
	width: 2.8rem;
	aspect-ratio: 1;
	position: absolute;
	right: 3rem;
	top: 50%;
	transform: translateY(-50%);
}
.pdfBtn a:hover {
	background-color: var(--c_or);
}
.shiryouArea ul {
	display: inline-block;
	text-align: left;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.3;
	padding-left: 1em;
	text-indent: -1em;
}
.shiryouArea li {
	margin-bottom: 1.5rem;
}
.shiryouArea li::before {
	content: "●";
	color: var(--c_bu);
}

/*papers
---------------------------------------------------------*/
.papersTop {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 5rem 5.5rem;
	margin-bottom: 4rem;
}
.papersWrap {
	display: flex;
	flex-direction: column;
}
.papersWrap h2 {
	font-size: 3.2rem;
	font-weight: 800;
	color: var(--c_bu);
	margin-bottom: 1rem;
}
.papersBox {
	flex: 1;
	border: .3rem solid var(--c_bu);
	border-radius: 2rem;
	overflow: hidden;
}
.papersBox h3 {
	font-size: 3.2rem;
	font-weight: 800;
	color: #fff;
	background: var(--c_bu);
	padding: 1rem;
}
.papersBox .cont {
	padding: 2rem 6rem;
}
.papersBox h4 {
	font-size: 3.2rem;
	font-weight: 800;
	border-bottom: 2px dotted #ccc;
	margin-bottom: 2rem;
}
.papersBox ul {
	width: fit-content;
	padding: 0 2rem;
	font-size: 2rem;
	text-align: left;
}
.papersBox li + li {
	margin-top: .5rem;
}
.papersBox li::before {
	content: "・";
	color: var(--c_bu);
}
._02.papersWrap h2,
._02 .papersBox li::before {
	color: #333;
}
._02 .papersBox {
	border-color: #333;
}
._02 .papersBox h3 {
	background-color: #333;
}
.papersDetail h2 {
	font-size: 2rem;
	font-weight: 600;
	margin-bottom: 3rem;
}
.papersDetailCont {
	background: #fff;
	border-radius: 5rem 5rem 2rem 2rem;
}
.papersDetailCont h3 {
	background: #333;
	color: #fff;
	font-size: 2.6rem;
	font-weight: 800;
	padding: 1rem 1rem 1.2rem;
	position: relative;
	border-radius: 10rem;
	transition: .2s;
	cursor: pointer;
}
.papersDetailCont h3:hover {
	background: var(--c_bk);
}
.papersContents {
	padding: 3rem 2rem 5rem;
	font-size: 1.8rem;
}
.noappli01 {
	margin-bottom: 6rem;
}
.noappli01 .txt01 {
	font-weight: 600;
	font-size: 2rem;
	margin-bottom: 0.5rem;
}
.noappli01 .txt01 b {
	font-size: 112.5%;
	color: var(--c_bu2);
}
.papersContents h3 {
	background: #e6e6e6;
	color: #000;
	margin: 0 auto 2rem;
	max-width: 74rem;
}
.papersContents h3 .tglIcon {
	right: 3rem;
}
.papersContents h3:hover {
	background-color: #f1f1f1;
}
.noapli02 h4 {
	font-size: 2.7rem;
	font-weight: 800;
	margin-bottom: 0.5rem;
}
.noapli02 h4  a {
	font-size: 150%;
	letter-spacing: 0.03em;
}
.papersContents,
.noapli02 {
	display: none;
}

/*faq
---------------------------------------------------------*/
#faq {
	padding: 3rem 0 0;
}
.faqTop {
	font-size: 2.4rem;
	font-weight: 500;
}
.faqArea {
	position: relative;
	z-index: 1;
	padding: 5rem 0;
}
.faqArea:nth-of-type(even)::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc(-50vw + 50%);
	right: calc(-50vw + 50%);
	background: var(--c_lb);
	z-index: -50;
}
.faqArea h2 {
	font-size: 3.6rem;
	font-weight: 600;
	margin-bottom: 2rem;
}
.faqWrap dl {
	font-size: 1.8rem;
	text-align: left;
	font-weight: 500;
	margin-bottom: 3rem;
}
.faqWrap dt,
.faqWrap dd {
	position: relative;
	padding: 2rem 5rem 2rem 10rem;
}
.faqWrap dt {
	font-size: 112.5%;
	background: var(--c_bu);
	color: #fff;
	border-radius: 10rem;
}
.faqWrap dt:hover {
	background-color: var(--c_bu2);
}
.faqWrap dd {
	display: none;
	line-height: 1.8;
}
.faqWrap dt .tglIcon {
	right: 3rem;
}
.faqWrap dd a:not(.spClick) {
	color: var(--c_bu);
	text-decoration: underline;
}
.faqWrap dd a:hover {
	color: var(--c_or);
	text-decoration: none;
}
.faqWrap dt::before,
.faqWrap dd::before {
	content: "";
	display: block;
	background: url(../img/faq/que.svg) left center no-repeat;
	background-size: contain;
	width: 3.7rem;
	aspect-ratio: 37/33;
	position: absolute;
	left: 4rem;
	top: 50%;
	transform: translateY(-50%);
}
.faqWrap dd::before {
	top: 2.2rem;
	transform: none;
	background-image: url(../img/faq/ans.svg);
}

/*company
---------------------------------------------------------*/
.companyCont {
	display: grid;
	grid-template-columns: 35rem 1fr;
	text-align: left;
	font-size: 2rem;
}
.companyCont dt,
.companyCont dd {
	padding: 2rem 4rem;
	border-bottom: 1.5px dotted #5E5E5E;
}
.companyCont dt:last-of-type,
.companyCont dd:last-of-type {
	border-bottom: none;
}
.companyCont dt {
	background: #E6E6E6;
	font-weight: 700;
}
.companyCont .img {
	max-width: 32rem;
	margin-top: 2rem;
}
.companyCont .bnr {
	max-width: 51rem;
	margin: .7rem 0;
}
.companyCont dd a {
	text-decoration: underline;
}

/*policy
---------------------------------------------------------*/
#policyPage h2 {
	text-align: center;
	margin-bottom: 3rem;
}
.txtPage {
	text-align: left;
	font-weight: 500;
	font-size: 1.8rem;
}
.txtPage.fo20 {
	font-size: 2rem;
}
.txtPage > *{
	margin-bottom: 3.5rem;
}
.txtPage h3 {
	background: #333;
	color: #fff;
	padding: .5rem 1rem .7rem;
	margin: 0 0 2rem;
	font-weight: 600;
	font-size: 100%;
	letter-spacing: .025em;
}
.txtPage h3:not(:first-of-type) {
	margin-top: 5rem;
}
.txtPage ol {
	padding-left: 1.3em;
}
.txtPage ol li {
	list-style: decimal
}
.txtPage ol li:not(:first-of-type) {
	margin-top: 1rem;
}
.policyInfo {
	font-size: 125%;
	margin-top: 8rem;
	text-align: center;
}
.policyInfo .ttl {
	display: inline-block;
	border-bottom: 1px solid #000;
	padding-bottom: 1.5rem;
	margin-bottom: 2rem;
}

/*increase_about
---------------------------------------------------------*/
.increase_about .container {
	width: 100%;
}
.increase_aboutTtl {
	position: relative;
	padding: 0 13.6rem;
	font-weight: 500;
}
.subTtl {
	font-size: 3.2rem;
	font-weight: 800;
	font-feature-settings: "palt";
	display: inline-block;
	position: relative;
	margin-bottom: .5rem;
	line-height: 1.4;
	letter-spacing: .1em;
	padding: 0 1em;
}
.subTtl::before,
.subTtl::after {
	content: "";
	display: block;
	width: 2.5px;
	height: 1.2em;
	background: #000;
	position: absolute;
	bottom: 0;
	right: 0;
	transform: skew(-30deg);
}
.subTtl::after {
	right: auto;
	left: 0;
	transform: skew(30deg);
}
.subTtl._wh::before,
.subTtl._wh::after {
	background-color: #fff;
}
.increase_aboutTtl h2 {
	font-size: 3.4rem;
	font-weight: 800;
	margin-bottom: 1rem;
}
.increase_aboutTtl figure {
	position: absolute;
	max-width: 13.6rem;
	top: 0;
	left: 0;
}
.increase_aboutTtl figure._02 {
	left: auto;
	right: 0;
}
.appInfo {
	max-width: 90rem;
	margin: 6rem auto 0;
	font-weight: 500;
}
.appInfo .subTtl {
	font-size: 2.4rem;
	margin-bottom: 1rem;
}
.appInfo dl {
	border-radius: 2rem;
	border: .3rem solid var(--c_rd);
}
.appInfo dt {
	background: var(--c_rd);
	color: #fff;
	position: relative;
	border-radius: 1.5rem 1.5rem 0 0;
	padding: 1.5rem;
	padding-left: 10rem;
}
.appInfo dt h2 {
	font-size: 3.7rem;
}
.appInfo dt h2 strong {
	font-size: 150%;
	line-height: 1;
}
.appInfo dt figure {
	position: absolute;
	max-width: 8.7rem;
	bottom: 0;
	left: 10rem;
}
.appInfo dd {
	padding: 2rem 6rem;
}
.appInfo dd .txt {
	font-size: 2.2rem;
	font-weight: 800;
	margin-bottom: 1rem;
}
.appInfo .appBtn a {
	font-size: 5.9rem;
}
.appInfo .appBtn a::after {
	right: 3rem;
}
.appInfo._02 dl {
	border-color: var(--c_bu);
}
.appInfo._02 dt {
	background-color: var(--c_bu);
	padding-left: 1.5rem;
}
.appInfo._02 dt figure {
	left: auto;
	right: 8rem;
	max-width: 10.5rem;
}
.appInfo._02 h3 {
	display: inline-block;
	border-radius: 10rem;
	background: var(--c_bu);
	color: #fff;
	font-size: 2.5rem;
	font-weight: 700;
	padding: .2rem 2rem;
	margin-bottom: 1rem;
}
.appInfo._02 h4 {
	font-size: 2.8rem;
	line-height: 1.2;
	margin-bottom: 0.5rem;
}
.appInfo._02 h4 small {
	display: block;
	font-size: 71%;
}
.appInfo._02 .telnum a {
	font-size: 12rem;
}
.increase_about .note {
	text-align: left;
	margin-top: 0.5rem;
	padding-left: 1em;
	text-indent: -1em;
}

/*borrow
---------------------------------------------------------*/
#borrowTop {
	padding: 0;
}
.borrowTop {
	padding: 3rem 13rem;
	position: relative;
}
.borrowTop h2 {
	font-size: 5.4rem;
}
.borrowTop figure img {
	max-height: 14.4rem;
}
.borrowTop figure {
	position: absolute;
	left: 0;
	bottom: 0;
}
.borrowTop figure._02 {
	left: auto;
	right: 0;
}
.borrowAnc h2 {
	font-size: 5.4rem;
	line-height: 1.2;
	margin-bottom: 7rem;
}
.borrowAnc ul {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 3rem;
}
.borrowAnc a {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	border: 2px solid var(--c_gr2);
	border-radius: 1rem;
	padding: 3.5rem 1rem 1rem;
	height: 100%;
}
.borrowAnc a h3 {
	font-size: 2rem;
	font-weight: 800;
	color: #fff;
	border-radius: 10rem;
	padding: 1rem 2rem;
	background: var(--c_gr2);
	position: absolute;
	left: 2rem;
	right: 2rem;
	top: -2.5rem;
	z-index: 1;
}
.borrowAnc a p {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2rem;
}
.borrowAnc a p::after {
	content: "";
	background: var(--c_gr2) url(../img/arrow_tri.svg) center center no-repeat;
	background-size: 35% auto;
	border-radius: 50%;
	aspect-ratio: 1;
	width: 2.7rem;
	transform: rotate(90deg);
}
.borrowAnc a .txt {
	font-size: 3.2rem;
	font-weight: 800;
}
.borrowAnc a .txt::before {
	content: "";
	display: block;
	background: url(../img/top/icon_tel.svg) center center no-repeat;
	background-size: contain;
	aspect-ratio: 23/39;
	width: 2.3rem;
}
.borrowAnc ._02 a {
	border-color: var(--c_bu);
}
.borrowAnc ._02 a h3,
.borrowAnc ._02 a p::after {
	background-color: var(--c_bu);
}
.borrowAnc a:hover {
	transform: translateY(-1rem);
	box-shadow: 0 1rem 0 rgba(0, 0, 0, .15);
}
.borrowContArea {
	padding: 0;
}
.borrowTtl {
	padding: 4rem 0;
	color: #fff;
}
.borrowTtl h2 {
	font-size: 2rem;
	position: relative;
	padding-bottom: 1rem;
}
.borrowTtl .subTtl {
	font-size: 120%;
}
.borrowTtl h2 figure {
	max-width: 8.4rem;
	position: absolute;
	left: 5rem;
	bottom: 0;
}
.borrowTtl h3 {
	background: #fff;
	border-radius: 10rem;
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 12rem;
	font-size: 3.8rem;
	font-weight: 800;
	color: #000;
	padding: 1rem;
	position: relative;
}
.borrowTtl h3 a {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}
.borrowTtl h3 strong {
	font-size: 133%;
}
.borrowTtl h3 img[src*="seven"] {
	height: 10rem;
}
#borrow02 .borrowTtl h3::before {
	content: "";
	display: block;
	background: url(../img/top/icon_tel.svg) center center no-repeat;
	background-size: contain;
	aspect-ratio: 23 / 39;
	width: 3rem;
	margin-right: 1.5rem;
}
#borrow02 .borrowTtl h2 figure {
	max-width: 9.2rem;
	right: 5rem;
	left: auto;
}
.borrowArea {
	padding: 4rem 0 6rem;
}
.borrowArea h3 {
	font-size: 2.8rem;
	font-weight: 800;
	line-height: 1.4;
	margin-bottom: 2rem;
}
.borrowArea h3 small {
	display: block;
	font-size: 1.6rem;
	font-weight: 500;
	margin-top: 1rem;
}
.borrowFlow .flowWrap {
	gap: 2rem;
	padding: 0 3rem;
	min-height: 16rem;
}
.borrowFlow .flowWrap .num {
	width: 10rem;
	font-size: 1.55rem;
	background: var(--c_gr2);
}
.borrowFlow figure {
	position: static;
	flex: 1;
	margin-right: 3rem;
}
.borrowFlow h4 {
	width: 41rem;
	font-size: 2.8rem;
	font-weight: 800;
	text-align: left;
}
.borrowFlow h4 p {
	font-size: 2rem;
}
.borrowFlow img[src*="/flow_img01"],
.borrowFlow img[src*="/flow_img04"] {
	max-height: 14.8rem;
}
.borrowFlow img[src*="/flow_img02"] {
	max-height: 9.1rem;
}
.borrowFlow img[src*="/flow_img03"] {
	max-height: 9.5rem;
}
.borrowFlow ._01 figure,
.borrowFlow ._04 figure {
	margin-bottom: -1.2rem;
}
.borrowFlow .flow-arw {
	border-top-color: var(--c_gr2);
	margin-bottom: 1.5rem;
}
.borrowFlow .flow-arw::before {
	display: none;
}
.flowNote {
	width: fit-content;
	margin: 1rem auto 0;
	text-align: left;
}
.tel02Box {
	background: #fff;
	border-radius: 2rem;
	padding: 2rem;
	font-weight: 500;
}
.tel02Box .ttl {
	display: inline-block;
	border-radius: 10rem;
	background: var(--c_bu);
	color: #fff;
	font-size: 2.4rem;
	font-weight: 700;
	padding: .2rem 2rem;
	margin-bottom: 1.5rem;
}
.tel02Box .ttl02 {
	font-size: 2.8rem;
	line-height: 1.2;
	font-weight: 700;
	color: var(--c_bu);
	margin-bottom: 0.5rem;
}
.tel02Box .ttl02 small {
	display: block;
	font-size: 71%;
}
.tel02Box .telnum a {
	font-size: 12rem;
}
.increaseTelArea .subTtl {
	font-size: 2.6rem;
}
.increaseTelArea h2 {
	font-size: 3.2rem;
	color: var(--c_bu);
}
.increaseTel {
	border-radius: 1.7rem;
	border: .3rem solid var(--c_rd);
	position: relative;
}
.increaseTel h3 {
	border-radius: 1rem 1rem 0 0;
	background: var(--c_rd);
	padding: .5rem;
	font-size: 3.2rem;
	color: #fff;
}
.increaseTel {
	font-weight: 700;
	margin: 1.5rem 0;
}
.increaseTelBox {
	padding: 2rem 2rem 5rem;
	position: relative;
}
.increaseTelBox .appBtn02 a {
	font-size: 3rem;
	max-width: 45rem;
	margin: 0 auto;
}
.increaseTelCont .txt {
	font-size: 3.2rem;
	white-space: nowrap;
}
.increaseTelCont .ttl {
	font-size: 2.6rem;
	font-weight: 800;
	margin-bottom: 0.1em;
}
.increaseTelCont .ttl small {
	display: block;
	font-size: 1.8rem;
}
.increaseTelCont .fo-din {
	font-size: 115%;
}
.increaseTelCont dd._tel {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	font-weight: 800;
}
.increaseTelBox figure img {
	max-height: 15.9rem;
}
.increaseTelBox figure {
	position: absolute;
	left: 3rem;
	bottom: 0;
}
.increaseTelBox figure._02 {
	left: auto;
	right: 5rem;
}
.increaseTel .btn {
	position: absolute;
	left: 0;
	right: 0;
	bottom: -2.5rem;
	margin: 0 auto;
	max-width: 27.5rem;
}

/*repayment
---------------------------------------------------------*/
.repaymentHow h2 {
	display: flex;
	justify-content: center;
	align-items: flex-end;
	font-size: 3.2rem;
	font-weight: 800;
}
.repaymentHow h2 strong {
	font-size: 131%;
	color: var(--c_bu);
	line-height: 1.4;
	margin-right: 0.2em;
}
.repaymentHow h2 img {
	height: 7.5rem;
	margin-bottom: -0.4em;
}
.repaymentWrap {
	margin-top: 5rem;
	border: .3rem solid var(--c_bu);
	border-radius: 2rem;
}
.repaymentWrap dt {
	position: relative;
	background: var(--c_bu);
	border-radius: 1.5rem 1.5rem 0 0;
	padding: .5rem 0 .7rem;
}
.repaymentWrap._02 {
	border-color: var(--c_gr2);
}
.repaymentWrap._02 dt {
	background-color: var(--c_gr2);
}
.repaymentWrap dt h3 {
	color: #fff;
	font-size: 3.7rem;
	font-weight: 800;
}
.repaymentWrap dt figure {
	width: 10.8rem;
	aspect-ratio: 108/132;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 17rem;
	z-index: 1;
}
.repaymentWrap dt figure img {
	max-height: 100%;
}
.repaymentWrap dd {
	padding: 2.5rem;
}
.repaymentWrap dd .txt {
	font-size: 2.4rem;
	font-weight: 700;
}
.repaymentWrap dd h4 {
	font-size: 2.6rem;
	font-weight: 800;
	margin-bottom: 3.5rem;
}
.repaymentWrap dd ul {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 3rem;
}
.repaymentWrap dd ul li {
	background: var(--c_lg3);
	border-radius: 1rem;
	position: relative;
	padding: 4rem 1rem 1.5rem;
	line-height: 1.3;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	position: relative;
}
.repaymentWrap dd ul li:not(:last-of-type)::after {
	content: "";
	display: block;
	aspect-ratio: 7/8;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1.4rem;
	right: -2.2rem;
	background-color: var(--c_gr2);
	clip-path: polygon(100% 50%, 0% 0%, 0% 100%);
}
.repaymentWrap dd ul li .num {
	font-size: 3.2rem;
	width: 4.5rem;
	aspect-ratio: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	background: var(--c_gr2);
	color: #fff;
	position: absolute;
	left: 0;
	right: 0;
	top: -2.25rem;
	margin: 0 auto;
	z-index: 1;
	border-radius: 50%;
}
.repaymentHow .note {
	text-align: left;
	font-feature-settings: normal;
}
.repaymentHow .note h3,
.repaymentHow .note h4 {
	font-size: 112.5%;
	font-weight: 500;
	border-bottom: 1px solid #000;
	margin-top: 1em;
	margin-bottom: 0.5rem;
}
.repaymentHow .note h4 {
	border-bottom: none;
}
.repaymentHow .note li {
	padding-left: 1em;
	text-indent: -1em;
}
.repaymentTblArea h2 {
	font-size: 4.2rem;
	margin-bottom: 4rem;
}
.repaymentTblArea .subTtl {
	font-size: 3.8rem;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 2rem;
}
.repaymentTblArea .subTtl strong {
	font-size: 150%;
	color: var(--c_or);
	font-weight: 700;
}
.repaymentTblArea dl {
	background: #fff;
	border-radius: 5rem;
	border: .3rem solid var(--c_bu);
}
.repaymentTblArea dl + dl {
	margin-top: 4rem;
}
.repaymentTblArea .tgl {
	background: var(--c_bu);
	color: #fff;
	border-radius: 10rem;
	font-size: 2.6rem;
	font-weight: 600;
	padding: 2rem;
	margin: -.3rem;
}
.repaymentTblArea .tgl:hover {
	background-color: var(--c_bu2);
}
.repaymentTblArea dd {
	display: none;
	padding: 4rem;
}
.repaymentTblArea ._01 dd {
	display: block;
}
.repaymentTbl table {
	font-size: 2rem;
	border-radius: 2rem;
	border: .2rem solid #333;
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
}
.repaymentTbl th,
.repaymentTbl td {
	font-weight: 500;
	padding: 1rem;
}
.repaymentTbl th,
.repaymentTbl td {
	border-bottom: none;
	border-right: none;
	white-space: nowrap;
	border-top: 1px solid #333;
}
.repaymentTbl thead th:first-of-type,
.repaymentTbl tbody th:first-of-type {
	border-right: 1px solid #333;
}
.repaymentTbl thead th {
	background: #333;
	color: #fff;
	font-size: 120%;
	border: none;
	border-color: #fff!important;
}
.repaymentTbl tbody tr:nth-of-type(even) {
	background: var(--c_gy);
}
.repaymentTbl tbody th {
	display: grid;
	justify-content: center;
	grid-template-columns: 12rem 6em 12rem;
	text-align: right;
}
.repaymentTbl tbody th span {
	text-align: center;
}
.repaymentTblArea .note {
	margin-top: 2rem;
}
.fluctuationArea h2 {
	font-size: 4.2rem;
	margin-bottom: 5rem;
}
.fluctuation {
	border-radius: 2rem;
	border: .3rem solid #333;
	overflow: hidden;
	margin-top: 5rem;
}
.fluctuation dt {
	padding: 1rem;
	background: #333;
	color: #fff;
	font-size: 2.6rem;
	font-weight: 700;
}
.fluctuation dd {
	padding: 4rem;
}
#fluctuation {
	padding-bottom: 0;
}

/*flow
---------------------------------------------------------*/
#flowContents {
	padding: 0;
}
.flowTtl {
	position: relative;
	padding: 2rem 0;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2rem;
}
.flowTtl::before {
	content: "";
	display: block;
	background: var(--c_lb);
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc(-50vw + 50%);
	right: calc(-50vw + 50%);
	z-index: -1;
}
.flowTtl .num {
	font-size: 5rem;
	background: var(--c_bu);
	border-radius: 50%;
	width: 6.5rem;
	aspect-ratio: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
}
.flowTtl h2 {
	font-size: 5.8rem;
	color: var(--c_bu);
}
.flowArea {
	padding: 4rem 0 6rem;
	font-size: 2rem;
	font-weight: 500;
}
.flowArea .box > h3 {
	background: var(--c_bu);
	color: #fff;
	padding: 1rem;
	margin-bottom: 2rem;
	font-size: 2.8rem;
	border-radius: 10rem;
}
.flowArea .flow-arw {
	border-top-color: var(--c_bu);
	margin: 3rem auto 4rem;
}
.flowArea .flow-arw::before {
	background: var(--c_lb);
}
.flowArea .box > .txt {
	font-size: 112.5%;
}
.flowCont {
	display: grid;
	gap: 2rem 4rem;
	grid-template-columns: 36.7rem 1fr;
	align-items: center;
}
.flowCont dl {
	text-align: left;
	line-height: 1.6;
}
.flowCont dt {
	font-size: 3.2rem;
	font-weight: 800;
	margin-bottom: 1rem;
	color: var(--c_bu);
}
#flow04 .flowCont dt {
	margin-right: -1.5em;
}
.flowCont dd .note {
	display: block;
	margin-top: 1rem;
	font-size: 1.6rem;
	line-height: 1.4;
	padding-left: 1em;
	text-indent: -1em;
}
.flowCont img[src*="cont01-1"] {
	max-height: 21.5rem;
}
.flowCont img[src*="cont02-1"] {
	max-height: 11.4rem;
}
.flowCont img[src*="cont02-2"] {
	max-height: 12.1rem;
}
.flowCont img[src*="cont03-1"] {
	max-height: 20.3rem;
}
.flowCont img[src*="cont04-1"] {
	max-height: 24.1rem;
}
.flowCont img[src*="cont05-1"] {
	max-height: 21.5rem;
}
.btn04 a {
	margin-top: 2rem;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 2rem;
	color: #fff;
	border-radius: 10rem;
	background: var(--c_or);
	font-size: 2.4rem;
	font-weight: 800;
	padding: .5rem 3rem .5rem 6rem;
}
.btn04 a::after {
	content: "";
	display: block;
	background: url(../img/arrow_wh.svg) center center no-repeat;
	background-size: contain;
	width: 1.5rem;
	aspect-ratio: 1;
}
.btn04 a:hover {
	border-color: #fff!important;
	background-color: var(--c_rd)!important;
	color: #fff;
}
.appli02Wrap {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 3rem;
}
.appli02Wrap li {
	padding: 2rem;
	border-radius: 2rem;
	background: var(--c_lb);
	padding: 2rem;
}
.appli02Wrap li h4 {
	font-size: 3rem;
	font-weight: 800;
	margin-bottom: 2rem;
}
.appli02Wrap li .cont {
	display: grid;
	grid-template-columns: 17.2rem 1fr;
	gap: 1rem;
	align-items: center;
}
.appli02Wrap li .cont .bnr img {
	max-height: 6.2rem;
}
.appli02Wrap li .cont .bnr a {
	display: inline-block;
	border-radius: 1rem;
	overflow: hidden;
}
.appli02Wrap + .note {
	font-size: 80%;
	margin-top: 1rem;
}
.flowBtnBox {
	margin-top: 3rem;
	border-radius: 2rem;
	padding: 3rem 10rem;
	background: var(--c_gy);
}
.flowBtnBox .btn02 {
	margin-top: 0;
}
.btn03 a {
	display: block;
	background: #4d4d4d;
	color: #fff;
	font-size: 2.8rem;
	font-weight: 800;
	border-radius: 10rem;
	padding: 1rem;
	position: relative;
	max-width: 70rem;
	margin: 2rem auto 0;
}
.btn03 a:hover {
	background: #000;
}
.btn03 a::after {
	content: "";
	display: block;
	background: url(../img/arrow_wh.svg) center center no-repeat;
	background-size: contain;
	width: 2rem;
	aspect-ratio: 1;
	position: absolute;
	top: 50%;
	right: 2rem;
	transform: translateY(-50%);
	z-index: 1;
}
.flowArea .papersDetailCont {
	margin-top: 2rem;
}
.flowArea .papersContents h3 {
	font-size: 2rem;
}

/*practicable
---------------------------------------------------------*/
.diagResultBox {
	padding: 4rem;
	border-radius: 2rem;
	border: .3rem solid #b3b3b3;
}
.practicableBox h2 {
	font-size: 3.4rem;
	margin-bottom: 2rem;
}
.practicableBox .txt {
	font-size: 3.4rem;
	font-weight: 700;
	margin-bottom: 2rem;
}
.faildBox h2 {
	font-size: 4.4rem;
	margin-bottom: 1rem;
}
.faildBox .txt {
	font-size: 3.2rem;
	font-weight: 500;
	margin-bottom: 2.5rem;
}
.diagResultArea .note {
	text-align: left;
	padding-left: 1em;
	text-indent: -1em;
}

/*simulation
---------------------------------------------------------*/
#simuTop {
	padding: 0;
}
.simuTtl {
	padding: 3rem 13rem;
	position: relative;
}
.simuTtl .subTtl {
	font-size: 2.6rem;
}
.simuTtl h2 {
	font-size: 4.2rem;
}
.simuTtl figure img {
	max-height: 17.3rem;
}
.simuTtl figure {
	position: absolute;
	left: 0;
	bottom: 0;
}
.simuTtl figure._02 {
	left: auto;
	right: 0;
}
.simulationForm {
	background: #fff;
	border-radius: 2rem;
	padding: 4rem 2rem;
}
.simulationForm dl {
	width: fit-content;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 25rem 1fr;
	gap: 3rem 2rem;
	align-items: center;
	text-align: left;
	font-size: 3.2rem;
	font-weight: 700;
}
.simulationForm select {
	width: 25rem;
	height: 5rem;
	padding: 1rem;
	font-size: 2.6rem;
	font-weight: 500;
	border-color: #949494;
	border-radius: .5rem;
}
.simulationForm select:invalid {
  color: #333;
	background: #EAF6FD;
	font-size: 2rem;
}
.simulationForm dd {
	display: flex;
	align-items: center;
	gap: 1rem;
}
.simulationForm button {
	margin-top: 5rem;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
	border-radius: 10rem;
	background: var(--c_or);
	font-size: 3.4rem;
	color: #fff;
	padding: 1.5rem 2rem;
	line-height: 1.2;
	letter-spacing: 0.05em;
}
.simulationForm button::after {
	content: "";
	display: block;
	background: url(../img/arrow_wh.svg) center center no-repeat;
	background-size: contain;
	width: 1.6rem;
	aspect-ratio: 1;
}
.simulationForm button:hover {
	background-color: var(--c_rd);
}
.simClear {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: .5rem;
	border-radius: 10rem;
	background: #fff;
	border: 1px solid #000;
	font-size: 1.4rem;
	padding: .5rem 2rem;
	margin-top: 2rem;
}
.simClear::after {
	content: "";
	display: block;
	background: url(../img/arrow.svg) center center no-repeat;
	background-size: contain;
	width: 1.5rem;
	aspect-ratio: 1;
}
.simClear:hover {
	background-color: var(--c_gy);
	color: #4d4d4d;
}
#simulationResult {
	padding-bottom: 0;
}
.simulationResult {
	background: #fff;
	border-radius: 2rem;
	overflow: hidden;
	border: .3rem solid var(--c_or);
	overflow: hidden;
	white-space: nowrap;
}
.simulationResult h2 {
	font-size: 3.2rem;
	background: var(--c_or);
	color: #fff;
	padding: 1rem;
}
.simulationResult .box {
	padding: 2rem;
}
.simulationResult dl {
	max-width: 50rem;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 20rem 1fr;
	gap: 3rem 1rem;
	align-items: center;
	text-align: left;
	font-size: 2rem;
	font-weight: 700;
}
.simulationResult dd {
	display: flex;
	align-items: flex-end;
	flex-wrap: wrap;
	font-size: 130%;
	line-height: 1;
}
.simulationResult dd span {
	font-size: 150%;
	display: inline-block;
	min-width: 1em;
	text-align: center;
}
.simulationResult dl + dl {
	padding-top: 1rem;
	margin-top: 1rem;
	border-top: .3rem dotted #ccc;
}
#simError {
	display: none;
	font-weight: 500;
	color: var(--c_rd);
	margin-top: 1rem;
}
.simulationResult + .note {
	margin-top: 1rem;
}

/*warning
---------------------------------------------------------*/
.warningWrap {
	padding: 5rem;
	text-align: left;
	background: #fff;
	font-size: 112.5%;
}
.warningWrap h2 {
	font-size: 3.2rem;
	text-align: center;
	margin-bottom: 3rem;
	color: var(--c_dr);
}















/*ieハック*/
@media screen\0  {
}

/*********************************/
/* タブレット用のスタイル記述 */
/*********************************/
@media screen and (max-width: 1150px) {
	html {
		font-size: .8vw;
	}
}

/*********************************/
/* スマートフォン用のスタイル記述 */
/*********************************/
@media screen and (max-width: 780px) {
/*全体レイアウト
---------------------------------------------------------*/
	html {
		font-size: 2.7777777vw;
	}
	body {
		font-size: 1.4rem;
		line-height: 1.5;
		padding-top: 5.8rem;
		padding-bottom: 10.26rem;
	}
	body.btnNone {
		padding-bottom: 0;
	}
	body.active {
		overflow: hidden;
	}
	article > section {
		padding: 4rem 0;
	}
	article > section:last-of-type {
		padding-bottom: 4rem;
	}
	.pageTtl {
		height: 9rem;
		font-size: 1.2rem;
		gap: .5rem;
	}
	.pageTtl h1 {
		font-size: 2.4rem;
	}
	.btn a {
		font-size: 1.8rem;
		padding: 1rem 3rem;
	}
	.spClick {
		pointer-events: all;
	}

	/*header
	-------------------------------------------------------*/
	.hWrap {
		padding: 1rem 0;
		padding-right: 5.2rem;
		height: 5.8rem;
		align-items: flex-end;
	}
	.hLogo {
		gap: 1rem;
	}
	.hLogo .ttl {
		display: none;
	}
	.hLogo .logo img {
		margin: 0;
		max-height: 3.4rem;
	}
	.hBtn {
		display: none;
	}
	.hBtn a {
		flex: 1;
		height: 2.9rem;
		flex-direction: column;
		gap: .5rem;
		width: auto;
		font-size: 1.6rem;
	}
	.hBtn a._01 small {
		font-size: 1rem;
		margin-right: 0.1em;
	}
	.hBtn a._02 {
		font-size: 1.4rem;
		width: auto;
		padding-right: 0;
	}
	.hBtn a::after {
		display: none!important;
	}
	.spBtn {
		display: flex;
		justify-content: flex-end;
		gap: .6rem;
		font-size: 1.2rem;
		font-weight: 700;
	}
	.spBtn a {
		width: 7.3rem;
		padding: .5rem .2rem;
		white-space: nowrap;
		background: var(--c_rd);
		border: 1px solid var(--c_rd);
		color: #fff;
		border-radius: 10rem;
	}
	.spBtn a._02 {
		background: #fff;
		border-color: #000;
		color: #000;
		border-radius: .5rem;
	}

	/*nav
	-------------------------------------------------------*/
	.menuIcon {
		top: 2.4rem!important;
		bottom: auto!important;
		width: 3.8rem;
		height: 2rem;
		z-index: 99999
	}
	.menuIcon span {
		transition: .2s;
		height: 0.3rem;
	}
	.menuIcon span:nth-of-type(2) {top: .8rem;	}
	.menuIcon.active span:nth-of-type(1) {
		-webkit-transform: translateY(1rem) rotate(45deg);
		transform: translateY(1rem) rotate(45deg);
	}
	.menuIcon.active span:nth-of-type(3) {
		-webkit-transform: translateY(-.7rem) rotate(-45deg);
		transform: translateY(-.7rem) rotate(-45deg);
	}
	.menuIcon::after {
		font-size: 1.1rem;
		top: -2rem;
	}
	.menuIcon::after {
		color: var(--c_bu)!important;
	}
	.menuIcon span {
		background: var(--c_bu)!important;
	}
	#nav {
		top: 5.8rem;
	}
	.navWrap {
		display: flex;
		flex-direction: column-reverse;
	}
	.navBtn {
		gap: 1.5rem;
	}
	.navHeader .navBtn {
		display: flex;
		margin-bottom: 0;
	}
	.navHeader .navBtn ._02 a {
		border: 1px solid #000;
	}
	.navCont {
		padding: 3rem 0;
	}
	.nav {
		flex-wrap: wrap;
		gap: 2rem 1%;
		margin-bottom: 3rem;
	}
	.nav > ul {
		width: 100%;
	}
	.nav a {
		display: inline-flex;
		font-size: 2rem;
		gap: .5rem;
	}
	.nav .child {
		margin-top: 2rem;
	}
	.nav .child a {
		font-size: 1.6rem;
	}
	.nav li + li {
		margin-top: 2rem;
	}
	.toLoan a {
		padding: .8rem;
		max-width: 20rem;
	}
	.toLoan a {
		font-size: 1.2rem;
	}
	.toLoan .logo img {
		max-height: 2.2rem;
	}
	.toLoan a span {
		gap: .7rem;
		margin-top: 0.5rem;
	}
	.toLoan a span::after {
		width: 1rem;
	}
	.navHeader {
		margin: 0;
		text-align: center;
		color: var(--c_bu);
		display: block;
		padding: 3rem 2rem;
	}
	.navLogo {
		width: 100%;
    gap: 1.5rem;
		margin-bottom: 2rem;
	}
	.navLogo .logo._01 img {
    max-height: 4rem;
	}
	.navLogo .logo._02 img {
		max-height: 2.8rem;
	}
	.navLogo .ttl {
		font-size: 3rem;
	}
	.navLogo .ttl span {
		display: block;
		margin-left: 0;
	}
	.navTel a {
		color: var(--c_bu);
		font-size: 6rem;
	}
	.navTel {
		display: block;
	}
	.navTel small {
		color: #000;
		font-size: 1.4rem;
	}
	.navBtn {
		flex-direction: column;
		margin-bottom: 3rem;
	}
	.navBtn a {
		font-size: 2.4rem;
	}



	/*footer
	-------------------------------------------------------*/
	.fTop {
		padding: 2rem 0;
	}
	.fTop::after {
		left: 0;
		right: 0;
	}
	.fLogo {
    gap: 1.5rem;
	}
	.fLogo .logo._01 img {
    max-height: 4rem;
	}
	.fLogo .logo._02 img {
		max-height: 2.8rem;
	}
	.fLogo .ttl {
		text-align: left;
		font-size: 1.8rem;
	}
	.footArea .hBtn a {
		width: 28rem;
		margin: 2rem auto 0;
		font-size: 2.5rem;
		padding: 1rem;
	}
	.footArea .hBtn a::before {
		display: none;
	}
	.fNav {
		flex-wrap: wrap;
		gap: 2rem 1%;
		font-feature-settings: "palt";
	}
	.fNav > ul {
		width: 49%;
	}
	.fNav a {
		font-size: 1.4rem;
		gap: .3rem;
	}
	.fNav a::before {
		width: 1rem;
		min-width: 1rem;
	}
	.fNav .child {
		margin-top: 2rem;
	}
	.fNav .child a {
		font-size: 1.3rem;
	}
	.fNav li + li {
		margin-top: 2rem;
	}
	.fBtn {
		margin-top: 3rem;
	}
	.fBtn a {
		white-space: nowrap;
		justify-content: space-between;
		gap: .8rem
	}
	.fBtn a b {
		width: 13rem;
		font-size: 1.1rem;
		padding: .5rem 0;
		white-space: nowrap;
	}
	.fAdd {
		font-size: 1.1rem;
		text-align: left;
	}
	.fixBtn {
		display: block;
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 9000;
		margin: 0;
		background: #fff;
		padding: .8rem 5%;
		box-shadow: 0 -1px 5px rgba(0, 0, 0, .075);
		transition: .2s;
		pointer-events: none;
		opacity: 0;
		bottom: -10.2rem;
	}
	.fixBtn.scl {
		pointer-events: all;
		opacity: 1;
		bottom: 0;
	}
	.fixBtn .txt {
		font-size: 4.75vw;
		font-weight: 500;
		white-space: nowrap;
		letter-spacing: -.05em;
    margin-bottom: .5rem;
	}
	.fixBtn .appBtn a {
		font-size: 2.6rem;
		border: none;
		box-shadow: none;
		margin-bottom: 0;
	}

	/*contetns
	-------------------------------------------------------*/
	.sliderBox {
		height: 57rem;
	}
	.slick-arrow {
		top: auto;
		bottom: 1rem;
		width: 2rem;
		transform: none;
		z-index: 10;
	}
	.slick-arrow.next {
		right: 22%;
	}
	.slick-arrow.prev {
		left: 22%;
		transform: rotate(180deg);
	}
	.sliderBox {
		position: relative;
		display: block;
		font-size: 1.8rem;
		padding-top: 2rem;
	}
	.mainArea .slick-dots {
		bottom: .6rem;
	}
	.mvBtn {
		margin-top: 0;
		padding-left: 1rem;
	}
	.sliderWrap._01 {background-image: url(../img/top/mv/mv01_bg_sp.jpg);}
	.sliderWrap._02 {background-image: url(../img/top/mv/mv02_bg_sp.jpg);}
	.sliderWrap._03 {background-image: url(../img/top/mv/mv03_bg_sp.jpg);}
	.slider01Box h2 {
		font-size: 2rem;
		line-height: 1.4;
		font-weight: 800;
		margin-bottom: 2rem;
		text-align: center;
	}
	.slider01Box h2 span {
		font-size: 200%;
		line-height: 1.2;
		white-space: nowrap;
	}
	.slider01Box dd {
		position: relative;
	}
	.slider01Box ul {
		margin-bottom: 2.5rem;
		gap: .5rem;
	}
	.slider01Box figure {
		max-width: 30rem;
		margin: 0 auto;
	}
	.slider01Box dd .txt {
		letter-spacing: 0.1em;
		white-space: nowrap;
		margin-bottom: 2rem;
	}
	.slider02Box figure {
		position: static;
		max-width: 30rem;
		margin: 2rem auto 0 3rem;
	}
	.slider02Box dt {
		margin-bottom: 1rem;
	}
	.slider02Box h2 {
		font-size: 3.6rem;
		margin-left: 0;
		text-align: center;
	}
	.slider02Box .sub {
		font-size: 2rem;
	}
	.slider02Box h2 .se {
		line-height: 1.2;
	}
	.slider02Box h2 .se p {
		padding: 0 1rem;
		margin: 0 .7rem;
	}
	.slider02Box h2 .se img {
		height: 5rem;
	}
	.slider02Box dd .txt {
		letter-spacing: 0.05em;
		white-space: nowrap;
	}
	.slider03Box {
		padding-top: 1rem;
	}
	.slider03Box dt {
		padding-bottom: 1rem;
	}
	.slider03Box h2	{
		width: 100%;
		font-size: 1.5rem;
		line-height: 1.4;
		white-space: nowrap;
		margin-bottom: .5rem;
	}
	.slider03Box h2 img {
		max-height: 4.3rem;
	}
	.slider03Box h3	{
		font-size: 1.8rem;
		line-height: 1.4;
	}
	.slider03Box dt figure {
		max-width: 5.8rem;
		left: .5rem;
	}
	.slider03Box dt figure._02 {
		max-width: 5rem;
		right: .5rem;
	}
	.slider03Box ul {
		display: flex;
		flex-wrap: wrap;
		gap: 0 2%;
		margin-bottom: 1.5rem;
	}
	.slider03Box ul li:nth-of-type(1) { width: 100%; }
	.slider03Box ul li:nth-of-type(2) { width: 49%; }
	.slider03Box ul li:nth-of-type(3) { width: 49%; }
	.warningLink a {
		font-size: 1.4rem;
		line-height: 1.5;
		margin-bottom: 3rem;
	}
	.warningLink a::before {
		width: 1.8rem;
		height: 1.8rem;
		margin-right: .5rem;
	}
	.joukenImg {
		margin-bottom: 2rem;
	}
	#topNews .appBtn,
	.btnArea .appBtn,
	.appBtn._arrow,
	.appBtnWrap .appBtn {
		background-size: auto 1.6rem;
		padding-top: 2.5rem;
	}
	.appBtn._arrow {
		margin-top: 1.5rem;
	}
	.appBtnWrap .appBtn a {
		font-size: 1.8rem;
		gap: 1rem;
	}
	.appBtnWrap .appBtn a::before {
		width: 3.5rem;
	}
	.btnBox + .btnBox {
    margin-top: 4rem;
	}
	.btnBox .ttl {
		font-size: 2rem;
		line-height: 1.1;
	}
	.btnBox .sub {
		font-size: 1.6rem;
		margin-bottom: 1rem;
	}
	.appBtn a,
	.appBtn._sm a {
		font-size: 2.6rem;
		white-space: nowrap;
		border-width: .3rem;
		box-shadow: .5rem .5rem 0 rgba(0, 0, 0, .15);
		gap:1rem;
		padding: 1.5rem;
		padding-right: 3rem;
	}
	.appBtn a::before,
	.appBtn._sm a::before {
		width: 4rem;
	}
	.appBtn a::after,
	.appBtn._sm a::after {
		width: 2rem;
		right: 2rem;
	}
	.appBtn._increase a {
		font-size: 2.2rem;
	}
	.toCrease a {
		flex-direction: column;
		gap: 1rem;
		font-size: 2.4rem;
		position: relative;
	}
	.toCrease a p {
		justify-content: center;
	}
	.toCrease a .ttl {
		width: 20rem;
		padding: 0.8rem;
		font-size: 1.4rem;
	}
	.toCrease a::after {
		position: absolute;
		right: 1rem;
		bottom: 2rem;
	}
	.topNav {
		margin-top: 2rem;
		display: block;
	}
	.topNav h3 {
		width: 13.5rem;
		position: relative;
		top: auto;
		font-size: 1.1rem;
	}
	.topNav a {
		font-size: 1.4rem;
		gap: 1rem;
		white-space: nowrap;
		padding: 1rem;
	}
	.topNav li + li {
		margin-top: 1rem;
	}
	.topNav ._02 a::after {
		width: 1.5rem;
	}
	.thingTtl {
		padding: 3.5rem 0 0;
	}
	.thingTtl .sub {
		font-size: 2rem;
		margin-bottom: 1rem;
	}
	.thingTtl h2 {
		width: fit-content;
		font-size: 2rem;
		white-space: nowrap;
	}
	.thingTtl figure img {
    max-height: 7rem;
	}
	.thingArea .tgl {
		font-size: 2rem;
		padding: 1.5rem;
	}
	.thingWrap > .txt {
		font-size: 1.6rem;
	}
	.thingBox h3 {
		padding: 1rem;
		font-size: 1.6rem;
	}
	.thingBox {
		border-radius: 2rem;
	}
	.thingBox .cont {
		padding: 2rem .5rem;
	}
	.thingBox .cont .img {
		overflow: hidden;
	}
	.thingBox .cont .img img {
		display: block;
		margin: 0 -5%;
		max-width: 110%;
	}


	.diagnosisTtl {
    margin-top: -1rem;
	}
	.diagnosisTtl h2 {
		font-size: 3rem;
		white-space: nowrap;
		padding-top: 1.5rem;
		margin-bottom: 1rem;
		padding-right: 2rem;
	}
	.diagnosisTtl h2::before {
		top: -1.5rem;
		width: 10rem;
	}
	.diagnosisTtl h2 .fo-futura {
		margin: 0 .5em 0 .4em;
	}
	.diagnosisTtlImg {
		padding: 0 2rem;
	}
	.diagnosisTtlImg img {
    max-height: 7rem;
	}
	.diagnosisTtl .sub {
		max-width: 15rem;
		margin-bottom: -0.05rem;
	}
	.diagnosisTtl02 {
		font-size: 2.2rem;
		white-space: nowrap;
		margin-bottom:2rem;
	}
	.diagnosisBox {
		padding: 2rem;
	}
	.diagForm {
		grid-template-columns: 5rem 1fr;
		gap: 1rem;
	}
	.diagForm dt {
		font-size: 1.8rem;
		text-align: left;
		-webkit-writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		-o-writing-mode: vertical-rl;
		writing-mode: vertical-rl;
		line-height: 1;
	}
	.diagForm input, .diagForm select {
		width: 100%;
		font-size: 2rem;
		padding: 1rem;
	}
	.diagForm input {
		max-width: 16rem;
	}
	.diagForm dd {
		padding: 1rem 0;
	}
	.diagForm dd b {
		font-size: 1.8rem;
	}
	.diagBtn {
		margin-top: 1rem;
	}
	.diagBtn button {
		font-size: 2.4rem;
		width: 25rem;
	}
	.diagnosisContArea .note {
		text-align: left;
	}
	.reasonTopWrap figure {
		display: none;
	}
	.reasonTopWrap {
		padding: 0;
	}
	.reasonTop .sub {
		font-size: 2.6rem;
		display: block;
	}
	.reasonTop h2 {
    font-size: 3.5rem;
	}
	.reasonTop .logo {
		margin-bottom: 1rem;
	}
	.reasonTop .logo img {
		max-height: 4rem;
	}
	.reasonArea {
		padding: 4rem 0;
	}
	.reasonTtl .num {
    width: 8rem;
		font-size: 5rem;
		top: -5.3rem;
		padding-top: 0.5rem;
	}
	.reasonTtl .num .img {
		top: -3rem;
	}
	.reasonTtl h2 {
		font-size: 2rem;
		display: block;
	}
	.sevenlogo img {
    max-height: 2.8rem;
	}
	.sevenlogo {
		padding: .3rem 1.2rem;
		margin: 0 .7rem -.7rem;
	}
	.reasonCont {
		display: block;
		padding: 2rem 1.5rem;
	}
	.reasonCont dl {
		width: 100%;
	}
	.reasonCont dt {
		font-size: 2rem;
		font-feature-settings: "palt";
	}
	.reasonCont dd {
		font-size: 1.6rem;
		text-align: justify;
	}
	.reasonCont figure {
		margin: 2rem auto -2rem;
	}
	.reasonCont figure img.onlysp {
		display: block;
		margin: 0 auto;
	}
	.reasonCont dt .tag {
		font-size: 1.8rem;
		display: inline-block;
		margin-bottom: 0.5rem;
	}
	.btn02 a {
		font-size: 1.4rem;
		gap: 1rem;
		padding: 1rem 2rem;
	}
	.reasonTtl h2 .appBtn02 {
		margin-top: 0.5rem;
	}
	img[src*="/reason_img04"] {
		max-height: 30rem;
	}
	.reason05Cont figure {
		margin-bottom: 0;
	}
	.reason05Cont figure img {
		max-height: 12rem;
	}
	.reason05Cont li {
		font-size: 2rem;
		line-height: 1.4;
		background-size: 3rem auto;
		background-position: left top 2.2rem;
		padding-left: 4rem;
	}
	.reason05Cont li img[src*="logo_nbc"] {
		margin-top: 0.5rem;
	}
	.reason05Cont li .note {
		position: relative;
		display: inline;
		bottom: auto;
		font-size: 1.4rem;
	}
	.reason05Cont ul {
		margin-bottom: 10rem;
	}
	.reason05Cont figure:nth-of-type(1) {
		left: 4rem;
	}
	.reason05Cont figure:nth-of-type(2) {
		right: 4rem;
	}
	.btnArea h2 {
		font-size: 2rem;
		margin-bottom: 1rem;
	}
	.productArea .btn02 a {
		min-width:100%;
	}
	.howtoTtl {
		display: block;
		font-size: 1.6rem;
		margin-bottom: 3rem;
	}
	.howtoTtl img {
		display: block;
		margin: 0 auto 1rem;
		max-height: 4rem;
	}
	.howtoTtl strong {
		font-size: 3rem;
		margin-bottom: 0;
	}
	.howtoWrap li {
		width: 100%;
	}
	.howtoWrap li h3 {
		font-size: 2.6rem;
	}
	.howtoCont {
		width: 100%;
		grid-template-columns: 4rem 1fr;
		gap: 1rem;
	}
	.howtoCont .ttl {
    font-size : 2rem;
	}
	.howtoCont .ttl small {
		font-size: 1.4rem;
		white-space: nowrap;
	}
	.howtoCont .txt {
		font-size: 2.4rem;
	}
	.howtoCont .note {
		font-size: 1.2rem;
	}
	.howtoWrap .appBtn02 a {
		font-size: 2rem;
		line-height: 1.2;
		padding: 1.2rem 0;
	}
	.cap {
		font-size: 1.4rem;
	}
	.orTxt {
		font-size: 2.2rem;
	}
	.reason05Cont li small {
		font-size: 80%;
	}
	.btnArea {
		padding: 3rem 0;
	}
	#howto {
		padding-bottom: 6rem;
	}
	#flow h2 {
		font-size: 3rem;
		margin-bottom: 4rem;
	}
	.flowWrap {
		padding: 1.5rem 1rem;
		padding-right: 8rem;
		gap: 1rem;
		overflow: visible;
	}
	.flowWrap figure {
		right: 2rem;
	}
	._04 .flowWrap figure {
		right: 1rem;
	}
	.flowWrap .num {
		width: 5rem;
		min-width: 5rem;
		font-size: 1rem;
	}
	.flowWrap .num strong {
		line-height: 0.8;
	}
	.flowWrap dl {
		font-size: 1.2rem;
	}
	.flowWrap .appBtn02 {
		position: absolute;
		left: 0;
		right: 0;
		margin: 0 auto;
		max-width: 22rem;
		top: -3.5rem;
	}
	.flowWrap .appBtn02 a {
		font-size: 1.8rem;
		min-width: auto;
	}
	.flowWrap dt {
		font-size: 1.8rem;
	}
	.flowWrap figure img {
		max-height: 8rem;
	}
	.flowWrap figure img[src*="/flow_img03"] {
		max-height: 6rem;
	}
	.flowWrap figure img[src*="/flow_img04"] {
		max-height: 7.5rem;
	}
	.flowWrap figure img[src*="/flow_img05"] {
		max-height: 7rem;
		margin-right: 2rem;
		margin-top: auto;
		margin-bottom: auto;
	}
	.flow-arw {
		border-right: 1.4rem solid transparent;
    border-left: 1.4rem solid transparent;
    border-top: 1rem solid #fff;
		margin: 1rem auto 1.5rem;
	}
	.flow-arw::before {
		width: 2.8rem;
		aspect-ratio: 14/5;
		top: -.4rem;
	}
	.contTel {
		margin-top: 3rem;
		font-size: 1.8rem;
	}
	.telTxt {
		font-size: 87.5%;
	}
	.telTxt .fo-din {
		display: block;
	}
	.contWrap {
		padding: 2rem;
	}
	.productArea .contWrap {
		padding: 1.5rem;
	}
	.tlbWrap {
    grid-template-columns: 9rem 1fr;
		font-size: 1.3rem;
	}
	.tlbWrap dt, .tlbWrap dd {
		padding: .7rem .5rem;
		border-width: 1px!important;
	}
	.productArea .note {
		margin-top: 1rem;
		text-align: left;
		font-size: 1.2rem;
	}
	#simuBtn {
		padding: 3rem 0;
	}
	#simuBtn h2 {
		font-size: 1.7rem;
	}
	#simuBtn .appBtn a {
		font-size: 2.4rem;
	}
	#simuBtn .appBtn a::after {
		right: 1.5rem;
	}
	.infoArea h2 {
		margin-bottom: 3rem;
	}
	.infoWrap h3 {
		font-size: 1.8rem;
	}
	.infoWrap dl {
		grid-template-columns: 13rem 1fr;
		padding: 0;
		border-width: .2em;
		border-radius: 1rem;
	}
	.telnum a {
		pointer-events: all;
		font-size: 3.2rem;
	}
	.infoWrap dt {
		padding: .5rem;
	}
	.infoWrap dt li {
		font-size: 1.2rem;
	}
	.infoWrap dd {
		padding: 2rem 1rem;;
	}
	.infoWrap h4 {
		font-size: 1.4rem;
	}
	.telnum small {
		font-size: 1rem;
		margin-top: 0.5rem;
	}
	.infoArea .note {
		font-size: 1.4rem;
	}
	#product h2,
	.infoArea h2 {
		font-size: 2.2rem;
	}
	.infoWrap {
		margin-top: 5rem;
	}
	.topBnr {
		gap: .7rem 2%;
	}
	.topBnr li {
		width: 49%;
	}
	#topInfo h2 {
		font-size: 2.4rem;
		margin-bottom: 2rem;
	}
	.topInfo a {
		font-size: 1.6rem;
	}
	.topInfo a::after {
		width: 1.3rem;
		right: 1rem;
	}

	/*form
	-----------------------------------------------------*/
	.formTopArea {
		padding: 2rem 0;
		font-size: 1.6rem
	}
	.formTopTxt h2 {
		font-size: 1.8rem;
	}
	.formTopArea .mb40 {
		margin-bottom: 2rem;
	}
	.formTopArea h3 {
		font-size: 100%;
		padding-right: 0;
	}
	.pdfdl {
		white-space: nowrap;
		position: static;
		font-size: 1.4rem;
		width: 18.5rem;
		margin: .5rem 0 1rem auto;
	}
	.policyBox {
		font-size: 1.4rem;
		padding: 1.5rem;
		height: 15rem;
	}
	.formSelect {
		display: block;
		font-size: 1.8rem;
		margin-top: 5rem;
	}
	.formSelect .box01 {
		width: 100%;
		margin-top: 5rem;
		background-size: auto 2.6rem;
		padding-bottom: 4.5rem;
	}
	.formSelect .box02 {
		width: 100%;
		font-size: 1.8rem;
	}
	.formSelect dt a {
		font-size: 2.4rem;
		height: auto;
		padding: 1.5rem 0;
		min-height: 9.5rem;
	}
	.formSelect .box02 dt a {
		font-size: 2.2rem;
	}
	.formSelect .box02 dt big {
    font-size: 115%;
	}
	.formSelect .box02 dt big img {
		width: 1.6rem;
	}
	.loginArea {
		margin-top: 5rem;
		font-size: 1.6rem;
	}
	.loginArea > dt {
		padding: 0 1.5rem 1rem	
	}
	.loginArea > dd {
		padding: 0 1.5rem;
	}
	.loginFormBox {
		display: block;
	}
	.loginFormBox dt,.loginFormBox dd {
		width: 100%;
		padding: 0;
	}
	.loginFormBox dt {
		padding-top: 10px;
	}
	.loginForm button {
		font-size: 2rem;
	}
	.passLink {
		font-size: 1.6rem;
	}
	.formArea {
		padding: 4rem 5%;
	}
	.formArea {
		font-size: 1.6rem;
	}
	.formWrap h2 {
		font-size: 120%;
	}
	.formWrap h2:not(:first-of-type) {
    margin-top: 5rem;
	}
	.formWrap dt {
		font-size: 110%;
		margin-top: 3rem;
	}
	.req dt::after {
		font-size: 1.4rem
	}
	.formWrap input[type="text"], .formWrap input[type="tel"], .formWrap input[type="email"], .formWrap select, .formWrap textarea {
		font-size: 1.6rem;
		padding: 1.5rem 1rem;
	}
	.formWrap .size-m {
		max-width: 80%;
	}
	.formWrap .size-s {
		max-width: 50%;
	}
	.formWrap input[name="zip"] {
		max-width: 70%;
	}
	.formWrap select {
		-moz-appearance: none;
		-webkit-appearance: none;
		appearance: none;
		display: inline-block;
		min-height: 5rem;
	}
	.form-birth select {
		width: 6rem
	}
	.form-birth select:first-of-type {
    width: 20rem;
	}
	.form-birth select:first-of-type + span {
		width: 5rem;
	}
	.zipBtn {
		width: 100%;
		margin: 1rem 0 0;
	}
	.formWrap .note {
		font-size: 90%;
	}
	.radioWrap {
		padding: 5px!important;
	}
	.radioWrap label {
		width: 49%!important;
		margin: 5px .5%!important;
		font-size: 1.6rem;
		display: flex;
		justify-content: center;
		align-items: center;
		padding: 1rem .5rem;
		min-height: 5.7rem;
	}
	.radioWrap label small {
		font-size: 80%;
	}
	.radioWrap.sp-100 label {
		width: 100%!important;
	}
	.confTxt {
		margin-top: 4rem;
		font-size: 1.2rem;
	}
	.formWrap .submitBtn {
		font-size: 2.2rem;
	}
	.formTxt {
		font-size: 2.2rem;
	}
	.kyojyu2 {
		padding-top: 6rem!important;
	}
	.formTerms h3 {
		font-size: 1.4rem;
		height: 5rem;
		padding: .5rem 1.5rem;
		display: flex;
		align-items: center;
	}
	.formTerms h3 span {
		right: 1rem;
	}
	.formTerms .box + .box {
		margin-top: 1rem;
	}
	.formTerms .cont {
		font-size: 1.2rem;
		margin: 1rem 0 2rem;
		padding: 0 1rem;
	}
	.termsTbl {
		grid-template-columns: repeat(1,1fr);
	}
	.deleteFormTop {
		font-size: 1.4rem;
		text-align: left;
	}
	.deleteFormTop h2 {
		font-size: 1.8rem;
		font-weight: 500;
		margin-bottom: 1rem;
	}
	.deleteFormTop .txt strong {
		font-size: 122%;
	}





	/*appli
	-------------------------------------------------------*/
	#appliTop {
		padding: 3rem 0 0;
		position: relative;
	}
	.appliTop {
		display: block;
		text-align: center;
		position: relative;
		padding-bottom: 4rem;
	}
	.appliTop figure {
		pointer-events: none;
		position: absolute;
		right: 0;
		bottom: 0;
	}
	.appliTop figure img {
		max-height: 10.5rem;
	}
	.appliTop .box {
		font-size: 1.8rem;
	}
	.appliTop .box h2 {
		font-size: 2.4rem;
		margin-bottom: 2.5rem;
	}
	.appliTop .box .txt {
		max-width: 22rem;
	}
	.appliArea h2 {
		font-size: 2.2rem;
		margin-bottom: 2rem;
	}
	.appliWrap {
		grid-template-columns: repeat(1,1fr);
	}
	.appliWrap dl {
		border-radius: 1rem;
	}
	.appliWrap dt {
		font-size: 2rem;
	}
	.appliWrap dd {
		padding: 1rem 2rem 2rem;
	}
	.appliWrap .txt,
	.appliArea .note {
		font-size: 1.2rem;
		margin-top: 1rem;
	}
	.pageBtmTel {
		padding-top: 3rem;
	}
	.pageBtmTel h2 {
		font-size: 1.6rem;
		margin-bottom: 2rem;
	}
	.telBox {
		width: 100%;
		border-width: .2em;
		border-radius: 1rem;
		padding: 1rem 2rem 1.5rem;
	}
	.telBox .ttl {
		font-size: 1.6rem;
		margin-bottom: .7rem;
	}
	.telBox .telnum a {
		font-size: 5rem;
	}
	.telBox .telnum small {
		font-size: 1.2rem;
	}

	/*jouken
	-------------------------------------------------------*/
	.joukenArea h2 {
		text-align: center;
	}
	.joukenCont {
		display: block;
		font-size: 1.4rem;
	}
	.joukenCont dt,
	.joukenCont dd {
		padding: 1rem;
		border-bottom: none;
	}
	.joukenCont dt {
		font-size: 100%;
	}
	.joukenCont dd {
		padding-bottom: 1.5rem;
	}
	.joukenArea h2:not(:first-of-type) {
		margin-top: 5rem;
	}

	/*shoryou
	-------------------------------------------------------*/
	.txtSec {
		font-size: 1.8rem;
		text-align: left;
	}
	.shiryouArea h2 {
		font-size: 2rem;
		margin-bottom: 1rem;
	}
	.pdfBtn a {
		font-size: 1.6rem;
		white-space: nowrap;
		gap: 1rem;
		margin-bottom: 3rem;
	}
	.pdfBtn a::before {
		width: 2rem;
	}
	.pdfBtn a::after {
		position: static;
		transform: none;
		width: 2rem;
	}
	.shiryouArea ul {
		font-size: 1.8rem;
	}
	.shiryouArea li {
		margin-bottom: 1rem;
	}

	/*papers
	-------------------------------------------------------*/
	.papersTop {
		grid-template-columns: repeat(1,1fr);
	}
	.papersWrap h2,
	.papersBox h3 {
		font-size: 2.2rem;
	}
	.papersBox h4 {
		font-size: 2rem;
	}
	.papersBox .cont {
		padding: 2rem;
	}
	.papersBox ul {
		font-size: 1.6rem;
	}
	.papersBox li {
		padding-left: .5em;
		text-indent: -.5em;
	}
	.papersDetail h2 {
		font-size: 1.8rem;
		text-align: left;
		margin-bottom: 2rem;
	}
	.papersDetailCont h3 {
		font-size: 1.4rem;
		line-height: 1.4;
		padding: .8rem;
		text-align: center;
	}
	.papersDetailCont h3 .tglIcon {
		right: 1.2rem;
		width: 1.2rem;
	}
	.papersContents {
		padding: 2rem;
		font-size: 1.4rem;
		text-align: left;
	}
	.noappli01 {
		margin-bottom: 3rem;
	}
	.noappli01 .txt01 {
		font-size: 1.5rem;
		text-align: left;
	}
	.noapli02 h4 {
		font-size: 1.6rem;
	}

	/*faq
	-------------------------------------------------------*/
	.faqTop {
		font-size: 1.8rem;
	}
	.faqArea {
		padding: 4rem 0;
	}
	.faqArea h2 {
		font-size: 2.2rem;
	}
	.faqWrap dl {
		font-size: 1.4rem;
		margin-bottom: 2rem;
	}
	.faqWrap dt,
	.faqWrap dd {
    padding: 1rem 3rem 1rem 5rem;
	}
	.faqWrap dt {
		display: flex;
		align-items: center;
		min-height: 6.7rem;
	}
	.faqWrap dt::before,
	.faqWrap dd::before {
		width: 2.2rem;
		left: 2rem;
	}
	.faqWrap dd::before {
		top: 1.2rem;
	}
	.faqWrap dt .tglIcon {
		right: 1rem;
		width: 1.5rem;
	}

	/*company
	-------------------------------------------------------*/
	#company {
		padding-bottom: 0;
	}
	.companyCont {
		display: block;
		font-size: 1.4rem;
	}
	.companyCont dt,
	.companyCont dd {
		padding: 1rem;
		border-bottom: none;
	}
	.companyCont dt {
		font-size: 100%;
	}
	.companyCont dd {
		padding-bottom: 1.5rem;
	}

	/*policy
	---------------------------------------------------------*/
	#policyPage h2 {
		font-size: 2rem;
		line-height: 1.4;
		margin-bottom: 2rem;
	}
	.txtPage,
	.txtPage.fo20 {
		font-size: 1.4rem;
		line-height: 1.6;
	}
	.txtPage > *{
		margin-bottom: 1.5rem;
	}
	.txtPage h3:not(:first-of-type) {
		margin-top: 3rem;
	}
	.txtPage ol li:not(:first-of-type) {
		margin-top: 1rem;
	}
	.policyInfo {
		font-size: 100%;
		margin-top: 4rem;
	}
	.policyInfo .ttl {
		padding-bottom: 1rem;
		margin-bottom: 1rem;
	}
	#policyPage section[id*="policy"] {
		padding-bottom: 0;
	}

	/*increase_about
	-------------------------------------------------------*/
	.increase_aboutTtl {
		padding: 0 0 12rem 0;
	}
	.increase_aboutTtl figure {
		top: auto;
		bottom: 0;
		max-width: 10rem;
		left: 3rem;
	}
	.increase_aboutTtl figure._02 {
		right: 3rem;
	}
	.subTtl {
		font-size: 2rem;
	}
	.increase_aboutTtl h2 {
		font-size: 2rem;
	}
	.appInfo .subTtl {
		font-size: 1.8rem;
	}
	.appInfo dt {
		padding: 1rem;
		padding-left: 8rem;
	}
	.appInfo dt figure {
		max-width: 5.8rem;
		left: 2rem;
	}
	.appInfo._02 dt {
		padding-right: 12rem;
	}
	.appInfo._02 dt figure {
		right: 4rem;
		max-width: 7.2rem;
	}
	.appInfo dt h2 {
		font-size: 2.2rem;
		line-height: 1.4;
	}
	.appInfo dt h2 strong {
		display: block;
	}
	.appInfo dd {
		padding: 1rem 1rem;
	}
	.appInfo dd .txt {
		font-size: 1.6rem;
	}
	.appInfo .appBtn a {
		font-size: 2rem;
	}
	.appInfo .appBtn a::after {
		right: 1rem;
		width: 1.5rem;
	}
	.appInfo._02 h3 {
		display: block;
		padding: .5rem;
		font-size: 1.4rem;
	}
	.appInfo._02 h4 {
		font-size: 1.7rem;
	}
	.appInfo._02 .telnum a {
		font-size: 5rem;
	}
	.increase_about .note {
		font-size: 1.2rem;
	}

	/*borrow
	-------------------------------------------------------*/
	.borrowTop {
		padding: 3rem 0 10rem;
	}
	.borrowTop h2 {
		font-size: 2.2rem;
	}
	.borrowTop figure img {
		max-height: 9rem;
	}
	.borrowTop figure {
		left: 4.5rem;
	}
	.borrowTop figure._02 {
		right: 5rem;
	}
	.borrowAnc h2 {
		font-size: 2.2rem;
		margin-bottom: 4rem;
	}
	.borrowAnc ul {
		grid-template-columns: repeat(1,1fr);
	}
	.borrowAnc a h3 {
		font-size: 1.6rem;
		left: .5rem;
		right: .5rem;
		padding: .5rem 1rem;
		top: -1.7rem;
	}
	.borrowAnc a .img img {
		max-height: 5rem;
	}
	.borrowAnc a .txt {
		font-size: 2.4rem;
	}
	.borrowAnc a p {
		gap: 1rem;
	}
	.borrowAnc a p::after {
		width: 2rem;
	}
	.borrowAnc a {
		padding: 2.7rem 2rem 1rem;
	}
	.borrowTtl {
		padding: 3rem 0;
	}
	.borrowTtl h2 figure {
		display: none;
	}
	.borrowTtl h2 {
		font-size: 1.6rem;
	}
	.borrowTtl .subTtl {
		font-size: 125%;
		margin-top: 0.5rem;
	}
	.borrowTtl h3 {
		font-size: 2rem;
		min-height: 6rem;
	}
	.borrowTtl h3 img[src*="seven"] {
    height: 4rem;
	}
	#borrow02 .borrowTtl h3::before {
		width: 2rem;
	}
	.borrowArea {
		padding: 4rem 0;
	}
	.borrowTtl h3 strong {
		font-size: 120%;
	}
	.borrowArea h3 {
		font-size: 2rem;
	}
	.borrowArea h3 small {
		text-align: left;
	}
	.flowNote {
		font-size: 1.2rem;
	}
	.borrowFlow {
		padding-top: 2rem;
	}
	.borrowFlow h4 {
		width: 60%;
		font-size: 1.4rem;
	}
	.borrowFlow h4 p {
		font-size: 1.3rem;
	}
	.borrowFlow .flowWrap .num {
    width: 5rem;
    font-size: .8rem;
		position: absolute;
		left: 0;
		right: 0;
		top: -2.5rem;
		margin: 0 auto;
		z-index: 1;
	}
	.borrowFlow .flowWrap { 
		padding: 0 1.5rem;
		padding-top: 2rem;
		gap: 1.5rem;
		min-height: 11rem;
	}
	.borrowFlow figure {
		margin-right: 0;
	}
	.borrowFlow .flowWrap img[src*="/flow_img01"],
	.borrowFlow .flowWrap img[src*="/flow_img04"] {
    max-height: 8rem;
	}
	.borrowFlow .flow-arw {
		margin-bottom: 3.5rem;
	}
	.tel02Box .ttl {
		width: 100%;
		font-size: 1.4rem;
		padding: .5rem;
	}
	.tel02Box .ttl02 {
		font-size: 1.7rem;
	}
	.tel02Box .telnum a {
		font-size: 5rem;
	}
	.increaseTelBox {
		padding-bottom: 4.5rem;
		overflow: hidden;
		border-radius: 0 0 1.3rem 1.3rem;
	}
	.increaseTelArea .subTtl {
		font-size: 1.6rem;
	}
	.increaseTelArea h2 {
		font-size: 2rem;
	}
	.increaseTel h3 {
		font-size: 2.2rem;
	}
	.increaseTelBox .appBtn02 a {
		font-size: 1.8rem;
	}
	.increaseTelBox .orTxt {
		font-size: 1.8rem;
	}
	.increaseTelCont .ttl {
		font-size: 1.8rem;
	}
	.increaseTelCont .ttl small {
		font-size: 1.2rem;
	}
	.increaseTelCont .icon {
		max-width: 1.8rem;
	}
	.increaseTelCont .txt {
		font-size: 2rem;
	}
	.increaseTelBox figure img {
    max-height: 8rem;
	}
	.increaseTelCont dd._tel {
		gap: .5rem;
	}
	.increaseTelCont dd._tel + dd {
		font-size: 1.2rem;
	}
	.increaseTelBox figure {
		left: -.5rem;
	}
	.increaseTelBox figure._02 {
		right: -1rem;
	}

	/*repayment
	-----------------------------------------------------*/	
	.repaymentHow h2 {
		font-size: 2.2rem;
		flex-wrap: wrap;
	}
	.repaymentHow h2 img {
    height: 6rem;
		margin-top: 0.5rem;
    margin-bottom: -0.55em;
	}
	.repaymentWrap dt h3 {
		font-size: 2.2rem;
	}
	.repaymentWrap dt figure {
    width: 7.5rem;
		height: 7.5rem;
		aspect-ratio: auto;
		left: 1rem;
	}
	.repaymentWrap dd {
		padding: 2rem;
	}
	.repaymentWrap dd .txt {
		font-size: 1.6rem;
		text-align: left;
	}
	.repaymentWrap dd h4 {
		font-size: 1.8rem;
		margin-bottom: 2rem;
	}
	.repaymentWrap dd ul {
		grid-template-columns: repeat(1,1fr);
		gap: 2.5rem;
	}
	.repaymentWrap dd ul li {
		min-height: 5rem;
		padding: 2rem 1rem 1rem;
	}
	.repaymentWrap dd ul li .num {
		width: 2.5rem;
		font-size: 2rem;
		top: -1rem;
	}
	.repaymentWrap dd ul li .txt {
		text-align: center;
		font-size: 1.4rem;
	}
	.repaymentWrap dd ul li:not(:last-of-type)::after {
		clip-path: polygon(50% 100%, 0% 0%, 100% 0%);
		aspect-ratio: 4/1;
		width: 3.5rem;
		right: 0;
		left: 0;
		margin: 0 auto;
		transform: none;
		top: 107%;
	}
	.repaymentHow .note {
		font-size: 1.2rem;
	}
	.repaymentTblArea h2 {
		font-size: 2.2rem;
		margin-bottom: 3rem;
	}
	.repaymentTblArea .subTtl {
		font-size: 1.8rem;
	}
	.repaymentTblArea dl {
		border-radius: 2rem;
	}
	.repaymentTblArea dl + dl {
		margin-top: 2rem;
	}
	.repaymentTblArea .tgl {
		padding:.7rem;
		font-size: 1.8rem;
	}
	.repaymentTblArea dd {
		padding: 1.5rem;
	}
	.repaymentTbl table {
		font-size: 1.2rem;
		border-radius: 1rem;
	}
	.repaymentTbl th,
	.repaymentTbl td {
		padding: .5rem;
	}
	.repaymentTbl thead th {
		font-size: 1.2rem;
	}
	.repaymentTbl tbody th {
		grid-template-columns: 7rem 2em 7rem;
	}
	.repaymentTblArea .note {
		font-size: 1.2rem;
		text-align: left;
		margin-top: 2rem;
	}
	.fluctuationArea h2 {
		font-size: 2.2rem;
		margin-bottom: 2rem;
	}
	.fluctuation {
		margin-top: 3rem;
	}
	.fluctuation dt {
		font-size: 1.6rem;
	}
	.fluctuation dd {
		padding: 2rem 1rem;
	}
	.spScl {
		overflow: auto;
	}


	/*flow
	-----------------------------------------------------*/	
	.flowTtl {
		gap: 1rem;
	}
	.flowTtl h2 {
		font-size: 2.2rem;
	}
	.flowTtl .num {
		width: 3.5rem;
		font-size: 2.5rem;
	}
	.flowArea {
		padding: 3rem 0 5rem;
		font-size: 1.4rem;
	}
	.flowArea .box > h3 {
		font-size: 1.8rem;
		line-height: 1.4;
	}
	.appli02Wrap {
		gap: 1rem;
	}
	.appli02Wrap li {
		padding: 1rem;
		border-radius: 1rem;
	}
	.appli02Wrap li h4 {
		font-size: 1.8rem;
		margin-bottom: 1rem;
	}
	.appli02Wrap li .cont {
		display: block;
	}
	.appli02Wrap li .cont .bnr img {
    max-height: 4rem;
	}
	.flowArea .flow-arw {
		border-right: 2.4rem solid transparent;
		border-left: 2.4rem solid transparent;
		border-top: 1.5rem solid var(--c_bu);
		margin: 2rem auto 2.5rem;
	}
	.flowArea .flow-arw::before {
		width: 4.8rem;
	}
	.flowBtnBox {
		padding: 1.5rem 1rem;
	}
	.flowBtnBox .btn02 a {
		display: flex;
		padding: 1rem;
		gap: .5rem;
	}
	.btn03 a {
		font-size: 1.6rem;
		margin-top: 1rem;
	}
	.btn03 a::after {
		width: 1.5rem;
	}
	.flowCont {
		display: block;
		padding: 0 2rem;
	}
	.flowCont figure {
		margin-bottom: 2rem;
	}
	.flowCont dt {
		font-size: 1.8rem;
	}
	.flowCont dd .note {
		font-size: 1.2rem;
	}
	.appli02Wrap + .note {
		text-align: left;
	}
	.flowCont img[src*="cont01-1"] {
		max-height: 12rem;
	}
	.flowCont img[src*="cont02-1"] {
		max-height: 8rem;
	}
	.flowCont img[src*="cont02-2"] {
		max-height: 8rem;
	}
	.flowCont img[src*="cont03-1"] {
		max-height: 12rem;
	}
	.flowCont img[src*="cont04-1"] {
		max-height: 12rem;
	}
	.flowCont img[src*="cont05-1"] {
		max-height: 12rem;
	}
	.btn04 {
		text-align: center;
	}
	.btn04 a {
		font-size: 1.8rem;
	}
	.flowArea .papersContents {
		padding: 2rem 1rem;
	}
	.flowArea .papersDetailCont h3 {
		font-size: 1.4rem;
	}
	.flowArea .papersContents h3 {
		font-size: 1.4rem;
		line-height: 1.4;
		padding: .8rem;
	}

	/*practicable
	-------------------------------------------------------*/
	.diagResultBox {
		padding: 2rem;
	}
	.practicableBox h2 {
		font-size: 3.4rem;
		margin-bottom: 2rem;
	}
	.practicableBox .txt {
		font-size: 2rem;
		font-weight: 700;
		margin-bottom: 2rem;
	}
	.faildBox h2 {
		font-size: 2rem;
	}
	.faildBox .txt {
		font-size: 1.6rem;
		text-align: left;
		margin-bottom: 2rem;
	}
	.diagResultArea .note {
		text-align: left;
		padding-left: 1em;
		text-indent: -1em;
	}

	/*simulation
	-------------------------------------------------------*/
	.simuTtl {
		padding: 3rem 0 10rem;
	}
	.simuTtl .subTtl {
		font-size: 1.8rem;
	}
	.simuTtl h2 {
		font-size: 2.2rem;
	}
	.simuTtl figure img {
		max-height: 9rem;
	}
	.simuTtl figure {
		left: 4.5rem;
	}
	.simuTtl figure._02 {
		right: 5rem;
	}
	.simulationForm dl {
		width: 100%;
		font-size: 1.8rem;
		grid-template-columns: repeat(1,1fr);
		gap: 1rem;
	}
	.simulationForm dt:not(:first-of-type) {
		margin-top: 1rem;
	}
	.simulationForm select {
		width: 22rem;
	}
	.simulationForm select:invalid {
		font-size: 1.8rem;
	}
	.simulationForm button {
		margin-top: 3rem;
		font-size: 2rem;
		white-space: nowrap;
	}
	#simError {
		text-align: left;
	}
	.simulationResult h2 {
		font-size: 2.2rem;
	}
	.simulationResult dl {
		font-size: 1.8rem;
		gap: 1rem;
		grid-template-columns: repeat(1,1fr);
	}
	.simulationResult + .note {
		text-align: left;
	}
	/*warning
	---------------------------------------------------------*/
	.warningWrap {
		padding: 2rem;
		font-size: 100%;
	}
	.warningWrap h2 {
		font-size: 2rem;
		margin-bottom: 1.5rem;
	}




}

/*--アプリ用-----------------------------------------*/
:root{ --sat: env(safe-area-inset-top); }
.appView #header .headerWrap{
  padding-top: calc(var(--sat) + 10px);
  box-sizing: border-box;
}
.appView #nav{
  padding-top: var(--sat);
}
.appView .menuIcon,
.appView .menuIcon.active {
	top: calc(var(--sat) + 26px)!important;
}

@media screen and (max-width: 780px) {
	body.appView {
		padding-bottom: 14.7rem;
	}
	body.appView.btnNone,
	body#apply.btnNone {
		padding-bottom: 4rem;
	}
	body.appView .fixBtn.scl {
		bottom: 4rem;
	}
	.to-app {
		position: fixed;
		bottom: 0;
		right: 0;
		left: 0;
		width: 100%;
		z-index: 9500;
	}
	.to-app a {
		background: var(--c_dr);
		font-size: 1.6rem;
		font-weight: 800;
		color: #fff;
		height: 4rem;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: row-reverse;
	}
	.to-app a::after {
		content: "";
		display: block;
		margin-right: .5rem;
		margin-bottom: -0.3rem;
		background: url("../img/arrow_wh.svg") center center no-repeat;
		background-size: 100% auto;
		width: 1.5rem;
		height: 1.5rem;
		-webkit-transform: rotate(180deg);
		-ms-transform: rotate(180deg);
		transform: rotate(180deg);
	}
}