
/* ==================================================
    main
================================================== */

.main .main_text h2 {
    color: #000;
    font-weight: normal;
    font-size: 2.2rem;
    letter-spacing: .1rem;
    padding: 16px;
}

.main .main_text > div {
    margin: 0 0 0 16px;
    font-size: 1.8rem;
    color: #000;
    line-height: 1.6;
}
.main .main_text > div > p {
    font-size: 1.8rem;
}

.main_price_box {
    margin: 1rem 1rem 0;
    padding: 1.5rem;
    border: 1px dashed #ccc;
}

@media screen and (min-width: 1024px) {
    .main {
        position: relative;
        height: 480px;
    }
    .main .main_text {
        position: absolute;
        top: 20px;
        left: 20px;
    }
    .main .main_text h2 {
        font-size: 40px;
        font-weight: normal;
        line-height: 1.2;
    }
    .main .main_text > div {
		width: 500px;
		margin: 0 0 0 10px;
		padding: 0 0 0 5px;
		line-height: 1.3;
    }
    .main .main_text > div > p {
        font-size: 24px;
    }
    .main_price {
        position: absolute;
        left: 30px;
        top: 220px;
    }
    .main_price_box {
        margin: 0;
        padding: 10px;
        border: unset;
    }
}

#main_content img {
    height: auto;
}


#main_content h2.title {
	text-align: center;
	font-size: 2.3rem;
	line-height: 1.3;
    margin-bottom: 1.5rem;
}
#main_content h3.title {
	font-size: 18px;
	color: #0096d6;
}
.list_basic.inner {
	background: rgba(0,150,214,.1);
    padding: 16px;
    border-radius: 6px;
    border: 1px dashed #0096d6;
}

@media screen and (min-width: 768px) {
	#main_content h2.title {
		font-size: 28px;
        margin-bottom: 2rem;
	}

}
@media screen and (min-width: 1024px) {
	#main_content h2.title {
		font-size: 28px;
	}

}


/* ==================================================
	text_area
================================================== */

.pic_area {
    text-align: center;
}
.text_area p {
    font-size: 1.5rem;
}

@media screen and (min-width: 768px) {
    .col_2_md {
        align-items: center;
    }
    .col_2_md.right > div:last-child {
        order: 1;
    }
    .col_2_md.right > div:first-child {
        order: 2;
        margin-right: 0;
        margin-left: 20px;
    }
}

@media screen and (min-width: 1024px) {
    .text_area p {
        font-size: 16px;
        /*letter-spacing: 1px;*/
        line-height: 1.7;
    }
}


/* ==================================================
	PIM
================================================== */

.cam_model {

}

@media screen and (max-width: 767px) {
	.cam_model .hpj-pim:nth-child(n+2) {
		margin-top: 20px;
        padding-top: 20px;
        border-top: 1px dotted #ccc;
	}
}

@media screen and (min-width: 768px) {
    .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 -------------------- */

.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;
	/*display: inline-block;*/
    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;
}

@media screen and (min-width: 1024px) {
    .hpj-pim.general-tax-price .price.taxed {
        margin-right: 8px;
    }
}


/* 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;
	margin-top: 0;
}
.cam_model .list_basic > li::before {
	background: #d7410b ;
}
.cam_model .list_basic > li > * {
	float: none;
}
.cam_model .list_basic .model_spec_title {
	display: none;
}
.cam_model .list_basic .model_spec_text {
	width: 100%;
}
.cam_model .list_basic .icon_customize::after {
	content: none;
	background: none;
}
.cam_model .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-top: 15px;
	}
	.cam_model .acco_trigger {
		font-size: 14px;
		background: #f2f2f2;
	}
}

@media screen and (min-width: 1024px) {
	.cam_model .list_basic {
		margin-top: 20px;
		padding: 16px;
	    border-top: 1px solid #f2f2f2;
	}
	.cam_model .acco_trigger {
		display: none;
	}
}


/* link_area -------------------- */

.link_area {
	margin: 10px 0 0;
	padding: 0 10px 10px;
	text-align: center;
}
.link_area a {
	font-size: 12px;
}
.campaign-link {
	margin-right: 15px;
}
@media screen and (min-width: 1024px) {
	.link_area {
	margin: 10px 10px 0;
	padding: 10px;
	border-top: 1px dotted #ccc;
	}
}



/* ----------------------------------------
    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,
    .model .style_basic td {
        font-size: 1.2rem;
    }
    .model .style_basic th {
        width: 8em;
    }
}