@charset "utf-8";

/* ========================================
   Suifeel Finance Application Page - PC
   Lease / Installment Application
   Contact Worldview Based
======================================== */

/* Base */

.FinanceApplicationPage{
	width: 100%;
	background: #fff;
	color: #0D0B2B;
	overflow: hidden;
}

.FinanceApplicationPage *{
	box-sizing: border-box;
}

.FinanceApplicationContainer{
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 40px;
	box-sizing: border-box;
}

/* ========================================
   Intro
======================================== */

.FinanceApplicationIntro{
	padding: 118px 0 0;
	background: #fff;
	text-align: center;
}

.FinanceApplicationIntro_inner{
	max-width: 880px;
	margin: 0 auto;
}

.FinanceApplicationEyebrow{
	margin: 0 0 24px;
	font-size: 12px;
	line-height: 1;
	font-weight: 600;
	letter-spacing: .24em;
	color: #7BAFCB;
}

.FinanceApplicationIntro h1{
	margin: 0;
	font-size: 42px;
	line-height: 1.55;
	font-weight: 400;
	letter-spacing: .055em;
	color: #0D0B2B;
}

.FinanceApplicationIntro_body{
	max-width: 760px;
	margin: 34px auto 0;
}

.FinanceApplicationIntro_body p{
	margin: 0;
	font-size: 14px;
	line-height: 2.25;
	letter-spacing: .04em;
	color: rgba(13,11,43,.66);
}

.FinanceApplicationIntro_body p + p{
	margin-top: 18px;
}

/* ========================================
   Form Section
======================================== */

.FinanceApplicationFormSection{
	position: relative;
	padding: 118px 0 170px;
	background:
		linear-gradient(
			180deg,
			#ffffff 0%,
			#f8fcfd 54%,
			#ffffff 100%
		);
}

.FinanceApplicationForm{
	position: relative;
	max-width: 1080px;
	margin: 0 auto;
	z-index: 1;
}

/* ========================================
   Notice / Error / Complete
======================================== */

.FinanceApplicationNotice,
.FinanceApplicationError,
.FinanceApplicationComplete{
	max-width: 980px;
	margin: 0 auto;
	padding: 58px 62px 64px;
	border-radius: 36px;
	background: rgba(255,255,255,.82);
	border: 1px solid rgba(13,11,43,.07);
	box-shadow: 0 24px 70px rgba(13,11,43,.045);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-sizing: border-box;
}

.FinanceApplicationNotice-restore{
	margin-bottom: 48px;
}

.FinanceApplicationNoticeLabel,
.FinanceApplicationBlockLabel{
	margin: 0 0 18px;
	font-size: 12px;
	line-height: 1;
	font-weight: 600;
	letter-spacing: .24em;
	color: #7BAFCB;
}

.FinanceApplicationNotice h2,
.FinanceApplicationError h2,
.FinanceApplicationComplete h2{
	margin: 0;
	font-size: 30px;
	line-height: 1.6;
	font-weight: 400;
	letter-spacing: .05em;
	color: #0D0B2B;
}

.FinanceApplicationNotice p,
.FinanceApplicationError p,
.FinanceApplicationComplete p{
	margin: 28px 0 0;
	font-size: 14px;
	line-height: 2.15;
	letter-spacing: .04em;
	color: rgba(13,11,43,.64);
}

.FinanceApplicationError ul{
	margin: 34px 0 0;
	padding-left: 1.4em;
}

.FinanceApplicationError li{
	margin: 8px 0;
	font-size: 13.5px;
	line-height: 2;
	letter-spacing: .04em;
	color: #9c3333;
}

/* ========================================
   Blocks
======================================== */

.FinanceApplicationBlock{
	margin: 0 0 82px;
	padding: 58px 62px 64px;
	border-radius: 36px;
	background: rgba(255,255,255,.78);
	border: 1px solid rgba(13,11,43,.07);
	box-shadow: 0 24px 70px rgba(13,11,43,.045);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-sizing: border-box;
}

.FinanceApplicationBlock:last-of-type{
	margin-bottom: 0;
}

.FinanceApplicationBlock_head{
	margin: 0 0 46px;
}

.FinanceApplicationBlock_head h2{
	margin: 0;
	font-size: 26px;
	line-height: 1.65;
	font-weight: 400;
	letter-spacing: .055em;
	color: #0D0B2B;
}

