@charset "UTF-8";

/*
 * ABSORBER改.2024.05.01
 */

 /*
 ------------------------------------------------- */
.top_title {
	position: relative;
	padding: 22px 12px 24px 24px;
	margin: 0 0 70px 0;
	font-size: 2.1em;
	line-height: 1.4em;
	text-align:left;
	color: #fff;
	font-weight: 400;
	font-family: "M PLUS Rounded 1c";
	background-color: #004198;
	border-radius: 4px 4px 0 0;
	letter-spacing: 0.4px;
}


.top_title:after {
    position: absolute;
    left: 0;
    content: '';
    width: 100%;
    height: 5px;
    box-sizing: border-box;
}

.top_title:after {
    bottom: 4px;
    border-bottom: 3px solid #fff;
}


.top_title span {
	display: block;
	font-size: 0.7em;
	line-height: 0.8em;
	padding: 0 0 6px 0;
}

.main-area h2 {
	position: relative;
	padding: 14px 18px 14px 24px;
	margin: 0 0 28px 0;
	border-radius: 3px;
	background-color: #004198;
	color: #fff;
	font-size: 1.6em;
	line-height: 1.6em;
	font-weight: 400;
	font-family: "M PLUS Rounded 1c";
	letter-spacing: 0.5px;
}

.main-area h2::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 18px;
    width: 0;
    height: 0;
    border: 9px solid transparent;
    border-top: 9px solid #004198;
}






.main-area h3 {
  position: relative;
  padding: 9px 16px 11px 18px;
  margin: 10px 0 36px 0;
	font-weight: 400;
	font-family: "BIZ UDPGothic", sans-serif;
	letter-spacing: 0.5px;
	font-size: 1.4em;
	line-height: 1.5em;
  color: #0f4081;
  background-color: #fff;
  border-top: 2px solid #004198;
  border-bottom: 2px solid #004198;
	letter-spacing: 0.2px;
}










table {
	border-collapse: collapse;
	border-spacing: 0;
}

table td,
table th {
	border: 1px solid #888 ;
}











/* 製品一覧表示 */

.product-each {
	display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 auto 50px auto;
	width: 97%;
	height: auto;
	/* min-height: 450px; */
	/*border-radius: 12px;*/
	/*border: 1px solid #8e8e8e;*/
	background-color: #fff;
	box-shadow: 0 1px 8px 4px rgba(0, 0, 0, 0.1);
}

.product-each a {
	display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 0 50px 0;
	width: 100%;
	height: auto;
	/* min-height: 450px; */
	overflow: hidden;
}

.p-each-list a{
	margin: 0;
}

@media screen and (max-width:768px) {

	.product-each a {

		min-height: 0;

	}

}




.product-each .p-each-img p,
.product-each .p-all-txt p {

	margin-top: 1em;

}

.product-each .p-each-img p a {
	display: block;
	position: relative;
	padding: 0.5em 0;
	margin: 0 auto;
	width: 100%;
	height: auto;
	min-height: 0;
	text-align: center;
	color: #fff;
	font-size: 1.2em;
	background-color: #53504c;
	border-radius: 3px;
	overflow: hidden;
	transition: all 0.3s;
}

.product-each .p-each-img p a:hover {
	background-color: #4d73a6;
}

.product-each .p-each-img p a::after {
	display: block;
	position: absolute;
	content: '';
	top: calc(50% - 0.4em);
	right: 1em;
	width: 0.8em;
	height: 0.8em;
	border-left: 2px solid rgba(255, 255, 255, 0);
	border-top: 2px solid rgba(255, 255, 255, 1);
	border-right: 2px solid rgba(255, 255, 255, 1);
	border-bottom: 2px solid rgba(255, 255, 255, 0);
	transform: rotate(45deg);
	border-radius: 2px;
}

@media screen and (max-width:480px) {

	.product-each {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 0 50px 0;
		width: 100%;
		height: auto;
		/* min-height: 450px; */
		background-color: #fff;
		box-shadow: none;
	}

}



/* 製品ページでのトップ表示 */

.product-page-each {
	display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 auto 50px auto;
	width: 100%;
	height: auto;
	/* min-height: 450px; */
	/*border-radius: 12px;*/
	/*border: 1px solid #8e8e8e;*/
	/*background-color: #fff;*/
	/*box-shadow: 0 1px 8px 4px rgba(0, 0, 0, 0.1);*/
}

@media screen and (max-width:480px) {

	.product-page-each {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 0 50px 0;
		width: 100%;
		height: auto;
		/* min-height: 450px; */
		/*background-color: #fff;*/
		/*box-shadow: none;*/
	}

}




/* タイトル */
.product-each .p-each-title,
.product-each a .p-each-title {
	display: block;
	position: relative;
	padding: 12px 12px 10px 28px;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
	min-height: 62px;
	border-bottom: 1px solid #8e8e8e;
	color: #fff;
	background-color: #004198;
	/*background-image: linear-gradient(90deg, rgba(0, 65, 152, 1)28%, rgba(48, 97, 96, 1)78%, rgba(0, 65, 152, 1));*/
	/*border-radius: 12px 12px 0 0;*/
	font-size: 2.1em;
	line-height: 1.3em;
	font-weight: 700;
	font-family: 'Zen Maru Gothic', sans-serif;
}

