header {
  margin: 0 auto;
  font-size: 1em;
  line-height: 1.4;
  color: #000;
  position: fixed;
  width: 100%;
  height: 90px;
  background: #fff;
  top: 0;
  z-index: 999; }
  @media screen and (max-width: 414px) {
    header {
      height: calc(9000vw/414); } }
  header .inner {
    position: relative;
    max-width: 1100px;
    /*background: #fff;*/ }

header h1,
header h2,
header h3,
header h4,
header h5 {
  font-weight: normal; }

header h1 {
  font-size: 1.6em;
  position: relative;
  left: 0;
  right: 0;
  top: 0;
  margin: auto;
  width: 90px;
  text-align: center; }
  @media screen and (max-width: 414px) {
    header h1 {
      width: calc(9000vw/414); } }
  header h1 a {
    display: block; }
  header h1 .sp {
    display: block; }
    @media screen and (min-width: 980px) {
      header h1 .sp {
        display: none; } }
  header h1 .pc {
    display: none; }
    @media screen and (min-width: 980px) {
      header h1 .pc {
        display: block; } }
  header h1 img {
    width: 100%;
    height: auto; }

header h2 {
  margin: 0 auto;
  padding: 1em 0;
  font-size: 1.4em; }

header h3 {
  margin: 0 auto;
  font-size: 1.25em; }

header h4 {
  margin: 0 auto;
  font-size: 1rem; }

header h5 {
  margin: 0 auto;
  font-size: 1rem; }

header p {
  margin: 0;
  padding: .5em 1em; }

header ul {
  margin: 0;
  padding: 0; }

header li {
  margin: 0;
  list-style: none; }
  header li.keyword {
    border-top: 3px solid #fff; }

header li a {
  padding: 0 0.25em; }

.s-logo {
  padding: 15px 0 0; }
  @media screen and (max-width: 414px) {
    .s-logo {
      padding: calc(1500vw/414) 0 0; } }

.x-logo {
  display: none; }

.z-logo {
  width: 60px;
  padding: 10px 0 0;
  text-align: center; }
  @media screen and (max-width: 414px) {
    .z-logo {
      width: calc(6000vw/414);
      padding: calc(1000vw/414) 0 0; } }

.is-non {
  display: none; }

.is-display {
  display: block !important;
  width: 41px;
  padding: 19px 0 0;
  margin: 0 auto; }
  @media screen and (max-width: 414px) {
    .is-display {
      width: calc(4100vw/414);
      padding: calc(1900vw/414) 0 0; } }
  @media screen and (min-width: 980px) {
    .is-display {
      width: 60px;
      padding: 10px 0 0; } }
  .is-display.x-logo2 {
    width: 38px;
    padding: 20px 0 0; }

/* SECTION
================================================== */
#sp-menu {
  background: #eaeff2 !important;
  padding: 0  0 20px 0;
  overflow: scroll;
  height: calc(100vh - 60px);
  position: relative; }
  #sp-menu .header-menu {
    background: #eaeff2;
    position: relative;
    /*z-index: 2;*/ }

.sp-menu-bg {
  position: fixed;
  /*z-index: 1;*/
  left: 0;
  width: 100%;
  height: 100vw;
  background: rgba(255, 255, 255, 0.4); }

.sp-menu-wrap {
  margin: 0 0 2.5em;
  max-width: 900px; }

.sp-menu {
  display: none;
  position: relative;
  z-index: 0;
  font-size: 0.9rem; }
  .sp-menu .sp-menu-search {
    margin-block-end: 0;
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
    z-index: 2; }

