@charset "utf-8";



/******************************************************************************
/* カテゴリーメインタイトル設定
******************************************************************************/

.main_title01 {
	position: relative;
	padding-top: 0px;
	padding-bottom: 10px;
	border-bottom: 4px solid #ccc;
	text-align: left;
	font-size: 130%;
	line-height: 110%;
	font-weight:700;
	margin-top: 50px;
	margin-bottom: 50px;
	color: #5472CD;
}

.main_title01::after {
	position: absolute;
	bottom: -4px;
	left: 0;
	z-index: 2;
	content: '';
	width: 20%;
	height: 4px;
	background-color: #5472CD;
}



.main_title01 p {
	font-size: 100%;
	line-height: 110%;
	font-weight:700;
	color: #AE2923;
	margin-bottom: 10px;
}




.main_title02 {
	position: relative;
	padding-top: 0px;
	padding-bottom: 10px;
	border-bottom: 4px solid #ccc;
	text-align: left;
	font-size: 130%;
	line-height: 110%;
	font-weight:700;
	margin-top: 0px;
	margin-bottom: 20px;
	color: #5472CD;
}

.main_title02::after {
	position: absolute;
	bottom: -4px;
	left: 0;
	z-index: 2;
	content: '';
	width: 20%;
	height: 4px;
	background-color: #5472CD;
}

.main_title02_sub {
	text-align: left;
	font-size: 110%;
	line-height: 110%;
	font-weight:700;
	color: #AE2923;
}


/******************************************************************************
/* カテゴリータイトル設定
*******************************************************************************/


.midashi_title2 {
	padding-left: 10px;
	margin-left:5px;
	border-left: 5px solid #3049A3;
	font-size: 100%;
	font-weight: 700;
}


 
.title_box2 {
	margin: 50px auto 50px auto;
	display:block;
	box-sizing:border-box;
	border: solid 1px #3049A3;
	width:100%;
	padding-left: 10px;
	padding-top: 10px;
	padding-bottom: 11px;
}

 
.midashi_title2 p {
	margin-top:2px;
	font-weight: 700;
}




/****************************************************************************************
/* 文字リンク
****************************************************************************************/


.textlink {
	position: relative;
	display: block;
	box-sizing:border-box;
	border-collapse:collapse;
	border-bottom: 1px solid #cccccc;

}



.textlink span {
	vertical-align: middle;

}


.textlink a {
	display: block;
	width:100%;
	position: relative;
	bottom: 0;
	right: 0;
	color: #333;
	width:100%;
	padding-top: 30px;
	padding-bottom: 30px;

}


.textlink:after {
  content: "";
  display: block;
  line-height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 120px;
  border-bottom: 1px solid #99DCE7;
}




.textlink a:hover {
	color: #2C91A7;
}


.textlink02 a::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0px;
	width: 0;
	height: 2px;
	border-collapse:collapse;
	background-color: #2C91A7;
	transition: 1.0s;
}

.textlink02 a:hover::after {
	width: 100%;
}





.link_icon {
	position: absolute;
	top: 50%;
	right: 0%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	width: 35px;
	height: 35px;

}





.link_icon2 {
	position: absolute;
	top: 40%;
	right: 0%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	width: 35px;
	height: 35px;
}







.news_title3 {
	font-size: 130%;
	font-weight: 700;
	margin-bottom: 35px;
}




 
.title_box {
	margin: 50px auto 0px auto;
	display:block;
	box-sizing:border-box;
	border: solid 1px #3049A3;
	width:100%;
	padding-left: 10px;
	padding-top: 10px;
	padding-bottom: 13px;
}


 
.title_box2 {
	position: relative;
	margin: 0px auto 5px auto;
	display:block;
	box-sizing:border-box;
	border: solid 1px #3049A3;
	width:100%;
	padding-left: 10px;
	padding-top: 10px;
	padding-bottom: 11px;
}


 
.title_box3 {
	position: relative;
	margin: 150px auto 5px auto;
	display:block;
	box-sizing:border-box;
	border: solid 1px #3049A3;
	width:100%;
	padding-left: 10px;
	padding-top: 10px;
	padding-bottom: 11px;
}





.midashi_title {
	margin: 0px auto 0px auto;
	padding-left: 10px;
	padding-top: 1px;
	margin-left:5px;
	margin-top:3px;
	margin-bottom:2px;
	border-left: 5px solid #3049A3;
	font-size: 100%;
	font-weight: 700;
	text-align: left;
}

 
.midashi_title p {
	display: inline-block;
	margin-top:1px;
	font-weight: 700;
}



ul.news {
   display: flex;
}

.news li{
	display: inline-block;
	vertical-align: top;
	position: relative;

}


.news li:nth-child(1){
	font-size: 90%;
	font-weight: 700;
	margin-right: 20px;
	margin-left: 5px;
	color: #5579B2;
	white-space: nowrap;
}


.news li:nth-child(2){
	font-size: 100%;
	font-weight: 700;
}



ul.news4 {
   display: flex;
}