.product-each a:hover .p-each-title {
	display: block;
	position: relative;
	padding: 12px 12px 10px 28px;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
	min-height: 62px;
	border-bottom: 1px solid #8e8e8e;
	color: #fff;
	background-color: #004198;
	/*background-image: linear-gradient(90deg, rgba(0, 65, 152, 1)28%, rgba(48, 97, 96, 1)78%, rgba(0, 65, 152, 1));*/
	/*border-radius: 12px 12px 0 0;*/
	font-size: 2.1em;
	line-height: 1.3em;
	font-weight: 700;
	font-family: 'Zen Maru Gothic', sans-serif;
	text-decoration: underline;
}

.p-each-title-line {
	display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 2px 0 2px 0;
	width: 100%;
	height: 2px;
	/*background-color: #004198;*/
	background-image: linear-gradient(90deg, rgba(0, 65, 152, 1)28%, rgba(48, 97, 96, 1)78%, rgba(0, 65, 152, 1));
}




/* 詳細ページでのタイトル */

.product-page-each .p-each-page-title {
	display: block;
	position: relative;
	padding: 14px 12px 8px 22px;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
	min-height: 34px;
	border-bottom: 1px solid #8e8e8e;
	color: #fff;
	background-color: #004198;
	/*background-image: linear-gradient(90deg, rgba(0, 65, 152, 1)28%, rgba(48, 97, 96, 1)78%, rgba(0, 65, 152, 1));*/
	/*border-radius: 12px 12px 0 0;*/
	font-size: 1.5em;
	line-height: 1.3em;
	font-weight: 400;
	font-family: 'Zen Maru Gothic', sans-serif;
}




/* コンテンツ */
.p-each-content {

	position: relative;
	padding: 24px 30px 30px 30px;
	margin: 0 0 30px 0;
	width: 100%;
	height: auto;
	/* min-height: 420px; */
	overflow: hidden;
	background-image: url(../images/bland_mark_product2.png);
	background-position: right 10px top -60px;
	background-repeat: no-repeat;
	overflow: hidden;

	display: grid;
	grid-template:
	"pro_img  pro_sum" auto
	"pro_detail pro_detail" auto
	"pro_cata pro_cata" auto
	"pro_list pro_list" auto
	/calc(50% - 3em) 50%;
	column-gap: 3em;
	row-gap: 22px;
	justify-content: space-between;
	justify-items: stretch;
	align-items: stretch;
}






.catalog_btn{
	grid-area: pro_cata;
	text-align: center;
	margin-bottom: 3em;
}

.catalog_btn a{
	display: inline-block;
	line-height: 1.4em;
	white-space: nowrap;
	background-color: #555;
	color: #fff;
	text-align: center;
	border-radius: 3px;
	padding: 1em 2em 1em 3em;
	margin: 1em auto;
	width: auto;
	position: relative;
	transition: all 0.4s;
}

.catalog_btn a:hover{
	background-color: #666;
	font-weight: bold;
}



.catalog_btn a::before{
	position: absolute;
	top: calc(50% - 0.125em);
	left: 1em;
	display: block;
	content: '';
	height: 0.5em;
	width: calc(tan(60deg) * 0.5em / 2);
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	background-color: #fff;
}




.p-each-img {
	grid-area: pro_img ;
	/* display: block;
	position: absolute;
	padding: 0 0 0 0;
	margin: 0 0 0 0;
	top: 26px;
	left: 30px;
	width: 43%;
	height: auto; */
}


.p-each-img img {
	display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
	overflow: hidden;
}

.p-each-txt {

	grid-area: pro_sum ;

	/* display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 0 22px 50%; */
}

.p-all-txt {

	grid-area: pro_detail ;

}

.p-each-list {

	grid-area: pro_list ;
}

.p-each-list p{

	font-size: 1.4em;
	line-height: 1.1em;
	padding: 0 0 6px 0;
	margin: 0 0 10px 0;
	color: #004198;
	font-weight: 700;
	font-family: "Zen Maru Gothic", serif;
	letter-spacing: 8px;
}

.p-each-list ul{

	display: flex;
	justify-content: start;
	align-items: stretch;
	column-gap: 3em;
	row-gap: 0.5em;
	flex-wrap: wrap;
	margin-bottom: 2em;
	padding: 1em 1.5em;
	box-shadow: 0 1px 3px 0 rgba(200, 200, 200, 0.5);
}


.p-each-list ul li a{
	display: block;
	min-width: 8em;
	margin: 0;
	color: rgba(12, 108, 164, 1);
	padding-left: 0.75em;
	font-weight: 700;
	font-size: 1.2em;
	font-family: "Zen Maru Gothic", serif;
	position: relative;
}

.p-each-list ul li a::before{
	position: absolute;
	top: calc(50% - 0.125em);
	left: 0;
	display: block;
	content: '';
	height: 0.5em;
	width: calc(tan(60deg) * 0.5em / 2);
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	background-color: rgba(12, 108, 164, 1);
}

