@charset "UTF-8";
.container {
  max-width: 960px;
  margin: 0 auto;
}

/* header */
header {
  position: relative;
  max-height: 600px;
  overflow: hidden;
}

header ul li img {
  width: 100%;
}

header .catch-copy {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 2;
  padding: 30px 0;
  border-radius: 40px 0 40px 0;
  background-color: #fff;
}

header .catch-copy h1 {
  color: #000;
  font-size: 5rem;
  font-weight: bold;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho",
 serif;
  line-height: 2;
  -webkit-writing-mode: vertical-rl;
          writing-mode: vertical-rl;
  -ms-writing-mode: vertical-rl;
}

/* main */
.main h2 {
  padding: 70px;
  font-size: 4.8rem;
  font-weight: bold;
  text-align: center;
}

.main h3 {
  font-size: 2.4rem;
}

.main p {
  padding-bottom: 1rem;
  font-size: 1.6rem;
  line-height: 1.5;
}

.main img {
  width: 100%;
  margin: 100px 0 80px;
}

.main ol {
  margin-bottom: 50px;
}

.main ol .list01 {
  margin-bottom: 50px;
  border: 3px solid #06b075;
  border-radius: 80px 0 80px 0;
}

.main ol .list01 h3 {
  padding: 30px 0 0 40px;
  color: #06b075;
  font-weight: bold;
  text-align: left;
}

.main ol .list01 p {
  padding: 10px 40px 30px;
  color: #06b075;
}

.main ol .list02 {
  margin-bottom: 50px;
  border: 3px solid #5ebf7a;
  border-radius: 0 80px 0 80px;
}

.main ol .list02 h3 {
  padding: 30px 0 0 40px;
  color: #5ebf7a;
  font-weight: bold;
  text-align: left;
}

.main ol .list02 p {
  padding: 10px 40px 30px;
  color: #5ebf7a;
}

.main ol .list03 {
  margin-bottom: 50px;
  border: 3px solid #9dcf6f;
  border-radius: 80px 0 80px 0;
}

.main ol .list03 h3 {
  padding: 30px 0 0 40px;
  color: #9dcf6f;
  font-weight: bold;
  text-align: left;
}

.main ol .list03 p {
  padding: 10px 40px 30px;
  color: #9dcf6f;
}

.main ol .list04 {
  margin-bottom: 50px;
  border: 3px solid #057568;
  border-radius: 0 80px 0 80px;
}

.main ol .list04 h3 {
  padding: 30px 0 0 40px;
  color: #057568;
  font-weight: bold;
  text-align: left;
}

.main ol .list04 p {
  padding: 10px 40px 30px;
  color: #057568;
}

.freestyle {
  height: 560px;
  background-color: #eeeeee;
}

.freestyle .flex01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 400px;
  padding-top: 40px;
}

.freestyle .flex01 .introduction {
  width: 400px;
}

.freestyle .flex01 .introduction .background-text {
  height: 120px;
  position: relative;
  background: no-repeat url("/img/freestyle_bg.png");
}

.freestyle .flex01 .introduction .background-text h2 {
  position: absolute;
  top: 70px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  font-size: 4rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝",
 "MS PMincho", serif;
  font-weight: bold;
  text-align: center;
}

.freestyle .flex01 .introduction p {
  padding: 30px;
  font-size: 1.6rem;
}

.freestyle .flex01 .picture {
  width: 50%;
  position: relative;
}

.freestyle .flex01 .picture img {
  position: absolute;
  top: 30px;
  left: 30px;
  -webkit-box-shadow: #006931 -30px -30px 0;
          box-shadow: #006931 -30px -30px 0;
}

.freestyle .link-box {
  width: 700px;
  margin: 24px auto;
  padding: 16px;
  background-color: #fff;
  border: #333 1px solid;
  border-radius: 20px 0 20px 0;
}

.freestyle .link-box p {
  text-align: center;
  margin-bottom: 16px;
}

.freestyle .link-box a {
  width: 120px;
}

.kawabe {
  height: 560px;
}

.kawabe .flex02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 400px;
  padding-top: 40px;
}

.kawabe .flex02 .introduction {
  width: 400px;
}

.kawabe .flex02 .introduction .background-text {
  height: 120px;
  position: relative;
  background: no-repeat url("/img/kawabe_bg.png");
}

