body {
  position: relative;
}

.inner {
  margin: auto;
  overflow: hidden;
}

img {
  height: auto;
}

img.fit {
  width: 100%;
}

* {
  text-align: center;
}

/*************************************/
h1, p, a {
  display: block;
  line-height: 1;
}

body {
  position: relative;
}

header {
  background: #fff;
  position: fixed;
  width: 100%;
}

#cnt00 {
  background-image: url(../img/2111-img00_back.png);
}

#cnt01 {
  background-image: url(../img/2111-img01_back.png);
  background-position: center center;
  background-size: cover;
}

#cnt01 img {
  max-width: 100%;
}

#cnt01 > div {
  position: relative;
  display: inline-block;
}

#cnt01 .link {
  position: absolute;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  bottom: 6.6%;
}

#cnt01 .link p {
  margin: 0 -1%;
  width: 41.8%;
}

#cnt02 {
  background-color: #fff585;
  padding-bottom: 120px;
}

.main-link {
  margin-bottom: -15px;
}

#cnt03 {
  background-image: url(../img/2111-img03_back.png);
  background-position: 0 4px;
}

#cnt03 .box {
  position: relative;
  display: inline-block;
}

#cnt03 .flex-link {
  position: absolute;
  top: 1585px;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: center;
}

#cnt03 .flex-link p {
  margin: 0 3px;
}

#cnt04 {
  background-image: url(../img/img04_back.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  padding-bottom: 80px;
}

#cnt04 .flex-link {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 0 auto;
}

#cnt04 .flex-link > p {
  margin: -15px;
}

.patternbox {
  padding-top: 200px;
}

.patternbox > div {
  padding-bottom: 70px;
  position: relative;
}

.patternbox > div:before {
  content: "";
  position: absolute;
  height: 540px;
  width: 100%;
  max-width: 1600px;
  left: 0;
  right: 0;
  margin: 0 auto;
  top: -100px;
  background-image: url(../img/img0501_main.png);
  background-position: top center;
  background-size: 100% auto;
  background-repeat: no-repeat;
  z-index: -1;
}

.patternbox > div:after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
  background-image: url(../img/img0501_back.png);
  z-index: -2;
}

#cnt0502.patternbox > div:before {
  background-image: url(../img/img0502_main.png);
}

#cnt0502.patternbox > div:after {
  background-image: url(../img/img0502_back.png);
}

#cnt0503.patternbox > div:before {
  background-image: url(../img/img0503_main.png);
}

#cnt0503.patternbox > div:after {
  background-image: url(../img/img0503_back.png);
}

#cnt0504.patternbox > div:before {
  background-image: url(../img/img0504_main.png);
}

#cnt0504.patternbox > div:after {
  background-image: url(../img/img0504_back.png);
}

#cnt0505.patternbox > div:before {
  background-image: url(../img/img0505_main.png);
}

#cnt0505.patternbox > div:after {
  background-image: url(../img/img0505_back.png);
}

#cnt06 {
  background-image: url(../img/2111-img03_back_arrow.png);
  background-repeat: no-repeat;
  background-size: auto auto;
  background-position: top center;
  position: relative;
  padding-bottom: 100px;
}

#cnt06:before {
  content: "";
  position: absolute;
  height: 33.5%;
  width: 100%;
  left: 0;
  top: 0;
  background-image: url(../img/img06_back01.png);
  background-size: cover;
  background-position: center center;
  z-index: -1;
}

#cnt06:after {
  content: "";
  position: absolute;
  height: 66.5%;
  width: 100%;
  left: 0;
  bottom: 0;
  background-image: url(../img/img06_back02.png);
  background-size: cover;
  background-position: center center;
  z-index: -1;
}

#cnt07 {
  background-color: #b5cfff;
  background-image: url(../img/img07_back.png?20211007);
  background-position: center top;
  background-repeat: no-repeat;
  padding-bottom: 80px;
}

#cnt08 {
  position: relative;
}

#cnt08:before {
  content: "";
  position: absolute;
  height: 430px;
  width: 100%;
  left: 0;
  top: 0;
  background-image: url(../img/img08_back.png);
  background-size: cover;
  background-position: center center;
  z-index: -1;
}

#cnt08:after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  left: 0;
  bottom: 0;
  background-color: #fff585;
  z-index: -2;
}

#cnt08 .box {
  position: relative;
  display: inline-block;
}

#cnt08 .box .link {
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 205px;
}

#cnt09 p {
  margin-bottom: -25px;
  position: relative;
  z-index: 1;
}

#cnt09 .flex {
  display: flex;
  align-items: center;
  max-height: 300px;
  overflow: hidden;
}

#cnt09 .flex > div {
  width: 25%;
}

#cnt09 .flex > div img {
  width: 100%;
}

#cnt09 .link {
  margin-top: 20px;
  margin-bottom: 80px;
}

footer .flex {
  display: flex;
  justify-content: center;
}

footer .logo {
  margin-bottom: 40px;
  margin-top: 20px;
}

footer .img {
  margin-left: 45px;
}