.FinanceApplicationBlock_head p:not(.FinanceApplicationBlockLabel){
	max-width: 820px;
	margin: 24px 0 0;
	font-size: 13.5px;
	line-height: 2.1;
	letter-spacing: .04em;
	color: rgba(13,11,43,.62);
}

/* ========================================
   Rows
======================================== */

.FinanceApplicationRow{
	display: grid;
	grid-template-columns: 260px minmax(0, 1fr);
	column-gap: 48px;
	align-items: start;
	padding: 30px 0;
	border-top: 1px solid rgba(13,11,43,.08);
	box-sizing: border-box;
}

.FinanceApplicationRow:last-child{
	border-bottom: 1px solid rgba(13,11,43,.08);
}

.FinanceApplicationRow > label{
	display: flex;
	align-items: center;
	gap: 12px;
	min-height: 58px;
	font-size: 13.5px;
	line-height: 1.8;
	font-weight: 500;
	letter-spacing: .08em;
	color: #0D0B2B;
}

.FinanceApplicationRow > label.required::after{
	content: "必須";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 22px;
	padding: 0 9px;
	border-radius: 999px;
	background: rgba(123,175,203,.14);
	color: #4D8CAE;
	font-size: 10px;
	line-height: 1;
	font-weight: 600;
	letter-spacing: .12em;
	box-sizing: border-box;
}

/* ========================================
   Fields
======================================== */

.FinanceApplicationField{
	min-width: 0;
}

.FinanceApplicationField input,
.FinanceApplicationField select,
.FinanceApplicationField textarea,
.FinanceApplicationFieldGroup input,
.FinanceApplicationFieldGroup select{
	width: 100%;
	border: 1px solid rgba(13,11,43,.12);
	background: rgba(255,255,255,.92);
	border-radius: 18px;
	box-sizing: border-box;
	outline: none;
	color: #0D0B2B;
	font-size: 15px;
	letter-spacing: .04em;
	transition:
		border-color .25s ease,
		box-shadow .25s ease,
		background .25s ease;
}

.FinanceApplicationField input,
.FinanceApplicationField select,
.FinanceApplicationFieldGroup input,
.FinanceApplicationFieldGroup select{
	height: 58px;
	padding: 0 18px;
}

.FinanceApplicationField input[type="file"]{
	height: auto;
	min-height: 58px;
	padding: 16px 18px;
}

.FinanceApplicationField textarea{
	display: block;
	min-height: 220px;
	padding: 22px 24px;
	line-height: 2;
	resize: vertical;
}

.FinanceApplicationField input::placeholder,
.FinanceApplicationField textarea::placeholder,
.FinanceApplicationFieldGroup input::placeholder{
	color: rgba(13,11,43,.34);
}

.FinanceApplicationField input:focus,
.FinanceApplicationField select:focus,
.FinanceApplicationField textarea:focus,
.FinanceApplicationFieldGroup input:focus,
.FinanceApplicationFieldGroup select:focus{
	border-color: rgba(123,175,203,.72);
	background: #fff;
	box-shadow: 0 0 0 4px rgba(123,175,203,.10);
}

.FinanceApplicationField select,
.FinanceApplicationFieldGroup select{
	appearance: none;
	-webkit-appearance: none;
	background-image:
		linear-gradient(45deg, transparent 50%, rgba(13,11,43,.45) 50%),
		linear-gradient(135deg, rgba(13,11,43,.45) 50%, transparent 50%);
	background-position:
		calc(100% - 22px) 50%,
		calc(100% - 16px) 50%;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 44px;
}

.FinanceApplicationField input[readonly],
.FinanceApplicationFieldGroup input[readonly]{
	background: rgba(247,251,253,.86);
	color: rgba(13,11,43,.58);
}

/* Field Group */

.FinanceApplicationFieldGroup{
	display: grid;
	grid-template-columns: minmax(0, 160px) minmax(0, 1fr);
	gap: 14px;
	align-items: center;
}