.news4 li{
	display: inline-block;
	vertical-align: top;
	position: relative;

}


.news4 li:nth-child(1){
	font-size: 90%;
	font-weight: 700;
	margin-right: 10px;
	margin-left: 5px;
	color: #5579B2;
	white-space: nowrap;
}

.news4 li:nth-child(2){
	width: 100px;
	margin-top: -3px;
	margin-right: 10px;
	white-space: nowrap;
}

.news4 li:nth-child(3){
	font-weight: 700;
}



/******************************************************************************
/* ページタイトル
*******************************************************************************/




.page_title {
 	position: relative;
	box-sizing: border-box;
	width: 100%;
	margin: 0px auto 50px auto;
	padding-left: 35px;
	padding-top: 8px;
	padding-bottom: 10px;
	border: 1px solid #CCC;
	border-radius: 5px;
	font-size: 120%;
	font-weight:700;
	letter-spacing: 1.5px;
	text-align: left;
	color: #3C3C3C;
}
 
.page_title::after {
	position: absolute;
	top: 50%;
 	left:1.0em;
	transform:translateY(-50%);
	content: '';
	width: 5px;
	height:20px;
	background-color: #1AA3B7;
}




.page_title2 {
 	position: relative;
	box-sizing: border-box;
	width: 100%;
	margin: 80px auto 30px auto;
	padding-left: 35px;
	padding-top: 8px;
	padding-bottom: 10px;
	border: 1px solid #CCC;
	border-radius: 5px;
	font-size: 120%;
	font-weight:700;
	letter-spacing: 1.5px;
	text-align: left;
	color: #3C3C3C;
}
 
.page_title2::after {
	position: absolute;
	top: 50%;
 	left:1.0em;
	transform:translateY(-50%);
	content: '';
	width: 5px;
	height:20px;
	background-color: #1AA3B7;
}



/******************************************************************************
/* ノベルティ詳細ページレイアウト
*******************************************************************************/


.main_area {
	width: 100%;
	margin: 30px auto 0px auto;

}

.detail_main{
	width: 100%;
	margin: 0px auto 0px auto;
	font-size: 100%;
	display: flex;
	margin-bottom: 30px;
	flex-wrap: wrap;
}


.detail_main .flex-1 {
	flex: 1;
	margin-right: 30px;

}



.detail_main .flex-2 {
	flex: 1;

}



.detail_main .flex-2 p {
	margin-bottom: 30px;
	line-height: 2.0;

}




/******************************************************************************
/* お知らせボタン設定用
******************************************************************************/

.infordata_button {
	width: 100%;
	margin: 0 auto 0 auto;
	height: 50px;
	text-align: right;
}

.infor_button,
a.infor_button,
infor_button.btn {
  font-size: 90%;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding-left: 20px;
  padding-right: 20px;
  padding-top: 5px;
  padding-bottom: 5px;

  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
white-space: nowrap;

}

.infor_button--orange,
a.infor_button--orange {
	width: 150px;
  color: #fff;
  background-color: #eb6100;
}
.infor_button--orange:hover,
a.infor_button--orange:hover {
	width: 150px;

  color: #fff;
  background: #f56500;
}


/******************************************************************************
/* バックボックス設定
*******************************************************************************/



.back_box {
	margin: 50px auto 0px auto;
	width: 100%;
	text-align: right;

}





/******************************************************************************
/* 戻るボタン設定
*******************************************************************************/


.datafile_button {
	display: inline-block;
	height: 50px;
	width: 200px;
	text-decoration: none;
	font-size: 100%;
	font-weight: 700;
	text-align: center;
	color: #4758E0;
	border: 1px solid #cbcbcb;
	border-bottom: 1px solid #b2b1b1;
	text-shadow: 0px 1px 0px #fafafa;
	-webkit-box-shadow: 0 1px 0 #f5f5f5 inset, 1px 1px 1px #e9e9e9;
	-moz-box-shadow: 0 1px 0 #f5f5f5 inset, 1px 1px 1px #e9e9e9;
	box-shadow: 0 1px 0 #f5f5f5 inset, 1px 1px 1px #e9e9e9;
	background: #eeeeee;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0.5, #ffffff), color-stop(0.5, #eeeeee));
	background: -moz-linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	background: -o-linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	background: -ms-linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	background: linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#ffffff 50%', endColorstr='#eeeeee 50%');
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#ffffff 50%', endColorstr='#eeeeee 50%')";
	border-radius: 5px;
	margin-right: 0px;
	cursor: pointer;

}
.datafile_button:active{ 
	-ms-transform: translateY(2px);
	-webkit-transform: translateY(2px);
	transform: translateY(2px);
	box-shadow: none;
}

.datafile_button span {
	display: block;
	font-size: 70%;
	font-weight: 700;
	margin-top: 5px;
}

.datafile_button p {
	font-size: 100%;
	font-weight: 700;
	margin-top: 0px;
	margin-left: 0px;
}


/******************************************************************************
/* セミナー申し込みボタン設定
*******************************************************************************/



