﻿@charset "utf-8";

/*
============================================================ */
/* BASE
============================================================ */
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}

body {
  line-height: 1.8;
  color: #323232;
  font-size: 16px;
  font-family: -apple-system, BlinkMacSystemFont, "Yu Gothic", YuGothic, Verdana, Meiryo, sans-serif;
  text-size-adjust: 100%;
  word-break:break-all;
  margin:0;
  padding:0;
}





li {
    list-style: none;
}




/*ここから*/
  .header-contact {
    right: 62px;
  }
  .header-contact a {
    display: block;
    width: 62px;
    height: 65px;
    overflow: hidden;
    text-indent: -9999px;
    background: #99cc66 url(../images/icon-mail-wht.svg) no-repeat 50% 50%;
    background-size: 31px auto;
  }
  .header-contact a:after {
    content: none;
  }
  .header-contact a br {
    display: none;
  }
  
  
  .header-nav-btn {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 62px;
    height: 65px;
    background: #323232;
  }
  .header-nav-btn span {
    display: block;
    position: absolute;
    left: 18px;
    width: 26px;
    height: 2px;
    background: #fff;
    transition: all .2s ease-in-out;
  }
  .header-nav-btn span:nth-child(1) {
    top: 21px;
  }
  .header-nav-btn span:nth-child(2) {
    top: 31px;
  }
  .header-nav-btn span:nth-child(3) {
    bottom: 22px;
  }
  .header-nav-btn.is-open span:nth-child(1) {
    transform: translateY(10px) rotate(-45deg);
  }
  .header-nav-btn.is-open span:nth-child(2) {
    opacity: 0;
  }
  .header-nav-btn.is-open span:nth-child(3) {
    transform: translateY(-10px) rotate(45deg);
  }
  .header-nav {
    display: none;
    position: absolute;
    top: 65px;
    right: 0;
    left: 0;
    margin: 0;
    padding: 0;
  }
  .header-nav ul {
    display: block;
    height: calc(100vh - 65px);
    overflow: auto;
  }
  .header-nav li {
    margin: 0;
    border-bottom: 1px solid #fff;
  }
  .header-nav a {
    display: block;
    height: auto;
    padding: 16px;
  }
  .header-nav a.is-active:after{
    display:none;
  }

/*ここまで*/
@media screen and (max-width: 1024px) {
  body {
  }
}

@media screen and (max-width: 599px) {
  body {
  }
  body.is-fixed {
    position: fixed;
    right: 0;
    left: 0;
    overflow-y: scroll;
  }
}

@media all and (-ms-high-contrast: none)  {
  body {
    font-family: Verdana, Meiryo, sans-serif;
  }
}

@media all and (-ms-high-contrast: active) {
  body {
    font-family: Verdana, Meiryo, sans-serif;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  line-height: 1.5;
}
p,
ol,
ul,
dl,
table {
  margin-top: 1em;
  margin-bottom: 1em;
}
p:first-child,
ol:first-child,
ul:first-child,
dl:first-child,
table:first-child {
  margin-top: 0;
}
p:last-child,
ol:last-child,
ul:last-child,
dl:last-child,
table:last-child {
  /*margin-bottom: 0;*/
}
figure {
  margin-right: 0;
  margin-left: 0;
}
a {
  color: #323232;
  text-decoration: underline;
  outline: none;
  transition: .3s;
}
a:hover {
  text-decoration: none;
}
a img {
  border: none;
}
.over:hover {
  text-decoration: none;
  opacity: .7;
}
.sp-link {
  text-decoration: none;
  cursor: default;
}
img {
  max-width: 100%;
  width:100%;
  height: auto;
  vertical-align: top;
}

/*** pc-only / sp-only ***/
@media screen and (min-width: 600px) {
  .sp-only {
    display: none !important;
  }
}

@media screen and (max-width: 599px) {
  .pc-only {
    display: none !important;
  }
  

}

/*
============================================================ */
/* header
============================================================ */
.header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  height: 73px;
  padding: 0 16px;
  background: #fff;
  z-index: 200;
}
.header-inner {
  position: relative;
  max-width: 1150px;
  margin: 0 auto;
}
.header-logo {
  height: 69px;
  line-height: 1;
  margin: 0;
  padding: 30px 0 0 147px;
  font-size: 14px;
  font-weight: bold;
  box-sizing: border-box;
}
.header-logo img {
  position: absolute;
  top: 12px;
  left: 0;
  width: 123px;
}
.header-tel {
  position: absolute;
  top: 0;
  right: 173px;
  right: 95px;
  display: flex;
  align-items: center;
  height: 69px;
}
.header-tel a {
  display: flex;
  align-items: center;
}
.header-tel a span {
  display: inline-block;
  margin: 0 16px 0 0;
  padding: 0 0 0 25px;
  font-size: 24px;
  font-family: "Montserrat";
  font-weight: 600;
  background: url(../images/icon-tel-pnk.svg) no-repeat 0 50%;
  background-size: 20px auto;
}
.header-tel a small {
  font-size: 12px;
}
.header-contact {
  position: absolute;
  top: 0;
  right: 65px;
  right: 0px;
}