.kawabe .flex02 .introduction .background-text h2 {
  position: absolute;
  top: 70px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 240px;
  font-size: 4rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝",
 "MS PMincho", serif;
  font-weight: bold;
  text-align: center;
}

.kawabe .flex02 .introduction p {
  padding: 30px;
  font-size: 1.6rem;
}

.kawabe .flex02 .picture {
  width: 50%;
  position: relative;
}

.kawabe .flex02 .picture img {
  position: absolute;
  top: 30px;
  left: -30px;
  -webkit-box-shadow: #006931 30px -30px 0;
          box-shadow: #006931 30px -30px 0;
}

.kawabe .link-box {
  width: 700px;
  margin: 24px auto;
  padding: 16px;
  background-color: #fff;
  border: #333 1px solid;
  border-radius: 20px 0 20px 0;
}

.kawabe .link-box p {
  text-align: center;
  margin-bottom: 16px;
}

.kawabe .link-box a {
  width: 200px;
}

.bmj {
  height: 560px;
  background-color: #eeeeee;
}

.bmj .flex01 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 400px;
  padding-top: 40px;
}

.bmj .flex01 .introduction {
  width: 400px;
}

.bmj .flex01 .introduction .background-text {
  height: 120px;
  position: relative;
  background: no-repeat url("/img/bmj_bg.png");
}

.bmj .flex01 .introduction .background-text h2 {
  position: absolute;
  top: 70px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 240px;
  font-size: 4rem;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝",
 "MS PMincho", serif;
  font-weight: bold;
  text-align: center;
}

.bmj .flex01 .introduction p {
  padding: 30px;
  font-size: 1.6rem;
}

.bmj .flex01 .picture {
  width: 50%;
  position: relative;
}

.bmj .flex01 .picture img {
  position: absolute;
  top: 30px;
  left: 30px;
  -webkit-box-shadow: #006931 -30px -30px 0;
          box-shadow: #006931 -30px -30px 0;
}

.bmj .link-box {
  width: 700px;
  margin: 24px auto;
  padding: 16px;
  background-color: #fff;
  border: #333 1px solid;
  border-radius: 20px 0 20px 0;
}

.bmj .link-box p {
  text-align: center;
  margin-bottom: 16px;
}

.bmj .link-box a {
  width: 120px;
}

footer {
  text-align: center;
}

footer small {
  font-weight: bold;
}

.grad-wrap {
  position: relative;
}

.grad-btn {
  z-index: 2;
  position: absolute;
  right: 0;
  bottom: -30px;
  left: 0;
  width: 148px;
  margin: auto;
  padding: 0.5em 0;
  border-radius: 2px;
  background: #006831;
  color: #fff;
  font-size: 1.6rem;
  text-align: center;
  opacity: 0.8;
  cursor: pointer;
  -webkit-transition: .2s ease;
  transition: .2s ease;
}

.grad-btn::before {
  content: "続きを読む";
}

.grad-item {
  position: relative;
  overflow: hidden;
  height: 160px;
  /*隠した状態の高さ*/
}

.grad-item::before {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100px;
  /*グラデーションで隠す高さ*/
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0)), color-stop(50%, rgba(255, 255, 255, 0.9)), color-stop(50%, rgba(255, 255, 255, 0.9)), to(#fff));
  background: linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.9) 50%, rgba(255, 255, 255, 0.9) 50%, #fff 100%);
  content: "";
}

.grad-trigger {
  display: none;
  /*チェックボックスは常に非表示*/
}

.grad-trigger:checked ~ .grad-btn {
  bottom: -40px;
}

.grad-trigger:checked ~ .grad-btn::before {
  content: "閉じる";
  /*チェックされていたら、文言を変更する*/
}

.grad-trigger:checked ~ .grad-item {
  height: auto;
  /*チェックされていたら、高さを戻す*/
}

.grad-trigger:checked ~ .grad-item::before {
  display: none;
  /*チェックされていたら、grad-itemのbeforeを非表示にする*/
}

