:root {
	--cl-skyblue: #4AA0DF;
	--cl-black: #333;
}

* {
	font-family: 'Noto sans JP', 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	line-height: 1.4;
	color: var(--cl-black);
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

nav ul.global_nav li a {
	font-size: 11px;
}

nav ul.global_nav li.small a {
	font-size: 10px;
}

.contents main p {
	text-align: initial;
	color: #333;
}

.contents main .fc_white {
	color: white;
}

.l-main a:hover {
	text-decoration: none !important;
}

.l-main ul li img {
	margin: 0;
}

span {
	font-family: inherit;
	font-size: inherit;
	color: inherit;
}

.cont-inner {
	width: 100%;
	max-width: 980px;
	margin: auto;
	position: relative;
	z-index: 1;
}

section {
	position: relative;
}

.section-headline {
	text-align: center;
	margin: 0;
	padding: 0;
	line-height: 1;
}

.l-header {
	width: 100%;
	height: 87px;
	background: #5AA2D9;
	position: relative;
}

.header-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 5%;
	display: flex;
}

.alto-logo {
	width: 245px;
	height: 87px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	border-left: 1px solid #fff;
	border-right: 1px solid #fff;
	position: relative;
}

.alto-logo .logo {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.alto-logo .logo:hover {
	background: rgba(40, 150, 200, 0.3);
}

.header-nav {
	width: calc(100% - 253px);
}

.header-nav__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 100%;
}

.header-nav__list--item {
	flex: 1;
	border-right: 1px solid #fff;
}

.header-nav__list--item a {
	width: 100%;
	height: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	font-family: 'Noto Sans JP';
	font-style: normal;
	line-height: 23px;
}

.header-nav__list--item a:hover {
	background: #1267cf;
	text-decoration: none;
}

.is-fixed {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 150;
	width: 100%;
	transition: all 0.3s ease;
	/* margin-top: 35px; */
}

.l-main {
	background: #fff;
	padding: 0;
	margin: 0;
}

.hero {
	width: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background-color: white;
	padding-bottom: 2rem;
}

.hero_kv {
	position: relative;
	width: 100%;
	display: flex;
	justify-content: center;
}

.hero_kv {
	position: relative;
	overflow: hidden;
}

.hero_kv_images {
	position: relative;
	width: 100%;
	aspect-ratio: 1366 / 690;
	overflow: hidden;
}

@media (max-width: 767px) {
	.hero_kv_images {
		aspect-ratio: 767 / 651;
	}
}

.kv_item {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: opacity 1s ease;
	pointer-events: none;
	display: flex;
	justify-content: center;
}

.kv_item picture,
.kv_item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.kv_item.active {
	opacity: 1;
	pointer-events: auto;
}

.hero .mov_thmb {
	position: absolute;
	bottom: 6px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 3;
}

.hero .mov_thmb img {
	width: 29.8vw;
	height: auto;
	max-width: 479px;
	transition: transform 0.3s ease;
	cursor: pointer;
}

@media (max-width: 767px) {
	.hero .mov_thmb img {
		width: 51.55vw;
	}
}

.hero .mov_thmb img:hover {
	transform: scale(1.05);
}

.hero>div {
	flex-basis: 100%;
	display: flex;
	justify-content: center;
}

.hero_lead {
	max-width: 610px;
}

.contents main .hero h2 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 175%;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;
	color: #333333;
	margin: 25px 0 17px;
}

@media (max-width: 767px) {
	.contents main .hero h2 {
		font-size: 14px;
	}
}

.section_ttl {
	display: flex;
	justify-content: center;
	overflow: hidden;
	height: 105px;
}

.exterior {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding-top: 2rem;
}

@media (max-width: 767px) {
	.exterior {
		margin-top: 62px;
	}
}

.exterior>div {
	width: 100%;
	display: flex;
	justify-content: center;
}