.header-nav {
  margin: 0 -16px;
  padding: 0 16px;
  background: #323232;
  height:80px;
}
.header-nav ul {
  display: flex;
  list-style: none;
  max-width: 1150px;
  margin: 0 auto;
  padding: 0;
  height:80px;
}
.header-nav li {
  margin: 0 80px 0 0;
}
.header-nav a {
  display: flex;
  align-items: center;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  position:relative;
}
.header-nav a:hover {
  color: #959595;
  border-bottom:3px #E8807D solid;
}
.header-nav a.is-active:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 3px;
  width: calc(100% + 10px);
  height: 3px;
  background: #e8807d;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
}
@media screen and (max-width: 1120px) {
  .header-nav li {
    /*margin: 0 64px 0 0;*/
	margin: 0 90px 0 0;	
  }
}

@media screen and (max-width: 1024px) {
  .header-logo {
    padding-left: 14.36vw;
    font-size: 1.37vw;
  }
  .header-logo img {
    width: 12.01vw;
  }
  .header-tel {
    right: 15.63vw;
  }
  .header-tel a span {
    font-size: 2.34vw
  }
  .header-tel a small {
    font-size: .98vw;
  }
  .header-contact {
    right: -16px;
  }
  .header-contact a {
    /*width: 16.11vw;*/
    font-size: 1.76vw;
  }
  .header-contact a:after {
    font-size: .98vw;
  }
  .header-nav li {
    /*margin: 0 40px 0 0;*/
	  margin: 0 60px 0 0;
  }
}

@media screen and (max-width: 599px) {
	.header-nav {
  margin: 0 -16px;
  padding: 0 16px;
  background: #323232;
  height:auto;
}
  .header {
    height: 55px;
  }
  .header-inner {
    position: static;
  }
  .header-logo {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 65px;
    padding: 0;
    font-size: 2.67vw;
  }
  .header-logo img {
    position: static;
    width: 32.93vw;
    margin: 0 0 8px;
  }
  .header-tel {
    right: 124px;
    right: 52px;
    height: auto;
  }
  .header-tel a {
    width: 52px;
    height: 55px;
    overflow: hidden;
    background: #F5F5F5 url(../images/icon-tel-pnk.svg) no-repeat 50% 50%;
    background-size: 24px auto;
  }
  .header-tel a span,
  .header-tel a small {
    display: none;
  }
  .header-contact {
    right: 52px;
    right: 0px;
  }
  .header-contact a {
    display: block;
    width: 52px;
    height: 55px;
    overflow: hidden;
    text-indent: -9999px;
    background: #99cc66 url(../images/icon-mail-wht.svg) no-repeat 50% 50%;
    background-size: 31px auto;
  }
  .header-contact a:after {
    content: none;
  }
  .header-contact a br {
    display: none;
  }
  .header-nav-btn {
    display: block;
	display:none;
    position: absolute;
    top: 0;
    right: 0;
    width: 62px;
    height: 65px;
    background: #323232;
  }
  .header-nav-btn span {
    display: block;
    position: absolute;
    left: 18px;
    width: 26px;
    height: 2px;
    background: #fff;
    transition: all .2s ease-in-out;
  }
  .header-nav-btn span:nth-child(1) {
    top: 21px;
  }
  .header-nav-btn span:nth-child(2) {
    top: 31px;
  }
  .header-nav-btn span:nth-child(3) {
    bottom: 22px;
  }
  .header-nav-btn.is-open span:nth-child(1) {
    transform: translateY(10px) rotate(-45deg);
  }
  .header-nav-btn.is-open span:nth-child(2) {
    opacity: 0;
  }
  .header-nav-btn.is-open span:nth-child(3) {
    transform: translateY(-10px) rotate(45deg);
  }
  .header-nav {
    display: none;
    position: absolute;
    top: 65px;
    right: 0;
    left: 0;
    margin: 0;
    padding: 0;
  }
  .header-nav ul {
    display: block;
    height: calc(100vh - 65px);
    overflow: auto;
  }
  .header-nav li {
    margin: 0;
    border-bottom: 1px solid #fff;
  }
  .header-nav a {
    display: block;
    height: auto;
    padding: 16px;
  }
  .header-nav a.is-active:after{
    display:none;
  }
}

