@charset "utf-8";
/* ==================================================
		
		ページ全般の共通 PC・SP

================================================== */

@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 100;
  src: url("../fonts/NotoSansJP-Thin.woff") format("woff"), url("../fonts/NotoSansJP-Thin.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 200;
  src: url("../fonts/NotoSansJP-ExtraLight.woff") format("woff"), url("../fonts/NotoSansJP-ExtraLight.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/NotoSansJP-Light.woff") format("woff"), url("../fonts/NotoSansJP-Light.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/NotoSansJP-Regular.woff") format("woff"), url("../fonts/NotoSansJP-Regular.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/NotoSansJP-Medium.woff") format("woff"), url("../fonts/NotoSansJP-Medium.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/NotoSansJP-SemiBold.woff") format("woff"), url("../fonts/NotoSansJP-SemiBold.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/NotoSansJP-Bold.woff") format("woff"), url("../fonts/NotoSansJP-Bold.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/NotoSansJP-ExtraBold.woff") format("woff"), url("../fonts/NotoSansJP-ExtraBold.otf") format("opentype");
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/NotoSansJP-Black.woff") format("woff"), url("../fonts/NotoSansJP-Black.otf") format("opentype");
}

/* --------------------------------------------------
		body
-------------------------------------------------- */
body {
 font-family: "Noto Sans JP";
 font-weight: 400;
 color: #333333;
 line-height: 1.4;
 position: relative;
}

/* --------------------------------------------------
		.clearfix
-------------------------------------------------- */
.clearfix {
	height: 0;
	clear: both;
	visibility: hidden;
	display: block;
	content: ".";
}

/* --------------------------------------------------
		link
-------------------------------------------------- */
.ldeco01 a:link, 
.ldeco01 a:visited  {
 color: #333333;
 text-decoration: underline;
 text-underline-offset: 9px;
 opacity: 1;
}
.ldeco02 a:link, 
.ldeco02 a:visited, 
.ldeco05 a:link, 
.ldeco05 a:visited {
 color: #333333;
 text-decoration: none;
}
.ldeco03 a:link, 
.ldeco03 a:visited  {
 color: #333333;
 text-decoration: underline;
 text-underline-offset: 5px;
 opacity: 1;
}
.ldeco04 a:link, 
.ldeco04 a:visited  {
 color: #ffffff;
 text-decoration: none;
}
.ldeco01 a:hover,
.ldeco03 a:hover {
 text-decoration: none;
}
.ldeco02 a:hover {
 color: #333333;
 text-decoration: none;
 transition: opacity 0.5s;
 opacity: 0.7;
}
.ldeco04 a:hover {
 color: #ffffff;
 transition: opacity 0.5s;
 opacity: 0.7;
}
.ldeco05 a:hover {
 color: #333333;
 text-decoration: none;
}

/* --------------------------------------------------
		parts
-------------------------------------------------- */
/*	横位置
-------------------------------------------------- */ 
.centered {
 text-align: center;
}
.leftjustified {
 text-align: left;
}
.rightjustified {
 text-align: right;
}
  
/*	flex
-------------------------------------------------- */ 
.col01 {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: center;
} 
.col02 {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: space-between;
} 
.col03 {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: flex-start;
} 
.col04 {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: flex-end;
} 
.colwrap {
 flex-wrap: wrap;
}
.colai01 {
 align-items: center;
}
.colai02 {
 align-items: baseline;
}
.colai03 {
 align-items: end;
}
.colai04 {
 align-items: flex-start;
}
.colfd01 {
 flex-direction: row-reverse;
}

/*	float
-------------------------------------------------- */ 
.fl {
 float: left;
}
.fr {
 float: right;
}