.datafile_button3 {
	display: inline-block;
	height: 60px;
	width: 420px;
	text-decoration: none;
	font-size: 100%;
	font-weight: 700;
	line-height: 60px;
	text-align: center;
	color: #4758E0;
	border: 1px solid #cbcbcb;
	border-bottom: 1px solid #b2b1b1;
	text-shadow: 0px 1px 0px #fafafa;
	-webkit-box-shadow: 0 1px 0 #f5f5f5 inset, 1px 1px 1px #e9e9e9;
	-moz-box-shadow: 0 1px 0 #f5f5f5 inset, 1px 1px 1px #e9e9e9;
	box-shadow: 0 1px 0 #f5f5f5 inset, 1px 1px 1px #e9e9e9;
	background: #eeeeee;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0.5, #ffffff), color-stop(0.5, #eeeeee));
	background: -moz-linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	background: -o-linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	background: -ms-linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	background: linear-gradient(top, #ffffff 50%, #eeeeee 50%);
	filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#ffffff 50%', endColorstr='#eeeeee 50%');
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#ffffff 50%', endColorstr='#eeeeee 50%')";
	border-radius: 5px;
	margin-right: 0px;
	cursor: pointer;

}
.datafile_button3:active{ 
	-ms-transform: translateY(2px);
	-webkit-transform: translateY(2px);
	transform: translateY(2px);
	box-shadow: none;
}



/******************************************************************************
/* アップロード済みPDF
*******************************************************************************/

.upload_box {
	background: #F5F5F5;
	border 1px solid #ff8e9d;
	font-size: 90%;
	font-weight: 700;
	padding: 20px;
}







.detail_image_size {
	object-fit: cover;
	width: 100%;
	height: 200px;
	object-position: 50% 50%
}




hr {
	height: 0;
	margin: 0;
	padding: 0;
	border: 0;
}

/* 点線 */
.hr1 {
	border-top: 1px solid #aaa;
	margin-bottom: 10px;
}





/******************************************************************************
/* ノベルティ詳細ページ写真レイアウト
*******************************************************************************/

ul.submenu_nav3 {
	width:100%; 
	display: block;
	margin-top: 20px;
	margin-bottom: 0px;
}





ul.submenu_nav3 li {
	letter-spacing:normal;
	display: block;
	width: 100%;
	vertical-align: top;
	text-align: left;
	margin-bottom: 20px;

}



/******************************************************************************
/* ノベルティ詳細ページ写真レイアウト
*******************************************************************************/

ul.submenu_nav4 {
	width:100%; 
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-top: 50px;
	margin-bottom: 20px;
}


ul.submenu_nav4::after {
	content: "";
	display: block;
	width: 32%;
	height: 0;
}




ul.submenu_nav4 li {
	letter-spacing:normal;
	display: inline-block;
	width: 32%;
	vertical-align: top;
	text-align: center;
	margin-bottom: 20px;

}

ul.submenu_nav4 li .detail_image_size {
	width: 100%;
	height: 200px;
	object-fit: cover;
	object-position: 50% 50%
}



ul.submenu_nav4 li p {
	font-size: 90%;
	margin-top: 10px;
	text-align: center;
	font-weight: 700;
	color: #5472CD;
}



ul.submenu_nav4 img {
	border-radius: 8px;

}


/******************************************************************************
/* お知らせ本文設定
*******************************************************************************/


.news_comment_area {
	display: block;
	margin: 0 auto 0 auto;
	width: 100%;
	line-height: 1.6;
	margin-bottom: 30px;
}

.news_comment_area p {
	font-weight: 700;
}




/*------------------------------------------------------------*/
/*------------------------------------------------------------*/
/* 601 - 768用（タブレット用）の記述 */
/*------------------------------------------------------------*/
/*------------------------------------------------------------*/


/******************************************************************************
/* タブレットサイズ
*******************************************************************************/


@media screen and (max-width:1200px) {



.pcOnly {
	display: none!important;
}
.spOnly {
	display: block!important;
}







}



/*------------------------------------------------------------*/
/*------------------------------------------------------------*/
/* 600px - 100px用（スマートフォン用）の記述 */
/*------------------------------------------------------------*/
/*------------------------------------------------------------*/


@media screen and (min-width: 100px) and (max-width: 600px)  {



/******************************************************************************
/* ノベルティ詳細ページレイアウト
*******************************************************************************/


.main_area {
	width: 100%;
	margin: 30px auto 0px auto;

}

.detail_main{
	width: 100%;
	margin: 0px auto 0px auto;
	font-size: 100%;
	display: block;
	margin-bottom: 30px;
	flex-wrap: nowrap;
}


.detail_main .flex-1 {
	display: block;
	margin-right: 0px;

}



.detail_main .flex-2 {
	display: block;

}



.detail_main .flex-2 p {
	margin-bottom: 30px;
	line-height: 2.0;

}



.infordata_button {
	width: 90%;
	margin: 0 auto 0 auto;
	height: 100px;
	text-align: right;
}



}
