@charset "UTF-8";

/* 共通部分
---------------------------------------------　*/


@supports (-ms-ime-align:auto) {
.selector img {
  height:100%;
  }
}


html {
	font-size: 100%;
}

body {
  font-family: 'Montserrat','Noto Sans JP';
	line-height: 2.5rem;
	color: #3B4043;
	font-size: 1.25rem;
}

a {
	text-decoration: none;
}

img {
	max-width: 100%;
}

.wrapper {
	max-width: 1125px;
	margin: 0 auto;
	padding: 0 4%;
}

.arrow_btn {
	display: inline-block;
	position: relative;
	padding: 1.250rem 3.125rem;
	text-align: center;
	text-decoration: none;
	font-size: 1.125rem;
	font-weight: 900;
	color: #fff;
	background: #FA4252;
	border-radius: 50px;
	transition: transform ease .3s;
}
.arrow_btn:hover {
	cursor: pointer;
	text-decoration: none;
	background: #448ef6;
	box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
}
.arrow_btn span {
	display: inline-block;
	text-decoration: none;
	transition: transform ease .3s;
}
.arrow_btn:hover span{
	cursor: pointer;
	text-decoration: none;
	transform: translateX(6px);
}

@media screen and (min-width: 600px){
  .spbr { display:none; }
}
@media screen and (max-width: 600px){
  .spbr { display:block; }
}

/* HEADER
--------------------------------------------- */

