@charset "UTF-8";
table {
	display: block;
}
.main_twcp {
	display: block;
	width: 100%;
	margin: 0 auto;
}
.twcp_img {
	width: 100%;
	max-width: 1280px;
	height: auto;
	margin: 30px auto 0;
}
.twcp_finish_img {
	width: 100%;
	max-width: 1280px;
	height: auto;
	margin: 16px auto 0;
}
.b {
	font-weight: bold;
}
.text_c {
	text-align: center;
}
.red {
	color: red;
}
.pt16 {
	padding-top: 16px;
}
.float-r {
	float: right;
}
.headLine_twcp {
	width: 100%;
	line-height: 2.5;
	background: linear-gradient(#4b0082 0%, #9932cc 100%);
	color: #ffffff;
	font-size: 17px;
	text-align: center;
	margin-bottom: 30px;
}
.twcp_subtitle {
	font-size: 16px;
	border-bottom: 1px solid #4b0082;
	padding-bottom: 20px;
	margin: 0 auto;
	text-align: center;
	width: 100%;
}
.headLine_twcp_h3 {
	font-size: 16px;
	font-weight: bold;
	margin: 0 auto 20px;
}
.headLine_twcp_h3::before {
	display: inline-block;
	content: "【"
}
.headLine_twcp_h3::after {
	display: inline-block;
	content: "】"
}
.ribbon02-wrapper, .ribbon01-wrapper {  
	display: block;
	position: relative;
	padding: 10px;
	width: 95%;
	color: #ffffff;
	background: #3B3F5C;
	box-sizing: border-box;
}
.ribbon02-wrapper {
	margin: 30px auto 30px;
}
.ribbon01-wrapper {
	margin: 30px auto 30px;
}
.ribbon02-wrapper::after {
	content: '';
	position: absolute;
	left: 50%;
	top: 100%;
	transform: translateX(-50%);
	height: 0;
	width: 0;
	border-left: 20px solid transparent;
	border-right: 20px solid transparent;
	border-top: 20px solid #3B3F5C;
}
.ribbon02 {  
	display: inline-block;
	position: absolute;
	top: -10px;
	left: 10px;
	margin: 0;
	padding: 10px 20px;
	z-index: 2;
	text-align: center;
	color: white;
	font-size: 17px;
	background: linear-gradient(#61BDF7 0%, #2177C0 100%);
	border-radius: 2px 0 8px 8px;
}
.ribbon02::before {
	position: absolute;
	content: '';
	top: 0;
	right: -10px;
	border: none;
	border-bottom: solid 10px #0C88C4;
	border-right: solid 10px transparent;
}
.ribbon02-text, .ribbon01-text {
	padding: 10px;
}
.ribbon02-text {
	font-size: 14px;
}
.ribbon01-text {
	font-size: 14px;
}
.text_area {
	display: block;
	box-sizing: border-box;
	text-align: center;
	line-height: 2;
}
.twcp_one {
	display: inline-block;
}
.twcp_button {
	display: inline-block;
	padding: 3px 10px;
	background: #B5DAF2;
	border-radius: 10px;
	border: 2px outset #48B8FF;
	color: #0C88C4;
}
.gpc_button {
	display: inline-block;
	padding: 1rem 2rem;
	background: #696969;
	border-radius: 10px;
	border: 2px outset #111111;
	color: #ffffff;
	font-size: 17px;
	text-align: center;
	margin: 1rem auto 0;
}
.twcp_finish　.gpc_finish .gallery_text {
	display: block;
	font-size: 17px;
	text-align: center;
}
.youkou_area, .gaiyou_area, .gallery_area {
	width: 95%;
	padding: 20px 10px;
	margin: 0 auto;
}
.caution-area {
	width: 95%;
	padding: 16px;
	margin: 0 auto;
}
.youkou_area {
	border-bottom: 1px dotted #0C88C4;
}
.twcp_jyouken, .twcp_list {
	list-style-type: none;
	padding: 0;
	padding-inline-start: 0;
	padding-inline-end: 0;
	margin-block-start: 0;
    margin-block-end: 0;
}
.twcp_caution {
	list-style: decimal-leading-zero;
	padding: 0 0 0 20px;
	padding-inline-start: 0;
	padding-inline-end: 0;
	margin-block-start: 0;
    margin-block-end: 0;
}
.twcp_jyouken .twcp_jyouken_list, .youkou_text, .twcp_caution .twcp_caution_list {
	font-size: 14px;
	margin: 0 auto;
	line-height: 2;
}
.twcp_list .twcp_syouhin, .twcp_jyouken .twcp_jyouken_list {
	font-size: 14px;
	line-height: 2;
	margin-block-start: 0;
    margin-block-end: 0;
}
.twcp_list .twcp_syouhin::before {
	display:inline-block; 
 	vertical-align: middle;
	content:'';
	width: 10px;
	height: 10px;
	background: #0C88C4;
	border-radius: 50%;
	margin-right: 8px;
}
.twcp_jyouken .twcp_jyouken_list::before {
	display:inline-block; 
 	vertical-align: middle;
	content:'';
	width: 8px;
	height: 8px;
	background: #000000;
	margin-right: 10px;
}
.twcp_color {
	background: #0C88C4;
	color: #ffffff;
	margin-right: 5px;
}
.gpc_sam01 {
	display: block;
	width: 100%;
	text-align: center;
}
.gpc_sam01 a {
	display: inline-block;
	width: 50%;
	margin: 0 auto;
	padding: 0;
	box-sizing: border-box;
	cursor: pointer;
}
.gpc_sam01 a img {
	display: inline-block;
	width: 100%;
	margin: 0 auto;
	max-width: 1080px;
}
/* luminous用 */
.lum-lightbox-inner img {
	width: 100%;
	height: auto;
	max-width: 100%;
}
.lum-lightbox.lum-open {
	z-index: 10;
}
/* gallery用 */
.gallery_wrap {
	display: flex;
	flex-direction: row;
	justify-content: space-around;
	width: 100%;
}
.gallery_item {
	display: block;
	width: calc(100% / 3);
	position: relative;
	border: thin;
	border-color: #ffffff;
}
.gallery_item:before {
    content:"";
    display: block;
	padding-top: 100%;
}
.gallery_item a img {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	object-fit: cover;
}
@media (min-width: 750px) {
	.ribbon02-wrapper, .ribbon01-wrapper {
		width: 80%;
		max-width: 1000px;
		text-align: center;
	}
	.twcp_subtitle {
		font-size: 18px;
	}
	.headLine_twcp_h3 {
		font-size: 18px;
	}
	.headLine_twcp {
		line-height: 3;
		font-size: 20px;
		margin-bottom: 20px;
	}
	.ribbon02 {
		font-size: 18px;
	}
	.ribbon02-text {
		font-size: 18px;
	}
	.ribbon01-text {
		font-size: 16px;
	}
	.twcp_finish, .gallery_text, .gpc_button {
		font-size: 20px;
	}
	.youkou_area, .gaiyou_area {
		width: 80%;
		padding: 30px;
	}
	.caution-area {
		width: 90%;
		padding: 16px 20px;
	}
	.twcp_jyouken .twcp_jyouken_list, .youkou_text, .twcp_list .twcp_syouhin, .twcp_caution .twcp_caution_list {
		font-size: 16px;
	}
	.twcp_jyouken .twcp_jyouken_list {
		padding: 0;
		margin: 0;
	}
	.twcp_caution, .caution-area {
		padding-left: 5px;
	}
	.lum-lightbox-inner img {
		width: auto;
		height: 100%;
		max-height: 1080px;
	}
}