@charset "UTF-8";
/* CSS Document */

#wrapper {
  position: relative;
  width: 100%;
  padding-top: 24vw;
}

/***********************
Utils
***********************/

.inner {
  width: 86.6vw;
  margin: 0 auto;
}
/***********************
Header-Nav
***********************/

#h-nav {
  width: 100%;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  opacity: 0;
  display: none;
}

#h-nav.open {
  display: block;
  background-color: #e5e5e5;
  margin-top: -6.6vw;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9000;
  opacity: 1;
  padding-top: 30.4vw;
}

#header.fix #h-nav.open {
  margin-top: -2.6vw;
}

#h-nav li {
  float: left;
  width: 50vw;
  height: 16.6vw;
  box-sizing: border-box;
  border-top: dashed 0.2vw #808080;
  border-right: dashed 0.2vw #808080;
}

#h-nav li.business_nav {
  background-color: aliceblue;
}
#h-nav li:nth-child(even) {
  border-right: none;
}
#h-nav li:last-child {
  border-bottom: dashed 0.2vw #808080;
}
#h-nav li.wide {
  border-right: none;
  width: 100vw;
  height: 16.6vw;
  border-right: none;
}

#h-nav li a {
  display: block;
  text-align: center;
  height: 50px;
  line-height: 50px;
  text-decoration: none;
}

#h-nav .sns {
  text-align: center;
  display: block;
  width: 100%;
  padding: 9.6vw 0;
}

#h-nav .sns a {
  width: 7vw;
  height: 7vw;
  display: inline-block;
  margin: 0 5.7vw;
}

#h-nav .sns a:last-child {
  width: 10vw;
}

/***********************
Header
***********************/

#header {
  height: 24vw;
  font-size: 0;
  line-height: 0;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #fff;
  z-index: 9998;
}

#header.fix {
  height: 14.8vw;
  z-index: 9999;
}

#header h1 {
  float: left;
  width: 49.3vw;
  height: 24vw;
  margin-right: 20vw;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
}

#header h1 a {
  display: block;
  width: 49.3vw;
  height: 24vw;
  background: url(../images/logo_head.png) center center no-repeat;
  background-size: cover;
}

#header.fix h1 {
  height: 14.8vw;
}

#header.fix h1 a {
  height: 14.8vw;
  background: url(../images/logo_head_fix.png) center center no-repeat;
  background-size: cover;
}
#header .head-right {
  padding-top: 6.6vw;
}

#header.fix .head-right {
  padding-top: 2.6vw;
}

#header .btn-tel,
#header .btn-menu {
  float: left;
  width: 9.6vw;
  height: 11.2vw;
  display: block;
  margin-right: 6.3vw;
}
#header .btn-menu {
  margin-right: 0;
  background: url(../images/btn_nav.png) center center no-repeat;
  background-size: cover;
  position: relative;
  z-index: 9100;
}
#header .btn-menu.open {
  margin-right: 0;
  background: url(../images/btn_close.png) center center no-repeat;
  background-size: cover;
}

/***********************
Footer-Nav
***********************/

#f-nav {
  width: 100%;
}

#f-nav ul {
  text-align: center;
  display: block;
  width: 100%;
  padding: 9.2vw 0 9.9vw;
}

#f-nav li {
  width: 8.6vw;
  height: 8.6vw;
  display: inline-block;
  margin: 0 8.8vw;
  margin: 0 4.4vw;
}

#f-nav li a {
  display: inline-block;
  width: 8.6vw;
  height: 8.6vw;
}

#f-nav li:last-child,
#f-nav li:last-child a {
  width: 12vw;
}

/***********************
Footer
***********************/

#footer {
  padding: 18.2vw 0 8.5vw;
  font-size: 0;
  line-height: 0;
  position: relative;
}

#footer .f-nav {
  padding: 7.6vw 0 6.6vw;
}

#footer a.pagetop {
  position: absolute;
  top: 9vw;
  right: 5vw;
  width: 8vw;
  height: 8vw;
  display: block;
}

#footerCopyright {
  text-align: center;
  font-size: 3.125vw;
}

#footerCopyright {
}
/***********************
Main
***********************/

#main {
}

#mv {
  text-align: center;
}

.container {
  position: relative;
}

.content {
}

.page-header {
  font-size: 0;
  line-height: 0;
  margin-bottom: 5.3vw;
}

.page-header h2 {
  font-size: 24px;
}

.side-bar {
}