.p-each-list ul li a:hover{
	text-decoration: underline;
	opacity: 0.8;
}



.p-each-list dl{

	display: grid;
	grid-template:
	"pro_seri_img pro_seri_list" auto
	"pro_seri_title pro_seri_list" auto
	/ 9em 1fr;
	column-gap: 4em;
	row-gap: 1em;
	justify-content: start;
	justify-items: stretch;
	align-content: start;
	align-items: start;
	margin-bottom: 2em;
	padding: 1em 1.5em;
	box-shadow: 0 1px 3px 0 rgba(200, 200, 200, 0.5);
}

.p-each-list dl > dt{

	grid-area: pro_seri_title;
	font-size: 1.075em;
	font-family: "Zen Maru Gothic", serif;
	font-weight: bold;
	text-align: center;
}




.p-each-list dl > dd:has(img){

	grid-area: pro_seri_img;

}

.p-each-list dl > div{

	grid-area: pro_seri_list;

	display: flex;
	justify-content: flex-start;
	align-content: flex-start;
	align-items: flex-start;
	flex-wrap: wrap;
	row-gap: 0.5em;
	column-gap: 1.5em;
}

.p-each-list dl > div dd a{
	display: block;
	min-width: 8em;
	margin: 0;
	color: rgba(12, 108, 164, 1);
	padding-left: 0.75em;
	font-weight: 700;
	font-size: 1.2em;
	font-family: "Zen Maru Gothic", serif;
	position: relative;
	transition: all 0.4s;
}

.p-each-list dl > div dd a:hover{

	font-weight: 900;
	color: rgba(12, 108, 164, 0.5);

}

.p-each-list dl > div dd a::before{
	position: absolute;
	top: calc(50% - 0.125em);
	left: 0;
	display: block;
	content: '';
	height: 0.5em;
	width: calc(tan(60deg) * 0.5em / 2);
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	background-color: rgba(12, 108, 164, 1);
	transition: all 0.4s;
}

.p-each-list dl > div dd a:hover::before{

	background-color: rgba(12, 108, 164, 0.5);

}




@media screen and (max-width:580px) {

	.p-each-list dl{

		grid-template:
			"pro_seri_img pro_seri_title" auto
			"pro_seri_list pro_seri_list" auto
		/ 4em 1fr;
		column-gap: 1em;
	}

	.p-each-list dl > dt{
		text-align: left;
	}

	.p-each-list dl > div{

		column-gap: 0.5em;
	}

	.p-each-list dl > div dd a{
		min-width: 7em;
	}


}








#p-main .p-all-txt .paragraph_lead{
	margin: 0 auto 3em;
	width: 100%;


}

.p-detail .main-area .paragraph .paragraph_lead{
	width: 88%;
	margin: 0 auto 3em;

}


.p-all-txt .paragraph_lead p:has(img){
	width: 100%;
	text-align: center;
}


.p-all-txt .paragraph_lead img{
	margin: 0 auto 0;
	max-width: 100%;
}



.main-area .p-all-txt .paragraph_lead > h3,
#p-main .p-all-txt .paragraph_lead > h3 {
	display: block;
	font-size: 1.1em;
	line-height: 1.1;
	padding: 0.5em 0;
	margin: 1em 0 10px 0;
	color: #333;
	font-weight: 600;
	font-family: 'メイリオ', "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro";
	border: none;
	background: none;
}

.p-each-feature {
	display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 0 18px 2%;
	width: 98%;
}

.p-each-spec {
	display: block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 0 18px 2%;
	width: 98%;
}

.p-each-feature p,
.p-each-spec p {
	display: block;
	position: relative;
	font-size: 1.4em;
	line-height: 1.1em;
	padding: 0 0 6px 8px;
	margin: 0 0 10px 0;
	color: #004198;
	border-bottom: 1px solid #2b3853;
	font-weight: 700;
	font-family: "Zen Maru Gothic", serif;
	letter-spacing: 8px;
}

.p-each-feature span {
	display: block;
	position: relative;
	font-size: 1.1em;
	line-height: 1.6em;
	padding: 0 0 0 0;
	margin: 0 0 0 16px;
	font-weight: 400;
	font-family: "Zen Maru Gothic", serif;
}

.p-each-spec ul {
	display: block;
	position: relative;
	list-style: none;
	padding: 0 0 0 0;
	margin: 0 0 0 0;
}



.p-each-spec ul li {
	position: relative;
	font-size: 1.1em;
	line-height: 1.8em;
	padding: 0 0 0 0;
	margin: 0 0 0 16px;
	list-style-position: outside;
	font-weight: 400;
	font-family: "Zen Maru Gothic", serif;
}

.p-each-spec ul li .ti {
	display: inline-block;
	position: relative;
	width: 120px;
	padding: 0 0 0 0;
	font-weight: 500;
}

.p-each-spec ul li .sp {
	display: inline-block;
	position: relative;
}

.p-each-spec ul .hosoku {
	display: block;
	position: relative;
	list-style: none;
	padding: 14px 12px 8px 16px;
	margin: 0 0 0 0;
	line-height: 160%;
}






