@charset "UTF-8";
@font-face {
  font-family: 'Font Awesome 5 Brands';
  font-style: normal;
  font-weight: 400;
  src: url("https://cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.10.1/webfonts/fa-brands-400.woff2") format("woff2");
  font-display: swap; }
@font-face {
  font-family: 'Font Awesome 5 Free';
  font-style: normal;
  font-weight: 900;
  src: url("https://cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5.10.1/webfonts/fa-solid-900.woff2") format("woff2");
  font-display: swap; }
html {
  position: relative;
  min-height: 100%;
  overflow-x: hidden; }

section {
  overflow: hidden; }

body {
  width: 100%;
  height: 100%;
  font-size: 16px;
  font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", sans-serif, "メイリオ", meiryo;
  position: relative;
  color: #101010;
  line-height: 1.8; }

img {
  width: 100%;
  vertical-align: top;
  height: auto; }

.sp {
  display: none !important; }

@media screen and (max-width: 767px) {
  body {
    font-size: 3.2vw; }

  .pc {
    display: none !important; }

  .sp {
    display: inherit !important; } }
a {
  outline: none;
  text-decoration: none; }

a:hover {
  text-decoration: none; }

/*=====================================================
ヘッダー
======================================================*/
header {
  width: 100vw;
  height: 100%;
  position: relative;
  box-sizing: border-box; }
  header .main_logo {
    max-width: 140px;
    width: 30%;
    position: absolute;
    top: 40px;
    left: 0;
    right: 0;
    margin: auto;
    z-index: 2; }
  header .slider {
    width: 100vw;
    height: 100%; }
    header .slider .item {
      width: 100vw;
      height: 100%;
      background-repeat: no-repeat;
      background-size: cover;
      background-attachment: fixed;
      background-position: center center; }
      header .slider .item.item01 {
        background-image: url("../img/main01.jpg"); }
      header .slider .item.item02 {
        background-image: url("../img/main02.jpg"); }
      header .slider .item.item03 {
        background-image: url("../img/main03.jpg"); }
  header .slick-dots {
    position: absolute;
    top: calc(50% - 40px);
    right: 30px; }
    header .slick-dots button {
      margin: 0;
      padding: 0;
      background: none;
      border: none;
      border-radius: 0;
      outline: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none; }
    header .slick-dots li {
      margin: 5px 0; }
      header .slick-dots li button {
        position: relative;
        text-indent: -9999px; }
        header .slick-dots li button:before {
          content: '●';
          font-size: 30px;
          text-indent: 0px;
          position: absolute;
          color: #fff;
          top: 0;
          left: 0;
          cursor: pointer; }
      header .slick-dots li.slick-active button:before {
        color: #aaa; }
  header .scroll {
    position: absolute;
    bottom: 50px;
    left: 0;
    right: 0;
    margin: auto;
    max-width: 140px;
    width: 40%; }
    header .scroll a {
      display: block; }

/*header*/
@media screen and (max-width: 767px) {
  header {
    height: calc(100% - 8vw); }
    header .main_logo {
      width: 30%;
      top: 8vw; }
    header .slider .item {
      background-attachment: inherit; }
      header .slider .item.item01 {
        background-image: url("../img/main01_sp.jpg"); }
      header .slider .item.item02 {
        background-image: url("../img/main02_sp.jpg"); }
      header .slider .item.item03 {
        background-image: url("../img/main03_sp.jpg"); }
    header .slick-dots {
      display: none !important; }
    header .scroll {
      bottom: 10vw;
      width: 30%; }

  /*header*/ }
/*=====================================================
フッター
======================================================*/
footer {
  background: #000;
  padding: 80px 0;
  text-align: center;
  color: #fff; }
  footer .foot_logo {
    max-width: 140px;
    margin-bottom: 20px; }
  footer a {
    color: #fff; }
  footer .address {
    font-size: 15px; }
  footer .tel {
    font-size: 16px; }
  footer .time {
    font-size: 14px; }
  footer .foot_link {
    display: block;
    max-width: 300px;
    width: 100%;
    border: 1px #fff solid;
    color: #fff;
    padding: 15px 0;
    text-align: center;
    margin: 20px auto;
    line-height: 1;
    transition: 0.3s;
    font-size: 15px; }
    footer .foot_link:hover {
      background: #fff;
      color: #000;
      transition: ease-in-out 0.3s; }
  footer .sns {
    margin: 20px 0; }
    footer .sns li {
      margin: 0 20px;
      display: inline-block; }
      footer .sns li a {
        font-size: 35px; }
  footer .copyright {
    font-size: 13px; }

/*footer*/
@media screen and (max-width: 767px) {
  /*footer*/ }
/*=====================================================
共通
======================================================*/
.contents_wrap {
  margin: 0 auto;
  width: 100%;
  max-width: 1980px;
  position: relative; }

.pagetop {
  width: 64px;
  height: 64px;
  position: absolute;
  bottom: 20px;
  right: 40px; }
  .pagetop a {
    display: block; }
    .pagetop a img {
      width: 100%; }

@media screen and (max-width: 767px) {
  .pagetop {
    width: 12vw;
    height: 12vw;
    bottom: 4vw;
    right: 4vw; } }
/*=====================================================
TOP
======================================================*/
#top #information {
  padding: 30px 0 55%;
  background-color: #fff;
  background-image: url("../img/tennai01.png");
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: bottom center; }
  #top #information .flex {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: flex-start;
    height: auto;
    justify-content: space-between; }
    #top #information .flex .left {
      width: 45%; }
    #top #information .flex .right {
      width: 50%; }
      #top #information .flex .right .txt_area {
        max-width: 540px;
        width: 90%;
        margin-bottom: 100px; }
        #top #information .flex .right .txt_area h2 {
          font-family: "Nunito Sans", sans-serif;
          font-size: 60px;
          margin-bottom: 80px;
          font-weight: bold;
          display: inline-block;
          position: relative;
          line-height: 1.2; }
          #top #information .flex .right .txt_area h2:after {
            content: "";
            width: 40px;
            height: 40px;
            background: url("../img/icon_logo.svg");
            background-size: 100%;
            background-repeat: no-repeat;
            background-position: center center;
            position: absolute;
            top: 100%;
            left: calc(50% - 20px); }
        #top #information .flex .right .txt_area .copy {
          font-family: "Shippori Mincho", sans-serif;
          font-size: 30px;
          line-height: 1.3;
          margin-bottom: 20px;
          color: #000; }
        #top #information .flex .right .txt_area .txt {
          color: #191919;
          font-size: 15px;
          margin-bottom: 50px; }
        #top #information .flex .right .txt_area .ttl {
          font-family: "Nunito Sans", sans-serif;
          font-size: 30px;
          font-weight: bold;
          margin-bottom: 20px; }
        #top #information .flex .right .txt_area table {
          width: 100%; }
          #top #information .flex .right .txt_area table th, #top #information .flex .right .txt_area table td {
            padding: 15px;
            line-height: 1.5;
            color: #191919;
            text-align: left;
            vertical-align: top; }
          #top #information .flex .right .txt_area table th {
            border-bottom: 2px #141414 solid;
            vertical-align: middle; }
          #top #information .flex .right .txt_area table td {
            border-bottom: 1px #B1B1B1 solid; }
            #top #information .flex .right .txt_area table td a {
              color: #191919; }
            #top #information .flex .right .txt_area table td span {
              font-size: 28px;
              letter-spacing: 1px; }
