@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
fieldset,
input,
textarea,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset,
img {
  border: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  font-weight: normal;
}

ol,
ul {
  list-style: none;
}

caption,
th {
  text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal;
}

q:before,
q:after {
  content: "";
}

abbr,
acronym {
  border: 0;
}

/*iosのフォームボタンリセット*/
input[type=submit],
input[type=button],
input[type=reset] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration,
input[type=reset]::-webkit-search-decoration {
  display: none;
}

input[type=submit]::focus,
input[type=button]::focus,
input[type=reset]::focus {
  outline-offset: -2px;
}

/*変数設定用*/
/*フォント*/
/*ボタングラデーション*/
* {
  padding: 0px;
  margin: 0px;
  box-sizing: border-box;
}

html {
  font-size: 0.7692307692vw;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}
@media screen and (min-width: 1301px) {
  html {
    font-size: 10px;
  }
}
@media screen and (max-width: 390px) {
  html {
    font-size: 1.3333333333vw;
  }
}

* {
  box-sizing: border-box;
}

img {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  vertical-align: bottom;
}

li {
  list-style: none;
}

a {
  color: #000;
  text-decoration: none;
}
a:hover {
  opacity: 0.7;
  transition: 0.3s;
}
a:hover img:hover {
  opacity: 0.7;
  transition: 0.3s;
}

.vsp {
  display: none;
}

.vpc {
  display: block;
}

body {
  font-family: "noto-sans-cjk-jp", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #000;
}

.js-fade {
  opacity: 0;
  transition-duration: 1.1s;
  transform: translateY(50px);
}
.js-fade.is-active {
  transform: translate(0, 0);
  opacity: 1;
}

