@charset "UTF-8";
html {
  position: relative;
  min-height: 100%;
  overflow-x: hidden; }

section {
  overflow: hidden; }

body {
  width: 100%;
  font-size: 16px;
  font-family: "Zen Kaku Gothic New", "游ゴシック体", YuGothic, sans-serif, "メイリオ", meiryo;
  color: #222;
  position: relative;
  line-height: 1.8;
  padding-top: 70px; }

img {
  max-width: 100%;
  width: auto;
  vertical-align: top;
  height: auto; }

.sp {
  display: none !important; }

@media screen and (max-width: 767px) {
  body {
    font-size: 3.2vw;
    padding-top: 12vw; }

  .pc {
    display: none !important; }

  .sp {
    display: inherit !important; } }
a {
  outline: none;
  text-decoration: none; }

a:hover {
  text-decoration: none; }

.pagetop {
  position: relative;
  display: block;
  z-index: 1100; }

.pagetop a {
  width: 50px;
  height: 50px;
  background: #E95B2B;
  border-radius: 50px;
  color: #fff;
  display: block;
  z-index: 1100;
  overflow: hidden;
  position: relative; }
  .pagetop a i {
    color: #fff;
    font-size: 34px;
    font-weight: bold;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); }
  .pagetop a:hover {
    opacity: 0.7;
    transition: 0.3s; }

/*=====================================================
ヘッダー
======================================================*/
header {
  width: 100%;
  height: 70px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  background: white;
  /*nav_wrap*/ }
  header .nav_wrap {
    width: 100%;
    padding: 0;
    margin: 0 auto;
    position: relative;
    /*nav*/ }
    header .nav_wrap .head_logo {
      width: 100%;
      max-width: 300px;
      display: block;
      float: left;
      position: relative;
      z-index: 5;
      margin: 15px 0 0 2%; }
      header .nav_wrap .head_logo img {
        width: 100%; }
        header .nav_wrap .head_logo img:hover {
          opacity: 0.7; }
    header .nav_wrap nav {
      width: auto;
      margin-right: 1%;
      margin-top: 5px;
      /*nav_area*/ }
      header .nav_wrap nav .nav_area {
        text-align: right;
        padding: 0; }
        header .nav_wrap nav .nav_area ul.nav01 {
          margin: 0px 0px 0px 0;
          padding: 0;
          display: inline-block; }
          header .nav_wrap nav .nav_area ul.nav01 li {
            position: relative;
            margin: 0 5px;
            text-align: center;
            display: inline-block; }
            header .nav_wrap nav .nav_area ul.nav01 li a {
              color: #2E2E2E;
              font-size: 16px;
              font-weight: 400;
              padding: 20px 20px;
              display: block;
              position: relative;
              text-decoration: none;
              line-height: 1.3; }
              header .nav_wrap nav .nav_area ul.nav01 li a:hover {
                color: #56B403; }
            header .nav_wrap nav .nav_area ul.nav01 li ul.subnavi {
              position: absolute;
              top: 90px;
              right: 20px;
              width: 230px;
              box-sizing: border-box;
              visibility: hidden;
              opacity: 0;
              padding-top: 0;
              background: #85BE78;
              border-radius: 5px; }
              header .nav_wrap nav .nav_area ul.nav01 li ul.subnavi li {
                text-align: center;
                border-bottom: 1px #fff solid;
                margin: 0;
                padding: 0;
                display: block; }
                header .nav_wrap nav .nav_area ul.nav01 li ul.subnavi li a {
                  width: 230px;
                  text-align: left;
                  padding: 15px 20px;
                  font-weight: normal;
                  display: block;
                  font-size: 15px;
                  color: #fff; }
                  header .nav_wrap nav .nav_area ul.nav01 li ul.subnavi li a:hover {
                    opacity: 0.7; }
                header .nav_wrap nav .nav_area ul.nav01 li ul.subnavi li:last-child {
                  border-bottom: none; }
              header .nav_wrap nav .nav_area ul.nav01 li ul.subnavi:before {
                content: "";
                width: 0;
                height: 0;
                border: 6px transparent solid;
                border-bottom: 12px #85BE78 solid;
                position: absolute;
                bottom: 100%;
                right: 20px; }
            header .nav_wrap nav .nav_area ul.nav01 li:hover ul.subnavi {
              visibility: visible;
              position: absolute;
              top: 60px;
              opacity: 1;
              transition: 0.5s;
              z-index: 3; }
        header .nav_wrap nav .nav_area .nav_join {
          display: inline-block;
          background: #ED765A;
          border-radius: 80px;
          color: #fff;
          font-size: 18px;
          letter-spacing: 3px;
          padding: 10px 40px; }
          header .nav_wrap nav .nav_area .nav_join:hover {
            opacity: 0.7;
            transition: 0.3s; }

/*header*/
header.on {
  position: fixed !important;
  top: 0 !important;
  transition: 0.3s ease-in-out;
  background: #fff;
  filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.7)); }
  header.on .nav_wrap .head_logo:hover {
    opacity: 0.7;
    transition: 0.3s ease-in-out; }

