/* CSS Document */
@media only screen and (min-width: 851px){
	.sp {
		display: none !important;
	}
}
@media only screen and (max-width: 850px){
	.pc {
		display: none !important;
	}
}
body:has(#csprogBoxWrap).fixed {
	/* overflow: hidden; */
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	overflow-y: scroll;
}
@media only screen and (max-width: 850px){
	body:has(#csprogBoxWrap).fixed {
		overflow: hidden;
	}
}
body:has(#csprogBoxWrap) .mfp-bg {
	z-index: 10042;
	background: none;	
}
body:has(#csprogBoxWrap) .mfp-wrap {
	z-index: 10043;
}
body:has(#csprogBoxWrap) .mfp-content {
	z-index: 10045;
}
@media only screen and (min-width: 851px){
	.mfp-bg.mfp-fade,
	.mfp-wrap.mfp-fade,
	.mfp-wrap.mfp-fade .mfp-container,
	.mfp-wrap.mfp-fade .mfp-container .mfp-content {
		pointer-events: none;
	}
}
@media only screen and (max-width: 850px){
	body:has(#csprogBoxWrap) .mfp-bg {
		background: rgba(129, 129, 129,0.81);
	}
}
html:has(.mfp-bg),
body:has(.mfp-bg) {
	overscroll-behavior-y: none;
}
.mfp-container {
	padding: 0;
	overscroll-behavior: contain;
	overscroll-behavior-y: none;
}
.mfp-fade.mfp-bg {
	opacity: 0;
	-webkit-transition: all 0.5s ease-out;
	transition: all 0.5s ease-out;
}
.mfp-fade.mfp-bg.mfp-ready {
	opacity: 0.81;
}
.mfp-fade.mfp-bg.mfp-removing {
	opacity: 0;
}
.mfp-fade.mfp-wrap .mfp-content {
	opacity: 0;
	-webkit-transition: all 0.5s ease-out;
	transition: all 0.5s ease-out;
}
.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
	opacity: 1;
}
.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
	opacity: 0;
}
#mainWrap {
    margin: 0;
	background: none;
}
#mainWrap #main {
	padding-bottom: 0;
	width: auto;
	min-width: 1000px;
}
.csprog_top_navi {
	padding: 9px 0;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	background: #3b3b3b;
	box-sizing: border-box;
}
.csprog_top_navi.fix {
	position: fixed;
    top: 141px;
    left: 0;
    width: 100%;
    z-index: 4000;
}
.csprog_top_navi ul {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.csprog_top_navi li {
	padding: 0 7px;
	border-right: 1px solid #ffb912;
}
.csprog_top_navi ul:last-child li:last-child {
	border-right: none;
}
.csprog_top_navi li a {
	padding: 0 11px;
	min-width: 86px;
	height: 42px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	font-size: 14px;
	letter-spacing: 0.1em;
	text-decoration: none;
	border-radius: 4px;
	box-sizing: border-box;
}
.csprog_top_navi li a:hover {
	color: #3B3B3B;
	background: #FFB912;
}
#csprogBoxWrap {
    padding-top: 19px;
    margin: 0;
}
#csprogBoxWrap .area {
	margin-top: -40px;
	padding-top: 40px;
}
#csprogBoxWrap .area:not(:last-child) {
	margin-bottom: 25px;
}
#csprogBoxWrap .area .inner {
	padding: 28px 0 48px;
	position: relative;
	background: #3b3b3b;
}
#csprogBoxWrap .area .inner::before {
	height: 10px;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	background: linear-gradient(to right,#f4b912 0%, #fdfdc3 100%);
	content: "";
}
#csprogBoxWrap .area .subInner {
	margin: 0 auto;
	width: 1000px;
}
#csprogBoxWrap .area h3 {
	margin: 0 auto 26px;
	padding: 3px 26px;
	width: fit-content;
	color: #fff;
	font-size: 26px;
	font-weight: bold;
	line-height: 1.4615;
	text-align: center;
	border-left: 1px solid #c8c8c8;
	border-right: 1px solid #c8c8c8;
}
#csprogBoxWrap .area .sliderBox {
	position: relative;
	overflow: hidden;
}
#csprogBoxWrap .area .sliderBox::before,
#csprogBoxWrap .area .sliderBox::after {
	width: 64px;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: linear-gradient(to left,rgba(0, 0, 0, 0.3) 0%, #000 100%);
	opacity: 0.86;
	content: "";
	z-index: 1;
}
#csprogBoxWrap .area .sliderBox::after {
	width: 63px;
	left: auto;
	right: 0;
	background: linear-gradient(to right,rgba(0, 0, 0, 0.3) 0%, #000 100%);
}
#csprogBoxWrap .area .slider {
	margin-left: -617px;
}
#csprogBoxWrap .area .slider li {
	margin-right: 21px;
	width: 192px !important;
	vertical-align: top;
}
#csprogBoxWrap .area .slider li a {
	display: block;
	color: #fff;
	font-size: 14px;
	line-height: 1.7142857;
	text-decoration: none;
}
#csprogBoxWrap .area .slider li .pho {
	aspect-ratio: 16 / 9;
}
#csprogBoxWrap .area .slider li img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
#csprogBoxWrap .area .slider li .txtBox {
	padding: 7px 15px 0 11px;
	position: relative;
	background: #646464;
}
#csprogBoxWrap .area .slider li .txtBox::before {
	width: 8px;
	height: 8px;
	position: absolute;
	right: 0;
	bottom: 0;
	background: #f4b912;
	clip-path: polygon(100% 0,100% 100%,0 100%);
	content: "";
}
#csprogBoxWrap .area .slider li .txtBox p {
	font-weight: bold;
	text-overflow: -o-ellipsis-lastline;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}