@media screen and (max-width:768px) {


.p-each-content {
	display: block;
	position: relative;
	padding: 26px 30px 30px 30px;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
	overflow: hidden;
	background-image: url(../images/bland_mark_product2.png);
	background-position: right 10px bottom -50px;
	background-repeat: no-repeat;
}


	.p-each-img {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 auto 30px auto;
		top: 0;
		left: 0;
		width: 95%;
		height: auto;
		overflow: hidden;
	}

	.p-each-txt {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 auto 22px auto;
		width: 95%;
	}

	.p-all-txt {
		display: block;
		position: relative;
		padding: 0 0 0 2%;
		margin: 0 auto 22px auto;
		width: 95%;
	  }

}




@media screen and (max-width:480px) {


.p-each-content {
	display: block;
	position: relative;
	padding: 26px 18px 30px 18px;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
	overflow: hidden;
	background-image: url(../images/bland_mark_product2.png);
	background-position: right 10px top 70%;
	background-repeat: no-repeat;
}


	.p-each-img {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 auto 30px auto;
		top: 0;
		left: 0;
		width: 95%;
		height: auto;
		overflow: hidden;
	}

	.p-each-txt {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 0 22px 0;
		width: 100%;
	}

	.p-each-feature {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 0 18px 0;
		width: 100%;
	}

	.p-each-feature span {
		display: block;
		position: relative;
		font-size: 1.1em;
		line-height: 1.6em;
		padding: 0 0 0 0;
		margin: 0 0 0 6px;
		font-weight: 400;
		font-family: "Zen Maru Gothic", serif;
	}

	.p-each-spec {
		display: block;
		position: relative;
		padding: 0 0 0 0;
		margin: 0 0 18px 0;
		width: 100%;
	}

	.p-each-spec ul li {
		position: relative;
		font-size: 1.1em;
		line-height: 1.8em;
		padding: 0 0 0 0;
		margin: 0 0 0 6px;
		list-style-position: outside;
		font-weight: 400;
		font-family: "Zen Maru Gothic", serif;
	}

}





















.main-area .layout_left div.free {
	float: right;
	width: 58%;
	font-family: 'Zen Maru Gothic', sans-serif;
}

.main-area .layout_left div.free table,
.main-area .layout_right div.free table {
	width: 100% !important;
	min-width: 150px;
}

.main-area .layout_right p.imagination {
	float: right;
	padding-left: 2%;
}

.main-area .layout_right div.free {
	float: left;
	width: 58%;
	font-family: 'Zen Maru Gothic', sans-serif;
}

.main-area .free {
	display: block;
	position: relative;
	padding: 1em 0 2em 0;
	margin-bottom: 2em;
	text-align:left;
	line-height: 200%;
	font-weight: 400;
	font-family: 'Zen Maru Gothic', sans-serif;

}


.main-area .free a {
	text-decoration: underline;
}

.main-area .paragraph_lead {
	padding: 0 0 0 0;
	margin: 0 auto 0 auto;
	width: 88%;
	max-width: 1400px;
	height: auto;
	font-size: 1.1em;
	font-weight: 400;
	font-family: 'Zen Maru Gothic', sans-serif;

}

.main-area .paragraph_lead p{
	display: block;
	position: relative;
	font-size: 1em;
	line-height: 1.6;
	padding: 0 0 0 16px;
	margin: 0 0 0;
	color: inherit;
	border: none;
	font-weight: normal;
	font-family: 14px/1.8 'メイリオ', "Meiryo", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pr";
	letter-spacing: 8px;

}

@media only screen and (max-width: 630px){

	.main-area .paragraph_lead {
		padding: 0 0 0 0;
		margin: 0 auto 0 auto;
		width: 95%;
		max-width: 600px;
		height: auto;
		font-size: 1.1em;
	}

}


.main-area .free table{
	border-collapse:collapse;
	border:1px solid #CCCCCC;
	margin:10px auto 15px;
	max-width: 100% !important;
}

.main-area .free table td,
.main-area .free table th{
	border:1px solid #CCCCCC;
	padding: 0.5em;
}

.main-area .free ul,
.main-area .free ol {
	margin: 1em 0 0 1em;
	display: block;
}

.main-area .free ul li {
	list-style: inside;
	list-style-type: disc;
	padding:0 0 0.2em 0.5em;
}

.main-area .free ol li {
	list-style: inside;
	list-style-type: decimal;
	padding:0 0 0.2em 0.5em;
}

.main-area .free strong{
	font-weight: bold;
}




/* .asset-items ---------------------------------------------------------- */

.main-area .etc_box .free .asset-items {
	margin-right: 0 0 10px 0;
	width: 100%;
}

.main-area .etc_box .free .asset-item {
	padding-bottom: 5px;
}

.main-area .etc_box .free .asset-item-head {
	padding-left: 18px;
	padding-bottom: 8px;
	padding-right: 18px;
	padding-top: 10px;
	font-style: normal;
	font-weight: normal;
	font-size: 1em;
	line-height: 160%;
	text-align: left;
	vertical-align: middle;
}

