@charset "UTF-8";
/* ---------------------

sdgs

--------------------*/
.sdgs body.sdgs * {
  box-sizing: border-box; }
.sdgs figure {
  margin: 0;
  padding: 0; }
.sdgs section {
  padding: 0; }
.sdgs map {
  cursor: pointer; }
.sdgs .sdgs_bg {
  padding-bottom: 220px;
  background: #f2f4f4 url(../assets/img/about/sdgs_bg.png) repeat-x bottom center; }
.sdgs .mv {
  position: relative;
  padding-top: 25%;
  background: url(../assets/img/about/main_sdgs.png) no-repeat bottom center;
  background-size: cover; }
  .sdgs .mv h2 {
    position: absolute;
    width: 100%;
    left: 0;
    top: 50%;
    color: #fff;
    text-align: center;
    font-size: 50px;
    font-weight: bold;
    line-height: 1.6;
    letter-spacing: 5px;
    transform: translateY(-50%); }
    .sdgs .mv h2 span {
      display: block;
      font-size: 35px; }
.sdgs .lead {
  width: 88%;
  font-size: 18px;
  line-height: 2;
  text-align: center;
  margin: 60px auto; }
.sdgs .sec {
  width: 88%;
  max-width: 1000px;
  margin: 0 auto; }
  .sdgs .sec h3.title {
    font-size: 40px;
    line-height: calc(62 / 40);
    letter-spacing: .1em;
    font-weight: bold;
    text-align: center;
    margin-bottom: 20px; }
    .sdgs .sec h3.title span {
      display: block;
      font-size: 32px; }
  .sdgs .sec .txt {
    font-size: 16px;
    line-height: 1.875;
    margin-bottom: 30px; }
  .sdgs .sec.sec1 {
    padding: 40px 40px 50px 60px;
    background: #fff; }
    .sdgs .sec.sec1 h3 {
      margin-bottom: 0; }
  .sdgs .sec.sec2 {
    max-width: 1147px;
    margin-bottom: 100px; }
  .sdgs .sec.sec3 .list_wrap {
    text-align: center;
    margin-bottom: 60px;
    padding: 40px;
    background: #f4f4f1; }
    .sdgs .sec.sec3 .list_wrap h3 {
      display: inline-block;
      font-size: 32px;
      color: #009b83;
      padding-bottom: 10px;
      border-bottom: 6px solid #009b83; }
    .sdgs .sec.sec3 .list_wrap ul {
      width: 80%;
      margin: 10px 0 0 50%;
      transform: translateX(-50%); }
    .sdgs .sec.sec3 .list_wrap li {
      position: relative;
      font-size: 24px;
      font-weight: bold;
      text-align: left;
      color: #009b83;
      line-height: 1.6;
      padding-left: 60px;
      margin-bottom: 10px; }
      .sdgs .sec.sec3 .list_wrap li span {
        position: absolute;
        left: 0;
        top: 0;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 18px;
        color: #fff;
        width: 40px;
        height: 40px;
        background: #009b83; }
  .sdgs .sec.sec4 {
    margin-top: 120px; }
    .sdgs .sec.sec4 .sec4_image {
      position: relative;
      margin-bottom: 60px;
      padding: 40px 40px 30px;
      text-align: center;
      background: #f4f4f1; }
      .sdgs .sec.sec4 .sec4_image .image_title {
        display: inline-block;
        font-size: 32px;
        font-weight: bold;
        line-height: 1.55;
        color: #009b83;
        margin-bottom: 25px;
        padding-bottom: 10px;
        border-bottom: 6px solid #009b83; }
  .sdgs .sec .flex_inner {
    position: relative;
    display: flex;
    justify-content: space-between;
    z-index: 5; }
    .sdgs .sec .flex_inner .title {
      font-size: 32px;
      font-weight: bold;
      line-height: calc(54 / 32);
      margin-bottom: 20px; }
    .sdgs .sec .flex_inner .txt_wrap {
      width: 50%;
      padding-top: 4%; }
      .sdgs .sec .flex_inner .txt_wrap .txt {
        font-size: 16px;
        line-height: calc(30 / 16);
        margin-bottom: 30px; }
    .sdgs .sec .flex_inner figure {
      padding-left: 30px; }
  .sdgs .sec .sdgs_wrap {
    margin-bottom: 60px;
    padding: 30px 40px 40px;
    border: 2px solid #009b83; }
    .sdgs .sec .sdgs_wrap h3 {
      font-size: 20px;
      color: #009b83;
      margin-bottom: 30px; }
    .sdgs .sec .sdgs_wrap ul {
      width: 80%;
      display: flex;
      justify-content: space-between;
      margin-left: 50%;
      transform: translateX(-50%); }
    .sdgs .sec .sdgs_wrap li {
      display: flex;
      align-items: center;
      width: 50%; }
      .sdgs .sec .sdgs_wrap li img {
        width: 128px; }
      .sdgs .sec .sdgs_wrap li p {
        font-size: 16px;
        line-height: calc(24 / 16);
        font-weight: bold;
        margin-left: 20px; }

@media only screen and (max-width: 769px) {
  .sdgs .sdgs_bg {
    padding-bottom: 130px;
    background: #f2f4f4 url(../assets/img/about/sdgs_bg-sp.png) no-repeat bottom center;
    background-size: 100%; }
  .sdgs .mv {
    position: relative;
    padding-top: 50%;
    background: url(../assets/img/about/main_sdgs-sp.png) no-repeat bottom center;
    background-size: cover; }
    .sdgs .mv h2 {
      font-size: 6.6666666667vw;
      letter-spacing: 0; }
      .sdgs .mv h2 span {
        font-size: 5.5vw; }
  .sdgs .lead {
    text-align: left;
    margin: 30px auto; }
  .sdgs h2 {
    font-size: 6.6666666667vw;
    letter-spacing: 0; }
  .sdgs .sec h3.title {
    font-size: 8vw;
    letter-spacing: 0; }
    .sdgs .sec h3.title span {
      font-size: 7vw; }
  .sdgs .sec.sec1 {
    padding: 30px; }
  .sdgs .sec.sec2 {
    margin-bottom: 70px; }
  .sdgs .sec.sec3 .list_wrap {
    margin-bottom: 30px;
    padding: 30px; }
    .sdgs .sec.sec3 .list_wrap h3 {
      display: block;
      font-size: 7vw; }
    .sdgs .sec.sec3 .list_wrap ul {
      width: 100%; }
    .sdgs .sec.sec3 .list_wrap li {
      font-size: 20px;
      padding-left: 40px;
      line-height: 1.4; }
      .sdgs .sec.sec3 .list_wrap li span {
        width: 30px;
        height: 30px; }
  .sdgs .sec.sec4 {
    margin-top: 60px; }
    .sdgs .sec.sec4 .sec4_image {
      margin-bottom: 30px;
      padding: 30px 30px 120px; }
      .sdgs .sec.sec4 .sec4_image .image_title {
        display: block; }
    .sdgs .sec.sec4 .image_btn {
      position: absolute;
      bottom: 8%;
      left: 30%;
      display: block;
      width: 40%;
      height: 40px;
      color: #fff;
      font-size: 3vw;
      font-weight: bold;
      line-height: 40px;
      text-align: center;
      border-radius: 3px;
      background-color: #009b83; }
      .sdgs .sec.sec4 .image_btn::before {
        content: "→";
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 10px;
        transition: all 0.3s ease 0s; }
  .sdgs .sec .flex_inner {
    display: block; }
    .sdgs .sec .flex_inner .txt_wrap {
      width: 100%; }
      .sdgs .sec .flex_inner .txt_wrap .txt {
        margin-bottom: 10px; }
    .sdgs .sec .flex_inner figure {
      padding-left: 0; }
  .sdgs .sec .sdgs_wrap {
    margin-bottom: 40px;
    padding: 30px; }
    .sdgs .sec .sdgs_wrap h3 {
      font-size: 5vw; }
    .sdgs .sec .sdgs_wrap ul {
      width: 100%;
      display: block; }
    .sdgs .sec .sdgs_wrap li {
      width: 100%; }
      .sdgs .sec .sdgs_wrap li:not(:last-of-type) {
        margin-bottom: 20px; }
      .sdgs .sec .sdgs_wrap li img {
        width: 40%; } }
