@charset "utf-8";

/* ------------------------------------------------------------------------ */

/*  詳細ページ

/* ------------------------------------------------------------------------ */
.caseHeader{
	background: #F3F3F3;
}
.caseHeader #crumb{
	position: inherit;
	max-width: 1320px;
	width: calc(100% - 32px);
	margin: 0 auto;
	padding-top: 10px;
}
.caseHeader .inner{
	max-width: 1208px;
	width: calc(100% - 32px);
	margin: 0 auto;
	padding: 30px 0 60px;
}

.caseHeader .inner > .ttlBox{
	width: 50%;
	text-align: left;
}
.caseHeader .inner > .rightBox{
	max-width: 580px;
	width: 48%;
}

.caseHeader .inner > .rightBox video{
	width: 100%;
	height: 100%;
}

.caseHeader .ttl{
	font-size: 2.8rem;
	text-align: left;
}

.caseHeader .companyBox {
	justify-content: flex-start;
	align-items: center;
	margin-top: 22px;
}
.caseHeader .companyBox figure{
	max-width: 240px;
}
.caseHeader .companyBox p{
	text-align: left;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.3;
}
.caseHeader .companyBox figure + p{
	margin-left: 16px;
}
.caseHeader .companyBox p a{
	font-size: 1.4rem;
	color: #131313;
	font-weight: 400;
	text-decoration: none;
    display: inline;
    position: relative;
    background: linear-gradient(#2D2D2D, #2D2D2D) 0 100% / 0 1px no-repeat;
    transition: background .4s;
}
.caseHeader .companyBox p a:hover{
    background-size: 100% 1px;
}
.caseHeader .freeTxt{
	text-align: left;
	margin-top: 12px;
	font-size: 1.4rem;
}

.caseHeader .btnBasic{
	padding: 17px 40px 18.44px 20px;
	line-height: 1.286;
	max-width: 360px;
	font-size: 1.6rem;
	margin-top: 32px;
	text-align: left;
}

.caseHeader #kvSlider{
	position: relative;
	
}
.caseHeader #kvSlider .slick-track img{
    object-fit: cover;
    object-position: center center;
    aspect-ratio: 580 / 360;
}
.caseHeader #kvSlider .slick-arrow{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	background: rgba(51,51,51,0.8);
	box-shadow: none;
	border: none;
	border-radius: 0;
	width: 40px;
	height: 40px;
	color: #fff;
	cursor: pointer;
}
.caseHeader #kvSlider .slick-arrow.slick-prev{
	left: 0;
}
.caseHeader #kvSlider .slick-arrow.slick-next{
	right: 0;
}
.caseHeader #kvSlider .slick-dots{
	position: absolute;
	top: calc(100% + 16px);
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	justify-content: center;
	align-items: center;
}
.caseHeader #kvSlider .slick-dots > li{
	width: 10px;
	height: 10px;
}
.caseHeader #kvSlider .slick-dots > li + li{
	margin-left: 24px;
}
.caseHeader #kvSlider .slick-dots button{
	color: transparent;
	padding: 0;
	border: none;
	background: rgba(51,51,51,0.2);
	border-radius: 50%;
	width: 100%;
	height: 100%;
}
.caseHeader #kvSlider .slick-dots .slick-active button{
	background: #A2000D;
}
.caseHeader #kvSlider .slick-dots button::before{
	content: "";
	display: block;
	cursor: pointer;
	width: 100%;
	height: 100%;
}

#contentsBlock #sec_detail > .inner{
	padding-top: 0;
	max-width: 1040px;
}
#sec_detail .container{
	margin-top: 88px;
	text-align: left;
	font-size: 1.6rem;
}

#sec_detail .container p,
#sec_detail .container img,
#sec_detail .container h2{
	margin-top: 32px;
}

#sec_detail .container h2{
	font-size: 2.8rem;
	letter-spacing: 0.04em;
}
#sec_detail .container p{
	font-weight: 400;
	font-size: 1.8rem;
	line-height: 2;
	letter-spacing: 0.04em;
}
#sec_detail .container ul,
#sec_detail .container ol{
	list-style-position: inside;
	margin-top: 16px;
}
#sec_detail .container ul li,
#sec_detail .container ol li{
	font-size: 1.8rem;
}
#sec_detail .container ul li + li,
#sec_detail .container ol li + li{
	margin-top: 0.5em;
}
#sec_detail .container ul li{
	list-style-type: disc;
	padding-left: 1.5em;
	text-indent: -1.5em;
}
#sec_detail .container ol li{
	list-style-type: decimal;
	padding-left: 1em;
	text-indent: -1em;
}