.main-area .etc_box .free .asset-item-body {
	padding-left: 20px;
	padding-bottom: 8px;
	padding-right: 16px;
	padding-top: 10px;
	font-size: 1em;
	line-height: 180%;
	text-align: left;
	vertical-align: top;
}

.main-area .etc_box .free .asset-item-head {
	border-bottom: 1px solid #ccc;
	height: 32px;
	color: #333;
	background: #f4f7f8 repeat-x;
	margin-top: 8px;
	margin-bottom: 4px;
	width: 24%;
}

.main-area .etc_box .free .asset-item-body {
	border-bottom: 1px solid #ccc;
	height: auto;
	background: #fff;
	margin-top: 8px;
	margin-bottom: 4px;
}

.main-area .free p.withline {
	display: block;
	padding-top: 4px;
}

.main-area .free .qa01 {
	font-size: 1.4em;
	color: #ad346d;
	padding-right: 8px;
	padding-left: 2px;
	font-weight: bold;
}

.main-area .free .qa02 {
	font-size: 1.4em;
	color: #0b07ad;
	padding-right: 8px;
	padding-left: 2px;
	font-weight: bold;
}



#p-main .movie_part {
	position: relative;
	display: block;
	position: relative;
	width: 100%;
	margin: 0 auto 2em auto;
	padding-top: 56.25%;
}

#p-main .movie_part {
	position: relative;
	display: block;
	position: relative;
	width: 100%;
	margin: 0 auto 2em auto;
	padding-top: 56.25%;
}

#p-main .movie_part iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}





#p-main h2 {
	position: relative;
	padding: 14px 18px 14px 24px;
	margin: 0 0 28px 0;
	border-radius: 3px;
	background-color: #004198;
	color: #fff;
	font-size: 1.6em;
	line-height: 1.6em;
	font-weight: 400;
	font-family: "M PLUS Rounded 1c";
	letter-spacing: 0.5px;
}

#p-main h2::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 18px;
    width: 0;
    height: 0;
    border: 9px solid transparent;
    border-top: 9px solid #004198;
}






#p-main h3 {
  position: relative;
  padding: 9px 16px 11px 18px;
  margin: 10px 0 36px 0;
	font-weight: 400;
	font-family: "BIZ UDPGothic", sans-serif;
	letter-spacing: 0.5px;
	font-size: 1.4em;
	line-height: 1.5em;
  color: #0f4081;
  background-color: #fff;
  border-top: 2px solid #004198;
  border-bottom: 2px solid #004198;
	letter-spacing: 0.2px;
}




#p-main .detail_text {
	display: block;
	padding: 0 0 0 0;
	margin: 0 auto 0 auto;
	width: 88%;
	max-width: 1400px;
	height: auto;
	font-size: 1.2em;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;
}

@media only screen and (max-width: 630px){

	#p-main .detail_text {
		display: block;
		padding: 0 0 0 0;
		margin: 0 0 0 0;
		width: 100%;
		max-width: 630px;
		height: auto;
		font-size: 1.2em;
	}

}







#p-main .layout_center,
#p-main .layout_left,
#p-main .layout_right,
#p-main .layout_line {
	clear: both;
	display: block;
	position: relative;
	margin: 0 auto 36px auto;
	padding: 0 0 1em 0 ;
	width: 95%;
	max-width: 880px;
	overflow: hidden;
	font-size: 1.2em;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;
}


#p-main .layout_center {
	clear: both;
	display: block;
	position: relative;
	margin: 0 auto 36px auto;
	padding: 0 0 0 0;
	width: 100%;
	max-width: 1800px;
	height: auto;
}

#p-main .layout_center img {
	padding: 0 0 0 0;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
}



/* 左右 */

#p-main .layout_left p.imagination,
#p-main .layout_right p.imagination{
	max-width: 40%;
	text-align: center;
	padding: 0 0 1em 0;
}

#p-main .layout_left p.wizpain,
#p-main .layout_right p.wizpain {
	width: 40%;
}



/* 横並び 3点 */

#p-main .layout_center p.imagination {
	width: 100%;
	padding: 0 0 1em 0;
}

#p-main .layout_line p.imagination {
	display: block;
	position: relative;
	float: left;
	padding: 0 0 0 0;
	margin: 0 1.5% 18px 1.5%;
	width: 30.3%;
}

#p-main .layout_line p.imagination a,
#p-main .layout_center p.imagination a,
#p-main .layout_left p.imagination a,
#p-main .layout_right p.imagination a {
	color: #333;
	text-decoration: none;
	padding: 0 0 0 0;
}

#p-main .layout_line p.imagination a:hover  img,
#p-main .layout_center p.imagination a:hover  img,
#p-main .layout_left p.imagination a:hover  img,
#p-main .layout_right p.imagination a:hover  img {
	opacity:0.7;
}

#p-main .layout_line p.imagination img,
#p-main .layout_center p.imagination img,
#p-main .layout_left p.imagination img,
#p-main .layout_right p.imagination img {
	display: block;
	margin: 0 0 0 0;
	width: 100%;
	height: auto;
}

