.visid > div {
	/* max-width: 1240px; */
	margin-right: auto;
	margin-left: auto;
}
.visid .content_area {
	max-width: 1240px;
	margin-right: auto;
	margin-left: auto;
}

@media screen and (max-width: 479px){
	.xl{
		font-size: 27px;
	}
}
visid .button, .visid .button {
	font-size: 20px!important;
}
#visid .button.critical, .visid .button.critical {
	background: #d7410b;
}
#visid .button.critical:hover, .visid .button.critical:hover {
	background: #c14018;
}

@media screen and (max-width: 1023px){
	#visid img{
		height: auto;
	}
	.main_ttl img{
		width: 100%;
	}
}



/* ----------------------------------------
	common
---------------------------------------- */
img{
	height: auto;
}

#visid h3 {
	padding: 1rem;
	border-top: 3px solid #006699;
	background: linear-gradient(#0096d6 , #fff);
	text-align: center;
}
@media screen and (min-width: 1024px){
	#visid h3 {
		height: 100px;
		padding: 2.5rem;
		font-size: 30px;
		background: url(images/tit_bg.png) no-repeat center;
	}
}

.bge5f4fb{
	background-color: #e5f4fb;
}



/* ----------------------------------------
	main
---------------------------------------- */

.main_ttl img {
	object-fit: cover;
	width: 100%;
	height: auto;
}


/* ----------------------------------------
	slick
---------------------------------------- */
#responsive1 {
	margin-top: 3rem;
}

#responsive1 .slick-prev,
#responsive1 .slick-next {
	transition: .2s;
	width: 30px;
	height: 30px;
	text-align: center;
	background: rgba(0,0,0,.4);
	border-radius: 50%;
	z-index: 1;
}
@media screen and (min-width: 768px){
	#responsive1 .slick-prev,
	#responsive1 .slick-next {
		width: 60px;
		height: 60px;
	}
}

#responsive1 .slick-prev {
	left: 10px;
}
#responsive1 .slick-next {
	right: 10px;
}
#responsive1 .slick-prev:hover,
#responsive1 .slick-next:hover {
	background: rgba(0,0,0,.6);
}
#responsive1 .slick-prev::before,
#responsive1 .slick-next::before {
	display: inline-block;
	content: "\E90c";
	position: absolute;
	top: 0;
	font-family: HPIcons;
	color: #fff;
	font-size: 14px;
	line-height: 30px;
	opacity: 1;
}
@media screen and (min-width: 768px){
	#responsive1 .slick-prev::before,
	#responsive1 .slick-next::before {
		display: inline-block;
		content: "\E90c";
		position: absolute;
		top: 0;
		font-family: HPIcons;
		color: #fff;
		font-size: 24px;
		line-height: 60px;
		opacity: 1;
	}
}



#responsive1 .slick-prev::before {
	transform: rotate(90deg);
	right: 10px;
}
#responsive1 .slick-next::before {
	transform: rotate(270deg);
	left: 10px;
}
#responsive1 .slick-list {
	margin: 0 20px;
}

@media screen and (min-width: 768px){
	#responsive1 .slick-prev::before {
		transform: rotate(90deg);
		right: 20px;
	}
	#responsive1 .slick-next::before {
		transform: rotate(270deg);
		left: 20px;
	}
	#responsive1 .slick-list {
		margin: 0 60px;
	}	
}

#responsive1 .slider .sl {
	padding: 1rem;
	margin: 0 1rem;
	border: 1px solid #999;
	background-color: #fff;
}

.sl_tit {
	padding: 1rem;
	color: #0096d6;
	background: #f2f2f2;
	border-left: 3px solid #0096d6;
}
.sl_txt {
	margin-top: 2rem;
}

@media screen and (min-width: 1024px){
	#responsive1 .slider .sl {
		padding: 3rem;
	}
	.sl_tit {
		font-size: 20px;
	}
}