.exterior h4 {
	width: 100%;
	border: none;
	font-style: normal;
	font-weight: 700;
	font-size: 20px;
	line-height: 185%;
	text-align: center;
	letter-spacing: 0.16em;
	font-feature-settings: 'palt' on;
	color: #333333;
	margin: 22px 0 26px;
}

.exterior h4 span.bg_black {
	font-size: 20px;
	padding: 2px 12px;
	background-color: black;
	color: white;
}

.exterior h4 span.fc_orange {
	font-size: 20px;
	color: #FB686A;
}

.exterior_btn {
	margin: 57px 0;
}

@media (max-width: 767px) {
	.exterior_btn {
		margin: 52px 0;
	}
}

.exterior_btn img {
	transition: all 0.3s ease;
	max-width: 90vw;
}

.exterior_btn img:hover {
	opacity: 0.8;
	transition: all 0.3s ease;
}

.ex_comp {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	background-color: #F9F3E7;
	background-image: url(../../img/alto/bg_exterior_comp.png);
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	margin: 0;
	padding: 41px 0 64px;
}

@media (max-width: 767px) {
	.ex_comp {
		background-image: url(../../img/alto/bg_exterior_comp_sp.png);
		background-position: center top;
		padding: 0;
	}
}

.ex_comp_container {
	max-width: 1300px;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
	gap: 19px;
	padding: 0 20px;
}

@media (max-width: 767px) {
	.ex_comp_container {
		gap: 10px;
		margin: 38px 20px;
	}
}

@media (max-width: 550px) {
	.ex_comp_container {
		gap: 10px;
		margin: 43px 0;
	}
}

.ex_comp_inner {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
	gap: 3%;
}

@media (max-width: 767px) {
	.ex_comp_inner {
		gap: 6.7%;
		margin: 0;
	}
}

.ex_comp_detail {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
}

.ex_comp_inner>div {
	width: 47%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-start;
}

@media (max-width: 767px) {
	.ex_comp_inner>div {
		width: 46.6%;
	}
}

.ex_comp_detail>div {
	width: 49%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: flex-start;
}

@media (max-width: 767px) {
	.ex_comp_detail>div {
		width: 100%;
		margin-bottom: 31px;
	}
}

.ex_comp_ttl,
.ex_comp_car {
	width: 100%;
	display: flex;
	justify-content: center;
}

.ex_comp_ttl {
	margin-bottom: -6px;
}

.ex_comp_car {
	margin-bottom: 14px;
}

.ex_comp_ttl>div,
.ex_comp_car>div {
	width: 50%;
	display: flex;
	justify-content: center;
}

@media (max-width: 767px) {

	.ex_comp_ttl,
	.ex_comp_car {

		gap: 35px;
	}

	.ex_comp_car {
		margin-bottom: 10px;
	}

	.ex_comp_ttl>div,
	.ex_comp_car>div {
		width: 100%;
	}
}

.ex_comp_detail>div>figure {
	width: 99%;
}

.interior {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	background-color: #292D30;
	background-image: url(../../img/alto/bg_interior.png);
	background-position: bottom right;
	background-repeat: no-repeat;
	background-size: 70%;
	padding: 65px 0 62px;
}

@media (max-width: 767px) {
	.interior {
		padding: 85px 0 33%;
	}
}

.interior>div {
	width: 100%;
	display: flex;
	justify-content: center;
}

.interior h4 {
	width: 100%;
	border: none;
	font-style: normal;
	font-weight: 700;
	font-size: 20px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.16em;
	font-feature-settings: 'palt' on;
	color: #FFFFFF;
	margin: 25px 0 40px;
}

#interior .interior_all {
	width: 60.5%;
	height: auto;
	border: 10px solid white;
}

@media (max-width: 767px) {
	#interior .interior_all {
		width: 88%;
		border: 4px solid white;
	}
}

.interior .interior_modals_flex {
	width: 64%;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 0;
	margin: 23px 0 0 9%;
}

@media (max-width: 767px) {
	.interior .interior_modals_flex {
		margin: 0;
		width: 88%;
	}

	#interior>div:nth-child(4)>div>div.interior_modalbox1>figure {

		width: 50%;
	}
}