#p-main .layout_line p.imagination span,
#p-main .layout_center p.imagination span,
#p-main .layout_left p.imagination span,
#p-main .layout_right p.imagination span {
	display: block;
	text-align: left;
	margin: 0.5em auto 0 auto;
	padding: 0 0 24px 0;
	font-size: 0.9em;
}

/* DLボタン赤 */
#p-main .layout_line p.imagination .down-bt {
	display: block;
	position: relative;
	margin: 8px auto 8px auto;

	width: 60%;
	max-width: 120px;
	height: 28px;
	line-height: 30px;
	color: #fff;
	font-size: 0.8em;
	background-color: #e71619;
	text-align: center;
	border-radius: 20px;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
}


#p-main .layout_left p.imagination {
	float: left;
	padding-right: 2%;
}

#p-main .layout_left div.free {
	float: right;
	width: 58%;
	font-family: 'Noto Sans JP', sans-serif;
}

#p-main .layout_left div.free table,
#p-main .layout_right div.free table {
	width: 100% !important;
	min-width: 150px;
}

#p-main .layout_right p.imagination {
	float: right;
	padding-left: 2%;
}

#p-main .layout_right div.free {
	float: left;
	width: 58%;
	font-family: 'Noto Sans JP', sans-serif;
}




@media only screen and (max-width: 768px){


	#p-main .layout_left p.imagination {
		float: none;
		width: 95%;
		max-width: 600px;
		margin: 0 auto 0 auto;
		padding: 0 0 0 0;
		overflow: hidden;
	}

	#p-main .layout_left div.free {
		float: none;
		width: 90%;
		margin: 0 auto 40px auto;
		padding: 0 0 0 0;
		text-align: center;
	}

	#p-main .layout_right p.imagination {
		float: none;
		width: 95%;
		max-width: 600px;
		margin: 0 auto 0 auto;
		padding: 0 0 0 0;
		overflow: hidden;
	}

	#p-main .layout_right div.free {
		float: none;
		width: 90%;
		margin: 0 auto 40px auto;
		padding: 0 0 0 0;
		text-align: center;
	}


	#p-main .layout_left p.imagination span,
	#p-main .layout_right p.imagination span {
		display: block;
		margin: 0 0 0 0;
		text-align: left;
		margin: 0.5em auto 0 auto;
		font-size: 0.8em;
	}


}






#p-main .layout_center p.imagination {
	text-align:center;
}

#p-main .layout_left p.imagination img ,
#p-main .layout_right p.imagination img ,
#p-main .layout_center p.imagination img {
	margin: 0 auto;
}

#p-main .layout_line p.imagination {
	float: left;
}


/*
#p-main .layout_line p.edge {
	padding-left: 0;
}
*/

#p-main .scaleup_images {
	display: block;
	position: relative;
	margin: 0 0 0 0;
	padding: 0 0 0 0;

	transition: opacity 300ms;
	display: none;
	-moz-opacity: 0;
	opacity: 0;
	filter:alpha(opacity=0);
	position: fixed;
	top: 0;
	left: 0;
	text-align: center;
	width: 100%;
	height: 100%;
	z-index: 10001;
	/*background-color:rgba(51,51,51,0.96);*/
	background-color:rgba(244,240,235,1);
}

#p-main .scaleup_images_a {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 201;
}


/*closeの位置_161行目*/
/*
#p-main .scaleup_images_a span {
	display:block;
	position:absolute;
	top:10%;
	right:10%;
	color:#fff;
	margin-top:-1.4em;
	font-size:200%;
}

/*代替*/
#p-main .scaleup_images_a .close img {
	width: 44px;
	height: 44px;
	position: absolute;
	right: 36px;
	top: 36px;
	border: none;
}

#p-main .scaleup_images p {
	width: 80%;
	height: 100%;
	text-align: center;
	margin: auto;
	position: relative;
}

#p-main .scaleup_images p img {
	max-height:80%;
	max-width:100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	z-index: 202;
}




#p-main .layout_thumb {
	display: block;
	width: 100%;
	max-width: 880px;
	margin: 0 auto 3em auto;
	padding: 0 0 0 0;
	overflow: hidden;
	clear: both;
}

#p-main .layout_thumb .big_images {
	width: 100%;
	height: 0;
	margin-bottom: 1em;
	text-align: center;
	z-index: 1;
	transition: all 500ms;
	overflow: hidden;
	position: relative;
}

#p-main .layout_thumb .big_images li {
	transition: all 1s;
	margin: 0 auto;
	-moz-opacity: 1;
	filter:alpha(opacity=100);
	display: block;
	opacity: 0;
	position: absolute;
	z-index: 1;
	height: auto;
	width: auto;
}

#p-main .layout_thumb .big_images li img {
	width: 100%;
	z-index: 1;
	position: relative;
}

#p-main .layout_thumb .thumbs {
	display: block;
	width: 100%;
	padding: 0 0 0 0;
	margin: 0 0 36px 0;
	list-style: none;
	z-index: 3;
	overflow: hidden;
}

#p-main .layout_thumb .thumbs li {
	display: block;
	float: left;
	width: 19%;
	height: auto;
	margin: 0 0.5% 1% 0.5%;
	padding:0 ;
	position: relative;
	text-align:center;
	z-index: 3;
}

