@charset "utf-8";
/*------------------------------------------------------------
	products
------------------------------------------------------------*/
#pagePath {
	margin-bottom: 56px;
}
.content {
	width: 1120px;
}
#main .headLine03 {
	margin-bottom: 65px;
}
#main .ttlImg {
	margin-bottom: 4px;
}
#main .note {
	margin-bottom: 64px;
	font-size: 1rem;
	text-align: right;
}
#main .text {
	margin-bottom: 60px;
	font-size: 1.6rem;
	font-weight: 500;
	text-align: center;
	line-height: 2;
}
#main .sec01 {
	padding-bottom: 78px;
}
#main .sec02 {
	padding: 65px 0 76px;
	position: relative;
}
#main .sec02::after,
#main .sec03::after {
	position: absolute;
	top: 0;
	left: -40px;
	right: -40px;
	width: 1200px;
	height: 1px;
	background-color: #d6d6d6;
	content: "";
}
#main .sec02 .comProductList li a .pho {
	margin-bottom: 9px;
}
#main .sec02 .comProductList li a .txtBox .ttl {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1.83;
}
#main .sec03 {
	padding: 65px 0 0;
	position: relative;
}
#main .sec03 .comProductList li a .pho {
	position: relative;
}
#main .sec03 .comProductList li a .pho::before {
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	position: absolute;
	top: 0;
	left: 0;
	border: 2px solid #e50012;
	content: "";
	transition: 0.3s;
	opacity: 0;
	z-index: 1;
}
#main .comRelateBox .content {
	width: 1200px;
}
@media all and (min-width: 1025px) {
	#main .sec03 .comProductList li a:hover .pho img {
		-webkit-transform: scale(1);
		-moz-transform: scale(1);
		-ms-transform: scale(1);
		-o-transform: scale(1);
		transform: scale(1);
	}
	#main .sec03 .comProductList li a:hover .pho::before {
		opacity: 1;
	}
}
@media all and (max-width: 1024px) {
	.content {
		width: auto;
	}
	#main .headLine03 {
		margin-bottom: 50px;
	}
	#main .note {
		margin-bottom: 30px;
		text-align: left;
	}
	#main .text {
		margin-bottom: 40px;
		font-size: 1.4rem;
	}
	#main .sec01 {
		padding-bottom: 50px;
	}
	#main .sec02 {
		padding: 50px 0;
	}
	#main .sec02::after,
	#main .sec03::after {
		left: 0;
		right: 0;
		width: 100%;
	}
	#main .sec02 .comProductList li a .txtBox .ttl {
		display: block;
	}
	#main .sec03 {
		padding: 50px 0;
	}
	#main .comRelateBox .content {
		width: auto;
	}
}

/*------------------------------------------------------------
	products_details
------------------------------------------------------------*/
.mainVisual {
	margin-bottom: 94px;
	position: relative;
}
.mainVisual::before {
	width: 100%;
	height: calc(100% - 200px);
	position: absolute;
	left: 0;
	bottom: 30px;
	background-color: #f5f5f5;
	content: "";
	z-index: -1;
}
.mainVisual .image {
	margin-bottom: 27px;
}
.mainVisual .image img {
	width: 100%;
}
.mainVisual .title {
	margin-bottom: 38px;
	text-align: center;
	font-size: 3rem;
	line-height: 1.66;
	font-weight: bold;
}
.mainVisual .listUl {
	margin: -12px -12px 65px;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.mainVisual .listUl li {
	margin: 12px 6px 0;
	width: 190px;
	font-size: 2.6rem;
	border-radius: 4px;
	font-weight: bold;
	overflow: hidden;
	background-color: #fff;
}
.mainVisual .listUl .ttl {
	color: #fff;
	font-size: 1.5rem;
	background-color: #717171;
	text-align: center;
	line-height: 1.4;
	padding: 3px 5px 6px;
}
.mainVisual .listUl .txt {
	padding: 5px 5px 12px;
	min-height: 90px;
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
}
.mainVisual .icon-new {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	margin-bottom: 20px;
}
.mainVisual .icon-new span {
	width: fit-content;
	padding: 6px 24px 8px;
	background: rgb(254, 94, 49);
	background: linear-gradient(90deg, rgba(254, 94, 49, 1) 30%, rgba(233, 13, 22, 1) 100%);
	color: #ffffff;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.25;
	letter-spacing: 0.1em;
}
.mainVisual .icon-new::after {
	content: "";
	height: 1px;
	display: block;
	background: rgb(254, 94, 49);
	background: linear-gradient(90deg, rgba(254, 94, 49, 1) 30%, rgba(233, 13, 22, 1) 100%);
}
@media all and (max-width: 768px) {
	.mainVisual .icon-new {
		grid-template-columns: auto;
		transform: translateY(-50%);
	}
	.mainVisual .icon-new::after {
		display: none;
	}
}
/* featuresBox */
#main .featuresBox .headLine03 {
	margin-bottom: 71px;
}
.featuresBox .imgBox {
	margin-bottom: 75px;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}
