
/* ----------------------------------------
	main_text
---------------------------------------- */

.main_text {
    padding: 2rem 1.5rem;
    background: #f2f2f2;
}
.main_text p {
    line-height: 1.7;
}
.main_text p + p {
    margin-top: 1.5rem;
}

@media screen and (min-width: 768px) {
    .main_text {
        padding: 2rem;
    }
}

@media screen and (min-width: 1024px) {
    .main_text {
        padding: 30px 40px;
    }
    .main_text p {
        line-height: 2;
    }
}



/* ----------------------------------------
	chara
---------------------------------------- */

.chara > div {
	margin-top: 2rem;
}
.chara .text_area {
	padding: 1.5rem;
}
.chara .text_area p {
	line-height: 1.7;
    color: #fff;
}
.chara .text_area h3 {
    color: #fff;
    margin-bottom: .5rem;
}

.chara > div .text_area {
    background: #333;
}


@media screen and (min-width:1024px) {
	.chara > div:nth-child(2) {
		margin-top: 0;
	}
    
	.chara > div {
		margin-top: 0;
	}
	.chara > div {
		position: relative;
	}
	.chara > div h2 {
		margin-bottom: 5px;
	}
	.chara > div .text_area {
        padding: 15px;
		position: absolute;
		width: 440px;
        top: 50%;
        transform: translateY(-50%);
        background: rgba(0,0,0,.8);
	}
	.chara > div.right .text_area {
		right: 20px;
	}
	.chara > div.left .text_area {
		left: 20px;
	}
	.chara h3 {
		margin-bottom: 5px;
	}
	.chara .right p, .chara .left p {
		letter-spacing: 1px;
	}
    
    .w410_lg {
        width: 410px!important;
    }
}


/* ----------------------------------------
	price
---------------------------------------- */

.price_area {
	text-align: center;
}
.price_area .price_box .button,
.price_area .main_price_box .button,
.price_area, .price ~ p.bold {
	margin-top: 1rem;
}
.price_area .regular_price {
	margin-top: .5rem;
	font-size: 1.1rem;
	text-decoration: none;
}
.price_area .regular_price::before {
	content: "[ \901A\5E38\4FA1\683C ";
}
.price_area .regular_price::after {
	content: " ]";
}
.price_area .non_taxed_price {
	color: #767676;
}
.price_area .non_taxed_price::before {
	content: "[ ";
}
.price_area .non_taxed_price::after {
	content: " ]";
}
.price_area .price_box .button,
.price_area .price ~ p.bold {
	margin-top: 1rem;
}

@media screen and (min-width: 480px) {
	.price_area .hpj-pim {
		display: flex;
		justify-content: center;
		align-items: flex-end;
	}
}


/* series_name -------------------- */

.series_name {
	text-align: center;
}


/* series_name -------------------- */

.cam_model_name {
	font-size: 18px;
	text-align: center;
	line-height: 1.3;
}


/* prod_img -------------------- */

.prod_img {
	position: relative;
    text-align: center;
}



/* ----------------------------------------
	table
---------------------------------------- */

.model .style_basic {
	width: 100%;
}
.model .style_basic th,
.model .style_basic td {
	vertical-align: middle;
	padding: .8em .5em;
	text-align: center;
}
.model .style_basic thead th {
	color: #fff;
	background: #333;
}

@media screen and (max-width: 767px) {
	.model .style_basic th {
		width: 8em;
	}
}

@media screen and (max-width: 1023px) {
	.model .style_basic th,
	.model .style_basic td {
		font-size: 1.2rem;
	}
}


/* ==================================================
	PIM
================================================== */

@media screen and (max-width: 1023px) {
	.cam_model .hpj-pim:nth-child(n+2) {
		margin-top: 20px;
        padding-top: 20px;
        border-top: 1px dotted #ccc;
	}
}

@media screen and (min-width: 1024px) {
    .cam_model {
        padding: 20px 16px;    
    }
	.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;
	}

	/* column3 -------------------- */
	.column3 .hpj-pim {
		width: 33.33333% !important;
	}
	.column3 .hpj-pim:nth-child(n+4) {
		margin-top: 40px;
	}
	/* column4 -------------------- */
	.column4 .hpj-pim {
		width: 25% !important;
	}
	.column4 .hpj-pim:nth-child(n+5) {
		margin-top: 40px;
	}
	/* column5 -------------------- */
	.column5 .hpj-pim {
		width: 20% !important;
	}
	.column5 .hpj-pim:nth-child(n+6) {
		margin-top: 40px;
	}
}


/* series_name -------------------- */

.cam_model_name {
	font-size: 18px;
	text-align: center;
	line-height: 1.3;
}


/* prod_img -------------------- */

.prod_img {
	position: relative;
    text-align: center;
}


/* price_area -------------------- */

.regular_price_area {
	display: flex;
	justify-content: center;
	margin-top: 10px;
}

.hpj-pim .regular_price_text_cam {
	margin-right: 10px;
}

.price_area {
	padding-top: 20px;
	text-align: center;
}
.price_area * + * {
	margin-top: 10px;
}

.price_area .price_off {
	color: #d7410b;
	font-size: 16px;
	font-weight: bold;
	line-height: 1;
}
.price_area .price_off span {
	font-size: 130%;
}

.hpj-pim.general-tax-price .regular_price_taxed {
    margin-top: 0 !important;
}

.hpj-pim.general-tax-price .price.taxed {
	margin-top: 0 !important;
}