/*
============================================================ */
/* main
============================================================ */
.main {
  overflow: hidden;
  margin: 73px 0 0;
}

@media screen and (max-width: 1024px) {
}

@media screen and (max-width: 599px) {
  .main {
    margin: 65px 0 0;
  }
}

/*
============================================================ */
/* footer
============================================================ */
.footer-cate {
  height: 100px;
}
.footer-cate-wrap {
  position: fixed;
  right: 0;
  bottom: -100px;
  left: 0;
  background: rgba(0, 160, 142, .9);
  background-color:#323232;
  z-index: 400;
}
.footer-cate-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1000px;
  height: 100px;
  margin: 0 auto;
  box-sizing: border-box;
}
.footer-cate-ttl {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  color: #fff;
  font-weight: bold;
  text-align: center;
}
.footer-cate-ttl:before,
.footer-cate-ttl:after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 20px;
  border-right: 2px solid #fff;
  border-left: 2px solid #fff;
}
.footer-cate-ttl:before {
  margin-right: 16px;
  transform: skewX(24deg);
}
.footer-cate-ttl:after {
  margin-left: 16px;
  transform: skewX(-24deg);
}
.footer-cate-btn {
  list-style: none;
  display: flex;
  justify-content: center;
  margin: 0;
  padding: 0;
}
.footer-cate-btn li {
  margin: 0 0 0 16px;
}
.footer-cate-btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 64px;
  padding: 0 32px 0 24px;
  border-radius: 15px;
  white-space: nowrap;
  text-decoration: none;
  box-shadow: 0 3px 0 rgba(0, 0, 0, .3)
}
.footer-cate-form a {
  color: #323232;
  font-weight: bold;
  background: #FFF46F;
}
.footer-cate-form a:hover {
  background: #FCF7C2;
}
.footer-cate-form a:before {
  content: "";
  display: block;
  width: 22px;
  height: 16px;
  margin: 0 8px 0 0;
  background: url(../images/icon-mail-blk.svg) no-repeat 0 0;
  background-size: 22px 16px;
}
.footer-cate-tel a {
  flex-direction: column;
  line-height: 1.4;
  color: #E8807D;
  background: #fff;
}
.footer-cate-tel a span {
  display: block;
  padding: 0 0 0 24px;
  font-size: 24px;
  font-family: "Montserrat";
  font-weight: 600;
  background: url(../images/tel-icon.png) no-repeat 0 50%;
  background-size: 20px auto;
  transition: .2s;
}
.footer-cate-tel a small {
  color: #323232;
  font-size: 11px;
  transition: .2s;
}
.footer-cate-tel a:hover span,
.footer-cate-tel a:hover small,
.footer-cate-tel a:hover:after {
  opacity: .7;
}
.footer-cate-btn a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 8px;
  height: 8px;
  border-top: 2px solid;
  border-right: 2px solid;
  transform: translateY(-50%) rotate(45deg);
  transition: .2s;
}
.footer {
  padding: 40px 16px;
  background: #323232;
}
.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1000px;
  margin: 0 auto;
}
.footer-logo {
  margin: 0 32px 0 0;
}
.footer-nav {
  flex: 1;
  position: relative;
}
.footer-nav-list {
  display: flex;
  justify-content: center;
  list-style: none;
  margin: 0 0 16px;
  padding: 0 0 16px;
  border-bottom: 1px solid #fff;
  font-size: 14px;
}
.footer-nav-list li {
  margin: 0 16px;
}
.footer-nav-list a {
  color: #fff;
  text-decoration: none;
}
.footer-nav-list a:hover {
  color: #959595;
}
.footer-copyright {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  line-height: 1;
  color: #fff;
}
.footer-copyright img {
  margin: 0 16px 0 0;
}
.footer-softcreate {
  position: absolute;
  right: 0;
  bottom: 0;
  line-height: 1;
}