.featuresBox .imgBox:last-child {
	margin-bottom: 0;
}
.featuresBox .imgBox .textBox {
	width: 800px;
	min-height: 320px;
	padding: 47px 73px 20px;
	border: 2px solid #ffb49d;
	position: relative;
	box-sizing: border-box;
}
.featuresBox .imgBox .innerBox {
	max-width: 520px;
}
.featuresBox .imgBox .photo {
	width: 550px;
	margin: 0 0 -40px -150px;
	flex-shrink: 0;
	position: relative;
	z-index: 10;
}
.featuresBox .imgBox p {
	line-height: 2;
	text-align: justify;
}
.featuresBox .imgBox .title {
	text-align: center;
	font-size: 2.5rem;
	border-bottom: 1px solid rgba(255, 57, 20, 0.2);
	padding-bottom: 11px;
	margin-bottom: 16px;
	line-height: 1.5;
}
.featuresBox .imgBox .num {
	position: absolute;
	min-width: 92px;
	top: -24px;
	left: 18px;
	color: #e50012;
	font-size: 5rem;
	font-family: "Poppins", sans-serif;
	background-color: #fff;
	padding: 0 12px 8px;
	line-height: 1;
	letter-spacing: 0.05em;
	text-align: center;
	box-sizing: border-box;
}
.featuresBox .imgBox .num::before {
	margin-left: -15px;
	width: 30px;
	height: 2px;
	position: absolute;
	bottom: 0;
	left: 50%;
	background-color: #fd865b;
	content: "";
}
.featuresBox .imgBox .banner {
	margin: 15px -1px 36px;
}
.featuresBox .imgBox .banner a {
	position: relative;
	display: block;
}
.featuresBox .imgBox .banner a::before {
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	position: absolute;
	top: 0;
	left: 0;
	border: 2px solid #e50012;
	content: "";
	transition: 0.3s;
	opacity: 0;
	z-index: 1;
}
.featuresBox .imgBox.right {
	padding-top: 40px;
	align-items: flex-start;
}
.featuresBox .imgBox.right .textBox {
	display: flex;
	justify-content: flex-end;
	order: 3;
}
.featuresBox .imgBox.right .photo {
	margin: -40px -150px 0 0;
}
.featuresBox .imgBox.right .num {
	left: auto;
	right: 18px;
}
.featuresBox .imgBox .notes {
	margin-top: 8px;
	font-size: 1.3rem;
	padding-left: 1em;
	text-indent: -1em;
}
.featuresBox {
	margin-bottom: 130px;
}
/* movieBox */
.movieBox {
	margin-bottom: 95px;
}

/* caseBox */
.caseBox {
	margin-bottom: 77px;
}
.caseBox .comLinkList {
	margin-bottom: 0;
}

/* pickBox */
.pickBox .comLinkList {
	margin-bottom: 53px;
}

/* speedBox */
.speedBox {
	margin-bottom: 94px;
}