#csprogBoxWrap .area .slider li .logoInn {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background-color: #505050;
}
#csprogBoxWrap .area .slider li .logoInn .logo {
	width: 36px;
	flex: none;
	aspect-ratio: 1 / 1;
	background: #fff;
}
#csprogBoxWrap .area .slider li .logoInn .logo img {
	object-fit: contain;
}
#csprogBoxWrap .area .slider li .logoInn p {
	padding-top: 5px;
	padding-right: 10px;
	width: calc(100% - 40px);
	color: #f4b912;
	font-size: 12px;
	text-align: right;
}
#csprogBoxWrap .area .prev,
#csprogBoxWrap .area .next {
	position: absolute;
	top: 50%;
	width: 26px;
	border: none;
	transform: translateY(-50%);
	z-index: 2;
}
#csprogBoxWrap .area .prev img,
#csprogBoxWrap .area .next img {
	width: 100%;
}
#csprogBoxWrap .area .prev {
	left: 17px;
}
#csprogBoxWrap .area .next {
	right: 17px;
}

.csprog_pop_box .lBox .urlLink a:hover {
	text-decoration: underline;
}
@media (min-width: 851px) and (max-width: 1050px){
	.csprog_top_navi li:not(:last-child) {
		padding: 0 0.667vw;
	}
	.csprog_top_navi li a {
		padding: 0 1.048vw;
		min-width: 8.19vw;
		height: 4vw;
		font-size: 1.333vw;
	}
}
@media only screen and (max-width: 850px){
	#mainWrap #main {
		min-width: inherit;
	}
	.csprog_top_navi {
		padding: 0;
		display: block;
		background: #fff;
	}
	.csprog_top_navi.fix {
		top: 113px;
	}
	.csprog_top_navi ul {
		padding: 13px 0;
		background: #3b3b3b;
	}
	.csprog_top_navi ul:not(:last-child) {
		margin-bottom: 11px;
	}
	.csprog_top_navi li {
		border-width: 2px;
	}
	.csprog_top_navi li:last-child {
		border-right: none;
	}
	.csprog_top_navi li a {
		padding: 0 7px 3px;
        min-width: 125px;
		height: 80px;
		font-size: 28px;
		letter-spacing: 0.05em;
		line-height: 38px;
	}
	#contentsUnderMain {
        padding: 0;
    }
	#csprogBoxWrap {
		padding-top: 44px;
	}
	#csprogBoxWrap .area {
		margin-top: -175px;
		padding-top: 175px;
	}
	#csprogBoxWrap .area:not(:last-child) {
		margin-bottom: 50px;
	}
	#csprogBoxWrap .area .inner {
		padding: 57px 0 105px;
	}
	#csprogBoxWrap .area .inner::before {
		height: 21px;
	}
	#csprogBoxWrap .area .subInner {
		width: auto;
	}
	#csprogBoxWrap .area h3 {
		margin-bottom: 42px;
		padding: 12px 23px;
		min-width: 149px;
		font-size: 34px;
		line-height: 1.1176;
		border-width: 2px;
		box-sizing: border-box;
	}
	#csprogBoxWrap .area .sliderBox {
		padding-left: 76px;
	}
	#csprogBoxWrap .area .sliderBox::before{
		display: none;
	}
	#csprogBoxWrap .area .sliderBox::after {
		width: 120px;
		background: linear-gradient(to right,rgba(0, 0, 0, 0) 0%, #000 100%);
	}
	#csprogBoxWrap .area .slider {
		margin-left: 0;
	}
	#csprogBoxWrap .area .slider li {
		margin-right: 68px;
		width: 512px !important;
	}
	#csprogBoxWrap .area .slider li a {
		font-size: 28px;
		line-height: 38px;
	}
	#csprogBoxWrap .area .slider li .txtBox {
		padding: 24px 27px 43px;
	}
	#csprogBoxWrap .area .slider li .txtBox::before {
		width: 20px;
		height: 20px;
	}
	#csprogBoxWrap .area .slider li .logoInn .logo {
		width: 72px;
	}
	#csprogBoxWrap .area .slider li .logoInn p {
		padding-right: 19px;
		width: calc(100% - 72px);
		font-size: 26px;
	}
	#csprogBoxWrap .area .prev,
	#csprogBoxWrap .area .next {
		margin-top: -47px;
		width: 64px;
	}
	#csprogBoxWrap .area .prev {
		left: 0;
	}
	#csprogBoxWrap .area .next {
		right: 0;
	}
	#csprogBoxWrap .area .slick-disabled {
		display: none !important;
	}
	#csprogBoxWrap .area .slider a:hover img {
		opacity: 1 !important; 
	}
}
/* popup */
.csprog_pop_box {
	margin: 0 auto;
	padding: 30px;
	width: 744px;
	text-align: left;
	pointer-events: auto;
}
.csprog_pop_box .inner {
	padding: 16px 0 25px 23px;
	display: flex;
	justify-content: space-between;
	background: #3b3b3b;
	color: #fff;
	border: 1px solid #646464;
	filter: drop-shadow(3px 3px 30px rgba(0, 0, 0, 0.6));
	-webkit-filter: drop-shadow(3px 3px 30px rgba(0, 0, 0, 0.6));
}
.csprog_pop_box .lBox {
	width: 286px;
}
.csprog_pop_box .lBox img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.csprog_pop_box .lBox .logoInn {
	margin-bottom: 15px;
	display: flex;
	align-items: center;
}
.csprog_pop_box .lBox .logoInn .logo {
	margin-right: 21px;
	width: 90px;
	flex: none;
}
.csprog_pop_box .lBox .logoInn .logo a {
	display: block;
	aspect-ratio: 1 / 1;
}
.csprog_pop_box .lBox .logoInn .logo a img {
	object-fit: contain;
}
.csprog_pop_box .lBox .logoInn p {
	color: #fff;
	font-size: 16px;
	font-weight: bold;
	line-height: 1.625;
}
.csprog_pop_box .lBox .urlLink {
	font-size: 12px;
	margin-bottom: 16px;
}
.csprog_pop_box .lBox .urlLink a {
	color: #f4b913;
	text-decoration: none;
}
.csprog_pop_box .lBox .twitter {
	margin-bottom: 44px;
	width: fit-content;
    text-align: left;
    padding: 0;
	min-height: 20px;
	border-radius: 10px;
	border: 1px solid #fff;
}
.csprog_pop_box .lBox .pho {
	aspect-ratio: 16 / 9;
}
.csprog_pop_box .lBox .sml {
	margin: 2px -2px 0 0;
	font-size: 8px;
	line-height: 1.25;
}
.csprog_pop_box .rBox {
	width: 395px;
}
.csprog_pop_box .rBox .ttl {
	margin: -43px 0 14px;
	padding: 4px 15px;
	width: fit-content;
	font-size: 14px;
	font-weight: bold;
	line-height: 26px;
	text-align: center;
	color: #3b3b3b;
	border-radius: 4px;
	background: #f4b913;
}
.csprog_pop_box .rBox dl {
	padding-right: 20px;
	font-size: 14px;
	line-height: 26px;
}
.csprog_pop_box .rBox .txtDl01 {
	margin-bottom: 5px;
	padding-bottom: 26px;
	border-bottom: 2px solid #f4b913;
}
.csprog_pop_box .rBox .txtDl01 dt {
	color: #F4B913;
	font-size: 16px;
	font-weight: bold;
}
.csprog_pop_box .rBox .txtDl01 dd strong {
	display: block;
}
.csprog_pop_box .rBox .txtDl02 dt {
	color: #f4b913;
	font-size: 12px;
	font-weight: bold;
}
@media only screen and (max-width: 850px){
	.csprog_pop_box {
		margin: 0 32px;
		padding: 150px 0 50px;
		width: auto;
		position: relative;
	}
	.csprog_pop_box .close {
		position: absolute;
		top: 10px;
		right: 10px;
		z-index: 1;
	}
	.csprog_pop_box .close img {
		width: 58px;
	}
	.csprog_pop_box .inner {
		padding: 23px 30px 60px;
		display: block;
		border: none;
		filter: none;
		position: relative;
	}
	.csprog_pop_box .lBox {
		margin-bottom: 50px;
		width: auto;
	}
	.csprog_pop_box .lBox .logoInn {
		margin-bottom: 33px;
	}
	.csprog_pop_box .lBox .logoInn .logo {
		margin-right: 25px;
		width: 108px;
	}
	.csprog_pop_box .lBox .logoInn p {
		font-size: 30px;
	}
	.csprog_pop_box .lBox .urlLink {
		margin-bottom: 26px;
	}
	.csprog_pop_box .lBox .urlLink a {
		font-size: 24px;
	}
	.csprog_pop_box .lBox .twitter {
		margin-bottom: 37px;
	}
	.csprog_pop_box .lBox .pho {
		margin: 0 -30px;
	}
	.csprog_pop_box .lBox .sml {
		margin: 15px 0 0;
		color: #c8c8c8;
		font-size: 18px;
		line-height: 22px;
	}
	.csprog_pop_box .rBox {
		margin-bottom: 54px;
		width: auto;
	}
	.csprog_pop_box .rBox .ttl {
		margin: 0;
		padding: 15px 38px;
		position: absolute;
		left: 50%;
		top: -50px;
		transform: translateX(-50%);
		font-size: 28px;
		line-height: 1.2;
		border-radius: 8px;
	}
	.csprog_pop_box .rBox dl {
		font-size: 28px;
		padding-right: 0;
		line-height: 42px;
	}
	.csprog_pop_box .rBox .txtDl01 {
		margin: 0 -30px 24px 0;
		padding: 0 10px 60px 0;
	}
	.csprog_pop_box .rBox .txtDl01 dt {
		margin-bottom: 10px;
		color: #f4b913;
		font-size: 30px;
	}
	.csprog_pop_box .rBox .txtDl01 dd strong {
		margin-bottom: 20px;
		font-size: 30px;
	}
	.csprog_pop_box .rBox .txtDl02 dt {
		margin-bottom: 16px;
		font-size: 30px;
	}
	.csprog_pop_box .rBox .txtDl02 dd {
		font-size: 30px;
	}
	.csprog_pop_box .closeBtn {
		margin: 0 auto;
		width: 180px;
	}
	.csprog_pop_box .closeBtn a {
		height: 60px;
		display: flex;
		justify-content: center;
		align-items: center;
		font-size: 30px;
		text-align: center;
		color: #c8c8c8;
		text-decoration: none;
		border-radius: 30px;
		background: transparent;
		border: 2px solid #c8c8c8;
		box-sizing: border-box;
	}
}