#about header .nav_wrap .head_pc_navi .h_navi p .navi_about {
  color: #5BA995; }

#product header .nav_wrap .head_pc_navi .h_navi p .navi_product {
  color: #5BA995; }

#company header .nav_wrap .head_pc_navi .h_navi p .navi_company {
  color: #5BA995; }

#ethic header .nav_wrap .head_pc_navi .h_navi p .navi_ethic {
  color: #5BA995; }

@media only screen and (min-width: 768px) and (max-width: 980px) {
  header .nav_wrap .head_logo {
    width: 30%; }
  header .nav_wrap nav .nav_area ul.nav01 li {
    margin: 0; }
    header .nav_wrap nav .nav_area ul.nav01 li a {
      padding: 15px 10px; }
  header .nav_wrap nav .nav_area .nav_join {
    padding: 10px 20px; } }
@media screen and (max-width: 767px) {
  header {
    height: 10vw;
    /*sp_nav*/ }
    header .sp_nav {
      position: relative;
      height: 10vw;
      width: 100%;
      /*btn_nav*/
      /*g_nav_sp*/ }
      header .sp_nav .head_logo_sp {
        margin: 0;
        display: block;
        text-align: left;
        z-index: 130;
        width: 100%;
        max-width: 45vw; }
        header .sp_nav .head_logo_sp img {
          width: 100%;
          margin: 3vw 0 0 2vw; }
      header .sp_nav .btn_nav,
      header .sp_nav .btn_nav a span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box; }
      header .sp_nav .btn_nav {
        position: absolute;
        right: 3vw;
        top: 3vw;
        width: 11vw;
        height: 11vw;
        margin: 0;
        z-index: 120;
        cursor: pointer;
        background: #64C610;
        border-radius: 10px; }
        header .sp_nav .btn_nav span {
          position: absolute;
          left: 25%;
          width: 50%;
          height: 2px;
          background-color: #fff;
          border-radius: 3px; }
        header .sp_nav .btn_nav span:nth-of-type(1) {
          top: 2.5vw; }
        header .sp_nav .btn_nav span:nth-of-type(2) {
          top: 4vw; }
        header .sp_nav .btn_nav span:nth-of-type(3) {
          top: 5.5vw; }
        header .sp_nav .btn_nav em {
          color: #fff;
          position: absolute;
          top: 6vw;
          right: 22%;
          font-size: 2.4vw; }
      header .sp_nav .btn_nav.active {
        background: #C1C1BE; }
        header .sp_nav .btn_nav.active a span {
          background-color: #fff; }
        header .sp_nav .btn_nav.active a span:nth-of-type(1) {
          -webkit-transform: translateY(3vw) rotate(-45deg);
          transform: translateY(3vw) rotate(-45deg); }
        header .sp_nav .btn_nav.active a span:nth-of-type(2) {
          opacity: 0; }
        header .sp_nav .btn_nav.active a span:nth-of-type(3) {
          -webkit-transform: translateY(0vw) rotate(45deg);
          transform: translateY(0vw) rotate(45deg); }
        header .sp_nav .btn_nav.active a em {
          display: none; }
      header .sp_nav nav.g_nav_sp {
        width: 100%;
        background: #fff;
        position: absolute;
        top: 10vw;
        left: 0;
        height: 100vh;
        padding: 5vw 5% 0;
        z-index: 100;
        overflow: scroll; }
        header .sp_nav nav.g_nav_sp .g_nav_flex {
          display: -webkit-box;
          display: -moz-box;
          display: -ms-box;
          display: -webkit-flexbox;
          display: -moz-flexbox;
          display: -ms-flexbox;
          display: -webkit-flex;
          display: -moz-flex;
          display: -ms-flex;
          display: flex;
          -webkit-box-lines: multiple;
          -moz-box-lines: multiple;
          -webkit-flex-wrap: wrap;
          -moz-flex-wrap: wrap;
          -ms-flex-wrap: wrap;
          flex-wrap: wrap;
          align-items: flex-start;
          height: auto;
          justify-content: space-between;
          margin-bottom: 7vw;
          width: 90%;
          padding: 0 5%; }
          header .sp_nav nav.g_nav_sp .g_nav_flex .icon {
            width: 20%; }
          header .sp_nav nav.g_nav_sp .g_nav_flex dl {
            width: 75%; }
            header .sp_nav nav.g_nav_sp .g_nav_flex dl dt {
              line-height: 1;
              margin-bottom: 4vw; }
              header .sp_nav nav.g_nav_sp .g_nav_flex dl dt a {
                color: #5FB119;
                font-size: 3.6vw;
                font-weight: 700; }
            header .sp_nav nav.g_nav_sp .g_nav_flex dl dd {
              line-height: 1;
              margin-bottom: 4vw; }
              header .sp_nav nav.g_nav_sp .g_nav_flex dl dd a {
                color: #191919; }
        header .sp_nav nav.g_nav_sp .g_nav_join {
          display: -webkit-box;
          display: -moz-box;
          display: -ms-box;
          display: -webkit-flexbox;
          display: -moz-flexbox;
          display: -ms-flexbox;
          display: -webkit-flex;
          display: -moz-flex;
          display: -ms-flex;
          display: flex;
          -webkit-box-lines: multiple;
          -moz-box-lines: multiple;
          -webkit-flex-wrap: wrap;
          -moz-flex-wrap: wrap;
          -ms-flex-wrap: wrap;
          flex-wrap: wrap;
          align-items: flex-start;
          height: auto;
          justify-content: space-between;
          align-items: stretch;
          margin-bottom: 8vw; }
          header .sp_nav nav.g_nav_sp .g_nav_join a {
            display: -webkit-box;
            display: -moz-box;
            display: -ms-box;
            display: -webkit-flexbox;
            display: -moz-flexbox;
            display: -ms-flexbox;
            display: -webkit-flex;
            display: -moz-flex;
            display: -ms-flex;
            display: flex;
            -webkit-box-lines: multiple;
            -moz-box-lines: multiple;
            -webkit-flex-wrap: wrap;
            -moz-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap;
            align-items: flex-start;
            height: auto;
            align-items: center;
            width: 49%;
            border-radius: 15px;
            line-height: 1.4;
            padding: 5vw;
            color: #fff;
            position: relative; }
            header .sp_nav nav.g_nav_sp .g_nav_join a.left {
              background: #ED765A;
              font-size: 4vw;
              font-weight: 500; }
            header .sp_nav nav.g_nav_sp .g_nav_join a.right {
              background: #5FB119;
              font-size: 2.8vw;
              line-height: 1.8; }
            header .sp_nav nav.g_nav_sp .g_nav_join a:after {
              content: "";
              width: 2.5vw;
              height: 2.5vw;
              background: url("../img/common/icon_btn.svg") no-repeat center;
              background-size: 100%;
              position: absolute;
              right: 2vw;
              top: 50%;
              transform: translateY(-50%); }
        header .sp_nav nav.g_nav_sp .g_nav_contact {
          text-align: center; }
          header .sp_nav nav.g_nav_sp .g_nav_contact a {
            display: block;
            width: 70%;
            margin: 0 auto;
            border: 2px #56B403 solid;
            border-radius: 50px;
            color: #56B403;
            padding: 3vw 0;
            line-height: 1; }
            header .sp_nav nav.g_nav_sp .g_nav_contact a img {
              width: 5vw;
              margin-right: 2vw; }

  header.on .sp_nav {
    /*btn_nav*/ } }
/*=====================================================
フッター
======================================================*/
footer {
  background: #fff; }
  footer .foot_address {
    background: #5FB119; }
    footer .foot_address .address_wrap {
      position: relative;
      padding: 50px 0 30px;
      overflow: hidden;
      text-align: center; }
      footer .foot_address .address_wrap .contents_wrap {
        z-index: 2; }
      footer .foot_address .address_wrap .address {
        margin: 20px 0; }
      footer .foot_address .address_wrap:before {
        content: "";
        background: #fff;
        width: 120%;
        height: 300px;
        border-radius: 50% / 70% 70% 0 0;
        position: absolute;
        top: 0;
        left: -10%;
        z-index: 1; }
      footer .foot_address .address_wrap .foot_contact {
        margin: 0 auto;
        display: inline-block;
        color: #56B405;
        border: 2px #56B405 solid;
        padding: 5px 30px;
        border-radius: 50px; }
        footer .foot_address .address_wrap .foot_contact:hover {
          transition: 0.3s;
          background: #56B405;
          color: #fff; }
  footer .foot_wrap {
    max-width: 740px;
    margin: 0 auto;
    border-top: 1px #56B405 solid; }
    footer .foot_wrap .foot_flex {
      display: -webkit-box;
      display: -moz-box;
      display: -ms-box;
      display: -webkit-flexbox;
      display: -moz-flexbox;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flex;
      display: flex;
      -webkit-box-lines: multiple;
      -moz-box-lines: multiple;
      -webkit-flex-wrap: wrap;
      -moz-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      align-items: flex-start;
      height: auto;
      justify-content: space-between;
      margin: 40px 0 0; }
      footer .foot_wrap .foot_flex .box {
        width: 48%; }
        footer .foot_wrap .foot_flex .box a:hover {
          opacity: 0.7; }
        footer .foot_wrap .foot_flex .box .box_flex {
          display: -webkit-box;
          display: -moz-box;
          display: -ms-box;
          display: -webkit-flexbox;
          display: -moz-flexbox;
          display: -ms-flexbox;
          display: -webkit-flex;
          display: -moz-flex;
          display: -ms-flex;
          display: flex;
          -webkit-box-lines: multiple;
          -moz-box-lines: multiple;
          -webkit-flex-wrap: wrap;
          -moz-flex-wrap: wrap;
          -ms-flex-wrap: wrap;
          flex-wrap: wrap;
          align-items: flex-start;
          height: auto;
          justify-content: flex-start;
          margin-bottom: 50px; }
          footer .foot_wrap .foot_flex .box .box_flex .icon {
            width: 100px;
            text-align: center;
            margin-right: 15px; }
            footer .foot_wrap .foot_flex .box .box_flex .icon a {
              color: #5FB119;
              font-size: 20px;
              line-height: 1.1; }
              footer .foot_wrap .foot_flex .box .box_flex .icon a img {
                margin-bottom: 15px; }
          footer .foot_wrap .foot_flex .box .box_flex .foot_link ul li {
            margin-bottom: 10px; }
            footer .foot_wrap .foot_flex .box .box_flex .foot_link ul li a {
              color: #191919; }
        footer .foot_wrap .foot_flex .box .foot_btn {
          background: #5FB119;
          border: 2px #56B403 solid;
          display: block;
          position: relative;
          color: #fff;
          padding: 15px 10px;
          border-radius: 50px;
          margin-bottom: 20px;
          text-align: center; }
          footer .foot_wrap .foot_flex .box .foot_btn:after {
            content: "";
            width: 16px;
            height: 16px;
            background: url("../img/common/icon_btn.svg") no-repeat center;
            background-size: 100%;
            position: absolute;
            right: 15px;
            top: 50%;
            transform: translateY(-50%); }
          footer .foot_wrap .foot_flex .box .foot_btn:hover {
            background: #fff;
            color: #5FB119;
            transition: 0.3s; }
          footer .foot_wrap .foot_flex .box .foot_btn.regular {
            background: #ED765A;
            border: 2px #ED765A solid; }
            footer .foot_wrap .foot_flex .box .foot_btn.regular:hover {
              background: #fff;
              color: #ED765A; }
    footer .foot_wrap .foot_privacy {
      background: #F3F1ED;
      border-radius: 16px;
      padding: 15px 20px;
      margin-bottom: 10px; }
      footer .foot_wrap .foot_privacy .privacy_flex {
        display: -webkit-box;
        display: -moz-box;
        display: -ms-box;
        display: -webkit-flexbox;
        display: -moz-flexbox;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: flex;
        -webkit-box-lines: multiple;
        -moz-box-lines: multiple;
        -webkit-flex-wrap: wrap;
        -moz-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        align-items: flex-start;
        height: auto;
        justify-content: space-between;
        align-items: center; }
        footer .foot_wrap .foot_privacy .privacy_flex .f_privacy {
          color: #191919; }
        footer .foot_wrap .foot_privacy .privacy_flex .sns li {
          margin-left: 30px;
          display: inline-block; }
          footer .foot_wrap .foot_privacy .privacy_flex .sns li a {
            display: inline-block; }
            footer .foot_wrap .foot_privacy .privacy_flex .sns li a img {
              width: 36px; }
    footer .foot_wrap .copyright {
      text-align: right;
      font-size: 12px;
      color: #717171;
      padding-bottom: 30px; }

/*footer*/
@media screen and (max-width: 767px) {
  footer .foot_address .address_wrap {
    padding: 15vw 0 6vw; }
    footer .foot_address .address_wrap .address {
      margin: 4vw 0; }
    footer .foot_address .address_wrap:before {
      width: 160%;
      height: 70vw;
      left: -30%;
      border-radius: 50% / 70% 70% 0 0; }
    footer .foot_address .address_wrap .foot_contact {
      padding: 1vw 6vw; }
  footer .foot_wrap {
    max-width: inherit;
    width: 90%; }
    footer .foot_wrap .foot_flex {
      margin: 6vw 0 5vw; }
      footer .foot_wrap .foot_flex .box {
        width: 100%; }
        footer .foot_wrap .foot_flex .box .box_flex {
          margin-bottom: 8vw; }
          footer .foot_wrap .foot_flex .box .box_flex .icon {
            width: 20vw;
            margin-right: 4vw; }
            footer .foot_wrap .foot_flex .box .box_flex .icon a {
              font-size: 3.8vw; }
              footer .foot_wrap .foot_flex .box .box_flex .icon a img {
                margin-bottom: 3vw; }
          footer .foot_wrap .foot_flex .box .box_flex .foot_link ul li {
            margin-bottom: 2vw; }
        footer .foot_wrap .foot_flex .box .foot_btn {
          padding: 3vw 2vw;
          margin-bottom: 4vw; }
          footer .foot_wrap .foot_flex .box .foot_btn:after {
            width: 3vw;
            height: 3vw;
            right: 3vw; }
    footer .foot_wrap .foot_privacy {
      padding: 6vw 4vw;
      margin-bottom: 2vw; }
      footer .foot_wrap .foot_privacy .privacy_flex {
        justify-content: center;
        align-items: center; }
        footer .foot_wrap .foot_privacy .privacy_flex .f_privacy {
          width: 100%;
          text-align: center;
          margin-bottom: 2vw; }
        footer .foot_wrap .foot_privacy .privacy_flex .sns li {
          margin: 0 5vw 0; }
          footer .foot_wrap .foot_privacy .privacy_flex .sns li a img {
            width: 8vw; }
    footer .foot_wrap .copyright {
      font-size: 2.4vw;
      padding-bottom: 5vw; }

  /*footer*/ }
/*=====================================================
共通
======================================================*/
.contents_wrap {
  margin: 0 auto;
  width: 90%;
  max-width: 1160px;
  position: relative; }

.contents_wrap02 {
  margin: 0 auto;
  width: 90%;
  max-width: 960px;
  position: relative; }

.center {
  text-align: center !important; }

.btn_area {
  text-align: center; }

.btn01 {
  background: #fff;
  border: 2px #56B403 solid;
  display: inline-block;
  position: relative;
  color: #56B403;
  padding: 15px 80px;
  border-radius: 50px; }
  .btn01:after {
    content: "";
    width: 16px;
    height: 16px;
    background: url("../img/common/btn_arrow.svg") no-repeat center;
    background-size: 100%;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%); }
  .btn01:hover {
    background: #56B403;
    color: #fff;
    transition: 0.3s; }

.btn02 {
  background: #707070;
  border: 2px #707070 solid;
  display: inline-block;
  position: relative;
  color: #fff;
  width: 260px;
  text-align: center;
  padding: 15px 20px;
  border-radius: 50px; }
  .btn02:after {
    content: "";
    width: 16px;
    height: 16px;
    background: url("../img/common/icon_btn.svg") no-repeat center;
    background-size: 100%;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%); }
  .btn02:hover {
    background: #fff;
    color: #707070;
    transition: 0.3s; }

.square_anime {
  position: relative;
  display: inline-block;
  overflow: hidden;
  z-index: 2;
  -webkit-transform: translateX(-100%);
  transform: translateX(-100%); }
  .square_anime:after {
    content: "";
    background: #5FB119;
    width: 100%;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    display: block;
    -webkit-transform-origin: right center;
    transform-origin: right center; }

#about_us, #join, #contact, #privacy {
  background: url("../img/top/top_bg.svg") center;
  background-attachment: fixed;
  background-size: cover; }

#main_img {
  padding: 80px 0 50px 10%; }
  #main_img .ttl_area {
    position: relative;
    left: 0;
    width: 100%;
    color: #191919;
    padding-bottom: 30px; }
    #main_img .ttl_area .wrap {
      max-width: 960px;
      width: 100%; }
    #main_img .ttl_area h1 {
      line-height: 1.2;
      font-size: 46px;
      font-weight: 500; }
    #main_img .ttl_area .h1_sub {
      font-family: "Urbanist", sans-serif;
      font-size: 24px;
      font-weight: 600;
      color: #3E8400; }
  #main_img .main_img_photo {
    width: 100%;
    height: 400px;
    position: relative; }
    #main_img .main_img_photo img {
      object-fit: cover;
      object-position: center;
      width: 100%;
      height: 100%; }
    #main_img .main_img_photo .radius {
      border-radius: 16px 0 0 16px;
      overflow: hidden;
      width: 100%;
      height: 100%; }
    #main_img .main_img_photo .breadcrumb {
      position: absolute;
      left: 0;
      top: 0;
      background: #fff;
      padding: 0 30px 10px 10px;
      border-radius: 0 0 10px 0;
      font-size: 12px;
      z-index: 2; }
      #main_img .main_img_photo .breadcrumb a {
        color: #A59F94; }