/* specificationsBox */
.specificationsBox .comTableBox {
	margin-bottom: 100px;
}
.specificationsBox {
	margin-bottom: 114px;
}
@media all and (min-width: 1025px) {
	.detailBox .content {
		width: 1200px;
	}
	.detailBox .comLinkList {
		margin-top: -42px;
	}
	.detailBox .comLinkList li {
		margin-top: 42px;
	}
	.speedBox.content,
	.specificationsBox.content {
		width: 1050px;
	}
	.productBox.content {
		width: 1120px;
	}
	/*
	.featuresBox .imgBox .banner a:hover {
		opacity: 0.7;
	}
	*/
	.featuresBox .imgBox .banner a:hover::before {
		opacity: 1;
	}
}
@media all and (max-width: 1024px) {
	.mainVisual .image {
		margin: 0 -20px 20px;
	}
	.mainVisual .title {
		margin-bottom: 15px;
		font-size: 2.2rem;
		line-height: 1.4;
	}
	.mainVisual .listUl {
		margin-bottom: 30px;
		justify-content: flex-start;
	}
	.mainVisual .listUl li {
		margin: 12px 4px 0;
		font-size: 1.8rem;
		width: calc(33.33% - 8px);
	}
	.mainVisual .listUl .txt {
		min-height: 70px;
	}
	.mainVisual .listUl .ttl {
		padding: 5px 5px 5px;
		font-size: 1.3rem;
	}
	.mainVisual::before {
		height: calc(100% - 30px);
	}
	.featuresBox .imgBox {
		display: block;
	}
	.featuresBox .imgBox .textBox {
		margin-bottom: 15px;
		width: auto;
		min-height: 0;
		padding: 30px 20px 20px;
	}
	.featuresBox .imgBox .photo {
		width: auto;
		margin: 0;
	}
	.featuresBox .imgBox .photo img {
		width: 100%;
	}
	.featuresBox .imgBox .title {
		font-size: 1.8rem;
	}
	.featuresBox .imgBox .num {
		min-width: 56px;
		top: -24px;
		left: 15px;
		font-size: 3.5rem;
		padding: 0 12px 8px;
	}
	.featuresBox .imgBox .banner {
		margin: 15px 0 0;
		text-align: center;
	}
	.featuresBox .imgBox .banner img {
		width: 100%;
	}
	.featuresBox .imgBox.right .photo {
		margin: 0;
	}
	.featuresBox .imgBox.right .textBox {
		display: block;
	}
	.featuresBox .imgBox .innerBox {
		max-width: inherit;
	}
	.specificationsBox .comTableBox {
		margin-bottom: 50px;
	}
	.specificationsBox {
		margin-bottom: 70px;
	}
	.featuresBox .imgBox.right {
		padding-top: 0;
	}
	.featuresBox {
		margin-bottom: 70px;
	}
}
@media all and (max-width: 374px) {
}
/*------------------------------------------------------------
	footer-fixed-navi(for Products)
------------------------------------------------------------*/
#footer-contact-wrap .footer-contact-block {
	background: url("/common/images/products/footer-contact-block.png") 0 0 no-repeat;
	-webkit-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}