/*
#p-main .layout_thumb .thumbs li.edge {
	display: block;
	float:left;
	width: 19%;
	margin: 0 0.5% 1% 0.5%;
	padding:0 ;
	z-index: 3;
}
*/

#p-main .layout_thumb .thumbs li a {
	width: 100%;
	margin: 0;
	padding: 0;
	z-index: 3;
}

#p-main .layout_thumb .thumbs li a:hover {
	opacity:0.9;
	filter: alpha(opacity=90);        /* ie lt 8 */
	-ms-filter: "alpha(opacity=90)";  /* ie 8 */
}








#p-main .panel_map {
	margin: 0 1em 35px 1em;
	padding:0;
	text-align: center;
	position: relative;
}

#p-main .panel_map p {
	margin: 0 1em 2em 1em;
	text-align:left;
	color:#000000;
}

#p-main .panel_map .gmap {
	width: 100%;
	height: 350px;
	margin: 0 0 0 1em;
}

#p-main p.map_title {
	margin-bottom: 15px;
	padding: 4px 0;
	color:#555555;
	font-weight:bold;
	border-bottom:1px dotted #999999;
}

.gmap_tag iframe {
	width: 100%;
	height: 600px;
	margin: 40px 0 40px 0;
}

@media only screen and (max-width: 640px){

	.gmap_tag iframe {
		width: 100%;
		height: 350px;
	}

}







#p-main p.entry {
	display: none;
}

#p-main .panel_map .marker_pop {
	width:330px;
	padding-bottom:44px;
}

#p-main .panel_map .marker_pop p.marker_title {
	padding:0 0 3px;
	margin:0 0 10px;
	border-bottom:1px dotted #666666;
	color:#666666;
	font-weight: bold;
}

#p-main .panel_map .marker_pop p.marker_summary {
	margin:0;
	padding:0 0 10px;
	font-weight: normal;
}

#p-main .movie_part {
	display: block;
	position: relative;
	width: 100%;
	margin: 0 auto 2em auto ;
	padding-top: 56.25%;
}

#p-main .movie_part iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}

#p-main p.mov_title {
	margin-bottom: 30px;
	padding: 4px 0;
	color:#555555;
	font-weight:bold;
	border-bottom:1px dotted #999999;
}

#p-main .flashcontent {
	margin: 0 0 0;
	text-align: center;
}

#p-main .etc_box {
	display: block;
	width: 95%;
	max-width: 1400px;
	margin:0 auto 2em auto;
	padding:28px 12px 22px 12px ;
	background-color: #fff;
	overflow: hidden;
	border-radius: 3px;
}

#p-main .etc_box p.etc_title {
	padding: 0 0.5em 0.5em 0.5em;
}


/* DLアイコンカラー */

#p-main .etc_box p.etc_title .ipdf {
	font-size: 1.4em;
	color: #c11e07;
}

#p-main .etc_box p.etc_title .iexel {
	font-size: 1.4em;
	color: #1e7145;
}

#p-main .etc_box p.etc_title .iword {
	font-size: 1.4em;
	color: #2b5797;
}

#p-main .etc_box p.etc_title .ifile {
	font-size: 1.4em;
	color: #aa89bd;
}









#p-main .etc_box p.etc_title a {
	text-decoration: none;
	color: #004198;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 1.3em;
	line-height: 1.2em;
	padding: 0 0.5em 0 0.5em;
	text-decoration: underline;
	/*
	text-decoration: underline;
	padding-left: 22px;
	background:url(../common/arrow.png) no-repeat left center;
	background-size:7px;
	color: #625541;
	*/
}

#p-main .etc_box p.etc_title a:hover {
	text-decoration: none;
}


#p-main .etc_box p.etc_title img {
	width: 17px;
	vertical-align:middle;
}

#p-main .etc_box .free {
	margin: 0 1em 1em 2em;
	font-family: 'Noto Sans JP', sans-serif;
}

#p-main .etc_box dl dt:last-child,
#p-main .etcBox dl dd:last-child {
	margin-bottom: 0;
}




/* etc_box / free / table  ABSORBER */


/* .free table --------------------------------------------------------- */


#p-main .etc_box .free table {
	background-color: #fff;
	font-size: 1.2em;
	line-height: 1.3;
	border-style: none;
	border-collapse: collapse;
	border-spacing: 0;
}





/* .free ---------------------------------------------------------- */

#p-main .free {
	display: block;
	position: relative;
	padding: 1em 0 2em 0;
	margin-bottom: 2em;
	text-align:left;
	line-height: 200%;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;

}


#p-main .free a {
	text-decoration: underline;
}

#p-main .paragraph_lead {
	padding: 0 0 0 0;
	margin: 0 auto 0 auto;
	width: 88%;
	max-width: 1400px;
	height: auto;
	font-size: 1.2em;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;

}

@media only screen and (max-width: 630px){

	#p-main .paragraph_lead {
		padding: 0 0 0 0;
		margin: 0 auto 0 auto;
		width: 95%;
		max-width: 600px;
		height: auto;
		font-size: 1.2em;
	}

}