.interior_modals_flex figure>figcaption>p {
	color: #FFFFFF;
	font-size: 96%;
}

@media (max-width: 767px) {
	.interior_modals_flex figure>figcaption>p {
		color: #FFFFFF;
		font-size: 96%;
		padding: 0;
		margin: 7px 0 13px;
	}
}

.interior_modalbox1 {
	width: 23%;
}

@media (max-width: 767px) {
	.interior_modalbox1 {
		width: 100%;
		justify-content: center;
		display: flex;
		margin: 20px 0;
	}
}

.interior_modalbox2 {
	width: 72%;
	display: flex;
	flex-wrap: wrap;
	justify-content: start;
	gap: 6%;
	margin: 21px 0 0 2%;
}

.interior_modalbox2>figure {
	width: 43%;
}

.interior_modalbox2>figure:last-of-type {
	width: 50%;
}

@media (max-width: 767px) {
	.interior_modalbox2 {
		width: 100%;
		margin: 0;
	}

	.interior_modalbox2>figure,
	.interior_modalbox2>figure:last-of-type {
		width: 100%;
		margin-bottom: 1px;
	}
}

.basic {
	width: 100%;
	background-color: #EDEDED;
	background-image: url(../../img/alto/bg_basic.png);
	background-repeat: no-repeat;
	background-position: right bottom;
	background-size: 66vw;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 63px 0;
}

@media (max-width: 767px) {
	.basic {
		padding: 63px 0 30px;
	}
}

.basic>div {
	width: 100%;
	display: flex;
	justify-content: center;
}

.basic_lead {
	margin: 14px 0 30px;
}


main .basic_lead p {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 20px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.16em;
	font-feature-settings: 'palt' on;
	color: #333333;
}

@media (max-width: 767px) {
	main .basic_lead p {
		text-align: center;
	}
}


.parts-modal {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(43, 46, 56, 0.9);
	z-index: 1001;
	overflow: hidden;
}

.parts-modal__img {
	position: absolute;
	top: 50%;
	left: 50%;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	/* ←クリックやフォーカスも除外 */
	transition: .5s ease opacity, .5s ease visibility, .5s ease transform;
	transform: translate(-50%, -50%) scale(0.8);
	max-width: 90vw;
}

@media only screen and (min-width: 768px) {
	.parts-modal__img {
		max-width: 784px;
	}
}

.parts-modal.is-large {
	max-height: 100vh;
	overflow-y: auto;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding: 40px 20px;
	box-sizing: border-box;
}

.parts-modal__img.is-show {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	/* 表示時にのみイベント有効化 */
	transform: translate(-50%, -50%) scale(1);
}

.parts-modal__img.is-large-vertically {
	position: static;
	transform: none;
	transition: opacity .5s ease, visibility .5s ease;
	/* transform除外 */
	display: inline-block;
	margin: 0 auto;
	max-height: none;
}

.option {
	padding: 40px 0 80px;
	background: url(../../img/alto/bg_othes.png) no-repeat center top/cover;
}

.option .section-headline {
	font-size: 28px;
	color: #333;
	font-weight: bold;
	text-align: center;
	letter-spacing: .15em;
	width: 322px;
	margin: auto;
	border-bottom: 1px solid #ccc;
	padding: 0 0 10px;
}

.option-box {
	padding: 40px 0;
	border-bottom: 1px solid rgba(0, 98, 160, 0.5);
}

.option-box__title {
	font-size: 18px;
	font-weight: bold;
	color: var(--cl-blue);
	text-align: center;
	margin: 0 0 20px;
	border: none;
}

.option-inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.option-inner .option-img {
	margin: 0 33px 0 0;
}

.option-inner .option-img.filter {
	min-width: 360px;
}

.option-inner .option-img.aircoorde {
	min-width: 432px;
}

.option-data {
	padding: 0 80px 0 0;
}

.option-data__text {
	font-size: 14px;
	margin: 0 0 16px;
	text-align: left;
}