.FinanceApplicationFieldGroup:has(input:nth-child(3)){
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* ========================================
   Radio
======================================== */

.FinanceApplicationRadio{
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px 18px;
	min-height: 58px;
}

.FinanceApplicationRadio label{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	line-height: 1.8;
	font-weight: 400;
	letter-spacing: .04em;
	color: rgba(13,11,43,.72);
	cursor: pointer;
	transition: opacity .25s ease;
}

.FinanceApplicationRadio label:hover{
	opacity: .72;
}

.FinanceApplicationRadio input{
	width: 18px;
	height: 18px;
	margin: 0;
	accent-color: #0D0B2B;
	flex: 0 0 auto;
}

/* ========================================
   Summary / Confirm List
======================================== */

.FinanceApplicationSummary{
	margin: 46px 0 0;
	padding: 34px 38px;
	border-radius: 30px;
	background:
		linear-gradient(
			180deg,
			rgba(247,251,253,.92) 0%,
			rgba(255,255,255,.98) 100%
		);
	border: 1px solid rgba(123,175,203,.16);
	box-sizing: border-box;
}

.FinanceApplicationSummary dl,
.FinanceApplicationConfirmList{
	margin: 0;
	padding: 0;
	border-top: 1px solid rgba(13,11,43,.08);
}

.FinanceApplicationSummary dl div,
.FinanceApplicationConfirmList div{
	display: grid;
	grid-template-columns: 260px minmax(0, 1fr);
	column-gap: 48px;
	align-items: start;
	padding: 22px 0;
	border-bottom: 1px solid rgba(13,11,43,.08);
	box-sizing: border-box;
}

.FinanceApplicationSummary dt,
.FinanceApplicationConfirmList dt{
	margin: 0;
	font-size: 13.5px;
	line-height: 1.9;
	font-weight: 500;
	letter-spacing: .08em;
	color: #0D0B2B;
}

.FinanceApplicationSummary dd,
.FinanceApplicationConfirmList dd{
	margin: 0;
	font-size: 15px;
	line-height: 2;
	letter-spacing: .04em;
	color: rgba(13,11,43,.76);
	word-break: break-word;
}

/* ========================================
   Assist Text
======================================== */

.FinanceApplicationAssist{
	margin: 12px 0 0;
	font-size: 12px;
	line-height: 1.9;
	letter-spacing: .035em;
	color: rgba(13,11,43,.46);
}

/* ========================================
   Authorization
======================================== */

.FinanceApplicationBlock-authorization{
	border-color: rgba(123,175,203,.18);
	background:
		linear-gradient(
			180deg,
			rgba(255,255,255,.82) 0%,
			rgba(247,251,253,.72) 100%
		);
}

.FinanceApplicationAuthorizationSteps{
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 0;
	margin: 0 0 34px;
	border-top: 1px solid rgba(13,11,43,.08);
	border-bottom: 1px solid rgba(13,11,43,.08);
}

.FinanceApplicationAuthorizationSteps div{
	position: relative;
	min-height: 128px;
	padding: 28px 20px 26px;
	text-align: center;
	background: rgba(255,255,255,.58);
	box-sizing: border-box;
}

.FinanceApplicationAuthorizationSteps div + div{
	border-left: 1px solid rgba(13,11,43,.08);
}

.FinanceApplicationAuthorizationSteps span{
	display: block;
	margin: 0 0 18px;
	font-size: 24px;
	line-height: 1;
	font-weight: 300;
	letter-spacing: .04em;
	color: #7BAFCB;
}

.FinanceApplicationAuthorizationSteps p{
	margin: 0;
	font-size: 12.5px;
	line-height: 1.8;
	letter-spacing: .04em;
	color: rgba(13,11,43,.68);
}

.FinanceApplicationDownloadBox{
	margin: 0 0 30px;
	padding: 34px 38px;
	border-radius: 30px;
	background:
		linear-gradient(
			180deg,
			rgba(247,251,253,.92) 0%,
			rgba(255,255,255,.98) 100%
		);
	border: 1px solid rgba(123,175,203,.16);
	box-sizing: border-box;
}

.FinanceApplicationSubBtn{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 260px;
	height: 56px;
	padding: 0 30px;
	border-radius: 999px;
	background: #0D0B2B;
	border: 1px solid #0D0B2B;
	color: #fff;
	font-size: 13px;
	line-height: 1;
	font-weight: 500;
	letter-spacing: .10em;
	text-decoration: none;
	box-shadow: 0 18px 40px rgba(13,11,43,.14);
	box-sizing: border-box;
	transition:
		transform .28s ease,
		opacity .28s ease,
		box-shadow .28s ease;
}

.FinanceApplicationSubBtn:hover{
	transform: translateY(-3px);
	opacity: .9;
	box-shadow: 0 24px 54px rgba(13,11,43,.18);
}

/* ========================================
   Privacy
======================================== */

.FinanceApplicationPrivacy{
	margin: 82px 0 0;
	padding: 46px 52px 50px;
	border-radius: 34px;
	background:
		linear-gradient(
			180deg,
			rgba(247,251,253,.92) 0%,
			rgba(255,255,255,.98) 100%
		);
	border: 1px solid rgba(13,11,43,.06);
	box-sizing: border-box;
}

.FinanceApplicationPrivacy_label{
	margin: 0 0 24px;
	font-size: 12px;
	line-height: 1;
	font-weight: 600;
	letter-spacing: .24em;
	color: #7BAFCB;
	text-align: center;
}

.FinanceApplicationPrivacy_box{
	height: 220px;
	overflow-y: auto;
	padding: 28px 30px;
	border-radius: 24px;
	background: rgba(255,255,255,.86);
	border: 1px solid rgba(13,11,43,.08);
	box-sizing: border-box;
}

.FinanceApplicationPrivacy_box p{
	margin: 0;
	font-size: 12.5px;
	line-height: 2;
	letter-spacing: .035em;
	color: rgba(13,11,43,.62);
}

.FinanceApplicationPrivacy_box p + p{
	margin-top: 18px;
}

.FinanceApplicationPrivacyNotice{
	margin: 24px 0 0;
	font-size: 13px;
	line-height: 2;
	letter-spacing: .04em;
	color: rgba(13,11,43,.58);
	text-align: center;
}

.FinanceApplicationPrivacyCheck{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	width: 100%;
	margin: 28px auto 0;
	cursor: pointer;
	font-size: 14px;
	line-height: 1.8;
	letter-spacing: .04em;
	color: rgba(13,11,43,.72);
	transition: opacity .25s ease;
}

.FinanceApplicationPrivacyCheck.is-disabled{
	cursor: not-allowed;
	opacity: .45;
}

.FinanceApplicationPrivacyCheck input{
	width: 18px;
	height: 18px;
	accent-color: #0D0B2B;
	flex: 0 0 auto;
}

/* ========================================
   Submit
======================================== */

.FinanceApplicationSubmitArea{
	margin: 72px auto 0;
	text-align: center;
}

.FinanceApplicationSubmitBtn,
.FinanceApplicationBackBtn{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 300px;
	height: 66px;
	padding: 0 34px;
	border-radius: 999px;
	font-size: 14px;
	line-height: 1;
	font-weight: 500;
	letter-spacing: .10em;
	text-decoration: none;
	cursor: pointer;
	box-sizing: border-box;
	transition:
		transform .28s ease,
		opacity .28s ease,
		border-color .28s ease,
		background .28s ease,
		box-shadow .28s ease;
}

.FinanceApplicationSubmitBtn{
	border: 1px solid #0D0B2B;
	background: #0D0B2B;
	color: #fff;
	box-shadow: 0 18px 40px rgba(13,11,43,.16);
}

.FinanceApplicationBackBtn{
	margin-left: 16px;
	border: 1px solid rgba(13,11,43,.12);
	background: rgba(255,255,255,.88);
	color: #0D0B2B;
}

button.FinanceApplicationBackBtn{
	font-family: inherit;
}

.FinanceApplicationSubmitBtn:hover,
.FinanceApplicationBackBtn:hover{
	transform: translateY(-3px);
	opacity: .9;
}

.FinanceApplicationSubmitBtn:hover{
	box-shadow: 0 24px 54px rgba(13,11,43,.20);
}

/* ========================================
   Complete
======================================== */

.FinanceApplicationComplete{
	text-align: center;
}

.FinanceApplicationCompleteNotes{
	margin: 54px auto 0;
	padding: 34px 38px;
	border-radius: 30px;
	background:
		linear-gradient(
			180deg,
			rgba(247,251,253,.92) 0%,
			rgba(255,255,255,.98) 100%
		);
	border: 1px solid rgba(123,175,203,.16);
	box-sizing: border-box;
	text-align: left;
}

.FinanceApplicationCompleteNotes h3{
	margin: 0 0 18px;
	font-size: 20px;
	line-height: 1.7;
	font-weight: 400;
	letter-spacing: .05em;
	color: #0D0B2B;
}

.FinanceApplicationCompleteNotes ol{
	margin: 0;
	padding-left: 1.5em;
}

.FinanceApplicationCompleteNotes li{
	margin: 7px 0;
	font-size: 13.5px;
	line-height: 2.1;
	letter-spacing: .04em;
	color: rgba(13,11,43,.64);
}