@charset "UTF-8";
/*! 共通 */
body {
  font-size: 62.5%;
  position: relative;
  margin: 0px;
  padding: 0px;
  font-family: "メイリオ", "MS Pゴシック", "Yu Gothic", "Yu Gothic UI"; }

p {
  font-size: 2em;
  margin: 0px;
  padding: 0px; }

li {
  margin: 0px;
  padding: 0px; }

h1 {
  margin: 0px;
  padding: 0px;
  font-size: 3em; }

h2 {
  margin: 0px;
  padding: 0px;
  font-size: 5em; }

h3 {
  margin: 0px;
  padding: 0px;
  font-size: 5em; }

h4 {
  margin: 0px;
  padding: 0px;
  font-size: 3em; }

h5 {
  margin: 0px;
  padding: 0px;
  font-size: 2em; }

ul {
  list-style: none;
  margin: 0px;
  padding: 0px; }

a {
  text-decoration: none;
  color: #333; }

img {
  margin: 0px;
  padding: 0px;
  width: 100%; }

/*! レスポンシブ対応 */
/*! トップ */
.header {
  height: 50px;
  margin: 20px 0px 0px 0px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  position: relative; }
  .header .hamburger-menu {
    width: 100px;
    height: 50px;
    position: relative;
    border: none;
    background: transparent;
    appearance: none;
    padding: 0;
    cursor: pointer; }
    .header .hamburger-menu .hamburger-menu__bar {
      display: inline-block;
      width: 44%;
      height: 2px;
      background: #242424;
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      transition: .5s; }
    .header .hamburger-menu .hamburger-menu__bar:first-child {
      top: 16px; }
    .header .hamburger-menu .hamburger-menu__bar:nth-child(2) {
      top: 24px; }
    .header .hamburger-menu .hamburger-menu__bar:last-child {
      top: 32px; }

.hamburger-menu--open .hamburger-menu__bar {
  top: 50%; }
.hamburger-menu--open .hamburger-menu__bar:first-child {
  transform: translateX(-50%) translateY(400%) rotate(45deg); }
.hamburger-menu--open .hamburger-menu__bar:last-child {
  transform: translateX(-50%) translateY(-400%) rotate(-45deg); }
.hamburger-menu--open .hamburger-menu__bar:nth-child(2) {
  display: none; }

.navigation {
  display: none;
  background: #fff;
  position: absolute;
  top: 50px;
  width: 200px;
  z-index: 9999;
  opacity: 0.9; }
  .navigation .navigation__list {
    text-align: center;
    list-style: none;
    padding: 0;
    margin: 0; }
    .navigation .navigation__list .navigation__list-item {
      border-bottom: solid 1px #333; }
      .navigation .navigation__list .navigation__list-item .navigation__link {
        color: #333;
        font-weight: 700;
        font-size: 1.5em;
        text-decoration: none;
        display: block;
        padding: 14px 0;
        transition: .5s; }
      .navigation .navigation__list .navigation__list-item .navigation__list-item:first-child {
        border-top: solid 1px #474747; }
  @media (hover: hover) and (pointer: fine) {
    .navigation .navigation__link:hover {
      background: #D3A14A; } }

.section-01 {
  position: relative;
  background: url(images/56.png) repeat-x;
  width: 100%;
  background-position: 0 bottom;
  background-size: auto;
  -webkit-animation: bgroop 0s linear infinite;
  animation: bgroop 60s linear infinite; }
@-webkit-keyframes bgroop {
  from {
    background-position: 0 bottom; }
  to {
    background-position: -813px bottom; } }
@keyframes bgroop {
  from {
    background-position: 0 bottom; }
  to {
    background-position: -813px bottom; } }
  @media screen and (max-width: 420px) {
    .section-01 {
      background-size: contain; } }
  .section-01 .main-topbox {
    position: relative;
    max-width: 1100px;
    height: 950px;
    margin: 0px auto;
    text-align: right; }
    @media screen and (max-width: 420px) {
      .section-01 .main-topbox {
        height: 630px; } }
    .section-01 .main-topbox h2 {
      text-align: left;
      max-width: 450px;
      padding: 50px 20px 0px 20px; }
      @media screen and (max-width: 900px) {
        .section-01 .main-topbox h2 {
          margin: 0px auto; } }
      @media screen and (max-width: 420px) {
        .section-01 .main-topbox h2 {
          max-width: 280px;
          padding: 30px 0px 0px 0px; } }
    .section-01 .main-topbox .main-topminibox01 ul .top-img02 {
      position: absolute;
      max-width: 800px;
      right: 0%;
      top: 200px;
      z-index: 3;
      animation: move02 30s infinite; }
      @media screen and (max-width: 900px) {
        .section-01 .main-topbox .main-topminibox01 ul .top-img02 {
          max-width: 900px;
          top: 400px;
          right: 3%;
          animation: move05 30s infinite; } }
      @media screen and (max-width: 420px) {
        .section-01 .main-topbox .main-topminibox01 ul .top-img02 {
          top: 300px;
          right: 0%;
          max-width: 400px; } }
@keyframes move02 {
  0% {
    transform: translateY(0px); }
  50% {
    transform: translateY(-50px); }
  100% {
    transform: translateY(0px); } }
@keyframes move05 {
  0% {
    transform: translateY(0px); }
  50% {
    transform: translateY(-70px); }
  100% {
    transform: translateY(0px); } }
    .section-01 .main-topbox .main-topminibox01 ul .top-img03 {
      position: absolute;
      max-width: 60px;
      left: 5%;
      bottom: 23%;
      z-index: 2;
      animation: move03 10s infinite; }
@keyframes move03 {
  0% {
    transform: translateX(0px); }
  50% {
    transform: translateX(-100px); }
  100% {
    transform: translateX(0px); } }
      @media screen and (max-width: 420px) {
        .section-01 .main-topbox .main-topminibox01 ul .top-img03 {
          bottom: 20%;
          left: 10%;
          max-width: 30px; } }
    .section-01 .main-topbox .main-topminibox02 {
      position: relative;
      top: 1700px; }
      .section-01 .main-topbox .main-topminibox02 ul {
        position: relative; }
        .section-01 .main-topbox .main-topminibox02 ul .top-img04 {
          position: absolute;
          max-width: 300px;
          left: -10%;
          top: 700px;
          z-index: 2; }
        .section-01 .main-topbox .main-topminibox02 ul .top-img05 {
          position: absolute;
          max-width: 300px;
          right: -10%;
          top: 0px;
          z-index: 2; }
        .section-01 .main-topbox .main-topminibox02 ul .top-img06 {
          position: absolute;
          max-width: 200px;
          left: 50%;
          top: 400px;
          z-index: 3;
          animation: fuwafuwa 20s infinite; }
@keyframes fuwafuwa {
  0% {
    transform: translateY(0px); }
  50% {
    transform: translateY(-50px); }
  100% {
    transform: translateY(0px); } }
        .section-01 .main-topbox .main-topminibox02 ul .top-img07 {
          position: absolute;
          max-width: 300px;
          left: -10%;
          top: 200px;
          z-index: 2; }

/*! section01 */
/*! section02 */
.section-02 {
  width: 100%;
  height: auto;
  background-color: #D3A14A;
  padding: 250px 0px 100px 0px; }
  @media screen and (max-width: 900px) {
    .section-02 {
      padding: 50% 0px 50px 0px; } }
  @media screen and (max-width: 420px) {
    .section-02 {
      padding: 100px 0px 50px 0px; } }
  .section-02 .section02-minibox {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 1050px;
    margin: 0px auto;
    padding: 20px; }
    .section-02 .section02-minibox .section02-message {
      max-width: 650px;
      padding: 50px 20px 20px 40px; }
      @media screen and (max-width: 900px) {
        .section-02 .section02-minibox .section02-message {
          padding: 20px; } }
      @media screen and (max-width: 420px) {
        .section-02 .section02-minibox .section02-message h3 {
          font-size: 4em;
          line-height: 1.1em;
          margin: 10px 0px; } }
      @media screen and (max-width: 420px) {
        .section-02 .section02-minibox .section02-message p {
          font-size: 1.8em; } }
    .section-02 .section02-minibox .section02-images01 {
      max-width: 250px;
      padding: 30px 20px;
      background-color: #fff;
      border-radius: 50%; }
      @media screen and (max-width: 420px) {
        .section-02 .section02-minibox .section02-images01 {
          max-width: 150px; } }

/*! section03 */
.section-03 {
  position: relative;
  width: 100%; }
  .section-03::before {
    content: "";
    position: absolute;
    top: 10px;
    background-image: url(images/background-images01.png);
    width: 100%;
    height: 50px;
    display: inline-block;
    background-size: contain;
    vertical-align: middle; }
    @media screen and (max-width: 420px) {
      .section-03::before {
        height: 20px; } }
  .section-03 .section03-minibox {
    position: relative;
    width: 100%;
    margin: 0px auto 0px auto;
    padding: 160px 0px 50px 0px; }
    @media screen and (max-width: 420px) {
      .section-03 .section03-minibox {
        padding: 100px 0px 50px 0px; } }
    .section-03 .section03-minibox h3 {
      padding: 0px 30px 0px 30px;
      margin: 20px auto 50px auto;
      max-width: 400px; }
      @media screen and (max-width: 420px) {
        .section-03 .section03-minibox h3 {
          margin: 20px auto 50px auto;
          font-size: 4em; } }
    .section-03 .section03-minibox .slick {
      width: 100%;
      margin: 0px auto; }
      .section-03 .section03-minibox .slick .slick__item {
        width: 90%;
        max-width: 200px;
        margin: 0px auto; }
        .section-03 .section03-minibox .slick .slick__item img {
          height: auto;
          width: 100%; }
    .section-03 .section03-minibox .section03-ky01 {
      display: flex;
      justify-content: space-around;
      flex-wrap: wrap;
      padding: 0px 0px 50px 0px; }
      .section-03 .section03-minibox .section03-ky01 li {
        max-width: 200px;
        margin: 30px; }
    .section-03 .section03-minibox .section03-ky02 {
      display: flex;
      justify-content: center;
      flex-wrap: wrap; }
      .section-03 .section03-minibox .section03-ky02 li {
        max-width: 200px; }

/*! section04 */
.section-04 {
  background: url(images/67.png) no-repeat;
  width: 100%;
  background-size: 400px;
  background-position: 0 bottom; }
  @media screen and (max-width: 900px) {
    .section-04 {
      background-size: 60%; } }
  .section-04 .section04-minibox {
    max-width: 1100px;
    width: 100%;
    margin: 0px auto;
    padding: 60px 0px 160px 0px; }
    .section-04 .section04-minibox h3 {
      padding: 0px 20px 0px 20px;
      margin: 0px auto 30px auto;
      max-width: 150px; }
    .section-04 .section04-minibox .section04-webbox {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      margin: 0px 20px 0px 20px; }
      @media screen and (max-width: 900px) {
        .section-04 .section04-minibox .section04-webbox {
          justify-content: center; } }
      @media screen and (max-width: 420px) {
        .section-04 .section04-minibox .section04-webbox {
          justify-content: space-around; } }
      .section-04 .section04-minibox .section04-webbox li {
        width: 300px;
        height: 270px;
        text-align: center;
        padding: 20px;
        border: 1px solid #333; }
        .section-04 .section04-minibox .section04-webbox li img {
          max-width: 300px;
          margin: 0px 0px 5px 0px; }
        .section-04 .section04-minibox .section04-webbox li p {
          text-align: left;
          font-size: 1.5em; }

/*! トップに戻るボタン */
.back-to-top {
  display: none;
  position: fixed;
  right: 5%;
  bottom: 5%;
  color: #fff;
  border-radius: 50%;
  display: inline-block;
  text-decoration: none;
  font-size: 1.6em; }
  @media screen and (max-width: 420px) {
    .back-to-top {
      right: 8%; } }
  .back-to-top:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: inline-block;
    width: 70px;
    height: 70px;
    background-color: #D3A14A;
    border: 3px solid #fff;
    border-radius: 50%;
    z-index: -1; }

/*! スクロールで表示する要素 */
.scroll_up {
  transition: 0.8s ease-in-out;
  transform: translateY(30px);
  opacity: 0; }

.scroll_up.on {
  transform: translateY(0);
  opacity: 1.0; }

/*! footer */
footer {
  width: 100%;
  padding: 20px 0px;
  background-color: #D3A14A; }
  footer .footer-box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    max-width: 1000px;
    width: 100%;
    padding: 0px 20px;
    margin: 0px auto; }
    footer .footer-box .footer-rogo {
      width: 20%; }
      @media screen and (max-width: 420px) {
        footer .footer-box .footer-rogo {
          margin: 0px auto;
          text-align: center;
          width: auto; } }
      footer .footer-box .footer-rogo a {
        color: #FFF; }
    @media screen and (max-width: 420px) {
      footer .footer-box {
        display: block; } }
    footer .footer-box ul {
      width: 80%;
      display: flex;
      justify-content: right;
      flex-wrap: wrap; }
      footer .footer-box ul a {
        font-size: 1em;
        color: #FFF;
        padding: 15px 15px; }
      @media screen and (max-width: 420px) {
        footer .footer-box ul {
          display: block;
          text-align: center;
          width: auto;
          margin: 0px auto; } }

/* Acordion Faq */
.tab {
  position: relative;
  margin-bottom: 1px;
  width: 100%;
  color: #fff;
  overflow: hidden; }

input {
  position: absolute;
  opacity: 0;
  z-index: -1; }

label {
  position: relative;
  display: block;
  padding: 0 0 0 1em;
  background: #fff;
  font-weight: bold;
  line-height: 3;
  cursor: pointer; }

.tab-content {
  max-height: 0;
  overflow: hidden;
  -webkit-transition: max-height .35s;
  -o-transition: max-height .35s;
  transition: max-height .35s;
  color: #000; }

.tab-content p {
  margin: 1em; }

/* :checked */
input:checked ~ .tab-content {
  max-height: 100%; }

/* Icon */
label::after {
  position: absolute;
  right: 0;
  top: 0;
  display: block;
  width: 3em;
  height: 3em;
  line-height: 3;
  text-align: center;
  -webkit-transition: all .35s;
  -o-transition: all .35s;
  transition: all .35s; }

input[type=checkbox] + label::after {
  content: ""; }

input[type=radio] + label::after {
  content: "\25BC"; }

input[type=checkbox]:checked + label::after {
  transform: rotate(315deg); }

input[type=radio]:checked + label::after {
  transform: rotateX(180deg); }

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