@charset "utf-8";

/******************************************
header
******************************************/
header {
	margin: 0;
	padding: 0;
}
header .inner {
	display: block;
	padding: 10px 2%;
}
header .inner #logo {
	float: left;
	position: initial;
	margin: 0;
}
#logo a {
	float: left;
	display: block;
}
#logo a:hover {
	opacity: 0.7;
}
#logo a.top img {
	max-height: 46px;
	width: auto;
}
#logo a.recruitTop img {
	max-height: 46px;
	width: auto;
}
#logo a:first-child {
	margin-right: 15px;
}
.mainVisual {
	height: 40vw;
	max-height: 440px;
}
.irregularHide {
	display: inline-block;
	position: initial;
	transform: initial;
}
hr {
	border: none;
	border-top: 1px dotted #a7a7a7;
	margin: 1em 0;
}
h3 {
	position: relative;
	line-height: 1.4;
	padding:0.25em 1em;
	display: inline-block;
	top:0;
	margin-top: 1.5em;
}

h3:before, h3:after { 
	position: absolute;
	top: 0;
	content:'';
	width: 8px;
	height: 100%;
	display: inline-block;
}

h3:before {
	border-top: dotted 2px #0666A8;
	border-left: dotted 2px #0666A8;
	border-bottom: dotted 2px #0666A8;
	left: 0;
}

h3:after {
	content: '';
	border-top: dotted 2px #0666A8;
	border-right: dotted 2px #0666A8;
	border-bottom: dotted 2px #0666A8;
	right: 0;
}
.btnSet.inquirySet ul li a {
	display: block;
	text-align: center;
	background-color: #FFF;
	border: 1px solid #AAA;
	color: #666;
	line-height: 2em;
	padding: 30px 80px 30px;
	font-size: 20px;
	letter-spacing: 0.1em;
}
.btnSet.inquirySet ul li a:hover{
	background-color: #06A3E0;
	border-color: #06A3E0;
	color: #FFF;
}
@media screen and (max-width: 890px) {
.headSet {
	padding: 10px 2%;
}
header .inner {
	display: block;
	padding: 0px 0%;
}
.headSet:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}
#logo a.top img {
	max-width: 466px;
	width: 100%;
}
}
@media screen and (max-width: 765px) {
#logo a:first-child{
	margin-right: 0;
}
.recruitTop{
	display: inline;
	text-align: center;
}
.recruitTop img{
	margin: auto;
}
.btnSet.inquirySet ul li a {
	padding: 30px 60px 30px;
	font-size: 15px;
}
}
@media screen and (max-width: 770px) {
.irregularHide {
	display: none;
}
}
@media screen and (max-width: 660px) {
header .inner #logo {
	float: none;
}
#logo a.top img {
	max-width: 466px;
	margin: 0 auto;
}
header .inner #logo a {
	float: none;
	width: 100%;
}
}