@media screen and (max-width: 1024px) {
  .footer-cate-wrap {
    padding: 0 16px;
  }
  .footer-cate-btn li {
    margin: 0 0 0 1.56vw;
  }
  .footer-cate-form a:before {
    width: 2.15vw;
    height: 1.56vw;
    margin: 0 .78vw 0 0;
    background-size: 2.15vw 1.56vw;
  }
  .footer-cate-tel a span {
    padding: 0 0 0 2.34vw;
    font-size: 2.34vw;
    background-size: 1.95vw auto;
  }
  .footer-cate-tel a small {
    font-size: 1.07vw;
  }
  .footer-nav-list {
    font-size: 1.37vw;
  }
}

@media screen and (max-width: 599px) {
  .footer-cate-inner {
    display: block;
    padding: 10px 0 0;
  }
  .footer-cate-ttl {
    line-height: 1.5;
    margin: 0 0 8px;
    font-size: 3.2vw;
  }
  .footer-cate-ttl:before,
  .footer-cate-ttl:after {
    width: 6px;
    height: 16px;
  }
  .footer-cate-ttl:before {
    margin-right: 8px;
  }
  .footer-cate-ttl:after {
    margin-left: 8px;
  }
  .footer-cate-btn {
    justify-content: space-between;
  }
  .footer-cate-btn li {
    width: 49%;
    margin: 0;
  }
  .footer-cate-btn a {
    height: 52px;
  }
  .footer-cate-form a {
    line-height: 1.4;
    padding: 0;
    font-size: 3.47vw;
    text-align: center;
  }
  .footer-cate-form a:before {
    content: none;
  }
  .footer-cate-btn a:after {
    content: none;
  }
  .footer-cate-tel a {
    padding: 0;
  }
  .footer-cate-tel a span {
    padding-left: 4.8vw;
    font-size: 4.53vw;
    background-size: 4.27vw auto;
  }
  .footer-cate-tel a small {
    font-size: 1.87vw;
    letter-spacing: 0;
  }
  .footer {
    padding: 24px 16px;
  }
  .footer-inner {
    display: block;
  }
  .footer-logo {
    float: left;
    width: 25vw;
    margin: 0 24px 16px 0;
  }
  .footer-nav-list {
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 0 16px;
    padding: 0;
    border: none;
    font-size: 3.2vw;
  }
  .footer-nav-list li {
    width: 50%;
    margin: 0 0 4px;
	text-align:center;
  }
  .footer-nav-list li:nth-child(2n) {
    width: 50%;
  }
  .footer-copyright {
   /* justify-content: flex-start;*/
    clear: both;
    padding: 16px 0 0;
    border-top: 1px solid #fff;
    font-size: 3.2vw;
	text-align:center;
  }
  .footer-copyright img {
    width: 28vw;
    margin: 0 8px 0 0;
  }
  .footer-softcreate {
    width: 35.2vw;
  }
}