@charset "UTF-8";
/*=======================================
トップページ
=========================================*/
.p-top__kv {
  position: relative;
  padding-top: 88px;
  margin-bottom: 203px;
}
.p-top__kv:before {
  display: block;
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 350px;
  background: url(../img/top/kv_bg1.jpg) no-repeat center top;
  background-size: cover;
  z-index: 1;
}
.p-top__kv .c-wrap {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
}
.p-top__kv-img1 {
  width: 29%;
}
.p-top__kv-img1 .box1 {
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 6px 6px 10px rgba(0, 0, 0, 0.1);
}
.p-top__kv-img1 .h {
  text-align: center;
  padding: 4px;
  font-size: 20px;
  font-size: 2rem;
  font-weight: 500;
  background: #F2F3F0;
}
.p-top__kv-img1 .img1 a {
  display: block;
  padding: 24px 36px 18px;
  text-decoration: none;
  color: #1D1D1D;
}
.p-top__kv-img1 .img1 img {
  width: 100%;
}
.p-top__kv-img1 .img1 p {
  margin-top: 12px;
  font-weight: 500;
  font-size: 18px;
  font-size: 1.8rem;
}
.p-top__kv-img1 .link {
  margin-top: 24px;
  text-align: center;
  font-weight: 500;
}
.p-top__kv-box1 {
  width: 68%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.p-top__kv-box1 .h {
  background: rgba(136, 136, 136, 0.3);
  border: 4px solid #fff;
  padding: 5px;
  font-size: 64px;
  font-size: 6.4rem;
  font-weight: 700;
  line-height: 1.29;
  color: #fff;
  margin-bottom: 115px;
  font-family: "Noto Serif JP", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  text-align: left;
}
.p-top__kv-box1 .h span {
  position: relative;
  display: block;
  margin-top: -9px;
}
.p-top__kv-box1 .txt2 {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.77;
}
.p-top__kv-box1 .txt2 strong {
  color: #0C6B42;
}
.p-top__kv-box1 .txt2.l {
  font-size: 24px;
  font-size: 2.4rem;
}
.p-top__kv-box1 .c-btn1 {
  margin-bottom: 16px;
}
.p-top__news {
  display: flex;
  justify-content: space-between;
  margin-bottom: 120px;
}
.p-top__news-heading {
  width: 20%;
}
.p-top__news-heading .category {
  max-width: 100px;
}
.p-top__news-heading .category li {
  margin-bottom: 10px;
  color: #0C6B42;
  text-decoration: none;
  border: 1px solid #0C6B42;
  border-radius: 40px;
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.5;
  background: #fff;
  padding: 9px;
  cursor: pointer;
  -webkit-transition: 0.4s ease all;
  transition: 0.4s ease all;
}
.p-top__news-heading .category li:last-child {
  margin-bottom: 0;
}
.p-top__news-heading .category li.is-active, .p-top__news-heading .category li:hover {
  opacity: 1;
  -ms-filter: "alpha(opacity=100)";
  filter: alpha(opacity=100);
  background-color: #0C6B42;
  color: #fff;
}
.p-top__news-content {
  width: 77%;
}
.p-top__news-content .content {
  display: none;
}
.p-top__news-content .content.is-active {
  display: block;
}
.p-top__news-content li {
  margin-bottom: 24px;
}
.p-top__news-content li:last-child {
  margin-bottom: 0;
}
.p-top__news-content li a {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 24px;
  background: #fff;
  border-radius: 4px;
  text-decoration: none;
  color: #1D1D1D;
}
.p-top__news-content li .img1 {
  width: 27.7008%;
  background: #F1F1F1;
  padding: 13px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  text-align: center;
}
.p-top__news-content li .box1 {
  width: 67.8670%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.p-top__news-content li .box1.w100 {
  width: 100%;
}
.p-top__news-content li .date {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 500;
  margin-right: 16px;
  line-height: 1.4;
}
.p-top__news-content li .category {
  width: 80px;
  border: 1px solid #0C6B42;
  border-radius: 20px;
  text-align: center;
  color: #0C6B42;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.4;
}
.p-top__news-content li .title {
  margin-top: 8px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.6;
  width: 100%;
}
.p-top__news-content li .lead {
  margin-top: 24px;
  color: #6B6B6B;
  width: 100%;
}
.p-top__magazine {
  background: #fff;
  box-shadow: 6px 6px 10px rgba(0, 0, 0, 0.1);
  border-radius: 4px;
  padding-top: 50px;
}
.p-top__magazine .c-title1 {
  margin-bottom: 40px;
}
.p-top__magazine .content {
  max-width: 936px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  *zoom: 1;
}
.p-top__magazine .content:after {
  display: block;
  content: "";
  clear: both;
}
.p-top__magazine .content ul {
  display: flex;
  flex-wrap: wrap;
}
.p-top__magazine .content li {
  width: 22.4358%;
  margin-left: 3.4189%;
}
.p-top__magazine .content li:nth-child(4n+1) {
  margin-left: 0;
}
.p-top__magazine .content li a {
  display: block;
  text-decoration: none;
  color: #1D1D1D;
}
.p-top__magazine .content li .img1 {
  text-align: center;
  margin-bottom: 40px;
}
.p-top__magazine .content li .img1 img {
  height: 224px;
  width: auto;
  object-fit: contain;
  box-shadow: 6px 6px 10px rgba(0, 0, 0, 0.1);
}
.p-top__magazine .content li .date {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: 6px;
}
.p-top__magazine .content li .title {
  font-weight: 400;
  line-height: 1.5;
}
.p-top__magazine .content .c-btn1 {
  margin-top: 50px;
  position: relative;
  margin-bottom: -30px;
  float: left;
  width: 100%;
}

/* ----------------------------- スマホ（～767px） */
@media screen and (max-width: 767px) {
  .p-top__kv {
    padding-top: 52px;
    margin-bottom: 85px;
  }
  .p-top__kv:before {
    background-image: url(../img/top/kv_bg1_sp.jpg);
  }
  .p-top__kv .c-wrap {
    display: block;
  }
  .p-top__kv-img1 {
    width: 290px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 54px;
  }
  .p-top__kv-img1 .h {
    font-size: 20px;
    font-size: 2rem;
  }
  .p-top__kv-box1 {
    width: auto;
  }
  .p-top__kv-box1 .h {
    font-size: 10.76923vw;
    margin-bottom: 12.82051vw;
    white-space: nowrap;
  }
  .p-top__kv-box1 p {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .p-top__kv-box1 .txt2 {
    font-size: 16px;
    font-size: 1.6rem;
  }
  .p-top__news {
    display: block;
    margin-bottom: 80px;
  }
  .p-top__news-heading {
    width: auto;
    margin-bottom: 40px;
  }
  .p-top__news-heading .category {
    max-width: initial;
    display: flex;
    flex-wrap: wrap;
  }
  .p-top__news-heading .category li {
    width: 100px;
    margin-right: 7px;
    margin-bottom: 7px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .p-top__news-heading .category li:last-child {
    margin-bottom: 7px;
  }
  .p-top__news-content {
    width: auto;
  }
  .p-top__news-content li a {
    display: block;
  }
  .p-top__news-content li .img1 {
    width: 200px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 23px;
  }
  .p-top__news-content li .img1 img {
    width: 140px;
  }
  .p-top__news-content li .box1 {
    width: auto;
  }
  .p-top__news-content li .title {
    font-size: 16px;
    font-size: 1.6rem;
  }
  .p-top__news-content li .lead {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.7;
  }
  .p-top__magazine {
    padding-top: 24px;
    position: relative;
  }
  .p-top__magazine .c-title1 {
    margin-bottom: 32px;
  }
  .p-top__magazine .content {
    max-width: initial;
    padding-left: 0;
    padding-right: 0;
  }
  .p-top__magazine .content ul {
    display: block;
  }
  .p-top__magazine .content li {
    width: auto;
    margin-left: 0;
    margin-bottom: 38px;
  }
  .p-top__magazine .content li:last-child {
    margin-bottom: 0;
  }
  .p-top__magazine .content li a {
    display: flex;
    justify-content: space-between;
  }
  .p-top__magazine .content li .img1 {
    width: 31.8471%;
    margin-bottom: 0;
    text-align: center;
  }
  .p-top__magazine .content li .img1 img {
    width: 76px;
  }
  .p-top__magazine .content li .txt1 {
    width: 64.9681%;
  }
}
