@charset "utf-8";


/**************************************************50
 * common
 **************************************************/
*{
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
body, html{
	margin: 0;
	height: 100%;
	width: 100%;
}
html{
	font-display: swap;
	font-family: "Noto Sans JP", -apple-system, "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "BIZ UDGothic", "メイリオ", Meiryo, "Meiryo UI", sans-serif;
	font-size: 16px;
	line-height: 2;
	color: #333333;
	padding: 0;
	min-width: 1260px;
}
body{
	padding: 80px 0 0;
}
h1,h2,h3,h4,h5,h6{
	margin: 0;
	font-size: inherit;
}
img{
	border: none;
}
ol, ul, p, dl, dt, dd, figure, figcaption{
	margin: 0;
	padding: 0;
}
ul,ol{
	list-style-type: none;
}
ol li, ul li{
	list-style: none;
}
iframe{
	border: none;
}
.wrap{
	padding-left: -webkit-calc((100% - 1260px) / 2);
	padding-left: calc((100% - 1260px) / 2);
	padding-right: -webkit-calc((100% - 1260px) / 2);
	padding-right: calc((100% - 1260px) / 2);
	min-width: 1260px;
}

/** - font - **/
.serif{
	font-family: "Noto Serif JP", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "BIZ UDMincho", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

/** - color - **/
.blue{
	color: #004DC5;
}

/** - title - **/
.title-block{
	padding: 0;
	overflow: hidden;
}
.title-block-blue{
	margin: 3px 0 0 0;
}
.title-block img{
	float: left;
	opacity: 0;
}
.title_borderLR{
	font-size: 275%;
	font-weight: normal;
	line-height: 70px;
	margin: -20px auto 30px;
	position: relative;
	width: 540px;
}
.title_borderLR:before,
.title_borderLR:after{
	background: -webkit-linear-gradient(top, #7B8CFF 0, #46ECFF 100%);
	background: linear-gradient(0deg, #7B8CFF 0, #46ECFF 100%);
	content: "";
	display: block;
	height: 120px;
	position: absolute;
	top: 50%;
	-ms-transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 1px;
}
.title_borderLR:before{
	left: 0;
}
.title_borderLR:after{
	right: 0;
}
.title_borderLR strong{
	color: #29ABFF;
	font-weight: normal;
}

/** - breadcrumbs - **/
.breadcrumbs{
	padding-top: 10px;
	padding-bottom: 10px;
	text-align: right;
	font-size: 75%;
}
.breadcrumbs > *{
	color: #666;
	display: inline-blok;
}
.breadcrumbs > a{
	text-decoration: underline;
}
.breadcrumbs > a:hover{
	text-decoration: none;
}
.breadcrumbs > *:first-child:before{
	margin: 0 7px 0 0;
	content: url(../images/icon/rabbit.png);
}
.breadcrumbs > *:not(:first-child):before{
	content: "\F142";
	font-family: "Material Design Icons";
	margin: 0 1em;
}

/** - list - **/
.list_dot{
}
.list_dot > li{
	padding-left: 1em;
	text-indent: -1em;
}
.list_dot > li:before{
	content: "・";
	text-indent: 0;
}
.list_dot > li *,
.list_dot > li *:before{
	text-indent: 0;
}
.list_brackets{
	counter-reset: brackets;
}
.list_brackets{
	padding-left: 2em;
	text-indent: -2em;
}
.list_brackets > li:before{
	counter-increment: brackets 1;
	content: "(" counter(brackets) ")";
	text-indent: 0;
	display: inline-block;
	width: 2em;
}
.list_square{
}
.list_square > li{
	padding-left: 1em;
	text-indent: -1em;
}
.list_square > li:before{
	content: "\F12E";
	font-family: "Material Design Icons";
	text-indent: 0;
}
.list_square > li *,
.list_square > li *:before{
	text-indent: 0;
}
.list_circle{
}
.list_circle > li{
	padding-left: 1em;
	text-indent: -1em;
}
.list_circle > li:before{
	content: "\F764";
	font-family: "Material Design Icons";
	text-indent: 0;
}
.list_circle > li *,
.list_circle > li *:before{
	text-indent: 0;
}

/** - title - **/
.title_border{
	background: -webkit-linear-gradient(left, #7B8CFF 0, #46ECFF 100%);
	background: linear-gradient(90deg, #7B8CFF 0, #46ECFF 100%);
	margin: 0 auto 50px;
	padding: 5px;
	width: 280px;
}
.title_border > div{
	background-color: #FFFFFF;
	color: #29ABFF;
	height: 230px;
	line-height: 1;
	padding: 40px;
	position: relative;
}
.title_border > div:before{
	background-color: #29ABFF;
	content: "";
	display: block;
	height: 25px;
	position: absolute;
	top: 115px;
	left: 50%;
	-ms-transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 1px;
}
.title_border > div:after{
	background: url("../images/industry/rabbit.png") center center no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 70px;
	position: absolute;
	bottom: 15px;
	left: 50%;
	-ms-transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 70px;
}
.title_border > div b{
	display: block;
	font-size: 200%;
}
.title_border > div span{
	display: block;
	font-size: 87.5%;
	margin-top: 10px;
}

/** - link - **/
.link_to{
	background: -webkit-linear-gradient(left, #344CE8 0, #00CBFF 100%);
	background: linear-gradient(90deg, #344CE8 0, #00CBFF 100%);
	border-radius: 100px;
	display: inline-block;
	overflow: hidden;
	padding: 2px;
	position: relative;
	text-decoration: none;
	vertical-align: middle;
	width: 270px;
}
.link_to:before{
	content: "\F142";
	font-family: "Material Design Icons";
	font-size: 150%;
	position: absolute;
	top: 50%;
	left: 1em;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.link_to:hover:before{
	color: #FFFFFF;
}
.link_to span{
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-color: #FFFFFF;
	border-radius: 100px;
	color: #004DC5;
	display: block;
	font-size: 87.5%;
	height: 48px;
	line-height: 48px;
	transition: background-color 0.2s ease-out 0s;
}
.link_to:hover span{
	background-color: transparent;
	color: #FFFFFF;
}

/** - pager - **/
.pager{
	margin-top: 50px;
	text-align: center;
}
.pager_num{
}
.pager_link{
}
.pager_link > *{
	border-style: solid;
	border-width: 1px;
	display: inline-block;
	height: 36px;
	line-height: 36px;
	vertical-align: middle;
	width: 36px;
}
.pager_link > a{
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-color: #FFFFFF;
	border-color: #004DC5;
	color: #004DC5;
	position: relative;
	text-decoration: none;
	transition: all 0.2s ease-out 0s;
}
.pager_link > a:hover{
	background-color: #004DC5;
	color: #FFFFFF;
}
.pager_link > a.mdi:before{
	font-size: 150% !important;
	line-height: 1;
	position: absolute;
	top: 50%;
	left: 50%;
	-ms-transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.pager_link > span{
	background-color: #004DC5;
	border-color: #004DC5;
	color: #FFFFFF;
}
.pager_link > strong{
	border: none;
}
.pager_link > * + *{
	margin-left: 20px;
}
.pager_num + .pager_link,
.pager_link + .pager_num{
	margin-top: 10px;
}


/**************************************************50
 * header
 **************************************************/
header{
	background-color: #004DC5;
	position: fixed;
	top: 0;
	left: 0;
	text-align: center;
	width: 100%;
	min-width: 1260px;
	z-index: 1000;
}
header:after{
	clear: both;
	content: "";
	display: block;
}
header > div{
	background-color: #FFFFFF;
	height: 80px;
	margin: 0 auto;
	padding: 0 70px;
	position: relative;
	width: 1260px;
}
header > div:before,
header > div:after{
	border-style: solid;
	content: "";
	display: block;
	height: 0;
	position: absolute;
	top: 50%;
	-ms-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 0;
}
header > div:before{
	border-color: transparent transparent transparent #004CC5;
	border-width: 80px 0 0 70px;
	left: 0;
}
header > div:after{
	border-color: transparent #004CC5 transparent transparent;
	border-width: 0 70px 80px 0;
	right: 0;
}
header > div #header_logo{
	display: block;
	float: left;
	height: 80px;
	line-height: 80px;
	margin-right: 10px;
}
header > div #header_logo img{
	height: 48px;
	vertical-align: middle;
}
header > div > p{
	float: left;
	height: 80px;
	line-height: 1;
	padding-top: 24px;
	text-align: left;
	width: 290px;
}
header > div > p span{
	display: block;
	font-size: 75%;
}
header > div > p strong{
	color: #29ABFF;
	display: block;
	font-size: 87.5%;
	margin-top: 6px;
}
header > div nav{
	float: right;
	width: 500px;
}
header > div nav p{
	font-size: 75%;
	height: 24px;
	line-height: 24px;
	padding: 0 1em;
	text-align: right;
}
header > div nav p a{
	color: #004DC5;
	text-decoration: none;
}
header > div nav p a:not(:first-child){
	margin-left: 1em;
}
header > div nav p a:hover,
header > div nav p a.active{
	text-decoration: underline;
}
header > div nav p a:before{
	content: "\F40A";
	font-family: "Material Design Icons";
}
header > div nav > a{
	color: #333333;
	display: inline-block;
	height: 56px;
	line-height: 1;
	position: relative;
	padding: 13px 5px;
	text-decoration: none;
	vertical-align: middle;
	width: 100px;
}
header > div nav > a:hover,
header > div nav > a.active{
	color: #004DC5;
}
header > div nav > a:after{
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-color: #004DC5;
	content: "";
	display: block;
	height: 2px;
	position: absolute;
	top: 50%;
	left: 50%;
	-ms-transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	transition: width 0.2s ease-out 0s;
	width: 0;
}
header > div nav > a:hover:after,
header > div nav > a.active:after{
	width: 80%;
}
header > div nav > a b{
	display: block;
	font-size: 75%;
}
header > div nav > a span{
	display: block;
	font-size: 75%;
	margin-top: 6px;
}
header > div a[href$="?page=contact"]{
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	background-color: #D20000;
	color: #FFFFFF;
	display: block;
	float: right;
	height: 80px;
	line-height: 1;
	padding: 25px 5px;
	text-decoration: none;
	transition: opacity 0.2s ease-out 0s;
	width: 80px;
}
header > div a[href$="?page=contact"]:hover{
	opacity: 0.7;
}
header > div a[href$="?page=contact"] b{
	display: block;
	font-size: 75%;
}
header > div a[href$="?page=contact"] span{
	display: block;
	font-size: 75%;
	margin-top: 6px;
}
#btn_totop{
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	cursor: pointer;
	position: fixed;
	bottom: 0;
	left: -webkit-calc(50% + 650px);
	left: calc(50% + 650px);
	transition: opacity 0.2s ease-out 0s;
	width: 70px;
}
#btn_totop:hover{
	opacity: 0.7;
}


/**************************************************50
 * footer
 **************************************************/
footer{
	text-align: center;
}
#footer_office{
	margin-top: 20px;
	margin-bottom: 50px;
}
#footer_office > li{
	border: 1px solid #004DC5;
	display: inline-block;
	line-height: 1.6;
	margin-top: 30px;
	padding-top: 20px;
	vertical-align: top;
	width: 282px;
}
#footer_office > li:not(:nth-child(4n+1)){
	margin-left: 24px;
}
#footer_office > li > div{
	background-color: #004DC5;
	border-radius: 5px;
	color: #FFFFFF;
	margin: 0 auto 20px;
	padding: 10px;
	width: -webkit-calc(100% - (20px * 2));
	width: calc(100% - (20px * 2));
}
#footer_office > li > div strong{
	display: block;
	font-size: 150%;
	font-weight: normal;
}
#footer_office > li > div span{
	display: block;
	font-size: 75%;
}
#footer_office > li > div span:before,
#footer_office > li > div span:after{
	content: "\F374";
	font-family: "Material Design Icons";
}
#footer_office > li > p:not(.blue){
	height: 3.5em;
}
#footer_office > li > p.blue{
	font-size: 87.5%;
}
#footer_office > li iframe{
	height: 195px;
	margin-top: 20px;
	vertical-align: middle;
	width: 100%;
}
#footer_info{
	background-color: #F5F5F5;
	padding-top: 30px;
	padding-bottom: 30px;
}
#footer_info:after{
	clear: both;
	content: "";
	display: block;
}
#footer_info figure{
	float: left;
	margin-left: 155px;
	width: 330px;
}
#footer_info figure picture{
}
#footer_info figure picture img{
	border-radius: 50%;
	width: 120px;
}
#footer_info figure figcaption{
}
#footer_info figure figcaption h2{
	color: #004DC5;
	font-size: 150%;
	margin-top: 10px;
	margin-bottom: 10px;
}
#footer_info figure figcaption p{
	font-size: 87.5%;
}
#footer_info table{
	border-collapse: separate;
	border-spacing: 0 10px;
	float: right;
	font-size: 75%;
	margin: -10px 155px -10px 0;
	width: 525px;
}
#footer_info table tr th{
	border: 1px solid #004DC5;
	color: #004DC5;
	width: 100px;
}
#footer_info table tr td{
	padding-left: 1em;
	text-align: left;
}
#copyright{
	background-color: #004DC5;
	color: #FFFFFF;
	font-size: 75%;
	height: 50px;
	line-height: 50px;
}
#copyright a{
	color: #FFFFFF;
	text-decoration: none;
}


/**************************************************50
 * footer
 **************************************************/
#page404 {
	padding: 50px;
	text-align: center;
	height: 600px;
}
