@charset "utf-8";

/********************
共通
********************/
*{
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	word-break: break-all;
}

html{
	min-width: 1100px;
	line-height: 1.7;
	letter-spacing: 0.05em;
}

body{
	font-size: 1.4rem;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	overflow: hidden;
}

main{
	width: 700px;
}

.inner{
	max-width: 960px;
	margin: 0 auto;
	position: relative;
}

.contents{
	padding: 70px 0;
}

img{
	max-width: 100%;
	vertical-align: middle;
	font-size: 0;
	line-height: 0;
	-webkit-backface-visibility: hidden;
}

a:hover{ 
	opacity: 0.6;
}

#title{
	background: url("../img/title_bg.jpg") no-repeat center;
	background-size: cover;
	padding: 70px 0;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2),
only screen and (min--moz-device-pixel-ratio: 2),
only screen and (-o-min-device-pixel-ratio: 2/1),
only screen and (min-device-pixel-ratio: 2),
only screen and (min-resolution: 192dpi),
only screen and (min-resolution: 2dppx) {
	.title{
		background-image: url("../img/title_bg@2x.jpg");
	}
}

#title h2{
	text-align: center;
	font-size: 3.4rem;
	font-weight: bold;
	line-height: 1;
	letter-spacing: 0.13em;
	color: #fff;
}

.flex{
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

p + p{
	margin-top: 15px;
}

ol.decimal{
	padding-left: 20px;
}

ol.decimal > li{
	list-style: decimal;
}

ol.decimal > li:not(:last-child){
	margin-bottom: 10px;
}

ol.count{
	padding-left: 20px;
}

ol.count > li{
	list-style: decimal;
	position: relative;
}

ol.count > li:not(:last-child){
	margin-bottom: 10px;
}

ol.count > li{
	list-style-type: none;
	counter-increment: cnt;
}

ol.count > li::before{
	content: "(" counter(cnt) ") ";
	left: -20px;
	position: absolute;
}

ol.count > li .position{
	position: relative;
	left: -20px;
}

.grayBox{
	background: #f5f5f5;
	padding: 20px;
	margin-top: 20px;
}

.block{
	display: block;
}

.pc{
	display: block !important;
}

.sp{
	display: none !important;
}

#pankuzu{
	background-color: #f5f5f5;
	font-size: 1.2rem;
	line-height: 3;
}

#pankuzu ul{
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}

#pankuzu ul li:not(:first-child)::before{
	content: "/";
	margin: 0 10px;
}

#pankuzu ul li a{
	-webkit-transition: .3s;
	transition: .3s;
}

#pankuzu ul li a:hover{
	text-decoration: none;
	opacity: 0.6;
}

main h3.basic{
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1.2;
	border-top: 2px solid #0548a8;
	background-color: #f5f5f5;
	padding: 20px;
	margin: 50px 0 20px;
}

main h3.basic:first-child{
	margin-top: 0;
}

main h4{
	font-size:1.8rem;
	font-weight: bold;
	line-height: 1.2;
	background-color: #f5f5f5;
	padding: 15px 15px 15px 20px;
	margin: 20px 0;
	position: relative;
}

main h4::before{
	content: "";
	width: 5px;
	height: 20px;
	background-color: #0548a8;
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -10px;
}

/********************
header
********************/
header{
	min-width: 1100px;
	position: relative;
	z-index: 10000;
}

header .upper{
	font-size: 1rem;
	line-height: 1;
	color: #666;
	padding: 15px 0;
}

header .upper ul{
	align-items: center;
}

header .upper ul li:not(:first-child)::before{
	content: "";
	display: inline-block;
	width: 1px;
	height: 10px;
	background-color: #999;
	margin: 0 10px;
}

header .lower{
	align-items: center;
	padding: 10px 0 25px;
}

header .logo{
	height: 40px;
}

header .lower dl dt{
	font-size: 1rem;
	line-height: 1.3;
	text-align: right;
	color: #666;
	margin-right: 15px;
}

header .lower dl dt strong{
	font-size: 1.4rem;
	color: #0548a8;
}

header .lower dl dt span{
	font-size: 2.2rem;
}