/* ==================================================
		
		ページ全般の共通 PC

================================================== */
@media screen and (min-width:741px) {
 
/* --------------------------------------------------
		SPの要素を非表示
-------------------------------------------------- */
.spDisp {
	display: none !important;
}

/* --------------------------------------------------
		body
-------------------------------------------------- */
body {
 font-size: 16px;
 min-width: 1200px;
}
 
/* --------------------------------------------------
		クリア
-------------------------------------------------- */
.pccolcl {
 display: block;
}
.pcflcl {
 float: none;
}

/* --------------------------------------------------
		link
-------------------------------------------------- */
.ldeco10 a:link, 
.ldeco10 a:visited  {
 color: #333333;
 text-decoration: underline;
 text-underline-offset: 9px;
 opacity: 1;
}
.ldeco10 a:hover {
 text-decoration: none;
}
 
/* --------------------------------------------------
		parts
-------------------------------------------------- */
.inner {
 width: 1140px;
 margin: 0 auto;
}
.contents p {
 font-size: 16px;
 color: #333333;
 line-height: 2;
 letter-spacing: 0;
 padding: 0;
 margin: 0;
}
 
/* --------------------------------------------------
		main
-------------------------------------------------- */
#main {
 margin-top: 90px !important;
}
 
/* --------------------------------------------------
		btn
-------------------------------------------------- */
.btn {
}
.btn a {
 display: block;
}

/*	.blue
-------------------------------------------------- */ 
.btnblue01 {
 display: block;
 background: #3e8db3;
 padding: 7px 0 10px !important;
 border-radius: 30px;
 width: 201px;
 margin: -8px auto 0 !important;
 position: absolute;
 bottom: -27px;
 left: 50%;
 transform: translateX(-50%);
}
.btnblue02,
.btnblue03 {
 display: block;
 background: #3e8db3;
 padding: 7px 0 10px !important;
 border-radius: 30px;
 width: 327px;
 margin: -8px auto 0 !important;
 position: relative;
 top: 27px;
}
a:hover .btnblue01, 
a:hover .btnblue02, 
a:hover .btnblue03 {
 background: #091c45;
}
.btnblue01 span, 
.btnblue02 span, 
.btnblue03 span {
 color: #ffffff !important;
}
.btnblue01 span::after {
 content: url(../images/arrow_plus.png);
 position: relative;
 top: 1px;
 margin-left: 11px;
}
.btnblue02 span::after {
 content: url(../images/arrow_down.png);
 position: relative;
 top: 1px;
 margin-left: 9px;
}
.btnblue03 span::after {
  content: url(../images/arrow_down.png);
  position: relative;
  top: 1px;
  margin-left: 9px;
} 
 