.option-data__text--strong {
	text-align: left;
	vertical-align: top;
	font-size: 18px;
	font-weight: bold;
	color: var(--cl-blue);
	margin: 0 0 15px;
}

.option-data .option-data__text--strong {
	color: #305CCD;
}

.option-data__text--strong__notes {
	font-size: 10px;
	display: inline-block;
	vertical-align: top;
	padding: 3px 0 0;
}

.option-data__pm25 {
	margin: 0 0 7px;
}

.option-data__pm25 img {
	max-width: 30%;
}

.option-data__item-name {
	font-size: 19px;
	font-weight: bold;
	text-align: left;
	margin: 0;
}

.option-data__item-name--ja {
	font-size: 10px;
	letter-spacing: .45em;
	display: block;
	line-height: .5;
}

.option-data__price {
	font-size: 16px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	margin: 0 0 10px;
}

.option-data__price--value {
	font-size: 24px;
	font-weight: bold;
}

.option-data__price--value__cautions {
	font-size: 12px;
	color: #f00;
	border: 1px solid #f00;
	padding: 6px;
	margin: 0 0 0 24px;
}

.option-data__notes {
	font-size: 12px;
	text-align: left;
	text-indent: -2.5em;
	padding: 0 0 0 2.5em;
	margin: 0;
}

.option-data__notes.type-02 {
	text-indent: 0;
	padding: 0 0 0 0;
}

.option-data__logo {
	margin: 0 0 10px;
}

.option-data__link {
	margin: 20px 0 0;
}

.option-data__link a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 310px;
	height: 38px;
	font-size: 19px;
	font-weight: bold;
	color: #233f93;
	background: #fff;
	border: 1px solid #233f93;
	-webkit-transition: .3s ease all;
	transition: .3s ease all;
}

.option-data__link a:hover {
	background: #233f93;
	color: #fff;
}

.option-banner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0;
	padding: 40px 0;
	border-bottom: 1px solid rgba(0, 98, 160, 0.5);
}

.option-banner a {
	-webkit-transition: .3s ease all;
	transition: .3s ease all;
}

.option-banner a:hover {
	opacity: .8;
}

.catalog {
	padding: 0 0 80px;
}

.catalog-inner {
	padding: 0 40px;
}

.catalog .section-headline {
	width: 100%;
	height: 50px;
	border-radius: 25px;
	border: 2px solid var(--cl-skyblue);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	font-size: 19px;
	font-weight: bold;
	color: var(--cl-skyblue);
	margin: 0 0 17px;
}

.catalog-list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	margin: 0 0 28px;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1rem;
}

.catalog-list__item {
	flex-basis: calc(50% - 1rem);
}

.catalog-list__item a {
	-webkit-transition: .3s ease all;
	transition: .3s ease all;
}

.catalog-list__item img {
	width: 100%;
}

.catalog-list__item a:hover {
	opacity: .8;
}

.catalog-notes__list--item {
	font-size: 12px;
	margin-bottom: 6px;
	line-height: 140%;
}

.catalog-notes__list {
	text-indent: -0.7em;
	padding-left: 0.7em;
}

figure {
	margin: 0 0 0;
}

.pconly {
	display: block;
}

.sponly {
	display: none;
}

nav ul.global_nav li a {
	font-size: 11px;
}

nav ul.global_nav li.small a {
	font-size: 10px;
}

body {
	font-family: "Noto Sans Japanese";
	font-weight: 400;
}

#header2 {
	display: none;
}

ul li img {
	margin-top: 8px;
}

.box_flex {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
}

.box_flex img {
	width: 100%;
	display: block;
	cursor: pointer;
	transition: transform 1s ease;
	height: 100%;
	object-fit: cover;
}

.box_flex img:hover {
	transform: scale(1.2);
}

.scrollTop {
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 999;
	display: none;
	cursor: pointer;
}

.scrollTop__link {
	display: block;
}

.scrollTop__img {
	transition: all .3s;
}