#sec_detail .mvBox iframe,
#sec_detail .mvBox video{
    aspect-ratio: 16 / 9;
    width: 100%;
    height: auto;
    max-width: 850px;
    display: block;
    margin: auto;
}

#sec_detail .aboutContainer{
	border: solid 1px #DBDBDB;
	padding: 40px;
	margin-top: 88px;
}
#sec_detail .aboutContainer + .aboutContainer{
	margin-top: 66px;
}

#sec_detail .aboutContainer h2{
	margin-top: 0;
}

#sec_detail .aboutContainer ul.ulStyle01 li{
	list-style-type: none;
	text-indent: -1em;
	padding-left: 1em;
}
#sec_detail .aboutContainer .linkBtn{
	margin-top: 24px;
}
#sec_detail .aboutContainer .btnBasic{
	font-size: 1.6rem;
	padding: 16px 35px 16px 20px;
	line-height: 1;
	max-width: 320px;
	text-align: left;
}
#sec_detail .caseStudiese{
	width: 100%;
}
#sec_detail .aboutContainer .case-hd01{
	font-size: 2.2rem;
	margin-bottom: 32px;
	text-align: left;
}
#sec_detail .caseStudiese .lead{
	font-size: 1.8rem;
	font-weight: 700;
}
#sec_detail .caseStudiese .documentImg{
	background: #F3F3F3;
	text-align: center;
	padding: 40px;
	max-width: 440px;
	width: 50%;
	margin-left: 20px;
}
#sec_detail .caseStudiese .documentImg img{
	margin-top: 0;
}
#sec_detail .aboutContainer.aboutProduct{
	padding-bottom: 8px;
}
#sec_detail .aboutContainer.aboutProduct ul{
	align-items: flex-start;
	flex-wrap: wrap;
}
#sec_detail .aboutContainer.aboutProduct li{
	display: flex;
	justify-content: space-between;
	width: 48%;
	max-width: 456px;
	margin-bottom: 32px;
}
#sec_detail .aboutContainer.aboutProduct li figure{
	width: 180px;
	flex-shrink: 0;
	margin-right: 16px;
}
#sec_detail .aboutContainer.aboutProduct li figure img{
    object-fit: cover;
    object-position: center center;
    aspect-ratio: 180 / 120;
}
#sec_detail .aboutContainer.aboutProduct li .txtBox{
	text-align: left;
	font-weight: 400;
}
#sec_detail .aboutContainer.aboutProduct li .txtBox h3{
	font-size: 1.8rem;
	margin-bottom: 8px;
}

#sec_detail .aboutContainer.aboutProduct li .txtBox h3 .genericTerm{
	font-size: 1.2rem;
}

#sec_detail .aboutContainer.aboutProduct li .txtBox .linkBtn .btnBasic{
	padding: 16px 35px 16px 20px;
	line-height: 1;
}

#denefits{
	justify-content: flex-start;
}
#denefits p{
	width: 124px;
	height: 124px;
	background: #A2000D;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 1.8rem;
	font-weight: 700;
	border-radius: 50%;
	margin-right: 40px;
	flex-shrink: 0;
}
#denefits ul li{
	color: #A2000D;
	font-size: 2rem;
	font-weight: 500;
	position: relative;
	padding-left: calc(1em + 8px);
}
#denefits ul li::before{
	content: "";
	display: inline-block;
	width: 20px;
	height: 20px;
	background: url("/common/img/icon/icon_check.svg") no-repeat center / contain;
	position: absolute;
	top: 5px;
	left: 0;
}
#denefits ul li + li{
	margin-top: 5px;
}

#sec_detail #denefits.container ul,
#sec_detail #denefits.container p{
	margin-top: 0;
}