#top #gallery {
  background: #000;
  padding: 20px 0 0; }
  #top #gallery .photo_flex {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    align-items: flex-start;
    height: auto;
    justify-content: flex-start; }
    #top #gallery .photo_flex .photo {
      width: 33.333%; }

/*top*/
@media only screen and (min-width: 768px) and (max-width: 834px) {
  #top #information {
    padding: 30px 0 55%; }
    #top #information .flex .left {
      width: 100%;
      padding-right: 15%;
      order: 2; }
    #top #information .flex .right {
      width: 100%;
      padding-left: 15%;
      margin-bottom: 80px;
      order: 1; }
      #top #information .flex .right .txt_area {
        max-width: 540px;
        width: 100%;
        margin-bottom: 40px;
        text-align: center; }
        #top #information .flex .right .txt_area .copy {
          text-align: left; }
        #top #information .flex .right .txt_area .txt {
          text-align: left; }
        #top #information .flex .right .txt_area .ttl {
          text-align: left; }
  #top #gallery .photo_flex .photo {
    width: 50%; } }
@media screen and (max-width: 767px) {
  #top #information {
    padding: 8vw 0 55%; }
    #top #information .flex .left {
      width: 100%;
      padding-right: 10%;
      order: 2; }
    #top #information .flex .right {
      width: 100%;
      padding-left: 10%;
      margin-bottom: 10vw;
      order: 1; }
      #top #information .flex .right .txt_area {
        max-width: 540px;
        width: 90%;
        margin-bottom: 8vw;
        text-align: center; }
        #top #information .flex .right .txt_area h2 {
          font-size: 9vw;
          margin-bottom: 12vw; }
          #top #information .flex .right .txt_area h2:after {
            width: 6vw;
            height: 6vw;
            left: calc(50% - 3vw); }
        #top #information .flex .right .txt_area .copy {
          text-align: left;
          font-size: 5vw;
          margin-bottom: 4vw; }
        #top #information .flex .right .txt_area .txt {
          text-align: left;
          font-size: 3vw;
          margin-bottom: 10vw; }
        #top #information .flex .right .txt_area .ttl {
          font-size: 6vw;
          text-align: left;
          margin-bottom: 4vw; }
        #top #information .flex .right .txt_area table th, #top #information .flex .right .txt_area table td {
          padding: 3vw 0 3vw 3vw; }
          #top #information .flex .right .txt_area table th span, #top #information .flex .right .txt_area table td span {
            font-size: 4.6vw; }
        #top #information .flex .right .txt_area table th {
          width: 23%; }
  #top #gallery .photo_flex .photo {
    width: 50%; } }
/*767px*/
/*=====================================================

======================================================*/