header .lower dl dd a{
	display: block;
	background: #0548a8;
	color: #fff;
	text-align: center;
	font-size: 1.4rem;
	font-weight: bold;
	padding: 10px 30px;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

.wrap header{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1;
}

.wrap header .upper{
	color: #fff;
}

.wrap header .upper a{
	color: #fff;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

.wrap header .upper ul li:not(:first-child)::before{
	background-color: #fff;
}

.wrap header .lower dl dt{
	color: #fff;
	font-weight: bold;
}

.wrap header .lower dl dt strong{
	color: #fff;
}

header .upper a{
	color: #666;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

/********************
nav
********************/
.navBtn,
#open{
	display:none;
}

nav{
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	background-color: #fff;
}

nav ul li{
	width: 192px;
	border-left: 1px solid #ddd;
}

nav ul li:nth-last-child(2){
	border-right: 1px solid #ddd;
}

nav ul li:last-child{
	display: none;
}

nav ul li a{
	display: block;
	padding: 20px;
	text-align: center;
	line-height: 1;
	font-weight: bold;
	font-size: 1.6rem;
	color: #333;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

nav ul li a:hover{
	background-color: #f5f5f5;
	color: #0548a8;
	opacity: 1;
}

nav ul li.ac a{
	color: #0548a8;
	border-bottom: 1px solid #0548a8;
}

.wrap nav{
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 1;
}

/********************
kv
********************/
#kv{
	width: 1920px;
	height: 716px;
	left: 50%;
	-webkit-transform: translateX(-960px);
	transform: translateX(-960px);
	position: relative;
	overflow: hidden;
}

#kv .bxslider li{
	position: relative;
	max-width: initial;
}

#kv .bxslider li > img{
	width: 1920px;
	height: 716px;
	max-width: initial;
}

.objectFit{
  object-fit: cover;
  object-position: left top;
  font-family: 'object-fit: cover; object-position: left top;';
}

/********************
トップ
********************/
ul.home01 li{
	width: 335px;
}

ul.home01 li p{
	font-size: 1.3rem;
	margin-top: 10px;
}

ul.home01 li a{
	display: block;
	position: relative;
	color: #fff;
	overflow: hidden;
	background-color: #000;
}

ul.home01 li a img{
	-webkit-transition: .3s;
	transition: .3s;
	width: 100%;
}

ul.home01 li a h2{
	font-size: 3rem;
	font-weight: bold;
	letter-spacing: 0.08em;
	line-height: 1;
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translateY(-50%) translateX(-50%);
	transform: translateY(-50%) translateX(-50%);
	z-index: 1;
}

ul.home01 li a h2::after{
	position: absolute;
	content: "";
	width: 10px;
	height: 10px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: calc(50% - 5px);
	right: -80px;
	z-index: 10;
}

ul.home01 li a h2 span{
	display: block;
	font-size: 1.4rem;
	margin-top: 10px;
}

ul.home01 li a:hover{
	opacity: 1;
}

ul.home01 li a:hover img{
	-webkit-transform: scale(1.03);
	transform: scale(1.03);
	opacity: 0.6;
}

/********************
aside
********************/
aside {
	display: block;
	width: 220px;
}

.cta{
	background-color: #0548a8;
	color: #fff;
	text-align: center;
	line-height: 1;
}

.cta p{
	border-bottom: 1px solid #fff;
	font-weight: bold;
	font-size: 1.6rem;
	padding: 15px 0;
}

.cta dl{
	padding: 15px 15px;
}

.cta dl dt{
	font-size: 1.1rem;
	line-height: 1.3;
	margin-bottom: 15px;
	font-weight: bold;
}

.cta dl dt strong{
	font-size: 1.2rem;
}

.cta dl dt span{
	font-size: 1.8rem;
	margin-bottom: 5px;
	display: inline-block;
}