#wrapper {
  overflow-x: hidden;
}
#wrapper img {
  max-width: none;
  width: 100%;
}
#wrapper .header {
  text-align: center;
  padding: 3rem 3rem 1.8rem 2.4rem;
}
@media screen and (max-width: 390px) {
  #wrapper .header {
    padding: 3rem 3rem 4.2rem;
  }
}
#wrapper .header__H1 {
  display: inline-block;
  width: 64.4rem;
}
@media screen and (max-width: 390px) {
  #wrapper .header__H1 {
    width: 62rem;
  }
}
#wrapper .mv__Thum {
  width: 100%;
  margin: auto;
  display: block;
}
@media screen and (min-width: 1301px) {
  #wrapper .mv__Thum {
    width: 130rem;
  }
}
#wrapper .sec01 {
  margin-top: -7rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01 {
    margin-top: -1.5rem;
  }
}
#wrapper .sec01__Ttl img {
  display: block;
  width: 47.1rem;
  margin: auto;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Ttl img {
    width: 47.1rem;
  }
}
#wrapper .sec01__Wrap {
  background: url("./../img/bg_sec01.png");
  background-size: 100%;
  background-repeat: no-repeat;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Wrap {
    background: url("./../img/bg_sec01_sp.png");
    background-size: 100%;
  }
}
#wrapper .sec01__Subttl {
  text-align: center;
  padding-top: 2rem;
  padding-bottom: 1.5rem;
  background: #947740;
}
#wrapper .sec01__Subttl img {
  display: block;
  width: 105rem;
  margin: auto;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Subttl img {
    width: 60.2rem;
  }
}
#wrapper .sec01__Box {
  position: relative;
  width: 100%;
  height: 82.5rem;
  margin: auto;
}
@media screen and (min-width: 1301px) {
  #wrapper .sec01__Box {
    width: 130rem;
  }
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Box {
    height: 144rem;
  }
}
#wrapper .sec01__Flow {
  position: absolute;
}
#wrapper .sec01__Flow.-flow01 {
  width: 56.1rem;
  top: 9.7rem;
  left: 10.6rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Flow.-flow01 {
    width: 60.1rem;
    top: 3.5rem;
    left: 7.5rem;
  }
}
#wrapper .sec01__Flow.-flow01:before {
  position: absolute;
  top: 18.7rem;
  right: -9.3rem;
  content: "";
  width: 8.4rem;
  height: 4rem;
  background: url("./../img/icon_arrow_01.png");
  background-size: cover;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Flow.-flow01:before {
    top: auto;
    bottom: -9.8rem;
    left: 27.8rem;
    width: 4rem;
    height: 8.4rem;
    background: url("./../img/icon_arrow_sp.png");
    background-size: cover;
  }
}
#wrapper .sec01__Flow.-flow02 {
  width: 52.9rem;
  top: 11.6rem;
  left: 67.5rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Flow.-flow02 {
    width: 58.69rem;
    top: 48.8rem;
    left: 8rem;
  }
}
#wrapper .sec01__Flow.-flow02:before {
  position: absolute;
  bottom: -8.8rem;
  left: 13.7rem;
  content: "";
  width: 5.4rem;
  height: 6.94rem;
  background: url("./../img/icon_arrow_02.png");
  background-size: cover;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Flow.-flow02:before {
    bottom: -9.8rem;
    left: 27.4rem;
    width: 4rem;
    height: 8.4rem;
    background: url("./../img/icon_arrow_sp.png");
    background-size: cover;
  }
}
#wrapper .sec01__Flow.-flow03 {
  width: 64.3rem;
  top: 43.3rem;
  left: 16.2rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Flow.-flow03 {
    width: 44.1rem;
    top: 92rem;
    left: 7.5rem;
  }
}
#wrapper .sec01__Case {
  display: flex;
  position: absolute;
  width: 102.8rem;
  top: 60rem;
  left: 16.2rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Case {
    flex-wrap: wrap;
    width: 63rem;
    top: 103rem;
    left: 7.3rem;
    gap: 4rem 0;
    justify-content: space-between;
  }
}
#wrapper .sec01__Case li {
  margin-right: 2.7rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Case li {
    margin-right: 0;
  }
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Case li:nth-child(1) {
    margin-right: 23.1rem;
  }
}
#wrapper .sec01__Case li:nth-child(2) {
  margin-right: 24.1rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Case li:nth-child(2) {
    margin-right: 0;
  }
}
#wrapper .sec01__Case li:nth-child(3) {
  margin-right: 1rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Case li:nth-child(3) {
    margin-right: 23.1rem;
  }
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Case li:nth-child(3) img {
    transform: translateX(-1.5rem);
  }
}
#wrapper .sec01__Case li:last-child {
  margin-right: 0;
}
@media screen and (max-width: 390px) {
  #wrapper .sec01__Case li:last-child img {
    transform: translateX(0.5rem);
  }
}
#wrapper .sec01__Case li img {
  width: auto;
  height: 16.2rem;
}
#wrapper .sec02 {
  background: #947740;
  padding: 3rem 0 3.2rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec02 {
    padding: 3.5rem 0 5rem;
  }
}
#wrapper .sec02__Inner {
  margin: auto;
  width: 100%;
}
@media screen and (min-width: 1301px) {
  #wrapper .sec02__Inner {
    width: 130rem;
  }
}
#wrapper .sec02__Ttl {
  width: 77.7rem;
  margin: 0 auto 1.2rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec02__Ttl {
    width: 58.1rem;
    margin: 0 auto 3rem;
  }
}
#wrapper .sec02__Box {
  margin: auto;
  position: relative;
  width: 107.4rem;
  height: 57.6rem;
  background: #fff;
  border-radius: 1rem;
  padding: 1.7rem 4rem 2.8rem 3.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 390px) {
  #wrapper .sec02__Box {
    width: 60rem;
    height: 133.6rem;
    flex-flow: column;
    gap: 4.5rem;
    padding: 3rem 3rem 4.8rem 2rem;
  }
}
#wrapper .sec02__Box-Left {
  width: 50.1rem;
  padding-top: 1.2rem;
  display: block;
}
@media screen and (max-width: 390px) {
  #wrapper .sec02__Box-Left {
    transform: translateX(1rem);
    width: 53.1rem;
  }
}
#wrapper .sec02__Box-Right {
  width: 47.79rem;
  display: block;
}
#wrapper .sec02__Box-Illust {
  position: absolute;
  bottom: -3.4rem;
  right: 4.7rem;
  width: 20.3rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec02__Box-Illust {
    bottom: -5.4rem;
    right: -1.5rem;
    width: 25.7rem;
  }
}
#wrapper .sec03 {
  margin-top: 7.8rem;
  margin-bottom: 9.3rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec03 {
    margin-top: 6.8rem;
    margin-bottom: 6rem;
  }
}
#wrapper .sec03__Inner {
  margin: auto;
  width: 100%;
}
@media screen and (min-width: 1301px) {
  #wrapper .sec03__Inner {
    width: 130rem;
  }
}
#wrapper .sec03__Thum.-thum01 {
  display: block;
}
#wrapper .sec03__Thum.-thum02 {
  display: block;
  margin: -4.2rem auto 0;
  width: 107.7rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec03__Thum.-thum02 {
    width: 61rem;
  }
}
#wrapper .sec04__Inner {
  margin: auto;
  width: 100%;
}
@media screen and (min-width: 1301px) {
  #wrapper .sec04__Inner {
    width: 130rem;
  }
}
@media screen and (max-width: 390px) {
  #wrapper .sec04__Inner {
    width: 60rem;
  }
}
#wrapper .sec04__Flex {
  display: flex;
  justify-content: space-between;
  margin-bottom: 3.5rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec04__Flex {
    flex-flow: column;
    gap: 3rem;
  }
}
#wrapper .sec04__Flex-Thum {
  width: 63.2rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec04__Flex-Thum {
    width: 100%;
  }
}
#wrapper .sec04__Flex-Detail {
  width: 63.2rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec04__Flex-Detail {
    width: 100%;
  }
}
#wrapper .sec04__Flex-Detail-Inner {
  width: 52.3rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec04__Flex-Detail-Inner {
    width: 100%;
  }
}
#wrapper .sec04__Flex-Detail-Ttl {
  margin-bottom: 1.9rem;
}
#wrapper .sec04__Flex-Detail-Tel {
  margin-bottom: 2.7rem;
  display: block;
}
#wrapper .sec04__Flex-Detail-Txt {
  margin-bottom: 1.4rem;
}
#wrapper .sec04__Flex-Detail-Btns {
  display: flex;
  justify-content: space-between;
}
#wrapper .sec04__Flex-Detail-Btns li {
  width: 25.5rem;
}
@media screen and (max-width: 390px) {
  #wrapper .sec04__Flex-Detail-Btns li {
    width: 29.3rem;
  }
}
#wrapper .footer {
  padding-bottom: 13rem;
}
@media screen and (max-width: 390px) {
  #wrapper .footer {
    padding-bottom: 6rem;
  }
}
#wrapper .footer__Txt {
  background: #004a85;
  padding: 1rem 0;
  text-align: center;
}
#wrapper .footer__Txt img {
  width: 59.3rem;
  display: inline-block;
}
@media screen and (max-width: 390px) {
  #wrapper .footer__Txt img {
    width: 54.5rem;
  }
}
#wrapper .footer__Logo {
  padding: 2.3rem 0 7rem;
  text-align: center;
}
#wrapper .footer__Logo img {
  width: 46.2rem;
  display: inline-block;
}
@media screen and (max-width: 390px) {
  #wrapper .footer__Logo img {
    width: 48.8rem;
  }
}
#wrapper .fix {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: #004a85;
  padding: 0.8rem 0;
}
#wrapper .fix__Inner {
  width: 81.5rem;
  margin: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 390px) {
  #wrapper .fix__Inner {
    width: 59.8rem;
  }
}
#wrapper .fix__Inner a {
  width: 39.6rem;
  display: block;
}
@media screen and (max-width: 390px) {
  #wrapper .fix__Inner a {
    width: 28.8rem;
  }
}