#report #main_img .main_img_photo, #join.join_form #main_img .main_img_photo, #contact #main_img .main_img_photo, #privacy #main_img .main_img_photo {
  height: 40px; }

#join.join_form #main_img .main_img_photo .breadcrumb {
  background: none; }

#join #main_img .main_img_photo img {
  object-position: left center; }

#contact #main_img .main_img_photo .breadcrumb {
  background: none; }

#privacy #main_img .main_img_photo .breadcrumb {
  background: none; }

.bottom_half_circle {
  background: #5FB119;
  padding: 0 0 200px;
  position: relative;
  overflow: hidden; }
  .bottom_half_circle:after {
    content: "";
    background: #fff;
    width: 120%;
    height: 500px;
    border-radius: 50% / 0 0 70% 70%;
    position: absolute;
    bottom: 0;
    left: -10%;
    z-index: 1; }

#join.join_form .bottom_half_circle:after {
  background: #F4F1ED; }

#join.form_thanks .bottom_half_circle:after {
  background: #fff; }

#contact .bottom_half_circle:after {
  background: #F4F1ED; }

#contact.contact_thanks .bottom_half_circle:after {
  background: #fff; }

.sec_ttl {
  border-bottom: 1px #5FB119 solid;
  padding: 0 20px 15px 80px;
  background: url("../img/common/icon_ttl.svg") no-repeat left top;
  background-size: 62px;
  line-height: 1.1;
  font-size: 42px;
  font-weight: 500;
  text-align: left;
  margin-bottom: 40px; }