/* ----------------------------------------
	product
---------------------------------------- */
.product {
	background: url(images/product_bg.png) no-repeat center;
	margin: 3rem 0 3rem;
}
@media screen and (min-width: 1024px){
	.product {
		height: 230px;
		paddin: 5rem 0 2rem;
		background-color: #e5f4fb;
	}
}



/* ==================================================
	PIM
================================================== */
.model_copy{
	background-color: #cceaf7;
	padding: .5rem;
	margin: 1rem;
	border-radius:2rem;
	/* border: 1px solid #fcf54b; */
}

.cam_model {
	padding: 0;
}

@media screen and (min-width: 768px) {
	.cam_model {
		padding: 20px;
	}
}

@media screen and (max-width: 767px) {
	.cam_model .hpj-pim:nth-child(n+2) {
		margin-top: 20px;
	}
}

@media screen and (min-width: 768px) {
	.cam_model > .aem-Grid {
		margin: 0 -10px;
	}
	.cam_model .hpj-pim {
		padding: 0 10px;
	}
	
	/* column2 -------------------- */
	.column2 .hpj-pim {
		width: 50% !important;
	}
	.column2 .hpj-pim:nth-child(n+3) {
		margin-top: 20px;
	}
}
@media screen and (min-width: 1024px) {
	.cam_model {
		padding: 0 20px;
	}
/*
	.cam_model > .aem-Grid {
		margin: 0 -10px;
	}
	.cam_model .hpj-pim {
		padding: 0 10px;
	}
*/

	/* column3 -------------------- */
	.column3 .hpj-pim {
		width: 33.33333% !important;
	}
	.column3 .hpj-pim:nth-child(n+4) {
		margin-top: 20px;
	}
}



/* model_box -------------------- */

.model_box {
	background: #fff;
	/* border-radius: 4px; */
	text-align: center;
	outline: 1px solid #0096d6;
	/* border-top: 2px solid #007dba ; */
}

@media screen and (min-width: 1024px) {
	/* column1 -------------------- */
	.model_inner > .aem-Grid > div > .aem-Grid {
		display: flex;
		justify-content: space-between;
	}
	.model_inner {
		display: flex;
		justify-content: space-between;
	}
	.model_inner > .aem-Grid > div > .aem-Grid > .hpj-freeHTML {
		width: 48%;
	}
	.model_inner > .model_l {
		width: 48%;
	}
	.model_inner > .aem-Grid > div > .aem-Grid > .hpj-pim {
		width: 48%;
	}
	.model_inner > .model_r {
		width: 48%;
	}
}



/* series_name -------------------- */

.series_name {
}



/* cam_model_name -------------------- */

.cam_model_name {
	/*margin: 0 10px;*/
	text-align: center;
	color: #000;
	/*border-bottom: 1px solid #000;*/
}


.prod_name {
	padding: 10px 10px 7px 10px;
	text-align: center;
	color: #fff;
	font-size: 20px;
	font-weight: normal;
	line-height: 1.4;
	background-color: #0096d6 ;
}

.cam_name {
	padding: 10px 10px 5px 10px;
	line-height: 1.4;
	color: #767676;
	font-weight: normal;
}

@media screen and (max-width: 479px) {
	.cam_name {
		text-align: left;
	}

	.cam_name br {
		display: none;
	}
}

.cam_name br{
	display: none;
}

@media screen and (min-width: 768px) {
	.cam_name br{
		display: block;
	}
}

/* prod_img -------------------- */

.prod_img {
	display: block;
	margin: 10px auto 0;
	padding: 10px 5px 0;
	text-align: center;
}
@media screen and (min-width: 768px) {
	.prod_img {
		padding: 10px 20px 5px;
	}
}



/* price_area -------------------- */

.price_area {
	margin: 0;
	padding: 10px;
	text-align: center;
}

