@charset "utf-8";

/*---------- common ----------*/

#cam_container{
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	text-align: left;
	color: #333;
	font-family: "Roboto", "Noto Sans JP", sans-serif;
	letter-spacing: 0;
	font-feature-settings: "palt";
}
#cam_container *,#cam_container *::before,#cam_container *::after{
	box-sizing: border-box;
}
#cam_container h1,#cam_container h2,#cam_container h3,#cam_container h4{
	margin: 0;
	padding: 0;
	border: none;
	font-weight: 400;
	line-height: 1.25;
	font-feature-settings: "palt";
}
#cam_container p{
	margin: 0;
	padding: 0;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	font-feature-settings: "palt";
}
#cam_container ul,#cam_container ol,#cam_container li,#cam_container dl,#cam_container dt,#cam_container dd{
	margin: 0;
	padding: 0;
	list-style: none;
}
#cam_container img{
	width: 100%;
}
#cam_container sup{
	font-size: 60%;
}
#cam_container small{
	font-size: 80%;
	line-height: 1.25;
}
#cam_container a{
	color: #1755AA;
	text-decoration: underline;
}
#cam_container a:hover{
	text-decoration: none;
}

@media screen and (max-width: 960px) {}
@media screen and (max-width: 428px) {
	#cam_container{font-size: 14px;line-height: 1.4;}
	#cam_container p{font-size: 14px;line-height: 1.4;}
}

/*---------- special ----------*/

.txt_red{color: #d00f31 !important;}

@media screen and (max-width: 960px) {
	.br_pc{display: none;}
}
@media screen and (max-width: 428px) {
	.br_pc{display: block;}	
}

/*---------- all ----------*/

#cam_container{}

@media screen and (max-width: 960px) {}
@media screen and (max-width: 428px) {}

/*---------- header ----------*/

#cam_headr{
	max-width: 1040px;
	margin: 0 auto 56px;
}
#cam_headr .mainvisual{
	margin-bottom: 16px;
}
#cam_headr .box_date{
	display: flex;
	align-items: center;
	border: 4px solid #e50013;
}
#cam_headr .box_date .title{
	background-color: #e50013;
	padding: 16px;
	font-size: 28px;
	line-height: 1;
	text-align: center;
	color: #fff;
}
#cam_headr .box_date .date{
	flex-grow: 1;
	width: auto;
	font-size: 32px;
	font-weight: 800;
	line-height: 1.25;
	text-align: center;
	color: #e50013;
}

@media screen and (max-width: 960px) {
	#cam_headr .box_date .title{padding: 16px 8px;font-size: 20px;}
	#cam_headr .box_date .date{font-size: 28px;}
}
@media screen and (max-width: 428px) {
	#cam_headr{margin-bottom: 32px;}
	#cam_headr .mainvisual{margin-bottom: 8px;}
	#cam_headr .box_date{flex-direction: column;border: 2px solid #e50013;}
	#cam_headr .box_date .title{width: 100%;padding: 8px;font-size: 14px;}
	#cam_headr .box_date .date{padding: 8px 4px;font-size: 17px;}
}

/*---------- contents ----------*/

#cam_contents .box_section{
	max-width: 1040px;
	margin: 0 auto;
}
#cam_contents .box_terms{
	margin-bottom: 40px;
}
#cam_contents h2.title{
	margin-bottom: 16px;
	font-size: 28px;
	font-weight: 800;
}
#cam_contents .list_notes{
	padding-top: 8px;
}
#cam_contents .list_notes li{
	padding-left: 1em;
	text-indent: -1em;
}
#cam_contents .list_disk li{
	padding-left: 1em;
	text-indent: -1em;
}
#cam_contents .list_disk li::before{
	content: "・";
	padding-right: 8px;
}

@media screen and (max-width: 960px) {
	#cam_contents .box_section{padding: 0 8px;}
}
@media screen and (max-width: 428px) {
	#cam_contents .box_section{padding: 0 4px;}
	#cam_contents h2.title{margin-bottom: 8px;font-size: 20px}
	#cam_contents .box_terms{margin-bottom: 20px;}
}

/* subscription */

#cam_contents .box_subscription{
	background-color: #f2f2f2;
	margin-bottom: 40px;
	padding: 40px 12px 48px;
}
#cam_contents .box_form{
	max-width: 1040px;
	margin: 0 auto;
}
#cam_contents .box_flex_2col{
	display: flex;
	justify-content: center;
}
#cam_container .box_item{
	display: flex;
	flex: 1;
}
#cam_container .box_item:first-child{
	margin-right: 40px;
}
#cam_contents .box_item .image{
	width: 240px;
	margin-right: 16px;
}
#cam_contents .box_item .image img{
    border: 1px solid #ccc;

}
#cam_contents .box_item .detail{
	width: calc(100% - 256px);
}
#cam_contents .box_item .detail .name{
	padding-bottom: 16px;
	font-size: 19px;
	font-weight: 800;
	line-height: 1.25;
}
#cam_contents .box_item .detail .price{
	padding-bottom: 32px;
	font-size: 19px;
	line-height: 1.25;
}
#cam_contents .box_item .detail .button a{
	display: block;
	padding: 16px 0;
	background-color: #e60012;
	border-radius: 5px;
	font-size: 18px;
	line-height: 1;
	text-align: center;
	color: #fff;
	text-decoration: none;
	transition: .3s;
}
#cam_contents .box_item .detail .button a:hover{
	opacity: 0.7;
}

@media screen and (max-width: 960px) {
	#cam_contents .box_subscription{padding: 40px 16px 48px;}
	#cam_contents .box_item{flex-direction: column;}
	#cam_contents .box_item .image{margin: 0 auto 16px;}
	#cam_contents .box_item .detail{display: flex;flex-direction: column;flex: 1 0 auto;width: 100%;}
	#cam_contents .box_item .detail .button{margin-top: auto;}
}
@media screen and (max-width: 428px) {
	#cam_contents .box_subscription{padding: 20px 12px 24px;}
	#cam_container .box_item:first-child{margin-right: 20px;}
	#cam_contents .box_item .image{width: 100%;margin-bottom: 8px;}
	#cam_contents .box_item .detail .name{padding-bottom: 8px;font-size: 16px;}
	#cam_contents .box_item .detail .price{padding-bottom: 16px;font-size: 16px;}
	#cam_contents .box_item .detail .button a{font-size: 14px;}
}

