/*- - - - - - - - - - - - - - - - - - - - - - -
 *
 * Read Initial files
 *
 *- - - - - - - - - - - - - - - - - - - - - - - */
/*** width ***/
/*** media ***/
/*** padding ***/
/***  color ***/
/*** font ***/
/*** url ***/
.esg-content {
  color: #17191A;
  text-align: left;
  padding: 60px 0 114px 0;
}
.esg-content h1 {
  margin-top: 80px;
  font-weight: bold;
  font-size: 24px;
  letter-spacing: 0.02em;
}
.esg-content p {
  font-weight: 500;
  font-size: 17px;
  letter-spacing: 0.1em;
  line-height: 29.75px;
  margin-top: 24px;
}
.esg-content a {
  text-decoration: underline;
  color: #3c90e5;
  cursor: pointer;
}
.esg-content h2 {
  font-weight: bold;
  font-size: 17px;
  letter-spacing: 0.1em;
  line-height: 30px;
  margin: 44px 0 0 40px;
}
.esg-content h2 img {
  width: 15px;
  height: 15px;
  margin-right: 10px;
  vertical-align: middle;
}
.esg-content h2.sub-title-with-ico ~ .esg-image-group {
  margin-left: 34px;
}
.esg-content img.esg-main-img {
  margin-top: 56px;
  margin-bottom: 32px;
}
.esg-content table {
  width: 100%;
  margin-top: 40px;
  margin-bottom: 20px;
}
.esg-content table tr td {
  border: 1px solid #e5e5e5;
  padding: 13.5px 14.5px;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.1em;
}
.esg-content table.esg-table tr:first-child {
  background: #f6f6f6;
}
.esg-content table.esg-table tr:first-child td {
  font-weight: bold;
}
.esg-content ul {
  margin-left: 4px;
  margin-top: 30px;
}
.esg-content ul li {
  font-weight: 500;
  font-size: 17px;
  letter-spacing: 0.1em;
  line-height: 29.75px;
  margin-top: 10px;
  margin-left: 20px;
  position: relative;
}
.esg-content ul li:before {
  content: '・';
  position: absolute;
  top: 0;
  left: -20px;
}
.esg-content ul li a.download-link {
  font-weight: 500;
  text-decoration: underline;
  font-size: 17px;
  letter-spacing: 0.1em;
  text-align: left;
  color: #3c90e5;
}
.esg-content ul li a.download-link img {
  margin: 0 0 0 10px;
}
.esg-content .flex-ul {
  display: grid;
  grid-template-columns: auto auto;
}
.esg-content .esg-image-group {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 40px;
  margin-left: 39px;
}
.esg-content .esg-image-group figure {
  margin: 6px;
  margin-inline-start: 6px;
  margin-inline-end: 6px;
  width: 216px;
}
.esg-content .esg-image-group figure img {
  width: 100%;
}
.esg-content .esg-image-group figure figcaption {
  margin-top: 16px;
  padding: 0 8px;
  font-size: 15px;
  letter-spacing: 0.1em;
  line-height: 22.5px;
  font-weight: 500;
}
.esg-content .esg-governance-image-group figure {
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  display: flex;
  margin-top: 40px;
}
.esg-content .esg-governance-image-group figure img {
  width: 390px;
}
.esg-content .esg-governance-image-group figure figcaption {
  width: 462px;
  font-weight: 500;
  font-size: 17px;
  letter-spacing: 0.1em;
  line-height: 29.75px;
  margin-left: 40px;
}
.esg-content .environment-img-content {
  text-align: center;
  padding: 40px 0 55px 0;
}
.esg-content .environment-img-content.environment-01 img {
  width: 648px;
}
.esg-content .env-article-content {
  padding: 26px 60px 26px 107px;
}
.esg-content .env-article-content h3 {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 29.75px;
}
.esg-content .env-article-content h3 span {
  font-weight: 500;
  font-size: 16px;
}
.esg-content .env-article-content h3 span:nth-child(2) {
  color: #747576;
}
.esg-content .env-article-content .env-tb-content {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: nowrap;
  margin-top: -15px;
}
.esg-content .env-article-content .env-tb-content.first {
  margin-top: 14px;
}
.esg-content .env-article-content .env-tb-content table {
  width: 397px;
  margin: 0 64px 0 20px;
}
.esg-content .env-article-content .env-tb-content table tr:first-child {
  background-color: unset;
}
.esg-content .env-article-content .env-tb-content table tr td {
  padding: 8.5px 15.5px;
}
.esg-content .env-article-content .env-tb-content table tr td:first-child {
  background-color: #F6F6F6;
  font-weight: bold;
}
.esg-content .env-tb-content-02 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
}
.esg-content .env-tb-content-02 div {
  width: 491px;
  min-width: 491px;
  margin-right: 33px;
}
.esg-content .env-tb-content-02 div h2 {
  margin-bottom: 36px;
}
.esg-content .env-tb-content-02 table {
  display: inline-block;
}
.esg-content .env-tb-content-02 table tr:first-child {
  background-color: unset;
}
.esg-content .env-tb-content-02 table tr td {
  padding: 17px 15.5px;
  font-size: 14px;
}
.esg-content .env-tb-content-02 table tr td:first-child {
  background-color: #F6F6F6;
  font-weight: bold;
  width: 90px;
}
.esg-content .env-tb-content-02 table tr td:last-child {
  width: 366px;
  max-width: 366px;
}
.esg-content .env-tb-content-02 table tr:last-child td {
  background-color: white;
  font-weight: 500;
}
.esg-content .env-tb-content-03 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
  margin-top: 40px;
}
.esg-content .env-tb-content-03 div:first-child {
  width: 228px;
  min-width: 228px;
  margin-right: 25.5px;
}
.esg-content .env-tb-content-03 div:last-child {
  width: 100%;
}
.esg-content .env-tb-content-03 div:last-child table {
  margin-top: 0;
  margin-bottom: 24px;
}
.esg-content .env-tb-content-03 div:last-child table tr td {
  font-size: 15px;
  padding: 8px 15.5px;
}
.esg-content .env-tb-content-03 div:last-child table tr td:nth-child(odd) {
  background-color: #F6F6F6;
  font-weight: bold;
}
.esg-content .env-tb-content-03 div:last-child div {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
}
.esg-content .env-tb-content-03 div:last-child div ul {
  width: 48%;
  margin-top: 0;
}
.esg-content .env-tb-content-03 div:last-child div ul li {
  position: relative;
  margin-left: 30px;
  font-size: 15px;
  line-height: 30px;
  margin-top: 5px;
}
.esg-content .env-tb-content-03 div:last-child div ul li::before {
  position: absolute;
  content: '';
  top: 3px;
  left: -30px;
  width: 20px;
  height: 20px;
  background-image: url(../images/ico_check.png);
}
.esg-content .env-tb-content-04 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: nowrap;
}
.esg-content .env-tb-content-04 h2 {
  width: 200px;
  min-width: 200px;
}
.esg-content .env-tb-content-04 .bg-tb-grey {
  background-color: #f6f6f6;
  font-weight: bold;
}
.esg-content .ml-40 {
  margin-left: 40px;
}
.esg-content table.tb-spec {
  width: 750px;
  margin: auto;
  margin-top: 40px;
  font-family: 'Noto Sans JP', sans-serif;
}
.esg-content table.tb-spec tr:first-child td {
  background-color: #f6f6f6;
  font-weight: bold;
}
.esg-content table.tb-spec tr:first-child td:first-child {
  border: unset;
  background-color: unset;
}
.esg-content table.tb-spec tr td:not(:first-child) {
  text-align: right;
}
.esg-content table.tb-spec tr .lb-scorp {
  text-align: center !important;
}
.esg-content img.env-img-05 {
  margin-top: 40px;
}
.esg-content img.build-green-img {
  width: 211px;
  min-width: 211px;
}
.esg-content img.build-belt-img {
  width: 120px;
  min-width: 120px;
}
.esg-content .for-next-p ~ p {
  font-size: 15px;
  letter-spacing: 0.1em;
  line-height: 26.25px;
  color: #747576;
  margin-top: 40px;
}
@media screen and (max-width: 1000px) {
  .esg-content {
    padding: 60rem 20px 114rem 20px;
  }
  .esg-content h1 {
    margin-top: 80rem;
    font-size: 24rem;
  }
  .esg-content p {
    font-size: 17rem;
    line-height: 29.75rem;
    margin-top: 24rem;
  }
  .esg-content h2 {
    font-size: 17rem;
    margin: 44rem 0 0 40rem;
  }
  .esg-content h2 img {
    width: 15rem;
    height: 15rem;
    margin-right: 10rem;
  }
  .esg-content h2.sub-title-with-ico ~ .esg-image-group {
    margin-left: 34rem;
  }
  .esg-content img.esg-main-img {
    margin-top: 56rem;
    margin-bottom: 32rem;
  }
  .esg-content table {
    margin-top: 40rem;
    margin-bottom: 20rem;
  }
  .esg-content table tr td {
    border: 1rem solid #e5e5e5;
    padding: 13.5rem 14.5rem;
    font-size: 15rem;
  }
  .esg-content ul {
    margin-left: 4rem;
    margin-top: 30rem;
  }
  .esg-content ul li {
    font-size: 17rem;
    line-height: 29.75rem;
    margin-top: 10rem;
    margin-left: 20rem;
  }
  .esg-content ul li:before {
    left: -20rem;
  }
  .esg-content ul li a.download-link {
    font-size: 17rem;
  }
  .esg-content ul li a.download-link img {
    margin: 0 0 0 10rem;
    width: 26rem;
    height: 26rem;
  }
  .esg-content .esg-image-group {
    margin-top: 40rem;
    margin-left: 39rem;
  }
  .esg-content .esg-image-group figure {
    margin-inline-start: 6rem;
    margin-inline-end: 6rem;
    width: 200rem;
  }
  .esg-content .esg-image-group figure figcaption {
    margin-top: 16rem;
    padding: 0 8rem;
    font-size: 15rem;
    line-height: 22.5rem;
  }
  .esg-content .esg-governance-image-group figure {
    margin-top: 40rem;
    margin-inline-start: 0;
    margin-inline-end: 0;
  }
  .esg-content .esg-governance-image-group figure img {
    width: 390rem;
  }
  .esg-content .esg-governance-image-group figure figcaption {
    width: 462rem;
    font-size: 17rem;
    line-height: 29.75rem;
    margin-left: 40rem;
  }
  .esg-content .environment-img-content {
    padding: 40rem 0 55rem 0;
  }
  .esg-content .environment-img-content.environment-01 img {
    width: 648rem;
  }
  .esg-content .env-article-content {
    padding: 26rem 60rem 26rem 107rem;
  }
  .esg-content .env-article-content h3 {
    font-size: 18rem;
    line-height: 29.75rem;
  }
  .esg-content .env-article-content h3 span {
    font-size: 16rem;
  }
  .esg-content .env-article-content .env-tb-content {
    margin-top: -15rem;
  }
  .esg-content .env-article-content .env-tb-content.first {
    margin-top: 14rem;
  }
  .esg-content .env-article-content .env-tb-content table {
    margin: 0 64rem 0 20rem;
  }
  .esg-content .env-article-content .env-tb-content table tr td {
    padding: 8.5rem 15.5rem;
  }
  .esg-content .env-tb-content-02 div {
    width: 491rem;
    min-width: 491rem;
    margin-right: 33rem;
  }
  .esg-content .env-tb-content-02 div h2 {
    margin-bottom: 36rem;
  }
  .esg-content .env-tb-content-02 table tr td {
    padding: 17rem 15.5rem;
    font-size: 14rem;
  }
  .esg-content .env-tb-content-02 table tr td:first-child {
    width: 90rem;
  }
  .esg-content .env-tb-content-02 table tr td:last-child {
    width: 366rem;
    max-width: 366rem;
  }
  .esg-content .env-tb-content-03 {
    margin-top: 40rem;
  }
  .esg-content .env-tb-content-03 div:first-child {
    width: 228rem;
    min-width: 228rem;
    margin-right: 25.5rem;
  }
  .esg-content .env-tb-content-03 div:last-child table {
    margin-bottom: 24rem;
  }
  .esg-content .env-tb-content-03 div:last-child table tr td {
    font-size: 15rem;
    padding: 8rem 15.5rem;
  }
  .esg-content .env-tb-content-03 div:last-child div ul li {
    margin-left: 30rem;
    font-size: 15rem;
    line-height: 30rem;
    margin-top: 15rem;
  }
  .esg-content .env-tb-content-03 div:last-child div ul li::before {
    left: -30rem;
    width: 20rem;
    height: 20rem;
  }
  .esg-content .env-tb-content-04 h2 {
    width: 200rem;
    min-width: 200rem;
  }
  .esg-content .ml-40 {
    margin-left: 40rem;
  }
  .esg-content table.tb-spec {
    width: 750rem;
    margin-top: 40rem;
  }
  .esg-content img.env-img-05 {
    margin-top: 40rem;
  }
  .esg-content img.build-green-img {
    width: 211rem;
    min-width: 211rem;
  }
  .esg-content img.build-belt-img {
    width: 120rem;
    min-width: 120rem;
  }
  .esg-content .for-next-p ~ p {
    font-size: 15rem;
    line-height: 26.25rem;
    margin-top: 40rem;
  }
}