.wp-pagenavi {
  clear: both;
  margin: 80px 0 0px 0;
  padding-top: 0px;
  font-size: 13px;
  width: 100%;
  line-height: 100%;
  text-align: center; }
  .wp-pagenavi a, .wp-pagenavi span {
    font-size: 20px;
    font-weight: 400;
    text-decoration: none;
    padding: 15px 20px;
    display: inline-block;
    line-height: 1;
    margin: 0 5px;
    border-radius: 50px; }
  .wp-pagenavi a {
    line-height: 1;
    background: #F5F5F5;
    color: #56B403; }
    .wp-pagenavi a.nextpostslink {
      background: #F5F5F5; }
    .wp-pagenavi a.previouspostslink {
      background: #F5F5F5; }
    .wp-pagenavi a:hover {
      opacity: 0.7; }
  .wp-pagenavi span {
    background: #56B403;
    color: #fff; }

@media screen and (max-width: 767px) {
  #main_img {
    padding: 6vw 0 10vw 5%; }
    #main_img .ttl_area {
      padding-bottom: 5vw; }
      #main_img .ttl_area h1 {
        font-size: 7vw; }
      #main_img .ttl_area .h1_sub {
        font-size: 4vw; }
    #main_img .main_img_photo {
      height: 62vw; }
      #main_img .main_img_photo .breadcrumb {
        position: absolute;
        top: 100%;
        padding: 2vw 0;
        border-radius: 0;
        font-size: 2.4vw; }

  .btn02 {
    width: 80vw;
    padding: 2vw 4vw; }
    .btn02:after {
      width: 3.2vw;
      height: 3.2vw;
      right: 3vw; }

  #report #main_img .main_img_photo, #join.join_form #main_img .main_img_photo {
    height: 0; }

  .bottom_half_circle {
    padding: 0 0 30vw; }
    .bottom_half_circle:after {
      width: 160%;
      height: 80vw;
      border-radius: 50% / 0 0 70% 70%;
      left: -30%; }

  .sec_ttl {
    padding: 0 4vw 3vw 15vw;
    background-size: 12vw;
    font-size: 6vw;
    margin-bottom: 6vw; }

  .wp-pagenavi {
    font-size: 2.6vw; }
    .wp-pagenavi a, .wp-pagenavi span {
      font-size: 3vw;
      padding: 2vw 2.8vw; } }
