@charset "UTF-8";

/* ----------------------------------

	車種モーダル

---------------------------------- */

.lineupModal{
	display: none;
	position: fixed;
	inset: 0;
	z-index: 3000;
	background: rgba(5,16,25,.72);
	padding: 14px;
	overflow: hidden;
}
.lineupModal__inner{
	position: relative;
	max-width: 100%;
	height: 95svh;
	margin: 0 auto;
	background: #fff;
	border-radius: 8px;
	color: var(--color-primary);
	display: flex;
	flex-direction: column;
	overflow: visible;
}
.lineupModal__grid{
	flex: 1;
	overflow-y: auto;
	overflow-x: hidden;
	background: #fff;
	border-radius: 8px 8px 0 0;
}
.lineupModal__grid::-webkit-scrollbar{
	width: 8px;
}
.lineupModal__grid::-webkit-scrollbar-thumb{
	background: rgba(0,0,0,.18);
	border-radius: 999px;
}

.lineupModal__close{
	position: absolute;
	top: -16px;
	right: -16px;
	z-index: 2;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	border: 3px solid #fff;
	background: var(--color-primary);
	color: #fff;
	font-size: 34px;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
.lineupModal__head{
	padding: 12px;
	border-bottom: 1px solid #B7BDC7;
}
.lineupModal__image{
	position: relative;
	margin-bottom: 18px;
}
.lineupModal__image img{
	width: 100%;
	height: auto;
	display: block;
	border-radius: 6px;
}
.lineupModal__bodyType{
	position: absolute;
	right: 12px;
	bottom: 12px;
	min-width: 44px;
	padding: 3px 10px;
	border: 1px solid #fff;
	border-radius: 4px;
	color: #fff;
	font-size: 12px;
	line-height: 1.2;
	text-align: center;
}

.lineupModal__maker{
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
}
.lineupModal__makerJa{
	color: #9AA4B1;
	font-size: 12px;
	font-weight: 500;
	margin-bottom: 14px;
}
.lineupModal__carName{
	font-size: 32px;
	font-weight: 500;
	line-height: 1.15;
	margin-bottom: 8px;
}
.lineupModal__grade{
	font-size: 14px;
	font-weight: 500;
	line-height: 1.45;
	margin-bottom: 5px;
}
.lineupModal__handle{
	font-size: 12px;
}
.lineupModal__price{
	display: grid;
	gap: 8px;
}
.lineupModal__price div{
	display: grid;
	grid-template-columns: 90px 1fr;
	align-items: baseline;
}
.lineupModal__price dt{
	font-size: 14px;
	font-weight: 700;
}
.lineupModal__price dd{
	font-size: 16px;
	font-weight: 500;
	line-height: 1.1;
	text-align: right;
}

.lineupModal__price dd span{
	font-size: 24px;
	font-weight: 500;
	margin-left: 2px;
}
.lineupModal__price .total dd span{
	font-size: 28px;
	font-weight: 700;
}

.lineupModal__bottom{
	padding: 12px;
}
.lineupModal__bottom-box{
	padding-bottom: 15px;
}

.lineupModal__heading{
	font-size: 15px;
	font-weight: 700;
	line-height: 1.4;
	padding-bottom: 12px;
	margin-top: 15px;
	margin-bottom: 8px;
	border-bottom: 1px solid var(--color-primary);
}
.lineupModal__table{
	width: 100%;
	border-collapse: collapse;
}
.lineupModal__table th,
.lineupModal__table td{
	padding: 10px 0;
	border-bottom: 1px solid #C9CDD3;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.4;
}
.lineupModal__table th{
	text-align: left;
}
.lineupModal__table td{
	text-align: right;
}
.lineupModal__equipmentList{
	display: grid;
}
.lineupModal__equipmentList li{
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	padding: 10px 0;
	border-bottom: 1px solid #C9CDD3;
	font-size: 14px;
	font-weight: 600;
}
.lineupModal__equipmentMark{
	width: 13px;
	height: 13px;
	border: 1px solid #8FA0AD;
	border-radius: 50%;
	flex-shrink: 0;
	font-size: 0;
}
.lineupModal__colorList{
	display: grid;
	gap: 10px;
}
.lineupModal__colorList li{
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.45;
}
.lineupModal__colorChip{
	width: 22px;
	height: 22px;
	border-radius: 50%;
	border: 1px solid #C9CDD3;
	flex-shrink: 0;
	overflow: hidden;
}
.lineupModal__colorAddon{
	font-size: .9em;
}
.lineupModal__optionGroup + .lineupModal__optionGroup{
	margin-top: 28px;
}
.lineupModal__optionTitle{
	font-size: 15px;
	font-weight: 700;
	line-height: 1.4;
	padding-bottom: 12px;
	margin-top: 15px;
	margin-bottom: 12px;
	border-bottom: 1px solid var(--color-primary);
}
.lineupModal__optionList{
	font-size: 14px;
	font-weight: 600;
	line-height: 1.7;
}

.lineupModal__buttons{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	flex-shrink: 0;
	position: relative;
	z-index: 5;
	background: #fff;
	border-radius: 0 0 8px 8px;
	overflow: hidden;
}
.lineupModal__form{
	margin: 0;
}
.lineupModal__buttons button{
	width: 100%;
	min-height: 64px;
	min-height: 72px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	border: 0;
	text-decoration: none;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: .04em;
	transition: all .4s;
}
.lineupModal__buttons button:hover{
	cursor: pointer;
	opacity: 0.4;
}
.lineupModal__buttons button span{
	display: none;
}
.lineupModal__contact{
	background: #D8D8D8;
	color: var(--color-primary);
}
.lineupModal__entry{
	background: var(--color-primary);
	color: #fff;
}
@media print, screen and (min-width: 768px){
	.lineupModal__head{
		display: flex;
		align-items: center;
		border-bottom: none;
	}
	.lineupModal__image{
		width: 40%;
	}
	.lineupModal__head-right{
		width: 60%;
		padding-left: 30px;
	}
	.lineupModal__price{
		border-bottom: 1px solid #B7BDC7;
		padding-bottom: 15px;
	}
	.lineupModal__bottom-left__inner{
		display: flex;
		justify-content: space-between;
	}
	.lineupModal__spec{
		width: 50%;
	}
	.lineupModal__equipment{
		width: 45%;
	}
}
@media print, screen and (min-width: 960px){
	.lineupModal{
		padding: 40px;
		align-items: center;
		justify-content: center;
	}
	.lineupModal.is-show{
		display: flex !important;
	}

	.lineupModal__grid{
		border-radius: 10px 10px 0 0;
	}
	.lineupModal__inner{
		max-width: 1040px;
		width: 100%;
		height: 80svh;
		margin: 0;
		border-radius: 10px;
		padding: 20px 20px 0;
		overflow: visible;
	}
	.lineupModal__close{
		top: -30px;
		right: -30px;
		width: 62px;
		height: 62px;
		font-size: 42px;
	}

	.lineupModal__image{
		margin-bottom: 0;
		width: 45%;
	}
	.lineupModal__head-right{
		padding-left: 50px;
		width: 55%;
	}

	.lineupModal__maker{
		font-size: 22px;
	}
	.lineupModal__makerJa{
		font-size: 13px;
		margin-bottom: 24px;
	}
	.lineupModal__carName{
		font-size: 44px;
		margin-bottom: 10px;
	}
	.lineupModal__grade{
		font-size: 18px;
	}
	.lineupModal__handle {
    font-size: 16px;
	}
	.lineupModal__price{
		padding-top: 25px;
		border-bottom: 1px solid #B9C0C8;
	}
	.lineupModal__price div{
		grid-template-columns: 120px 1fr;
	}
	.lineupModal__price dt{
		font-size: 15px;
	}
	.lineupModal__price dd{
		font-size: 28px;
	}
	.lineupModal__price .total dd span{
		font-size: 36px;
		font-weight: 500;
	}

	.lineupModal__bottom{
		display: flex;
		justify-content: space-between;
	}
	.lineupModal__bottom-left{
		width: 60%;
	}
	.lineupModal__bottom-right{
		width: 35%;
	}

	.lineupModal__equipment {
		width: 40%;
	}

	.lineupModal__buttons{
		margin-left: -20px;
		margin-right: -20px;
		margin-bottom: 0;
		border-radius: 0 0 10px 10px;
	}
	.lineupModal__buttons button{
		font-size: 18px;
		letter-spacing: 4px;
		height: 86px;
	}
	.lineupModal__buttons button span{
		display: inline;
	}
}