@media (max-width: 960px) {
  .container {
    margin: 0 24px;
  }
  header {
    min-height: 400px;
  }
  header ul li img {
    height: 80vh;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .main h2 {
    padding: 40px 0;
    font-size: 2.6rem;
  }
  .main img {
    width: 100%;
    margin: 80px 0 50px;
  }
  .main ol .list01 {
    border-radius: 60px 0 60px 0;
  }
  .main ol .list01 h3 {
    padding: 20px 0 0;
    text-align: center;
  }
  .main ol .list01 p {
    padding: 10px 10px 20px;
  }
  .main ol .list02 {
    border-radius: 0 60px 0 60px;
  }
  .main ol .list02 h3 {
    padding: 20px 0 0;
    text-align: center;
  }
  .main ol .list02 p {
    padding: 10px 10px 20px;
  }
  .main ol .list03 {
    border-radius: 60px 0 60px 0;
  }
  .main ol .list03 h3 {
    padding: 20px 0 0;
    text-align: center;
  }
  .main ol .list03 p {
    padding: 10px 10px 20px;
  }
  .main ol .list04 {
    border-radius: 0 60px 0 60px;
  }
  .main ol .list04 h3 {
    padding: 20px 0 0;
    text-align: center;
  }
  .main ol .list04 p {
    padding: 10px 10px 20px;
  }
  .freestyle {
    height: auto;
    padding-bottom: 50px;
  }
  .freestyle .flex01 {
    display: block;
    height: auto;
  }
  .freestyle .flex01 .picture {
    width: 100%;
    max-height: 346px;
  }
  .freestyle .flex01 .picture:before {
    content: "";
    display: block;
    padding-top: 70%;
  }
  .freestyle .flex01 .picture img {
    top: 15px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    -webkit-box-shadow: #006931 -15px -15px 0;
            box-shadow: #006931 -15px -15px 0;
  }
  .freestyle .flex01 .introduction {
    width: 100%;
  }
  .freestyle .flex01 .introduction .background-text {
    height: 15vh;
    max-width: 500px;
    margin: 0 auto;
    background-size: contain;
  }
  .freestyle .flex01 .introduction .background-text h2 {
    top: 60px;
  }
  .freestyle .flex01 .introduction p {
    padding: 10px 0 0 0;
  }
  .freestyle .link-box {
    width: 100%;
    margin: 20px 0;
  }
  .kawabe {
    height: auto;
    padding-bottom: 50px;
  }
  .kawabe .flex02 {
    display: block;
    height: auto;
  }
  .kawabe .flex02 .picture {
    width: 100%;
    max-height: 346px;
  }
  .kawabe .flex02 .picture:before {
    content: "";
    display: block;
    padding-top: 70%;
  }
  .kawabe .flex02 .picture img {
    top: 15px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    -webkit-box-shadow: #006931 15px -15px 0;
            box-shadow: #006931 15px -15px 0;
  }
  .kawabe .flex02 .introduction {
    width: 100%;
  }
  .kawabe .flex02 .introduction .background-text {
    height: 15vh;
    max-width: 500px;
    margin: 0 auto;
    background-size: contain;
  }
  .kawabe .flex02 .introduction .background-text h2 {
    top: 60px;
  }
  .kawabe .flex02 .introduction p {
    padding: 10px 0 0 0;
  }
  .kawabe .link-box {
    width: 100%;
    margin: 20px 0;
  }
  .bmj {
    height: auto;
    padding-bottom: 50px;
  }
  .bmj .flex01 {
    display: block;
    height: auto;
  }
  .bmj .flex01 .picture {
    width: 100%;
    max-height: 346px;
  }
  .bmj .flex01 .picture:before {
    content: "";
    display: block;
    padding-top: 70%;
  }
  .bmj .flex01 .picture img {
    top: 15px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    -webkit-box-shadow: #006931 -15px -15px 0;
            box-shadow: #006931 -15px -15px 0;
  }
  .bmj .flex01 .introduction {
    width: 100%;
  }
  .bmj .flex01 .introduction .background-text {
    height: 15vh;
    max-width: 500px;
    margin: 0 auto;
    background-size: contain;
  }
  .bmj .flex01 .introduction .background-text h2 {
    top: 60px;
  }
  .bmj .flex01 .introduction p {
    padding: 10px 0 0 0;
  }
  .bmj .link-box {
    width: 100%;
    margin: 20px 0;
  }
  .grad-btn {
    width: 120px;
    font-size: 1.4rem;
  }
}
/*# sourceMappingURL=style.css.map */