.page-header {
	background-image: url(../img/top.png),linear-gradient(to right, #448ef6 0%, #65daf7 30%, rgba(117, 194, 246, 0) 100%);
	background-blend-mode: normal;
	-webkit-background-size: cover;
	background-size: cover;
	background-position: right top;
	background-repeat: no-repeat;
}

.main-v {
	padding-bottom: 7.5rem;
}

h1 img {
  /*width: 137px;*/
  height: 90px;
	margin-top: 6.875rem;
}

h2 {
	margin-top: 3.75rem;
	margin-bottom: 5rem;
  font-size: 2.5rem;
	line-height: 3.75rem;
  font-family: 'Noto Sans JP';
  font-weight: 900;
	color: #fff;
	text-shadow: 0px 0px 9px rgba(24, 43, 93, 1);
}

h2 .sub {
	display: inline-block;
	font-size: 1.5rem;
}

/* LOAN------------------------------------------------- */


h3 {
	margin-top: 11.25rem;
	text-align: center;
	font-size: 3.375rem;
	font-weight: 900;
	margin-bottom: 3.125rem;
	line-height: 4rem;
}

.loan-container {
	margin-top: 3.125rem;
	display: flex;
	-webkit-flex-direction: row;
	-ms-flex-direction: row;
	flex-direction: row;
	align-items: flex-start;
}

.loan img {
	width: 45%;
	height: 45%;
	margin-left: 5%;
	flex-shrink: 0
}


/* MERIT --------------------------------------------------------- */

h4 {
	font-size: 2.250rem;
	line-height: 2.625rem;
	font-weight: 900;
	text-align: center;
	margin-top: 6rem;
	padding-bottom: 1.5rem;
}

h4 .num {
	color: #65DAF7;
	font-size: 6.750rem;
	font-weight: 400;
	font-style: italic;
	vertical-align: -50%;
}

.merit dt {
	margin-top: 2.8rem;
	font-size: 1.5rem;
	font-weight: 900;
	color: #448ef6;
}

.merit dd {
	margin-top: 0.5rem;
}

.kome {
	vertical-align: 20%;
	font-size: 1rem;
}

.comment {
	font-size: 1rem;
}

.bottom {
	margin-bottom: 10.625rem;
}

.ex {
	margin-top: 2.5rem;
	margin-bottom: 4.063rem;
	width: 65%;
	padding: 4%;
	border-radius: 20px;
	background: #fff;
	border: 4px solid #fa4252;
}

.ex span {
	font-weight: 900;
}

.web-service {
	border-radius: 20px;
	background: #d2fafb;
	margin-top: 7.5rem;
	padding: 3.75rem;
}

h5{
	font-weight: 900;
	font-size: 1.875rem;
	text-align: center;
	color: #0c4b8e;
	margin-bottom: 1.25rem;
}

.web-service p {
	margin-bottom: 1.875rem
}

.web-service ul {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}

.web-service li {
	border-radius: 10px;
	background: #fff;
	border: 5px solid #5acfd6;
	padding: 3%;
	font-size: 1.500rem;
	line-height: 2.25rem;
	text-align: left;
	color: #0c4b8e;
	width: 24%;
}

.web-service .comment {
	margin-top: 1.875rem;
	padding-left:2.6rem;
	text-indent:-2.6rem;
}

.web-service .comment p {
		font-size: 1rem;
		line-height: 1.875rem;
		margin-bottom: 0;
}

.customer-merit {
	margin-top: 10.625em;
	background: linear-gradient(to right, #448ef6 0%, #65daf7 100%);
}

.customerInner {
	padding: 8.750rem 3%;
	display: flex;
  align-items: flex-start;
	margin: 0	20%;
}

#h {
	margin-top: 0;
	font-size: 2.0rem;
	color: #FFF;
	line-height: 3rem;
	font-weight: 900;
	padding-bottom: 1rem;
	text-align: left;
}

.customerInner p {
	color: #FFF;
	font-size: 1.250rem;
	line-height: 2.500rem;
}

.customerInner img {
	width: 40%;
	height: auto;
	margin-left: 4%;
	flex-shrink: 0
}



/* FLOW---------------------------------------------------- */

.flow {
    padding-left: 120px;
    position: relative;
		margin-top: 6rem;
}
.flow::before {
    content: "";
    width: 16px;
    height: 100%;
    background: #EBEBEB;
    margin-left: -9px;
    display: block;
    position: absolute;
    top: 0;
    left: 120px;
}
.flow > li {
    position: relative;
}
.flow > li:not(:last-child) {
    margin-bottom: 3rem;
}
.flow > li .icon {
    font-size: 1.25rem;
		font-family: 'Montserrat';
		font-weight: 700;
    color: #fff;
    background: #65DAF7;
    padding: 0 10px;
    display: block;
    position: absolute;
    top: 0;
    left: -120px;
    z-index: 100;
}
.flow > li .icon::after {
    content: "";
    border-style: solid;
    border-width: 8px 0 8px 10px;
    border-color: transparent transparent transparent #65DAF7;
    position: absolute;
    top: 50%;
    left: 100%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.flow > li dl {
    padding-left: 40px;
    position: relative;
}
.flow > li dl::before,
.flow > li dl::after {
    content: "";
    display: block;
    position: absolute;
    top: 20px;
}
.flow > li dl::before {
    width: 7px;
    height: 7px;
    margin-top: -3px;
    background: #6b90db;
    border-radius: 50%;
    left: -4px;
}
.flow > li dl::after {
    width: 30px;
    border-bottom: 1px dashed #999;
    position: absolute;
    left: 5px;
}
.flow > li dl dt {
    font-size: 1.5rem;
    font-weight: 900;
    color: #448EF6;
    margin-bottom: 1vh;
}

.flow > li dl dt dd {
    font-size: 1.250rem;
		line-height: 2.5em;
    font-weight: 400;
}


/* ENTRY------------------------------------- */

.entry {
	text-align: center;
	margin-top: 11.875em;
}


/* FOOTER------------------------------------ */

footer {
	background: #3B4043;
	margin-top: 11.875rem;
	padding-bottom: 3.125rem;
}

.info {
	padding-top: 6.250rem;
	}

.info img {
	width: 24%;
	height: 24%;
}

address {
	margin-top: 1.25rem;
	color: #FFF;
	font-size: 0.75rem;
	line-height: 1.125rem;
}

.bar {
	margin-top: 1.875rem;
	margin-bottom: 1rem;
	display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  border: 0;
}

.footerNav li {
	font-size: 0.75rem;
	display: inline;
	position: relative;
	margin-right: 10px;
	margin-bottom: 50px;
}

.footerNav li:not(:first-child) {
	padding-left: 12px;
}

.footerNav li+li {
	border-left: 1px solid #fff;
}

.footerNav a:link {
	color: #fff;
}

.footerNav a:visited {
	color: #fff;
}

.footerNav a:hover {
	color: #fff;
	text-decoration: underline;
}

.footerNav a:active {
	color: #448EF6;
}

small {
	color: #FFF;
	font-size: 0.75rem;
	font-weight: 400;
	text-align: left;
	margin-top: 1.25rem;
}


/* モバイル版------------------------------------------------- */
@media (max-width: 600px) {

/* HEADRE */

	.page-header {
		background-image: url(../img/top_sp.png),linear-gradient(to right, #448ef6 0%, #65daf7 30%, rgba(117, 194, 246, 0) 100%);
		background-blend-mode: normal;
		background-size: cover;
		background-position: right 25% top;
		background-repeat: no-repeat;
	}

	.main-v {
		padding-bottom: 3.125em;
	}

	h1 img {
	  /*width: 94px;*/
	  height: 74px;
		margin-top: 3.125rem;
	}

	h2 {
		margin-top: 2.5rem;
		margin-bottom: 6.5rem;
	  font-size: 1.875rem;
		line-height: 2.5rem;
	}

	h2 .sub {
		font-size: 1.25rem;
		line-height: 1.875rem;
	}

	.btn {
		text-align: center;
	}

/* LOAN */


h3 {
	margin-top: 4.75rem;
	font-size: 2.5rem;
	line-height: 3.75rem;
	font-weight: 900;
	margin-bottom: 3.125rem;
}

.loan-container {
	margin-top: 3.125rem;
	flex-direction: column;
}

.loan img {
	margin: 2.5rem 0 7.5rem 0;
	width: 100%;
	height: 100%;
}

/* MERIT */

h4 {
	font-size: 1.875rem;
	line-height: 3rem;
	text-align: center;
	margin-top: 2rem;
	margin-bottom: 0;
	padding-bottom: 0;
}

.num {
	display: inline-block;
	font-size: 5rem;
	line-height: 7rem;
}

.bottom {
	margin-bottom: 4rem;
}

.ex {
	margin-top: 1.5rem;
	margin-bottom: 4.063rem;
	width: auto;
	padding: 4%;
	border-radius: 20px;
	background: #fff;
	border: 4px solid #fa4252;
}

.ex span {
	font-weight: 900;
}

.web-service {
	margin-top: 6.250rem;
	padding: 2.5rem 1.250rem;
}

h5{
	font-size: 1.5rem;
	line-height: 2.625rem;
	margin-bottom: 1.25rem;
}

.web-service p {
	margin-bottom: 1.875rem
}

.web-service ul {
	flex-direction: column;
}

.web-service li {
	padding: 5%;
	color: #0c4b8e;
	width: auto;
}

.web-service li:not(:last-child) {
	margin-bottom: 0.8rem;
}

.customer-merit {
	margin-top: 3.750rem;
	margin-bottom: 7.500rem;
}

.customerInner {
	display: block;
	margin: auto;
	padding: 3.750em 4%;
}

#h {
	text-align: center;
}

.customerInner img {
	width: auto;
	height: auto;
	margin: 1.563rem 0 0 0;
}

/* FLOW */

	.flow {
	    padding-left: 120px;
			margin-top: 3.438rem;
	}

	.flow::before {
	    content: "";
	    width: 11px;
	    margin-left: -30px;
	}

	.flow > li:not(:last-child) {
	    margin-bottom: 2rem;
	}

	.flow > li .icon {
	    font-size: 1rem;
	}

	.flow > li dl {
	    padding-left: 5px;
	}

	.flow > li dl::before {
	    left: -28px;
	}

	.flow > li dl::after {
	    width: 20px;
	    left: -20px;
	}

	.flow > li dl dt {
	    margin-bottom: 0;
	}

	.flow dt {
			font-size: 1.2rem;
		}

	.flow dd {
	    font-size: 1.125rem;
			line-height: 2rem;
	    font-weight: 400;
	}

	.flow .comment {
		margin-top: 1rem;
		line-height: 1.7rem;
	}

	/* ENTRY*/

	.entry {
		margin-top: 4.375rem;
	}


	/* FOOTER------------------------------------ */

	footer {
		margin-top: 8.125rem;
	}

	.info {
		padding-top: 6rem;
		}

	.info img {
		width: 200px;
		height: auto;
	}

	small {
		color: #FFF;
		font-size: 0.5rem;;
	}



 }   /*メディアクエリおわり */