@media screen and (min-width: 1024px) {
	.price_area {
		padding: 20px 20px 0;
		text-align: left;
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
		flex-flow: wrap;
	}
	.price_area > div:first-of-type {
		flex-shrink: 0;
	}
}
.price_area * + * {
	margin-top: 5px;
}
@media screen and (min-width: 1024px) {
	.price_area * + * {
		margin-top: 0;
	}
}
.price_area .bold {
	margin-top: 10px;
	line-height: 35px;
}
.price_area .price_off {
	color: #d7410b;
	font-size: 14px;
	padding-bottom: 10px;
	font-weight: normal;
	line-height: 1;
}
.price_area .price_off span {
	font-size: 170%;
}
.price_area .price_off > span:first-child {
	/*margin:0 -3px;*/
}
.price_area .price_off > span:last-child {
	/*letter-spacing: -3px;*/
	font-size: 165%;
}
/*
.price_area .button {
	margin-top: 10px;
}
*/
.hpj-pim .regular_price_text_cam {
	display: inline-block;
}
.hpj-pim.general-tax-price .regular_price_taxed {
	display: inline-block;
}
/* v_balloon */
.price_area .price_off.v_balloon {
	display: inline;
	position: relative;
	padding: 0.5em 0 0.2em 0;
	color: #d7410b;
	font-size: 13px;
	line-height: 1.2;
	/*border-radius: 5px;*/
	white-space: nowrap;
	
	background: #fefcc9;
	background: linear-gradient(transparent 65%, rgba(255,204,0,.3) 65%);
	text-align: left;
}
.price_area .price_off.v_balloon::after {
	content: "";
	margin-bottom: 1rem;
}
/*.price_area .price_off.v_balloon::after {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 6px solid transparent;
	border-top: 6px solid #fefcc9;
}*/

/* icon -------------------- */