.scrollTop__link:hover .scrollTop__img {
	opacity: .8;
	transition: .3s;
}

.scrollTop img {
	display: block;
	margin-bottom: 1px;
}

.scrollTop {
	transition: all 1s;
}

figure.snip1212 {
	position: relative;
	overflow: hidden;
	margin: 0;
	display: flex;
	justify-content: left;
	flex-wrap: wrap;
}

figure.snip1212 * {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
	overflow: hidden;
}

figure.snip1212 img {
	max-width: 100%;
	object-fit: cover;
}

figure.snip1212 figcaption {
	pointer-events: none;
	width: 100%;
}

figure.snip1212 p {
	margin: 0;
	width: 100%;
	padding: 10px 20px;
}

figure.snip1212 p {
	text-align: left;
	bottom: 0;
	font-size: 95%;
	font-weight: 500;
	padding: 10px 0;
}

.modal {
	font-family: -apple-system, BlinkMacSystemFont, avenir next, avenir, helvetica neue, helvetica, ubuntu, roboto, noto, segoe ui, arial, sans-serif;
}

.modal__content {
	margin-top: 2rem;
	margin-bottom: 2rem;
	line-height: 1.5;
	color: rgba(0, 0, 0, .8);
}

@media (max-width: 767px) {
	.pconly {
		display: none;
	}

	.sponly {
		display: block;
	}

	.scrollTop {
		bottom: 0;
		top: auto;
	}

	.scrollTop img {
		width: 59px;
	}

	.scrollTop {
		right: 0;
	}

	.scrollTop:hover {
		transform: translate(-123px, 0px);
	}

	#header2 {
		display: block;
		margin-top: 50px;
	}

	.hero {
		padding: 0;
	}

	.contents main .hero h2 {
		padding: 0 20px;
	}

	.text-color {
		color: #333333;
	}

	.sponly {
		font-size: 14px;
		text-align: left;
	}

	.parts-modal__img {
		max-width: 100%;
	}

	.parts-modal {
		box-sizing: border-box;
		width: 100%;
		margin-bottom: 10px;
		padding: 35px;
		transform: translate3d(0px, 0px, 0px);
		color: rgb(43, 46, 56);
		display: block;
	}

	.parts-modal img {
		width: 95%;
	}

	.option {
		padding: 40px 0 40px;
	}

	.option-box2 {
		padding: 40px 0;
		border-bottom: 1px solid rgba(0, 98, 160, 0.5);
	}

	.contents main p.option-banner {
		padding: 0;
		text-align: center;
		border-bottom: none;
	}

	.option-data__logo {
		width: 60%;
		margin: 20px 0;
	}

	.option-data__logo img {
		max-width: 250px;
	}

	.catalog-list__item {
		float: none;
	}

	.catalog-list__item:last-child {
		float: none;
		width: 90%;
		margin: 0 auto;
		margin-bottom: 10px;
	}

	.catalog-notes__list {
		text-indent: -0.7em;
		padding-left: 0.7em;
	}

	.catalog-inner .bt_accessory {
		width: 88%;
		margin-top: 21px;
		font-size: 86%;
		margin: 0px auto 20px;
	}

	.option-inner img {
		width: 100%;
	}

	.option-inner .option-img.aircoorde {
		min-width: 0;
	}

	.option-inner {
		display: initial;
	}

	.option-inner .option-img {
		width: 85%;
		margin: 0 auto;
	}

	.option-data {
		margin: 0 auto;
		width: 90%;
	}

	.background_img {
		background-size: 100%;
	}

	.option-banner img {
		width: 85%;
	}

	.catalog-list__item {
		width: 90%;
		margin: 0 auto;
		margin-bottom: 10px;
	}

	.catalog-list__item img {
		width: 100%;
	}

	.catalog-inner {
		padding: 0;
	}

	.catalog-list {
		display: initial;
	}

	.catalog-notes__list {
		width: 95%;
		margin: 0 auto;
		padding-top: 10px;
	}

	.option-data__text {
		margin-top: 20px;
	}

	.option-data {
		padding: 0;
	}

	.option-data__pm25 {
		width: 100%;
	}

	.option-data__pm25 img {
		max-width: 37.5%;
	}

	.option-data__text--strong {
		font-size: 16px;
	}

	.option-data__item-name {
		font-size: 17px;
	}

	.option-data__notes {
		font-size: 10px;
		text-align: left;
		text-indent: -2.5em;
		padding: 0 0 0 2.5em;
	}

	.fsponly {
		text-align: left;
		margin: 0;
	}

	.option_text {
		font-size: 26px;
		font-weight: bold;
	}

	.option_text2 {
		text-align: left;
		margin: 0;
		font-size: 14px;
	}

	.option-data__notes.type-02 {
		margin: 0;
	}

	.catalog {
		padding: 0;
	}

	.fsponly .fsponly_text {
		margin-top: 0;
		margin-bottom: 0;
	}

	.scrollTop:hover {
		transform: none;
	}

	#header2 {
		padding: 10px;
		background: #ccc;
	}

	#nav-drawer {
		position: relative;
	}

	.nav-unshown {
		display: none;
	}

	#nav-open {
		display: inline-block;
		width: 30px;
		height: 22px;
		vertical-align: middle;
	}

	#nav-open span,
	#nav-open span:before,
	#nav-open span:after {
		position: absolute;
		height: 3px;
		width: 25px;
		border-radius: 3px;
		background: #555;
		display: block;
		content: '';
		cursor: pointer;
	}

	#nav-open span:before {
		bottom: -8px;
	}

	#nav-open span:after {
		bottom: -16px;
	}

	#nav-close {
		display: none;
		position: fixed;
		z-index: 99;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: black;
		opacity: 0;
		transition: .3s ease-in-out;
	}

	#nav-content {
		overflow: auto;
		position: fixed;
		top: 0;
		right: 0;
		z-index: 9999;
		width: 90%;
		max-width: 330px;
		height: 100%;
		background: #000;
		transition: .3s ease-in-out;
		-webkit-transform: translateX(105%);
		transform: translateX(105%);
	}

	#nav-input:checked~#nav-close {
		display: block;
		opacity: .5;
	}

	#nav-input:checked~#nav-content {
		-webkit-transform: translateX(0%);
		transform: translateX(0%);
		box-shadow: 6px 0 25px rgba(0, 0, 0, .15);
	}

	.header-logo-menu {
		padding-top: 4px;
		display: flex;
		flex-direction: row;
	}

	.logo-area {
		text-align: center;
		margin: auto;
	}

	.logo-area img {
		width: 100%;
	}

	div#nav-content ul li {
		text-align: center;
		border-bottom: 1px solid #6f6b6a;
		height: 60px;
		vertical-align: middle;
		position: relative;
	}

	div#nav-content ul li a {
		color: #fff;
		text-decoration: none;
		position: absolute;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		padding-top: 20px;
	}

	figure.snip1212 p {
		font-size: 83%;
		padding: 13px 0px 0px;
	}
}