.sp-menu.target {
  background-color: #ffa000; }

.sp-menu.target .active a {
  background-color: #161b1d; }

.sp-menu.target .active a:hover {
  background-color: #2c363a !important; }

.sp-menu.target .active a:before {
  background-color: #ffa000 !important; }

.sp-menu.active a {
  background-color: #ffa000; }

.sp-menu.active a:hover {
  background-color: #ffb333 !important; }

.sp-menu-list {
  background: #eaeff2; }
  .sp-menu-list li h3.trigger {
    z-index: 0;
    line-height: 1em;
    background-color: #eaeff2;
    border-bottom: 3px solid #fff; }
    .sp-menu-list li h3.trigger i {
      color: #006075; }
    .sp-menu-list li h3.trigger a {
      position: relative;
      display: block;
      padding: 1em 1em;
      color: #000;
      text-decoration: none;
      -webkit-transition: .35s all ease;
      transition: .35s all ease; }
      .sp-menu-list li h3.trigger a:hover {
        background-color: #e8e8e8; }
      .sp-menu-list li h3.trigger a:before {
        position: absolute;
        top: 1em;
        right: 35px;
        display: block;
        content: '';
        width: 3px;
        height: 12px;
        background-color: #000;
        -webkit-transition: .25s all ease;
        transition: .25s all ease;
        border-radius: 10px;
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg); }
      .sp-menu-list li h3.trigger a:after {
        position: absolute;
        top: 1em;
        right: 28px;
        display: block;
        content: '';
        width: 3px;
        height: 12px;
        background-color: #000;
        -webkit-transition: .25s all ease;
        transition: .25s all ease;
        border-radius: 10px;
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
      .sp-menu-list li h3.trigger a .span {
        display: inline-block;
        width: 30%;
        color: #006075 !important;
        font-size: 0.8rem !important;
        letter-spacing: 0 !important; }
      .sp-menu-list li h3.trigger a .icon-search-blue {
        width: 1.2em;
        height: 1.2em;
        margin: -0.2em 0.3em; }
    .sp-menu-list li h3.trigger.active a:before {
      background-color: #006075;
      -ms-transform: rotate(45deg);
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg); }
    .sp-menu-list li h3.trigger.active a:after {
      background-color: #006075;
      -ms-transform: rotate(-45deg);
      -webkit-transform: rotate(-45deg);
      transform: rotate(-45deg); }
  .sp-menu-list li > .target {
    z-index: 1;
    display: none;
    margin: 0 auto;
    padding: 0;
    background-color: #fff;
    color: #fff; }

.condition {
  position: relative;
  background-color: #eaeff2;
  line-height: 1.4;
  padding-bottom: 1px; }
  @media screen and (min-width: 980px) {
    .condition {
      padding: 30px 20px;
      background-color: #eaeff2; } }
  .condition ul.tab {
    list-style-type: none;
    padding: 0;
    margin: 0; }
    .condition ul.tab li h4 {
      margin: 0 auto;
      font-size: 1rem;
      font-weight: normal; }
      .condition ul.tab li h4 a {
        padding: .5em 1em .6em; }
        .condition ul.tab li h4 a:before {
          position: absolute;
          top: 1em;
          right: 35px;
          display: block;
          content: '';
          width: 3px;
          height: 12px;
          background-color: #000;
          -webkit-transition: .25s all ease;
          transition: .25s all ease;
          border-radius: 10px;
          -ms-transform: rotate(-45deg);
          -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg); }
        .condition ul.tab li h4 a:after {
          position: absolute;
          top: 1em;
          right: 28px;
          display: block;
          content: '';
          width: 3px;
          height: 12px;
          background-color: #000;
          -webkit-transition: .25s all ease;
          transition: .25s all ease;
          border-radius: 10px;
          -ms-transform: rotate(45deg);
          -webkit-transform: rotate(45deg);
          transform: rotate(45deg); }
    .condition ul.tab li.active a {
      opacity: .8; }
      .condition ul.tab li.active a:before {
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
      .condition ul.tab li.active a:after {
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg); }
  .condition ul.tab-area {
    background: #eaeff2;
    padding: 0;
    margin: 0;
    list-style: none; }
    .condition ul.tab-area li h4.trigger {
      width: 90%;
      margin: 0 auto;
      font-size: 1rem;
      font-weight: normal; }
      .condition ul.tab-area li h4.trigger a {
        position: relative;
        display: block;
        padding: 1em;
        background-image: linear-gradient(to right, #006075 50%, rgba(255, 255, 255, 0) 0%);
        background-position: bottom;
        background-size: 8px 1px;
        background-repeat: repeat-x;
        background-color: #fff;
        color: #000;
        border-radius: 5px 5px 0 0;
        text-decoration: none; }
        .condition ul.tab-area li h4.trigger a:before {
          position: absolute;
          top: 1.3em;
          right: 35px;
          display: block;
          content: '';
          width: 3px;
          height: 12px;
          background-color: #000;
          -webkit-transition: .25s all ease;
          transition: .25s all ease;
          border-radius: 10px;
          -ms-transform: rotate(-45deg);
          -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg); }
        .condition ul.tab-area li h4.trigger a:after {
          position: absolute;
          top: 1.3em;
          right: 28px;
          display: block;
          content: '';
          width: 3px;
          height: 12px;
          background-color: #000;
          -webkit-transition: .25s all ease;
          transition: .25s all ease;
          border-radius: 10px;
          -ms-transform: rotate(45deg);
          -webkit-transform: rotate(45deg);
          transform: rotate(45deg); }
      .condition ul.tab-area li h4.trigger.active a:before {
        background-color: #006075;
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
      .condition ul.tab-area li h4.trigger.active a:after {
        background-color: #006075;
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg); }
    .condition ul.tab-area li .target {
      z-index: 1;
      display: none;
      margin: 0 auto;
      padding: 0;
      background-color: #eaeff2;
      color: #fff; }
      @media screen and (min-width: 980px) {
        .condition ul.tab-area li .target {
          display: block; } }
      .condition ul.tab-area li .target ul {
        list-style-type: none;
        padding: 0;
        margin: 0; }
        @media screen and (min-width: 980px) {
          .condition ul.tab-area li .target ul {
            display: flex;
            flex-wrap: wrap; } }
        .condition ul.tab-area li .target ul li {
          width: 90%;
          margin: 0 auto;
          background-color: #fff;
          color: #000;
          border: 1px solid #eaeff2; }
          .condition ul.tab-area li .target ul li.nospan h5 {
            line-height: 2.1em; }
            @media screen and (min-width: 980px) {
              .condition ul.tab-area li .target ul li.nospan h5 {
                line-height: 2.2em; } }
          .condition ul.tab-area li .target ul li.last {
            border-radius: 0 0 5px 5px; }
          .condition ul.tab-area li .target ul li:last-child {
            border-radius: 0 0 5px 5px; }
          @media screen and (min-width: 980px) {
            .condition ul.tab-area li .target ul li {
              width: 33.33%; }
              .condition ul.tab-area li .target ul li.last {
                border-radius: 0 0; }
              .condition ul.tab-area li .target ul li:last-child {
                border-radius: 0 0; } }
            .condition ul.tab-area li .target ul li.googlemap {
              width: 100%; text-align: right;}
            .condition ul.tab-area li .target ul li.googlemap a {
              padding: 5px 10px; color: #006075; background-color: transparent; }
          .condition ul.tab-area li .target ul li label:hover {
            opacity: .8;
            cursor: pointer; }
          .condition ul.tab-area li .target ul li label input[type="checkbox"] {
            border: 0;
            margin-top: 0;
            transform: translateY(10%); }
          .condition ul.tab-area li .target ul li h5 {
            font-size: 1rem;
            font-weight: normal;
            margin: 0 .5em; }
  .condition .header-search-submit {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 2;
    display: flex;
    color: #fff;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 1em;
    background-color: rgba(0, 96, 117, 0.9);
    transition-duration: 0.5s; }
    @media screen and (min-width: 980px) {
      .condition .header-search-submit {
        position: static;
        background-color: #006075; } }
    .condition .header-search-submit .header-search-submit-hit {
      font-size: 1.3rem;
      font-weight: bold; }
      @media screen and (min-width: 980px) {
        .condition .header-search-submit .header-search-submit-hit {
          padding-left: 2em; } }
    .condition .header-search-submit .header-search-submit-button {
      font-size: 1.3rem;
      font-weight: bold;
      background-color: #fff;
      color: #006075;
      padding: .5em;
      border: 0;
      border-radius: 5px; }
      .condition .header-search-submit .header-search-submit-button.disabled {
        position: relative;
        cursor: not-allowed; }
        .condition .header-search-submit .header-search-submit-button.disabled:after {
          content: '';
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          background-color: rgba(0, 0, 0, 0.25); }
    .condition .header-search-submit.disabled {
      transform: translateY(100%); }
      .condition .header-search-submit.disabled .header-search-submit-button {
        position: relative; }
        .condition .header-search-submit.disabled .header-search-submit-button:after {
          content: none; }
      @media screen and (min-width: 980px) {
        .condition .header-search-submit.disabled {
          display: none;
          transform: translateY(0); } }
      @media screen and (min-width: 980px) {
        .condition .header-search-submit.disabled.pc-enabled {
          display: flex; } }

.keywords {
  background-color: #eaeff2; }
  .keywords h3.keyword-title {
    z-index: 0;
    line-height: 1em;
    padding: 0 5%;
    border-top: 3px solid #fff;
    font-size: 1.25em;
    font-weight: normal;
    margin: 20px auto; }
    @media screen and (min-width: 980px) {
      .keywords h3.keyword-title {
        padding: 20px;
        margin-top: 20px; } }
    .keywords h3.keyword-title a {
      position: relative;
      display: block;
      padding: 1em .2em .5em;
      color: #000;
      text-decoration: none;
      -webkit-transition: .35s all ease;
      transition: .35s all ease; }
      @media screen and (min-width: 980px) {
        .keywords h3.keyword-title a {
          width: 240px; } }
      .keywords h3.keyword-title a .icon-search-blue {
        width: 1.2em;
        height: 1.2em;
        margin: -0.2em 0.3em; }
  .keywords .keyword-search {
    border-bottom: 3px solid #fff;
    padding: 0 5%; }
    @media screen and (min-width: 980px) {
      .keywords .keyword-search {
        padding: 0 20px 0 260px;
        margin-top: -105px; } }
    .keywords .keyword-search input[type="text"] {
      display: inline;
      width: 77.5%;
      height: 50px;
      line-height: 50px;
      border: 0;
      border-radius: 5px;
      padding: 0 10px;
      margin-right: 2.5%; }
    .keywords .keyword-search .header-search-btn {
      display: inline;
      position: relative;
      width: 20%;
      height: 50px;
      line-height: 50px;
      color: #fff;
      font-size: 1.5rem;
      background: #006075;
      border-radius: 5px;
      text-align: center;
      margin: 20px auto;
      border: none;
      vertical-align: middle; }
      .keywords .keyword-search .header-search-btn .icon-search-white {
        width: 100%;
        left: 50%; }
      .keywords .keyword-search .header-search-btn.disabled {
        position: relative;
        cursor: not-allowed; }
        .keywords .keyword-search .header-search-btn.disabled:after {
          content: '';
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          background-color: rgba(0, 0, 0, 0.25); }
    .keywords .keyword-search button {
      display: inline; }

.sp-menu-list > .target ul {
  padding-top: 1em; }

/*.sp-menu-list li > div.target {
    background: $lightblue;
}*/
h4.trigger span {
  color: #006075;
  font-size: 0.8rem;
  padding-top: 1em;
  padding-bottom: 0.5em;
  display: block; }

.sp-menu-wrap .target .condition .googlemap-area {
  display: none;
}
@media screen and (max-width: 980px) {
  .sp-menu-wrap .target .condition .googlemap-area {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
  }
  .sp-menu-wrap .target .condition .googlemap-area a {
    padding: 5px 10px;
    color: #006075;
    background-color: transparent;
  }
}
/*.sp-menu-wrap .target .target {
    border-bottom: 1px solid $lightblue;
    padding: {
        bottom: 1em;
    };
}*/
.sp-menu-wrap .target .target a:hover {
  background-color: #374449; }

.sp-menu-wrap .target .trigger a:before {
  background-color: #006075;
  top: 1em;
  right: 20px;
  height: 12px;
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg); }

.sp-menu-wrap .target .trigger a:after {
  background-color: #006075;
  top: 1em;
  right: 13px;
  height: 12px;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg); }

.sp-menu-wrap .target a {
  display: block;
  color: #fff;
  -webkit-transition: .35s all ease;
  transition: .35s all ease; }

.sp-menu-wrap .active a {
  color: #000; }

.sp-menu-wrap .active a:hover {
  background-color: #fff;
  color: #000;
  border-radius: 5px 5px 0 0;
  opacity: .8; }

.sp-menu-wrap .active a:before, .sp-menu-wrap .active a:after {
  background-color: #006075; }

.sp-menu-wrap .active a:before {
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg); }

.sp-menu-wrap .active a:after {
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg); }

.sp-menu-wrap > ul > li {
  border-bottom: 3px #fff solid; }

.header-icon {
  position: absolute;
  display: flex;
  top: 23px;
  right: 18px; }
  @media screen and (max-width: 414px) {
    .header-icon {
      top: calc(2300vw/414);
      right: calc(1800vw/414); } }
  .header-icon svg {
    background: #afc2cb;
    border-radius: 5px;
    color: #fff;
    width: 40px;
    height: 40px;
    text-align: center;
    line-height: 40px;
    font-size: 1.5rem; }
    @media screen and (max-width: 414px) {
      .header-icon svg {
        width: calc(4000vw/414);
        height: calc(4000vw/414);
        line-height: calc(4000vw/414);
        border-radius: calc(500vw/414);
        padding: calc(800vw/414) calc(600vw/414); } }

h3.item-list-title {
  border-bottom: 3px solid #fff; }
  h3.item-list-title a {
    text-decoration: none;
    display: block;
    height: 50px;
    line-height: 50px;
    color: #333;
    font-weight: normal;
    font-size: 1rem;
    position: relative; }
    h3.item-list-title a:after {
      position: absolute;
      right: 10px;
      content: '';
      border-bottom: 4px solid transparent;
      border-right: 6px solid transparent;
      border-left: 6px solid #006075;
      border-top: 4px solid transparent;
      top: 50%;
      margin-top: -3px; }
    h3.item-list-title a span {
      display: inline-block;
      width: 28%;
      color: #006075 !important;
      font-size: 0.6rem !important;
      font-weight: normal;
      letter-spacing: 0.05rem !important;
      vertical-align: middle;
      font-family: 'Oswald', sans-serif;
      padding-left: 2%; }

.header-search-btn {
  display: block;
  position: relative;
  width: 90%;
  height: 50px;
  line-height: 50px;
  color: #fff;
  font-size: 1.5rem;
  background: #006075;
  border-radius: 5px;
  text-align: center;
  margin: 20px auto;
  border: none; }
  .header-search-btn .icon-search-white {
    width: 100%;
    left: 50%; }

.ac-children h5 {
  padding-left: 1.5em; }

ul.va-middle li.area-check h5 {
  line-height: 2.1em; }

#header-footer {
  padding-top: 30px;
  background-image: url(../images/mainimage-human.png);
  background-position: 90% 50%;
  background-repeat: no-repeat; }
  #header-footer ul.header-footer-menu li {
    list-style: none; }
    #header-footer ul.header-footer-menu li a {
      padding: 0.5em 0 0.5em 1em;
      color: #000;
      display: block;
      text-decoration: none; }
  #header-footer .footer-sns {
    display: flex;
    justify-content: space-between;
    margin: 30px 0 0 0;
    padding: 0 0.5em; }
    #header-footer .footer-sns li {
      width: 30%;
      list-style: none; }
      #header-footer .footer-sns li a {
        color: #000;
        display: block;
        border-radius: 5px;
        background: #fff;
        text-align: center;
        font-size: 2rem; }

/* BUTTON
================================================== */
.btn_hamburger {
  position: absolute;
  top: 30px;
  left: 25px;
  width: 35px;
  height: 25px;
  padding: 0 !important; }
  @media screen and (max-width: 414px) {
    .btn_hamburger {
      top: calc(3000vw/414);
      left: calc(2500vw/414);
      width: calc(3500vw/414);
      height: calc(2500vw/414); } }

.btn_hamburger a {
  position: relative;
  display: block;
  height: 24px;
  -webkit-transition: all .4s;
  transition: all .4s;
  box-sizing: border-box; }
  @media screen and (max-width: 414px) {
    .btn_hamburger a {
      height: calc(2500vw/414); } }

.btn_hamburger span {
  position: absolute;
  display: inline-block;
  left: 0;
  width: 100%;
  height: 4px;
  background-color: #161b1d;
  border-radius: 2px;
  -webkit-transition: all .4s;
  transition: all .4s;
  box-sizing: border-box; }
  @media screen and (max-width: 414px) {
    .btn_hamburger span {
      height: 3px; } }

.btn_hamburger span:nth-of-type(1) {
  top: 0; }

.btn_hamburger span:nth-of-type(2) {
  top: 50%;
  transform: translateY(-50%); }

.btn_hamburger span:nth-of-type(3) {
  bottom: 0; }

.btn_hamburger span:nth-of-type(2)::after {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  width: 100%;
  height: 4px;
  background-color: #161b1d;
  border-radius: 2px;
  -webkit-transition: all .4s;
  transition: all .4s; }
  @media screen and (max-width: 414px) {
    .btn_hamburger span:nth-of-type(2)::after {
      height: 3px; } }

.btn_hamburger .active span:nth-of-type(2) {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg); }

.btn_hamburger .active span:nth-of-type(2)::after {
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg); }

.btn_hamburger .active span:nth-of-type(1) {
  -webkit-transform: translateY(20px) scale(0);
  -ms-transform: translateY(20px) scale(0);
  transform: translateY(20px) scale(0); }

.btn_hamburger .active span:nth-of-type(3) {
  -webkit-transform: translateY(-20px) scale(0);
  -ms-transform: translateY(-20px) scale(0);
  transform: translateY(-20px) scale(0); }

/*# sourceMappingURL=header.css.map */