.cta dl dd a{
	display: block;
	background: #fff;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1;
	padding: 10px;
	color: #0548a8;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

/********************
footer
********************/
footer{
	background-color: #1b1b1b;
	color: #999;
	padding: 30px 0;
}

footer h1{
	font-weight: bold;
}

footer a{
	color: #999;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

footer ul{
	width: 510px;
	}

footer ul li{
	width: 125px;
	float: left;
	line-height: 2;
}

footer ul li:last-child{
	width: auto;
}

footer ul li a::before{
	content: "";
	display: inline-block;
	width: 4px;
	height: 4px;
	border-top: 1px solid #999;
	border-right: 1px solid #999;
	transform: rotate(45deg);
	vertical-align: 4px;
	margin-right: 7px;
}

footer .call{
	padding-right: 12px;
}

/********************
pagetop
********************/
.pagetop{
	position: fixed;
	bottom: 50px;
	right: 50px;
	z-index: 10;
}

.pagetop a{
	line-height: 50px;
	width: 50px;
	background: #0548a8;
	display: block;
	text-align: center;
	-webkit-transition: .3s;
	transition: .3s;
}

.pagetop img{
	max-width: 100%;
	vertical-align: middle;
	font-size: 0;
	line-height: 0;
	-webkit-backface-visibility: hidden;
}

/********************
会社案内
********************/
table{
	width: 100%;
}

table td,
table th{
	border: 1px solid #ddd;
	padding: 15px;
}

table th{
	background-color: #f5f5f5;
	width: 25%;
	font-weight: bold;
}

a.btn01{
	display: inline-block;
	background: #0548a8;
	color: #fff;
	text-align: center;
	line-height: 1;
	font-weight: bold;
	padding: 18px 30px;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

.pdf{
	font-size:10px;
	color: #0548a8;
	padding: 1px 3px;
	margin-left:3px;
	background-color: #fff;
	position: relative;
	top: -1px;
}

img.ceo{
	vertical-align: text-bottom;
}

.map{
	width: 100%;
	height: 350px;
	border: none;
}

/********************
お問い合わせ
********************/
form span{
	font-size: 10px;
	color: #999;
}

form table th{
	width: 200px;
}

form th span{
	font-weight: normal;
	display: inline-block;
	background: #ff0000;
	color: #fff;
	padding: 3px;
	float: right;
}

form th span.option{
	background: #0548a8;
}

form input[type="text"]{
	width: 100%;
	border: 1px solid #ddd;
	padding: 7px;
	font-size: 1.4rem;
	border-radius: 0;
}

form textarea{
	width: 100%;
	height: 150px;
	border: 1px solid #ddd;
	padding: 7px;
	font-size: 1.4rem;
	border-radius: 0;
}

form input[type="submit"]{
	width: 150px;
	height: 40px;
	background-color: #0548a8;
	font-size: 1.6rem;
	font-weight: bold;
	border: none;
	color: #fff;
	cursor: pointer;
	border-radius: 0;
	-webkit-transition: .3s;
	transition: .3s;
}

form input[type="submit"]:hover{
	opacity: 0.6;
}

.radioWrap label{
	display: inline-block;
	margin-right: 20px !important;
	cursor: pointer;
}

form input[type=radio],
form input[type=checkbox]{
	display: none;
}

form label .radioIcon{
	line-height: 16px;
	width: 16px;
	margin-right: 8px;
	display: inline-block;
	vertical-align: middle;
	position: relative;
	top: -2px;
}

form label .radioIcon::after{
	content: "";
	background: #fff;
	width: 16px;
	height: 16px;
	margin-top: -10px;
	display: block;
	border: 2px solid #ccc;
	position: absolute;
	top: 50%;
	left: 0;
	-webkit-transition: border-color 0.2s linear;
	transition: border-color 0.2s linear;
}

form label .radioIcon::after{
  border-radius: 50%;
}

form label .radioIcon::before{
  content: "";
  width: 10px;
  height: 10px;
  background-color: #0548a8;
  margin-top: -5px;
  display: block;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 5px;
  opacity: 0;
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
  z-index: 10;
}

form input[type=radio]:checked ~ .radioIcon::before{
	opacity: 1;
}

form label.agree{
	background: #f5f5f5;
	padding: 20px 25px;
	display: inline-block;
	margin-bottom: 20px;
	cursor: pointer;
}

form label .checkIcon{
	line-height: 20px;
	width: 20px;
	margin-right: 8px;
	display: inline-block;
	vertical-align: middle;
	position: relative;
	top: -2px;
}

form label .checkIcon::after{
	content: "";
	background: #fff;
	width: 16px;
	height: 16px;
	margin-top: -10px;
	display: block;
	border: 2px solid #ccc;
	position: absolute;
	top: 50%;
	left: 0;
	-webkit-transition: border-color 0.2s linear;
	transition: border-color 0.2s linear;
}

form label .checkIcon::before{
	content: "";
	position: absolute;
	border: solid #0548a8;
	border-width: 0 3px 3px 0;
	width: 7px;
	height: 12px;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	display: block;
	top: 50%;
	left: 5px;
	margin-top: -11px;
	opacity: 0;
	-webkit-transition: opacity 0.2s linear;
	transition: opacity 0.2s linear;
	z-index: 10;
}

form input[type=checkbox]:checked ~ .checkIcon::before{
	opacity: 1;
}

/********************
サイトマップ
********************/
ul.sitemap li{
	margin-bottom: 15px;
}

ul.sitemap li a{
	display: block;
	border: 1px solid #0548a8;
	padding: 15px;
	position: relative;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}

ul.sitemap li a::after{
	content: "";
	display: block;
	width: 6px;
	height: 6px;
	border-top: 1px solid #0548a8;
	border-right: 1px solid #0548a8;
	transform: rotate(45deg);
	position: absolute;
	right: 20px;
	top: 50%;
	margin-top: -5px;
}

/********************
SP
********************/
@media screen and (max-width: 480px){

/********************
共通
********************/	
html{
	min-width:initial;
}

main{
	width: 100%;
}

.inner{
	margin: 0 5%;
	max-width: 100%;
}

.contents{
	padding: 20px 0;
}

.pc{
	display: none !important;
}	
	
.sp{
	display: block !important;
}

#pankuzu{
	background-color: #f5f5f5;
	overflow-x: scroll;
	white-space: nowrap;
	padding-left: 10px;
}

h2{
	font-size: 2.6rem;
}

main h3.basic{
	font-size: 2rem;
	padding: 15px;
}

main h4{
	font-size:1.6rem;
	padding: 10px 20px;
}

table{
	width: 100%;
}

table td,
table th{
	display: block;
	padding: 10px;
	margin-bottom: -1px;
}

table th{
	width: 100%;
}

/********************
header
********************/
header{
	background-color: #fff;
	min-width:initial;
}

header .upper{
	display: none;
}

header .lower{
	padding: 15px 0;
}

header .lower img{
	height: 30px;
}

header .lower dl{
	display: none;
}

.wrap header{
	position: relative;
	background-color: #fff;
	z-index: 10000;
}

.wrap header img{
	display: none;
}
	
header .lower figure a{
	display: block;
}

.wrap header .lower figure a{
	display: block;
	width: 243px;
	height: 30px;
	background: url(../img/logo_02.png) no-repeat center / contain;
}
	
/********************
nav
********************/
nav{
	border: none;
	background-color: #fff;
	position: absolute;
	top: 60px;
	left: 0;
	width: 100%;
	display: none;
	z-index: 10000;
}

nav ul li{
	width: 100%;
	border-left: none;
	border-bottom: 1px solid #ddd;
}
	
nav ul li:first-child{
	border-top: 1px solid #ddd;
}

nav ul li:nth-last-child(2){
	border-right: none;
}

nav ul li:last-child{
	display: block;;
}

nav ul li.ac a{
	background-color: #0548a8;
	color: #fff;
}

.wrap nav{
	position: absolute;
	bottom: inherit;
	z-index: 10000;
}
	
nav .inner{
	margin: 0;
}

#navToggle{
	display: block;
	width: 30px;
	position: absolute;
	top: 20px;
	right: 0;
	z-index: 1000;
}
	
#navToggle div{
	position: relative;
	height: 22px;
}
	
#navToggle span{
	display: block;
	height: 2px;
	position: absolute;
	width: 100%;
	left: 0;
	-webkit-transition: 0.5s ease-in-out;
	-moz-transition: 0.5s ease-in-out;
	transition: 0.5s ease-in-out;
	background: #0548a8;
}