@media screen and (max-width: 980px) and (min-width: 768px) {
	.cont-inner {
		width: 100%;
		padding: 0 1rem;
	}

	.header-inner {
		width: 100%;
	}

	.alto-logo {
		width: 20%;
		padding: 1rem;
	}

	.header-nav {
		width: 90%;
		max-width: 90%;
		display: flex;
	}

	.header-nav__list {
		flex-basis: 95%;
	}

	.header-nav__list--item a {
		font-size: clamp(12px, 1.5vw, 16px);
	}
}

#modalvideo {
	width: 100%;
}

@media (max-width: 767px) {
	.remodal {
		margin-bottom: 10px;
		padding: 15px 15px 10px;
	}

	.remodal-close:before {
		font-size: 18px;
		line-height: 18px;
		width: 18px;
	}

	.remodal-close {
		width: 20px;
		height: 20px;
	}

	.option-inner .option-img.filter {
		min-width: 80%;
	}
}

.sim_nav {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: 125px 0 67px;
}

.sim_nav>div {
	width: 100%;
	display: flex;
	justify-content: center;
}

@media (max-width: 767px) {
	.sim_nav>div {
		margin: 0 20px;
	}
}

.simulation {
	width: 568px;
	height: 180px;
	background: #BFAC78;
	border-radius: 10px;
	position: relative;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.simulation::before {
	content: '';
	position: absolute;
	top: -11%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 292px;
	height: 122px;
	background: url(../../img/alto/img_3d_simulation_text1.png) no-repeat center center/cover;
}

.simulation h3 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 32px;
	line-height: 100%;
	text-align: center;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;
	color: #FFFFFF;
	border: none;
	padding-bottom: 10px;
	padding: 3rem 0 0 0;
	margin-bottom: -4px;
}

