@charset "UTF-8";
/*====================================================================

====================================================================*/
@media only screen and (min-width: 1200px) {
  .spOnly {
    display: none;
  }
}
@media only screen and (max-width: 1199px) {
  .pcOnly {
    display: none;
  }
}
/*====================================================================
  このファイルはutf-8です
====================================================================*/
section.content div.in {
  max-width: 900px;
}
section.content p.body {
  text-align: justify;
  line-height: 2em;
}
section.content div.header h2 {
  color: #003e8d;
  font-family: "HiraKakuPro-W6", "ヒラギノ角ゴ Pro W6", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "メイリオ", sans-serif;
  font-weight: bold;
  margin-bottom: 50px;
}
@media only screen and (min-width: 1200px) {
  section.content div.header h2 {
    font-size: 36px;
    font-size: 2.25rem;
  }
}
@media only screen and (max-width: 1199px) {
  section.content div.header h2 {
    font-size: 36px;
    font-size: 2.25rem;
  }
}
@media only screen and (max-width: 799px) {
  section.content div.header h2 {
    font-size: 26px;
    font-size: 1.625rem;
  }
}

section.content.catch div.catch img {
  width: 100%;
}

section.content.info ul.sdgs {
  display: flex;
  -js-display: flex;
  -moz-flex-direction: row;
  -o-flex-direction: row;
  flex-direction: row;
  -moz-justify-content: center;
  -ms-justify-content: center;
  -o-justify-content: center;
  justify-content: center;
  margin-bottom: 50px;
}
section.content.info ul.sdgs > li {
  -moz-flex: 0 0 30%;
  -o-flex: 0 0 30%;
  flex: 0 0 30%;
  max-width: 150px;
  margin: 0 10px;
}
section.content.info ul.sdgs > li img {
  width: 100%;
}
section.content.info p {
  text-align: left;
}
section.content.info p.body {
  text-align: justify;
  line-height: 2em;
}
section.content.info p.note a {
  text-decoration: underline;
}
section.content.info div.link {
  text-align: left;
  margin-top: 10px;
  margin-bottom: 10px;
}
section.content.info div.link a {
  text-decoration: underline;
}

section.content.thirdparty h3 {
  background: #003e8d;
  color: #ffffff;
  padding-top: 8px;
  padding-bottom: 8px;
  margin-bottom: 20px;
  border-radius: 20px;
  max-width: 300px;
}
section.content.thirdparty p.body {
  color: #003e8d;
}

section.content.purpose div.img img,
section.content.flowchart div.img img {
  width: 100%;
}

section.content.robot div.header h2 {
  margin-bottom: 50px;
}
@media only screen and (min-width: 1200px) {
  section.content.robot div.header h2 {
    font-size: 30px;
    font-size: 1.875rem;
  }
}
@media only screen and (max-width: 1199px) {
  section.content.robot div.header h2 {
    font-size: 30px;
    font-size: 1.875rem;
  }
}
@media only screen and (max-width: 799px) {
  section.content.robot div.header h2 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media only screen and (min-width: 1200px) {
  section.content.robot p.msg {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media only screen and (max-width: 1199px) {
  section.content.robot p.msg {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
@media only screen and (max-width: 799px) {
  section.content.robot p.msg {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
section.content.robot ul.photo {
  display: flex;
  -js-display: flex;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -moz-flex-direction: row;
  -o-flex-direction: row;
  flex-direction: row;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
section.content.robot ul.photo > li {
  -moz-flex: 0 0 48%;
  -o-flex: 0 0 48%;
  flex: 0 0 48%;
  margin-bottom: 20px;
}
section.content.robot ul.photo > li div.img img {
  width: 100%;
}
section.content.robot ul.photo > li p {
  text-align: left;
}