#navToggle span:nth-child(1){
	top: 0px;
}
	
#navToggle span:nth-child(2){
	top: 10px;
}
	
#navToggle span:nth-child(3){
	top: 20px;
}

.open #navToggle span:nth-child(1){
	top: 12px;
	-webkit-transform: rotate(135deg);
	-moz-transform: rotate(135deg);
	transform: rotate(135deg);
}

.open #navToggle span:nth-child(2){
	width: 0;
	left: 50%;
}

.open #navToggle span:nth-child(3){
	top: 12px;
	-webkit-transform: rotate(-135deg);
	-moz-transform: rotate(-135deg);
	transform: rotate(-135deg);
}
	
/********************
kv
********************/
#kv{
	width: initial;
	height: initial;
	left:  initial;
	-webkit-transform: initial;
	transform: initial;
}
	
#kv .bxslider li{
	width: 100%;
	height: 40vh;
}

#kv .bxslider li > img{
	width: 100%;
	height: 40vh;
}

/********************
トップ
********************/
ul.home01 li{
	width: initial;
}
	
ul.home01 li:last-child{
	margin-top: 15px;
}	

/********************
aside
********************/
aside{
	width: 100%;
}

.cta dl{
	padding: 20px 15px;
}

aside{
	width: 100%;
	padding-top: 20px;
}

.cta dl dt span{
	font-size: 2.4rem
}

.cta dl dt span a{
	color: #fff;
}

/********************
footer
********************/
footer{
	padding: 0;
}
	
footer .inner{
	margin: 0;
}
	
footer ul{
	width: initial;
	margin-left: -1px;
}

footer ul li{
	width: 50%;
	line-height: 1;
	border-bottom: 1px solid #666;
	border-left: 1px solid #666;
}
	
footer ul li:last-child{
	width: 50%;
}

footer ul li a{
	display: block;
	padding: 15px;
	text-align: center;
}

footer ul li a::before{
	content: none;
}

footer div div{
	padding: 15px 15px 35px 15px;
}

footer div div p + p{
	text-align: center;
}
	
footer address a{
	text-decoration: underline;
}
	
/********************
お問い合わせ
********************/
form table th{
	width: 100%;
}

/********************
pagetop
********************/
.pagetop{
	bottom: 20px;
	right: 20px;
}

.pagetop a{
	line-height: 30px;
	width: 30px;
}
}