#p-main .free table{
	border-collapse:collapse;
	border:1px solid #CCCCCC;
	margin:10px auto 15px;
}

#p-main .free table td,
#p-main .free table th{
	border:1px solid #CCCCCC;
	padding: 0.5em;
}

#p-main .free ul,
#p-main .free ol {
	margin: 1em 0 0 1em;
	display: block;
}

#p-main .free ul li {
	list-style: inside;
	list-style-type: disc;
	padding:0 0 0.2em 0.5em;
}

#p-main .free ol li {
	list-style: inside;
	list-style-type: decimal;
	padding:0 0 0.2em 0.5em;
}

#p-main .free strong{
	font-weight: bold;
}




/* .asset-items ---------------------------------------------------------- */

#p-main .etc_box .free .asset-items {
	margin-right: 0 0 10px 0;
	width: 100%;
}

#p-main .etc_box .free .asset-item {
	padding-bottom: 5px;
}

#p-main .etc_box .free .asset-item-head {
	padding-left: 18px;
	padding-bottom: 8px;
	padding-right: 18px;
	padding-top: 10px;
	font-style: normal;
	font-weight: normal;
	font-size: 1em;
	line-height: 160%;
	text-align: left;
	vertical-align: middle;
}

#p-main .etc_box .free .asset-item-body {
	padding-left: 20px;
	padding-bottom: 8px;
	padding-right: 16px;
	padding-top: 10px;
	font-size: 1em;
	line-height: 180%;
	text-align: left;
	vertical-align: top;
}

#p-main .etc_box .free .asset-item-head {
	border-bottom: 1px solid #ccc;
	height: 32px;
	color: #333;
	background: #f4f7f8 repeat-x;
	margin-top: 8px;
	margin-bottom: 4px;
	width: 24%;
}

#p-main .etc_box .free .asset-item-body {
	border-bottom: 1px solid #ccc;
	height: auto;
	background: #fff;
	margin-top: 8px;
	margin-bottom: 4px;
}

#p-main .free p.withline {
	display: block;
	padding-top: 4px;
}

#p-main .free .qa01 {
	font-size: 1.4em;
	color: #ad346d;
	padding-right: 8px;
	padding-left: 2px;
	font-weight: bold;
}

#p-main .free .qa02 {
	font-size: 1.4em;
	color: #0b07ad;
	padding-right: 8px;
	padding-left: 2px;
	font-weight: bold;
}








/*
 * page newsBox
 */

#p-main .newsBox {
	display: block;
	width: auto;
	float: none;
	padding: 0 0 0 0;
	margin: 20px 0 0 0 ;
}

#p-main .newsBox li {
	display: table;
	-webkit-box-align: center;
	-webkit-align-items: center;
	 -ms-flex-align: center;
	     align-items: center;
	width: auto;
	padding: 8px 0 8px 0;
	margin: 0;
	table-layout: fixed;
	border-bottom: 1px dashed #959595;
}


#p-main .newsBox li em {
	display: table-cell;
	/*white-space: nowrap;
	overflow: hidden;
	text-overflow: clip;*/
	font-size: 15px;
	vertical-align: top;
	overflow: hidden;
}

#p-main .newsBox li em a {
	display: block;
	overflow: hidden;
}






#p-main .news_date {
	display: block;
	position: relative;
	text-align: right;
	font-size: 1.2em;
	line-height: 16px;
	padding: 0 0 0 0;
	margin: 2px 18px 22px 0;
	color: #082978;
	height: auto;
	min-height: 16px
}

/*
#p-main .news_date span {
	display: inline-block;
	padding: 0 0 0 0;
	margin: 0 12px 0 0;
	width: 58px;
	height: 23px;
	line-height: 23px;
	text-align: center;
	color: #fff;
	background-color: #e60011;
	font-size: 0.7em;
	border-radius: 3px;
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
}
*/




#p-main .news_date span {
	display: inline-block;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 10px 0 0;
	width: 58px;
	height: 22px;
	line-height: 22px;
}

#p-main .news_date span p {
	position: relative;
	text-align: center;
	padding: 3px 0 3px 0;
	color: #fff;
	background-color: #e60011;
	font-size: 0.8em;
	border-radius: 3px;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;
}

.p-detail .p-each-feature {
	margin: 0 0 2.5em 0;
	width: 100%;
  }
















.p-detail .p-each-feature span {
	display: block;
	position: relative;
	font-size: 1.1em;
	line-height: 1.6em;
	padding: 0 0 0 0;
	margin: 0 0 0 16px;
	font-weight: 400;
	font-family: inherit;
  }

.p-detail .main-area,
.p-detail .main-area .free,
.p-detail .main-area .paragraph_lead {
	font-family: inherit;
	/* padding: 0 0 0 0; */
	/* margin: 0 auto 2.5em; */
	/* width: 100%; */
/*max-width: 1400px;
	height: auto;
	border-radius: 3px;
	font-weight: 400;
	font-family: "Zen Maru Gothic", serif; */
}
.p-detail .main-area .free,
.p-detail .main-area .paragraph_lead {

	width: 100%;
	margin: 0 0 2.5em 16px;

}