.icon {
	margin-bottom: 2rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.icon li {
	color: #666;
	text-align: center;
	align-self: center;
	padding: .5rem;
}
.icon [class*="hpic_"]::before {
	display: block;
	line-height: 60px;
}
.icon p {
	font-size: 11px;
	line-height: 1.1;
}

/* v2 */
.icon.v2 li:first-child {
	display: block;
	width: 100%;
	padding-bottom: 15px;
}
.icon.v2 li:nth-child(n+3) {
	margin-left: 20px;
}

/* v1 */
.icon.v1 li:first-child {
	display: block;
	width: 100%;
	padding-bottom: 15px;
}
.icon.v1 li:nth-child(n+3) {
	margin-left: 20px;
}
@media screen and (min-width: 480px) {
	.icon.v1 li:first-child {
		display: flex;
		align-items: center;
		width: auto;
		height: 60px;
		padding-bottom: 0;
	}
	.icon.v1 li:nth-child(n+2) {
		margin-left: 20px;
	}
}



/* model_spec -------------------- */

.model_spec {
	margin: 15px 10px 0;
}
.model_spec_list > li {
	font-size: 13px;
}

@media screen and (max-width: 1023px) {
	.model_spec_list > li {
		padding: 5px;
	}
}

@media screen and (min-width: 1024px) {
	.model_spec {
		border: none;
	}
	.model_spec_list > li::after {
		content: "";
		display: block;
		clear: both;
	}
	.model_spec_title {
		display: block;
		width: 7em;
	}
	.model_spec_text {
		float: right;
		width: calc(100% - 8em);
	}
}



/* list_basic -------------------- */

.cam_model .list_basic {
	font-size: 13px;
	text-align: left;
}
.cam_model .list_basic > li::before {
	background: rgba(169,27,41,.7);
}
.cam_model .list_basic > li > * ,
.prod_area .list_basic > li > * {
	float: none;
}
.cam_model .list_basic .model_spec_title ,
.prod_area .list_basic .model_spec_title {
	display: none;
}
.cam_model .list_basic .model_spec_text,
.prod_area .list_basic .model_spec_text {
	width: 100%;
}
.cam_model .list_basic .icon_customize::after,
.prod_area .list_basic .icon_customize::after{
	content: none;
	background: none;
}
.cam_model .list_basic .model_spec_momery .model_spec_text::after,
.prod_area .list_basic .model_spec_momery .model_spec_text::after{
	display: inline;
	content: " \30E1\30E2\30EA";
}

@media screen and (max-width: 1023px) {
	.cam_model .acco_basic {
		margin: 15px 10px 0;
	}
	.cam_model .acco_trigger {
		font-size: 14px;
		background: #f2f2f2;
	}
}

@media screen and (min-width: 1024px) {
	.cam_model .acco_trigger {
		display: none;
	}
	.cam_model .list_basic {
		margin-top: 15px;
		padding: 10px 20px;
	}
}



/* link_area -------------------- */

.link_area {
	margin: 0;
	padding: 10px 5px;
	text-align: center;

}
.link_area a {
	font-size: 12px;
}
.campaign-link {
	margin-right: 15px;
}

@media screen and (min-width: 1024px) {
	.link_area {
		border-top: 1px dotted #ccc;
	}
}




/*----------------------------------------- model_content_area */
.model_content_area {
	background: #ecfcfe;
	padding-bottom: 4rem;
	position: relative;
	padding: 0 2rem 2rem;
	border: 1px solid #9bd5df;
	border-radius: 1rem 1rem 0 0;
}
.model_content_area_title {
	text-align: center;
	background: #000000;
	border-radius: 1rem 1rem 0 0;
	margin: 0 -2rem;
	padding: 1rem 0 0;
	color: #fff;
}

/*----------------------------------------- title__area */
.title_area {
	color: #000;
	text-align: center;
}

.lg_title {
	position: relative;
    padding: 2.5rem 0 0;
    /*background: linear-gradient(#fef0f7, #e5ffbd); */
    /*border-top: 13px solid #ff63bc;*/
}



/* 
.series_title::before,
.series_title::after {
	content: "";
	position: absolute;
	top: 100%;
	border-style: solid;
	border-color: transparent;
}

.series_title::before {
	left: 0;
	border-width: 0 10px 10px 0;
	border-right-color: #ff63bb;
}
.series_title::after {
	right: 0;
	border-style: solid;
	border-width: 10px 10px 0 0;
	border-top-color: #ff63bb;
}

.series_title span {
	display: block;
	padding: .2em 1em;
    line-height: 1.6;
}
*/



/*----------------------------------------- series_area */

.series_box{
	background-color: #ffeff8;
	align-items: center;
	border-radius: 1rem;
}

.series_box > div{
	border-radius: 1rem 1rem 0 0;
}


.series_box .check span {
	text-decoration: underline;
    text-decoration-style: dashed;
    /* padding-bottom: 1rem; */
    text-underline-offset: 1rem;
    text-decoration-thickness: 1px;
    text-decoration-color: #cccccc;
}

.check{
	position: relative;
}
.check::before{
	content: "";
	font-size:4rem;
	position: absolute;
	left: 0;
	top: 30%;
	width: 1em;
	height: 0.5em;
	border-bottom: 0.2em solid #40defa;
	border-left: 0.2em solid #40defa;
    -webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}



/* cam_btn -------------------- */

.cam_btn {
	margin-top: 10px;
	text-align: center;
}
.cam_btn .button {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	position: relative;
	min-width: 196px;
	min-height: 56px;
	padding: .5em 45px .5em 20px!important;
	font-size: 20px!important;
	text-align: center;
	background: #000;
	border: 2px solid #fff;
	border-radius: 10px!important;
}
.cam_btn .button::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 15px;
	transform: translateY(-50%) rotate(270deg);
	width: 22px;
	height: 22px;
	background: url(images/arrow.svg) no-repeat center center / 20px;
	filter: invert(1);
}
.cam_btn .button:hover {
	background: #666;
}

@media screen and (min-width: 480px) {
	.cam_btn .button {
		padding-right: 55px!important;
	}
	.cam_btn .button::after {
		right: 20px;
		width: 26px;
		height: 26px;
		background-size: 25px;
	}
}

@media screen and (min-width: 768px) {
	.cam_btn {
		
	}
	.cam_btn .button {
		min-width: 240px;
		min-height: 66px;
		font-size: 25px;
	}
}