/* --------------------------------------------------
		スペース
-------------------------------------------------- */
.mt05 { margin-top: 5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt45 { margin-top: 45px !important; }
.mt50 { margin-top: 50px !important; }
.mt55 { margin-top: 55px !important; }
.mt60 { margin-top: 60px !important; }
.mt65 { margin-top: 65px !important; }
.mt70 { margin-top: 70px !important; }
.mt75 { margin-top: 75px !important; }
.mt80 { margin-top: 80px !important; }
.mt85 { margin-top: 85px !important; }
.mt90 { margin-top: 90px !important; }
.mt95 { margin-top: 95px !important; }
.mt100 { margin-top: 100px !important; }
.mt105 { margin-top: 105px !important; }
.mt110 { margin-top: 110px !important; }
.mt115 { margin-top: 115px !important; }
.mt120 { margin-top: 120px !important; }
.mt125 { margin-top: 125px !important; }
.mt130 { margin-top: 130px !important; }
.mt135 { margin-top: 135px !important; }
.mt140 { margin-top: 140px !important; }
.mt145 { margin-top: 145px !important; }
.mt150 { margin-top: 150px !important; }

.mb05 { margin-bottom: 5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb45 { margin-bottom: 45px !important; }
.mb50 { margin-bottom: 50px !important; }
.mb55 { margin-bottom: 55px !important; }
.mb60 { margin-bottom: 60px !important; }
.mb65 { margin-bottom: 65px !important; }
.mb70 { margin-bottom: 70px !important; }
.mb75 { margin-bottom: 75px !important; }
.mb80 { margin-bottom: 80px !important; }
.mb85 { margin-bottom: 85px !important; }
.mb90 { margin-bottom: 90px !important; }
.mb95 { margin-bottom: 95px !important; }
.mb100 { margin-bottom: 100px !important; }
.mb105 { margin-bottom: 105px !important; }
.mb110 { margin-bottom: 110px !important; }
.mb115 { margin-bottom: 115px !important; }
.mb120 { margin-bottom: 120px !important; }
.mb125 { margin-bottom: 125px !important; }
.mb130 { margin-bottom: 130px !important; }
.mb135 { margin-bottom: 135px !important; }
.mb140 { margin-bottom: 140px !important; }
.mb145 { margin-bottom: 145px !important; }
.mb150 { margin-bottom: 150px !important; }
 
.pt05 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt45 { padding-top: 45px !important; }
.pt50 { padding-top: 50px !important; }
.pt55 { padding-top: 55px !important; }
.pt60 { padding-top: 60px !important; }
.pt65 { padding-top: 65px !important; }
.pt70 { padding-top: 70px !important; }
.pt75 { padding-top: 75px !important; }
.pt80 { padding-top: 80px !important; }
.pt85 { padding-top: 85px !important; }
.pt90 { padding-top: 90px !important; }
.pt95 { padding-top: 95px !important; }
.pt100 { padding-top: 100px !important; }
.pt105 { padding-top: 105px !important; }
.pt110 { padding-top: 110px !important; }
.pt115 { padding-top: 115px !important; }
.pt120 { padding-top: 120px !important; }
.pt125 { padding-top: 125px !important; }
.pt130 { padding-top: 130px !important; }
.pt135 { padding-top: 135px !important; }
.pt140 { padding-top: 140px !important; }
.pt145 { padding-top: 145px !important; }
.pt150 { padding-top: 150px !important; }

.pb05 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb45 { padding-bottom: 45px !important; }
.pb50 { padding-bottom: 50px !important; }
.pb55 { padding-bottom: 55px !important; }
.pb60 { padding-bottom: 60px !important; }
.pb65 { padding-bottom: 65px !important; }
.pb70 { padding-bottom: 70px !important; }
.pb75 { padding-bottom: 75px !important; }
.pb80 { padding-bottom: 80px !important; }
.pb85 { padding-bottom: 85px !important; }
.pb90 { padding-bottom: 90px !important; }
.pb95 { padding-bottom: 95px !important; }
.pb100 { padding-bottom: 100px !important; }
.pb105 { padding-bottom: 105px !important; }
.pb110 { padding-bottom: 110px !important; }
.pb115 { padding-bottom: 115px !important; }
.pb120 { padding-bottom: 120px !important; }
.pb125 { padding-bottom: 125px !important; }
.pb130 { padding-bottom: 130px !important; }
.pb135 { padding-bottom: 135px !important; }
.pb140 { padding-bottom: 140px !important; }
.pb145 { padding-bottom: 145px !important; }
.pb150 { padding-bottom: 150px !important; }

}


/* ==================================================
		
		ページ全般の共通 SP

================================================== */
@media screen and (max-width:740px) {
 
/* --------------------------------------------------
		PCの要素を非表示
-------------------------------------------------- */
.pcDisp {
	display: none !important;
}

/* --------------------------------------------------
		body
-------------------------------------------------- */
body {
 font-size: 14px;
}
 
/* --------------------------------------------------
		img
-------------------------------------------------- */
img {
 width: 100%;
	max-width: 100%;
	height: auto;
}

/* --------------------------------------------------
		クリア
-------------------------------------------------- */
.spcolcl {
 display: block;
}
.spflcl {
 float: none;
}

/* --------------------------------------------------
		link
-------------------------------------------------- */
.ldeco10 a:link, 
.ldeco10 a:visited  {
 color: #333333;
 text-decoration: underline;
 text-underline-offset: 5px;
 opacity: 1;
}
.ldeco10 a:hover {
 text-decoration: none;
}
 
/* --------------------------------------------------
		parts
-------------------------------------------------- */
.inner {
 margin: 0 20px;
}
.contents p {
 font-size: 14px;
 color: #333333;
 line-height: 1.8;
 padding: 0;
 margin: 0;
}
 
/* --------------------------------------------------
		btn
-------------------------------------------------- */
.btn {
}
.btn a {
 display: block;
}

/*	.blue
-------------------------------------------------- */ 
.btnblue01, 
.btnblue02 {
 display: block;
 background: #3e8db3;
 padding: 5px 0 6px !important;
 border-radius: 30px;
 width: 90%;
 margin: -8px auto 0 !important;
 position: absolute;
 bottom: -20px;
 left: 50%;
 transform: translateX(-50%);
}

.btnblue03 {
  display: block;
  background: #3e8db3;
  padding: 5px 0 6px !important;
  border-radius: 30px;
  width: 90%;
  margin: -8px auto 0 !important;
  position: relative;
  bottom: -20px; 
}

a:hover .btnblue01 {
 background: #091c45;
}
.btnblue01 span, 
.btnblue02 span, 
.btnblue03 span {
 color: #ffffff !important;
}
.btnblue01 span::after {
 content: url(../images/arrow_plus.png);
 position: relative;
 top: 2px;
 margin-left: 9px;
}
.btnblue02 span::after {
 content: url(../images/arrow_down.png);
 position: relative;
 top: 2px;
 margin-left: 8px;
}
.btnblue03 span::after {
  content: url(../images/arrow_down.png);
  position: relative;
  top: 2px;
  margin-left: 8px;
 } 
 
/* --------------------------------------------------
		.table
-------------------------------------------------- */
.table01 dl {
 border-bottom: 1px solid #d8d8d8;
} 
.table01 dl:last-of-type {
 border-bottom: none;
} 
.table01 dl dt {
 font-weight: normal;
 width: 25%;
 background: #fbfbfb;
 padding: 0 10px 0 5px;
} 
.table01 dl dd {
 width: calc(100% - 25%);
 padding: 0 5px 0 10px;
} 
.table01 dl dd > ul li {
 text-indent: -14px;
 margin-left: 14px;
} 
.table01 dl dd > ul li::before {
 content: "・";
}  
.table01 .cap {
 font-size: 12px;
}  
.table02 li {
 width: 49%;
} 
.table02 li .txt {
 line-height: 1.7;
 padding: 0 5px;
} 
 
/* --------------------------------------------------
		スペース
-------------------------------------------------- */
.spmt05 { margin-top: 5px !important; }
.spmt10 { margin-top: 10px !important; }
.spmt15 { margin-top: 15px !important; }
.spmt20 { margin-top: 20px !important; }
.spmt25 { margin-top: 25px !important; }
.spmt30 { margin-top: 30px !important; }
.spmt35 { margin-top: 35px !important; }
.spmt40 { margin-top: 40px !important; }
.spmt45 { margin-top: 45px !important; }
.spmt50 { margin-top: 50px !important; }
.spmt55 { margin-top: 55px !important; }
.spmt60 { margin-top: 60px !important; }
.spmt65 { margin-top: 65px !important; }
.spmt70 { margin-top: 70px !important; }
.spmt75 { margin-top: 75px !important; }
.spmt80 { margin-top: 80px !important; }
.spmt85 { margin-top: 85px !important; }
.spmt90 { margin-top: 90px !important; }
.spmt95 { margin-top: 95px !important; }
.spmt100 { margin-top: 100px !important; }
.spmt105 { margin-top: 105px !important; }
.spmt110 { margin-top: 110px !important; }
.spmt115 { margin-top: 115px !important; }
.spmt120 { margin-top: 120px !important; }
.spmt125 { margin-top: 125px !important; }
.spmt130 { margin-top: 130px !important; }
.spmt135 { margin-top: 135px !important; }
.spmt140 { margin-top: 140px !important; }
.spmt145 { margin-top: 145px !important; }
.spmt150 { margin-top: 150px !important; }

.spmb05 { margin-bottom: 5px !important; }
.spmb10 { margin-bottom: 10px !important; }
.spmb15 { margin-bottom: 15px !important; }
.spmb20 { margin-bottom: 20px !important; }
.spmb25 { margin-bottom: 25px !important; }
.spmb30 { margin-bottom: 30px !important; }
.spmb35 { margin-bottom: 35px !important; }
.spmb40 { margin-bottom: 40px !important; }
.spmb45 { margin-bottom: 45px !important; }
.spmb50 { margin-bottom: 50px !important; }
.spmb55 { margin-bottom: 55px !important; }
.spmb60 { margin-bottom: 60px !important; }
.spmb65 { margin-bottom: 65px !important; }
.spmb70 { margin-bottom: 70px !important; }
.spmb75 { margin-bottom: 75px !important; }
.spmb80 { margin-bottom: 80px !important; }
.spmb85 { margin-bottom: 85px !important; }
.spmb90 { margin-bottom: 90px !important; }
.spmb95 { margin-bottom: 95px !important; }
.spmb100 { margin-bottom: 100px !important; }
.spmb105 { margin-bottom: 105px !important; }
.spmb110 { margin-bottom: 110px !important; }
.spmb115 { margin-bottom: 115px !important; }
.spmb120 { margin-bottom: 120px !important; }
.spmb125 { margin-bottom: 125px !important; }
.spmb130 { margin-bottom: 130px !important; }
.spmb135 { margin-bottom: 135px !important; }
.spmb140 { margin-bottom: 140px !important; }
.spmb145 { margin-bottom: 145px !important; }
.spmb150 { margin-bottom: 150px !important; }
 
.sppt05 { padding-top: 5px !important; }
.sppt10 { padding-top: 10px !important; }
.sppt15 { padding-top: 15px !important; }
.sppt20 { padding-top: 20px !important; }
.sppt25 { padding-top: 25px !important; }
.sppt30 { padding-top: 30px !important; }
.sppt35 { padding-top: 35px !important; }
.sppt40 { padding-top: 40px !important; }
.sppt45 { padding-top: 45px !important; }
.sppt50 { padding-top: 50px !important; }
.sppt55 { padding-top: 55px !important; }
.sppt60 { padding-top: 60px !important; }
.sppt65 { padding-top: 65px !important; }
.sppt70 { padding-top: 70px !important; }
.sppt75 { padding-top: 75px !important; }
.sppt80 { padding-top: 80px !important; }
.sppt85 { padding-top: 85px !important; }
.sppt90 { padding-top: 90px !important; }
.sppt95 { padding-top: 95px !important; }
.sppt100 { padding-top: 100px !important; }
.sppt105 { padding-top: 105px !important; }
.sppt110 { padding-top: 110px !important; }
.sppt115 { padding-top: 115px !important; }
.sppt120 { padding-top: 120px !important; }
.sppt125 { padding-top: 125px !important; }
.sppt130 { padding-top: 130px !important; }
.sppt135 { padding-top: 135px !important; }
.sppt140 { padding-top: 140px !important; }
.sppt145 { padding-top: 145px !important; }
.sppt150 { padding-top: 150px !important; }

.sppb05 { padding-bottom: 5px !important; }
.sppb10 { padding-bottom: 10px !important; }
.sppb15 { padding-bottom: 15px !important; }
.sppb20 { padding-bottom: 20px !important; }
.sppb25 { padding-bottom: 25px !important; }
.sppb30 { padding-bottom: 30px !important; }
.sppb35 { padding-bottom: 35px !important; }
.sppb40 { padding-bottom: 40px !important; }
.sppb45 { padding-bottom: 45px !important; }
.sppb50 { padding-bottom: 50px !important; }
.sppb55 { padding-bottom: 55px !important; }
.sppb60 { padding-bottom: 60px !important; }
.sppb65 { padding-bottom: 65px !important; }
.sppb70 { padding-bottom: 70px !important; }
.sppb75 { padding-bottom: 75px !important; }
.sppb80 { padding-bottom: 80px !important; }
.sppb85 { padding-bottom: 85px !important; }
.sppb90 { padding-bottom: 90px !important; }
.sppb95 { padding-bottom: 95px !important; }
.sppb100 { padding-bottom: 100px !important; }
.sppb105 { padding-bottom: 105px !important; }
.sppb110 { padding-bottom: 110px !important; }
.sppb115 { padding-bottom: 115px !important; }
.sppb120 { padding-bottom: 120px !important; }
.sppb125 { padding-bottom: 125px !important; }
.sppb130 { padding-bottom: 130px !important; }
.sppb135 { padding-bottom: 135px !important; }
.sppb140 { padding-bottom: 140px !important; }
.sppb145 { padding-bottom: 145px !important; }
.sppb150 { padding-bottom: 150px !important; }

}