.simulation>div {
	width: 100%;
	color: white;
	text-align: center;
}

.detail_btn {
	width: 100%;
	display: flex;
	justify-content: center;
}

.detail_btn a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	position: relative;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 244px;
	height: 45px;

	font-weight: 700;
	font-size: 16px;
	line-height: 150%;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;

	color: #FFFFFF;

	border: 1px solid white;
	-webkit-transition: .3s ease all;
	transition: .3s ease all;
}

.detail_btn a::after {
	content: '';
	background: url(../../img/alto/icon_arrow_b.png) no-repeat;
	background-size: cover;
	position: absolute;
	width: 5px;
	height: 10px;
	top: 50%;
	right: 20px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	-webkit-transition: .3s ease all;
	transition: .3s ease all;
}

.suzuki_navi {
	background: url(../../img/alto/bg_suzuki_navi.jpg) no-repeat center center/cover;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	position: relative;
	color: white;
	padding: 76px 0 87px;
	overflow: hidden;
}

.suzuki_navi>div {
	width: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}

.suzuki_navi h3 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 32px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;
	color: #E8E179;
	border: none;
}

.suzuki_navi .lead p {
	width: 100%;
	text-align: center;
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 24px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.02em;
	font-feature-settings: 'palt' on;
	color: #FFFFFF;
}

main .suzuki_navi p {
	color: white;
}

main .suzuki_navi p.why_gen {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 32px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;
	color: #E8E179;
	border-bottom: 2px solid #E8E179;
	margin: 77px 0;
}

.suzuki_navi p.about {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 16px;
	line-height: 150%;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;
	color: #FFFFFF;
	margin: 25px 0;
}

@media (max-width: 767px) {
	.suzuki_navi p.about {
		margin: 25px 21px;
		max-width: 378px;
	}
}

.suzuki_navi_img {
	position: relative;
	width: 100%;
	height: 212px;
	display: flex;
	justify-content: center;
	align-items: center;
	overflow: visible;
	margin-top: 48px;
}

.suzuki_navi_img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.suzuki_navi .detail_btn a {
	width: 242px;
	height: 44px;
	transition: all .3s ease;
}

.suzuki_navi .detail_btn a:hover {
	background: #5179bd;
	transition: all .3s ease;
}

.simulation .detail_btn a {
	width: 200px;
	height: 40px;
	transition: all .3s ease;
}

@media (max-width: 767px) {
	.simulation .detail_btn a {
		width: 245px;
	}
}

.simulation .detail_btn a:hover {
	background: #978966;
	transition: all .3s ease;
}

@media (min-width: 768px) {
	.suzuki_navi_img {
		height: 212px;
	}

	.suzuki_navi_img img {
		width: 531px;
		height: 212px;
		object-fit: contain;
	}
}

.suzuki_navi_img::before {
	content: '';
	position: absolute;
	top: -1%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 405px;
	height: 67px;
	background: url(../../img/alto/title_navi.png) no-repeat center center / contain;
	z-index: 2;
	pointer-events: none;
}

@media (max-width: 767px) {
	.suzuki_navi_img::before {
		width: 87%;
		height: auto;
	}
}