@media screen and (max-width: 1023px){
	#sec_detail .aboutContainer .case-hd01{
		margin-bottom: 24px;
	}
	#sec_detail .aboutContainer.aboutProduct{
		padding-bottom: 20px;
	}
	#sec_detail .aboutContainer.aboutProduct ul{
		display: block;
	}
	#sec_detail .aboutContainer.aboutProduct li + li{
		margin-top: 48px;
	}
	#sec_detail .aboutContainer.aboutProduct li{
		max-width: inherit;
		width: 100%;
		margin-bottom: 0;
	}
}
@media screen and (max-width: 768px){
	.caseHeader .inner{
		display: block;
	}
	.caseHeader .companyBox{
		flex-direction: column;
		justify-content: flex-start;
		align-items: flex-start;
	}
	.caseHeader .companyBox figure + p{
		margin: 8px 0 0;
	}
	.caseHeader .inner > .ttlBox{
		width: 100%;
	}
	.caseHeader .inner > .rightBox{
		margin: 16px auto 0;
		width: 100%;
	}
	.caseHeader #kvSlider{
		margin-bottom: 30px;
	}
	#sec_detail .caseStudiese{
		flex-direction: column-reverse;
	}
	#sec_detail .caseStudiese .documentImg{
		margin-left: 0;
		margin-bottom: 32px;
		width: 100%;
	}
	#sec_detail .caseStudiese .txtBox{
		width: 100%;
	}
}
@media screen and (max-width: 767px){
	.caseHeader .ttl{
		font-size: 2.4rem;
	}
	#sec_detail .container{
		margin-top: 80px;
	}
	#sec_detail .container h2{
		font-size: 2rem;
	}
	#sec_detail .container p,
	#sec_detail .container ul li,
	#sec_detail .container ol li{
		font-size: 1.6rem;
	}

	#sec_detail .aboutContainer{
		padding: 20px;
		margin-top: 80px;
	}
	#sec_detail .aboutContainer + .aboutContainer{
		margin-top: 80px;
	}
	#sec_detail .aboutContainer .case-hd01{
		font-size: 1.8rem;
	}
	#sec_detail .caseStudiese .documentImg{
		padding: 24.6px 27px 27px 20px;
	}
	#sec_detail .aboutContainer.aboutProduct li{
		display: block;
	}
	#sec_detail .aboutContainer.aboutProduct li figure{
		width: 100%;
		margin: 0 auto 8px;
	}
	#sec_detail .aboutContainer.aboutProduct li .txtBox{
		font-size: 1.6rem;
	}
	#sec_detail .aboutContainer.aboutProduct li figure img{
		width: 100%;
		height: 100%;
		object-fit: cover;
	}

	#denefits{
		display: block;
	}
	#denefits p{
		margin: 0 auto 24px;
	}
	#denefits.container p{
		font-size: 1.8rem;
		font-weight: 700;
	}
	#denefits ul li{
		font-size: 1.8rem;
	}
}


/* ------------------------------------------------------------------------ */

/*  その他の導入事例

/* ------------------------------------------------------------------------ */

#sec_aboutCase{
	background: #F3F3F3;
}
#sec_aboutCase ul{
	margin-top: 68px;
	justify-content: flex-start;
	align-items: flex-start;
}
#sec_aboutCase ul li{
	max-width: 376px;
    width: calc((100% - 80px) / 3);
}
#sec_aboutCase ul li + li{
	margin-left: 40px;
}

#sec_aboutCase ul li a{
	text-decoration: none;
	color: #131313;
	text-align: left;
}

#sec_aboutCase ul li a h3{
	display: flex;
	justify-content: flex-start;
	align-items: center;
    margin-top: 8px;
    font-size: 2rem;
    font-weight: 700;
}
#sec_aboutCase ul li a h3 span{
    background: linear-gradient(#2D2D2D, #2D2D2D) 0 100% / 0 1px no-repeat;
    transition: background .4s;
}
#sec_aboutCase ul li a:hover h3 span{
    background-size: 100% 1px;
}

#sec_aboutCase ul li h3 .logo + .name-txt{
	margin-left: 16px;
}

#sec_aboutCase ul li a figure img{
    display: block;
    margin: 0 auto;
    object-fit: cover;
    object-position: center center;
    aspect-ratio: 372 / 214;
}

#sec_aboutCase ul li .txtBox{
	margin-top: 8px;
}
#sec_aboutCase ul li .freeTxt{
    margin-top: 16px;
    font-size: 1.4rem;
}

#sec_aboutCase .btnBasic{
	margin-top: 55px;
}
@media screen and (max-width: 767px){
	#sec_aboutCase ul{
		margin: 40px -16px 0;
	}
	#sec_aboutCase ul li {
		margin: 0 12px;
		max-width: inherit;
	}
	#sec_aboutCase ul li + li{
		margin-left: 12px;
	}
	
	#sec_aboutCase ul li a h3{
		font-size: 1.8rem;
		flex-direction: column;
		text-align: left;
		align-items: flex-start;
		justify-content: flex-end;
		height: auto;
	}
	#sec_aboutCase ul li h3 .logo + .name-txt{
		margin-top: 7px;
		margin-left: 0;
	}
	#sec_aboutCase ul li .freeTxt {
		margin-top: 8px;
	}
	#sec_aboutCase .btnBasic{
		margin-top: 40px;
	}
	/* スライダー矢印 */
	.slick-arrow{
		border: none;
		width: 48px;
		height: 48px;
		display: flex;
		justify-content: center;
		align-items: center;
		background: #A2000D;
		border-radius: 50%;
		color: #fff;
		position: absolute;
		top: 20%;
		transform: translateY(-50%);
		z-index: 10;
	}
	.slick-arrow.slick-prev{
		left: 6px;
	}
	.slick-arrow.slick-next{
		right: 6px;
	}
}