#footer-contact-wrap .footer-contact-block .content {
	width: 1200px;
}
#footer-contact-wrap .footer-contact-block.is-sticky {
	position: fixed;
	z-index: 1;
	bottom: 0;
	left: 0;
	width: 100%;
}
#footer-contact-wrap .footer-contact-block.is-hide {
	visibility: hidden;
	opacity: 0;
	z-index: 0;
}
@media (max-width: 1024px) {
	#footer-contact-wrap {
		display: none;
	}
}
@media (min-width: 1025px) {
	#footer-contact-wrap {
		display: block;
		height: 120px;
	}
	#footer-contact-wrap > .footer-contact-block {
		position: static;
	}
	#footer-contact-wrap > .footer-contact-block.fix {
		position: fixed;
		z-index: 11;
		width: 100%;
		bottom: 0;
		left: 0;
	}
	#footer-contact-wrap > .footer-contact-block .footer-contact-block-menu {
		display: flex;
		align-items: center;
		justify-content: space-between;
		height: 120px;
	}
	#footer-contact-wrap > .footer-contact-block .footer-contact-block-menu ul {
		flex-basis: 910px;
		display: flex;
		justify-content: space-between;
	}
	#footer-contact-wrap > .footer-contact-block .footer-contact-block-menu ul li a {
		transition: 0.3s;
	}
	#footer-contact-wrap > .footer-contact-block .footer-contact-block-menu ul li a:hover {
		opacity: 0.7;
	}
	#footer-contact-wrap .footer-contact-block .content .switch {
		display: none;
	}
	#footer-contact-wrap > .footer-contact-block.fix.close {
		bottom: -120px;
	}
	#footer-contact-wrap .footer-contact-block.fix .content .switch {
		display: flex;
		justify-content: center;
		align-items: center;
		position: absolute;
		width: 284px;
		top: -45px;
		/*background: #7F7F7F;*/
		background: url("/common/images/common/footer-switch-bg.png") no-repeat;
		border-radius: 8px 8px 0 0;
		text-align: center;
	}
	#footer-contact-wrap .footer-contact-block.fix .content .switch p {
		position: relative;
		width: 100%;
		height: 45px;
		line-height: 2.5;
		letter-spacing: 0.05em;
		text-indent: -0.05em;
		color: #fff;
		cursor: pointer;
		transition: 0.5s;
	}
	#footer-contact-wrap .footer-contact-block.fix .content .switch p:hover {
		opacity: 0.8;
	}
	#footer-contact-wrap .footer-contact-block.fix .content .switch p::before {
		position: absolute;
		top: 18px;
		left: 95px;
		content: "";
		display: inline-block;
		border-bottom: solid 1px #fff;
		border-right: solid 1px #fff;
		width: 5px;
		height: 5px;
		transform: rotate(45deg);
	}
	#footer-contact-wrap .footer-contact-block.fix.close .content .switch p::before {
		top: 22px;
		border-top: solid 1px #fff;
		border-left: solid 1px #fff;
		border-bottom: unset;
		border-right: unset;
	}
}
/*------------------------------------------------------------
	Column Box
------------------------------------------------------------*/
.productColumn {
	display: grid;
	justify-content: center;
	align-items: start;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 20px 40px;
}
.productColumn figure {
	margin: 0;
	overflow: hidden;
}
.productColumn .-border {
	border: #dbdbdb solid 1px;
}
.productColumn .title {
	margin-top: 10px;
	font-size: 1.7rem;
	font-weight: 600;
	text-align: center;
}
.productColumn .description {
	margin-top: 8px;
	line-height: 1.65;
}
.productColumn > li > a figure {
	overflow: hidden;
}
.productColumn > li > a figure img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	transition: transform 0.25s ease-in-out;
}
.productColumn > li > a:hover figure img {
	transform: scale(1.2);
}
.productColumn > li > a:hover .title {
	color: #e50012;
	text-decoration: underline;
}
/*------------------------------------------------------------
	Hero Image
------------------------------------------------------------*/
.productHero {
	width: 100%;
	overflow: hidden;
	aspect-ratio: 3/1;
	margin-bottom: 96px;
}
.productHero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (max-width: 1024px) {
	.productHero {
		aspect-ratio: 39 / 43;
		margin-bottom: 64px;
	}
}
/*------------------------------------------------------------
	Box
------------------------------------------------------------*/
.productBox--white {
	background-color: #ffffff;
	border-radius: 6px;
	padding: 48px 32px 32px 32px;
}
.productBox--white a {
	color: #2396cf;
	display: block;
	width: fit-content;
	margin: 0 auto;
	text-decoration: underline;
	font-weight: 700;
}
.productBox__text {
	text-align: center;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 2;
}
.productBox--white a:hover {
	text-decoration: none;
}
@media (max-width: 1024px) {
	.productBox__text {
		text-align: left;
		font-size: 1.4rem;
	}
}
/*------------------------------------------------------------
	Movie
------------------------------------------------------------*/
.comMovieList.movie-single li {
	margin: 20px 0 0 0;
}
.comMovieList.movie-single li .phoBox .pho {
	padding-bottom: 56.25%;
}
@media (min-width: 1025px) {
	.comMovieList.movie-single li .phoBox .pho .youtubeLink {
		height: auto;
		aspect-ratio: 16/9;
	}
	.comMovieList.movie-single li .phoBox .pho .youtubeLink img {
		height: 100%;
		width: 100%;
		object-fit: cover;
	}
}
/*------------------------------------------------------------
	Banner
------------------------------------------------------------*/
.productBanner {
	margin: 0 auto;
	display: block;
	width: fit-content;
	position: relative;
}
.productBanner::before {
	width: calc(100% - 2px);
	height: calc(100% - 2px);
	position: absolute;
	top: 0;
	left: 0;
	border: 2px solid #e50012;
	content: "";
	transition: 0.3s;
	opacity: 0;
}
.productBanner:hover::before {
	opacity: 1;
}
.productBanner + .comProductList{
	margin-top: 0;
}
@media (max-width: 1024px) {
	.productBanner + .comProductList{
		margin-top: 48px;
	}
}
/*------------------------------------------------------------
	お問い合わせフォームがある場合
------------------------------------------------------------*/
.pageTitle {
	margin-bottom: 12px;
	padding: 0 0 8px;
	height: 130px;
	background: url(/common/images/common/page_title_bg.jpg) no-repeat center center / cover;
}
#gFooter {
	padding: 80px 100px 75px;
	background-color: #656565;
}
#gFooter .fBox {
	justify-content: space-between;
}
#gFooter .navBox address {
	color: #fff;
}
@media (max-width: 1024px) {
	#gFooter {
		padding: 40px 40px 50px;
	}
}
/*------------------------------------------------------------
	Margin
------------------------------------------------------------*/
.mb0 {
	margin-bottom: 0px !important;
}
.mb5 {
	margin-bottom: 5px !important;
}
.mb10 {
	margin-bottom: 10px !important;
}
.mb15 {
	margin-bottom: 15px !important;
}
.mb20 {
	margin-bottom: 20px !important;
}
.mb25 {
	margin-bottom: 25px !important;
}
.mb30 {
	margin-bottom: 30px !important;
}
.mb35 {
	margin-bottom: 35px !important;
}
.mb40 {
	margin-bottom: 40px !important;
}
.mb45 {
	margin-bottom: 45px !important;
}
.mb50 {
	margin-bottom: 50px !important;
}
.mb60 {
	margin-bottom: 60px !important;
}
.mb80 {
	margin-bottom: 80px !important;
}
.mt0 {
	margin-top: 0px !important;
}
.mt5 {
	margin-top: 5px !important;
}
.mt10 {
	margin-top: 10px !important;
}
.mt15 {
	margin-top: 15px !important;
}
.mt20 {
	margin-top: 20px !important;
}
.mt25 {
	margin-top: 25px !important;
}
.mt30 {
	margin-top: 30px !important;
}
.mt35 {
	margin-top: 35px !important;
}
.mt40 {
	margin-top: 40px !important;
}
.mt45 {
	margin-top: 45px !important;
}
.mt50 {
	margin-top: 50px !important;
}
.mt60 {
	margin-top: 60px !important;
}
.mt80 {
	margin-top: 80px !important;
}
/*------------------------------------------------------------
	Padding
------------------------------------------------------------*/
.pb0 {
	padding-bottom: 0px !important;
}
.pb5 {
	padding-bottom: 5px !important;
}
.pb10 {
	padding-bottom: 10px !important;
}
.pb15 {
	padding-bottom: 15px !important;
}
.pb20 {
	padding-bottom: 20px !important;
}
.pb25 {
	padding-bottom: 25px !important;
}
.pb30 {
	padding-bottom: 30px !important;
}
.pb35 {
	padding-bottom: 35px !important;
}
.pb40 {
	padding-bottom: 40px !important;
}
.pb45 {
	padding-bottom: 45px !important;
}
.pb50 {
	padding-bottom: 50px !important;
}
.pb80 {
	padding-bottom: 80px !important;
}
.pb100 {
	padding-bottom: 100px !important;
}