.suzuki_navi_list {
	max-width: 708px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
	gap: 85px 40px;
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 14px;
	line-height: 175%;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;
	color: #333333;
}

.suzuki_navi_list>div {
	width: 50%;
	max-width: 334px;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	text-align: left;
	background: #FFFFFF;
	border-radius: 10px;
	position: relative;
	padding: 25px 30px;
}

@media (max-width: 767px) {
	.suzuki_navi_list {
		gap: 84px;
		margin: 0 20px;
	}

	.suzuki_navi_list>div,
	.suzuki_navi_list>div>div.text {
		width: 100%;
		max-width: 100%;
	}

}

main .suzuki_navi_list h5 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 24px;
	line-height: 150%;
	letter-spacing: 0.02em;
	font-feature-settings: 'palt' on;
	color: #5AA2D9;
}

main .suzuki_navi_list p {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 16px;
	line-height: 150%;
	letter-spacing: 0.04em;
	font-feature-settings: 'palt' on;
	color: #333333;
	margin: 1px 0 12px;
}

.suzuki_navi_icon {
	position: absolute;
	top: -85px;
	left: 33px;
	width: 104px;
}

@media (max-width: 767px) {
	.suzuki_navi_icon {
		top: -90px;
	}
}


.suzuki_navi_title {
	width: 100%;
}

.suzuki_navi_list img {
	width: 100%;
	height: auto;
	object-fit: contain;
	padding: 17px 0 0;
}

@media (max-width: 767px) {
	.suzuki_navi_list img {
		max-width: 270px
	}
}

.basic_itembox_outer {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0 31px;
}

@media (max-width: 767px) {
	.basic_itembox_outer {
		gap: 0;
		margin: 16px 20px;
	}

	.basic_itembox_outer figcaption>p {
		font-size: 92%;
		padding: 10px 0 32px;
	}
}

.basic_itembox_outer>.basic_itembox_inner1 {
	width: 32%;
}

.basic_itembox_outer>.basic_itembox_inner2 {
	width: 27%;
}

.basic_itembox_outer>.basic_itembox_inner3 {
	width: 38%;
	margin-top: 26px;
}

@media (max-width: 767px) {
	.basic_itembox_outer>.basic_itembox_inner1 {
		width: 100%;
	}

	.basic_itembox_outer>.basic_itembox_inner2 {
		width: 100%;
	}

	.basic_itembox_outer>.basic_itembox_inner3 {
		width: 100%;
	}
}

#basic>div.basic_itembox_outer>div.basic_itembox_inner2>div>div:nth-child(1) {
	margin-bottom: 15px;
}

#basic>div.basic_itembox_outer>div.basic_itembox_inner2>div>div:nth-child(2)>figure>div>a>img {
	width: 80%;
}

@media (max-width: 767px) {
	#basic>div.basic_itembox_outer>div.basic_itembox_inner2>div>div:nth-child(2)>figure>div>a>img {
		width: 100%;
	}
}

.package {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 61px 0 89px;
	background: url(../../img/alto/bg_package.png) repeat top;
}

.package>div {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.package .section_ttl {
	width: 170px;
	height: 71px;
}

.contents main .package .package_lead p {
	font-style: normal;
	font-weight: 700;
	font-size: 20px;
	line-height: 150%;
	text-align: center;
	letter-spacing: 0.16em;
	font-feature-settings: 'palt' on;
	color: #000000;
}

@media (max-width: 767px) {
	.package .package_lead p {
		margin: 20px 0 0;
	}
}

.package .package_img {
	margin: 30px 12% 0;
}

@media (max-width: 767px) {
	.package .package_img {
		margin: 39px 19px 0;
		width: 100%;
	}
}

.package .package_img img {
	width: 100%;
	height: auto;
	object-fit: contain;
	max-width: 1024px;
}

.fade-up {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease, transform 0.6s ease;
	will-change: opacity, transform;
}

.fade-up.in-view {
	opacity: 1;
	transform: translateY(0);
}