@charset "UTF-8";
@media screen and (max-width: 768px) {
  main .img_small_new.sustaina .image_small_new {
    padding-top: 44.5%; } }

.csr_menu-list {
  display: flex;
  gap: 4rem;
  margin-bottom: 6.5rem; }
  @media screen and (max-width: 768px) {
    .csr_menu-list {
      flex-direction: column;
      margin-bottom: 5rem; } }
  .csr_menu-list li {
    width: 50%;
    display: flex;
    justify-content: center; }
    @media screen and (max-width: 768px) {
      .csr_menu-list li {
        width: 100%; } }
    .csr_menu-list li a {
      border-bottom: 0.1rem solid #32ac57;
      display: block; }
      .csr_menu-list li a:hover {
        opacity: 0.5;
        transition: all 0.2s; }
      .csr_menu-list li a img:hover {
        opacity: 1; }
    .csr_menu-list li p {
      font-size: 2rem;
      text-align: center;
      padding: 1.2rem 3.5rem;
      position: relative; }
      @media screen and (max-width: 768px) {
        .csr_menu-list li p {
          font-size: 1.4rem;
          padding: 1.5rem 3.5rem; } }
      .csr_menu-list li p::after {
        content: "";
        display: inline-block;
        width: 24px;
        height: 20px;
        background-image: url(../images/icon_arw.png);
        background-repeat: no-repeat;
        background-position: top;
        background-size: contain;
        position: absolute;
        right: 1rem;
        top: 2rem; }
        @media screen and (max-width: 768px) {
          .csr_menu-list li p::after {
            width: 17px;
            height: 17px; } }

.esg {
  background-color: #f2f4f7;
  padding-top: 2rem;
  padding-bottom: 5rem; }
  @media screen and (max-width: 1300px) {
    .esg {
      padding-top: 3rem;
      padding-bottom: 4rem; } }
  @media screen and (max-width: 1300px) {
    .esg .container {
      margin-top: 0; } }
  .esg h2 {
    font-size: 3.2rem;
    text-align: center;
    position: relative;
    font-weight: normal;
    margin-bottom: 6rem; }
    @media screen and (max-width: 1300px) {
      .esg h2 {
        font-size: 2.1rem;
        padding-bottom: 0.5rem;
        margin-bottom: 3rem; } }
    .esg h2::after {
      content: "";
      width: 3.2rem;
      height: 0.2rem;
      background-color: #32ac57;
      position: absolute;
      bottom: 0;
      left: 50%;
      transform: translateX(-50%); }
      @media screen and (max-width: 1300px) {
        .esg h2::after {
          width: 2.4rem; } }
  .esg .esg_menu-list .esg_menu-list__item {
    margin-bottom: 8rem; }
    @media screen and (max-width: 1300px) {
      .esg .esg_menu-list .esg_menu-list__item {
        margin-bottom: 4rem; } }
    .esg .esg_menu-list .esg_menu-list__item:last-of-type {
      margin-bottom: 0; }
    .esg .esg_menu-list .esg_menu-list__item figure {
      position: relative; }
      .esg .esg_menu-list .esg_menu-list__item figure::after {
        content: "";
        width: 32rem;
        height: 6.9rem;
        background-color: #fff;
        position: absolute;
        left: 0;
        bottom: -2.7rem; }
        @media screen and (max-width: 768px) {
          .esg .esg_menu-list .esg_menu-list__item figure::after {
            width: 26rem;
            height: 5rem; } }
    .esg .esg_menu-list .esg_menu-list__item .esg_title {
      color: #fff;
      width: 32rem;
      padding: 1.3rem 2rem 1.3rem 1rem;
      position: absolute;
      left: 0;
      bottom: -2.7rem;
      z-index: 1; }
      .esg .esg_menu-list .esg_menu-list__item .esg_title:hover {
        opacity: 0.5;
        transition: all 0.2s; }
      @media screen and (max-width: 768px) {
        .esg .esg_menu-list .esg_menu-list__item .esg_title {
          width: 26rem;
          padding: 0.9rem 1rem; } }
      .esg .esg_menu-list .esg_menu-list__item .esg_title h3 {
        font-size: 2.4rem;
        position: relative;
        padding-left: 1.5rem;
        font-weight: normal; }
        @media screen and (max-width: 768px) {
          .esg .esg_menu-list .esg_menu-list__item .esg_title h3 {
            font-size: 1.8rem;
            padding-left: 1rem; } }
        .esg .esg_menu-list .esg_menu-list__item .esg_title h3::before {
          content: "";
          height: 3rem;
          width: 0.3rem;
          background-color: #fff;
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%); }
          @media screen and (max-width: 1300px) {
            .esg .esg_menu-list .esg_menu-list__item .esg_title h3::before {
              width: 0.2rem;
              height: 1.8rem; } }
        .esg .esg_menu-list .esg_menu-list__item .esg_title h3::after {
          content: "";
          height: 2.4rem;
          width: 2.4rem;
          position: absolute;
          right: 0;
          top: 50%;
          transform: translateY(-50%);
          background-image: url(../images/icon_arw_transparent.png);
          background-repeat: no-repeat;
          background-position: top;
          background-size: contain; }
          @media screen and (max-width: 1300px) {
            .esg .esg_menu-list .esg_menu-list__item .esg_title h3::after {
              height: 1.7rem;
              width: 1.7rem; } }
        .esg .esg_menu-list .esg_menu-list__item .esg_title h3 span {
          font-size: 1.2rem;
          margin-left: 2rem; }
          @media screen and (max-width: 1300px) {
            .esg .esg_menu-list .esg_menu-list__item .esg_title h3 span {
              font-size: 1rem;
              margin-left: 1rem; } }
    .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list {
      display: flex;
      margin-left: auto;
      width: 65%;
      flex-wrap: wrap;
      row-gap: 1rem;
      margin-top: 2rem; }
      @media screen and (max-width: 1300px) {
        .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list {
          flex-direction: column;
          width: 100%;
          margin-top: 5rem;
          row-gap: 1.5rem; } }
      .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list li {
        width: 33%; }
        @media screen and (max-width: 1300px) {
          .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list li {
            width: 100%; } }
        .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list li a {
          position: relative;
          padding-left: 2rem;
          display: inline-block; }
          .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list li a:hover {
            text-decoration: underline; }
          .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list li a::before {
            content: "";
            display: inline-block;
            width: 16px;
            height: 16px;
            background-image: url(../images/icon_arw.png);
            background-repeat: no-repeat;
            background-position: top;
            background-size: contain;
            position: absolute;
            left: 0;
            top: 50%;
            transform: translateY(-50%); }
          @media screen and (max-width: 1300px) {
            .esg .esg_menu-list .esg_menu-list__item .esg_menu-child-list li a {
              padding-left: 2.5rem; } }
    .esg .esg_menu-list .esg_menu-list__item.environment .esg_title {
      background-color: #198a3b; }
    .esg .esg_menu-list .esg_menu-list__item.social .esg_title {
      background-color: #195e8a; }
    .esg .esg_menu-list .esg_menu-list__item.governance .esg_title {
      background-color: #8a6b19; }

.report {
  display: flex;
  max-width: 82rem;
  margin: auto;
  align-items: center;
  gap: 4rem; }
  @media screen and (max-width: 768px) {
    .report {
      flex-direction: column;
      align-items: normal;
      gap: 0;
      margin-bottom: 6rem; } }
  .report .report__content {
    width: 38%; }
    @media screen and (max-width: 768px) {
      .report .report__content {
        width: 100%; } }
    .report .report__content h2 {
      font-size: 3.2rem;
      font-weight: normal;
      padding-left: 2rem;
      position: relative;
      margin-bottom: 2.5rem; }
      @media screen and (max-width: 768px) {
        .report .report__content h2 {
          font-size: 2.1rem;
          padding-left: 1rem;
          margin-bottom: 1rem; } }
      .report .report__content h2::before {
        content: "";
        height: 3.2rem;
        width: 0.3rem;
        background-color: #32ac57;
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%); }
        @media screen and (max-width: 768px) {
          .report .report__content h2::before {
            width: 0.2rem;
            height: 1.8rem; } }
    .report .report__content a {
      display: block;
      background-color: #32ac57;
      text-align: center;
      position: relative;
      color: #fff;
      padding: 2rem 0; }
      .report .report__content a:hover {
        opacity: 0.5;
        transition: all 0.2s; }
      @media screen and (max-width: 768px) {
        .report .report__content a {
          display: none; } }
      .report .report__content a::after {
        content: "";
        height: 1.3rem;
        width: 1.3rem;
        position: absolute;
        right: 2rem;
        top: 50%;
        transform: translateY(-50%);
        background-image: url(../images/icon_arw_w.png);
        background-repeat: no-repeat;
        background-position: top;
        background-size: contain; }
  .report figure {
    width: 62%; }
    @media screen and (max-width: 768px) {
      .report figure {
        width: 100%;
        margin-bottom: 2rem; } }
  .report a.sp {
    display: none; }
    @media screen and (max-width: 768px) {
      .report a.sp {
        display: block;
        background-color: #32ac57;
        text-align: center;
        position: relative;
        color: #fff;
        padding: 1.2rem 0;
        margin: 0 2rem; } }
    .report a.sp::after {
      content: "";
      height: 1.3rem;
      width: 1.3rem;
      position: absolute;
      right: 2rem;
      top: 50%;
      transform: translateY(-50%);
      background-image: url(../images/icon_arw_w.png);
      background-repeat: no-repeat;
      background-position: top;
      background-size: contain; }

.policy {
  max-width: 89rem;
  border: 0.1rem solid #3ca95d;
  margin: auto;
  margin-top: 4rem;
  margin-bottom: 6rem; }
  .policy__inner {
    background-color: #edf7f5;
    padding: 3rem 2rem; }
    @media screen and (max-width: 768px) {
      .policy__inner {
        padding: 3rem; } }
    .policy__inner .policy__item {
      text-align: center;
      margin-bottom: 2rem; }
      .policy__inner .policy__item:last-of-type {
        margin-bottom: 0; }
      @media screen and (max-width: 768px) {
        .policy__inner .policy__item {
          text-align: left; } }
      .policy__inner .policy__item dt {
        font-size: 2rem;
        border-bottom: 0.1rem solid #3ca95d;
        font-weight: 500;
        padding-bottom: 0.5rem; }
        @media screen and (max-width: 768px) {
          .policy__inner .policy__item dt {
            font-size: 1.7rem; } }
      .policy__inner .policy__item dd {
        font-size: 1.6rem; }
        @media screen and (max-width: 768px) {
          .policy__inner .policy__item dd {
            font-size: 1.4rem;
            margin-top: 1rem; } }

main .txt_img.sustaina figure p {
  padding-top: 86%; }

.sdgs-list__item {
  display: flex;
  gap: 0.5rem; }
  @media screen and (max-width: 768px) {
    .sdgs-list__item {
      flex-direction: column;
      gap: 0; } }
  .sdgs-list__item .contents {
    display: flex;
    background-color: #f7faf1;
    padding: 1rem;
    width: 75%;
    border-top: 1px solid #807b76; }
    @media screen and (768px <= width <= 1300px) {
      .sdgs-list__item .contents {
        width: 65%; } }
    @media screen and (max-width: 768px) {
      .sdgs-list__item .contents {
        width: 100%;
        display: block;
        position: relative;
        padding: 2rem 1rem; } }
    .sdgs-list__item .contents .num {
      width: 5rem;
      font-size: 3.6rem;
      color: #fff;
      display: flex;
      align-items: center;
      justify-content: center;
      background-color: #04a86e;
      font-family: Roboto; }
      @media screen and (max-width: 768px) {
        .sdgs-list__item .contents .num {
          position: absolute;
          top: 2.5rem;
          width: 2.5rem;
          height: 2.5rem;
          font-size: 1.8rem; } }
    .sdgs-list__item .contents .details {
      padding: 1rem;
      padding-left: 1.5rem;
      width: 100%; }
      @media screen and (max-width: 768px) {
        .sdgs-list__item .contents .details {
          padding: 0; } }
      .sdgs-list__item .contents .details h4 {
        font-weight: 500;
        color: #07a86e;
        font-size: 2rem;
        margin-bottom: 1rem; }
        @media screen and (max-width: 768px) {
          .sdgs-list__item .contents .details h4 {
            padding-left: 3.5rem;
            font-size: 1.7rem;
            line-height: 1.4; } }
      .sdgs-list__item .contents .details ul {
        display: flex;
        gap: 1rem;
        margin-top: 2rem; }
        @media screen and (768px <= width <= 1300px) {
          .sdgs-list__item .contents .details ul {
            flex-direction: column; } }
        @media screen and (max-width: 768px) {
          .sdgs-list__item .contents .details ul {
            flex-direction: column;
            margin-top: 1rem;
            gap: 1.5rem; } }
        .sdgs-list__item .contents .details ul li {
          width: 33%; }
          @media screen and (768px <= width <= 1300px) {
            .sdgs-list__item .contents .details ul li {
              width: 22rem; } }
          @media screen and (max-width: 768px) {
            .sdgs-list__item .contents .details ul li {
              width: 100%; } }
          .sdgs-list__item .contents .details ul li a {
            display: block;
            background-color: #fff;
            position: relative;
            border: 0.1rem solid #dddddd;
            padding: 0.8rem 2rem; }
            .sdgs-list__item .contents .details ul li a:hover {
              opacity: 0.5; }
            .sdgs-list__item .contents .details ul li a::after {
              content: "";
              height: 1.3rem;
              width: 1.2rem;
              position: absolute;
              right: 2rem;
              top: 50%;
              transform: translateY(-50%);
              background-image: url(../images/icon_arw_green.png);
              background-repeat: no-repeat;
              background-position: top;
              background-size: contain; }
  .sdgs-list__item .icons {
    width: 25%;
    display: flex;
    gap: 0.5rem;
    align-items: center;
    padding-left: 1rem;
    border-top: 1px solid #807b76; }
    @media screen and (768px <= width <= 1300px) {
      .sdgs-list__item .icons {
        width: 35%; } }
    @media screen and (max-width: 768px) {
      .sdgs-list__item .icons {
        width: 100%;
        justify-content: center;
        border-top: none;
        padding-left: 0;
        padding: 2rem 0;
        gap: 1rem; } }
    .sdgs-list__item .icons img {
      width: 7.6rem;
      height: 7.6rem; }
      @media screen and (768px <= width <= 1300px) {
        .sdgs-list__item .icons img {
          width: 30%;
          height: auto; } }
      @media screen and (max-width: 768px) {
        .sdgs-list__item .icons img {
          width: 7rem;
          height: 7rem; } }
  .sdgs-list__item:last-of-type .contents, .sdgs-list__item:last-of-type .icons {
    border-bottom: 1px solid #807b76; }

.annotation-list li {
  font-size: 1.4rem;
  padding-left: 3rem; }
  .annotation-list li::before {
    position: absolute;
    left: 0; }
  .annotation-list li:nth-of-type(1)::before {
    content: "※1."; }
  .annotation-list li:nth-of-type(2)::before {
    content: "※2."; }
  .annotation-list li:nth-of-type(3)::before {
    content: "※3."; }
  .annotation-list li:nth-of-type(4)::before {
    content: "※4."; }

.annotation-text {
  font-size: 1.4rem;
  padding-left: 3rem;
  margin-bottom: 1rem; }
  .annotation-text::before {
    content: "※5.";
    position: absolute;
    left: 0; }
  .annotation-text.nan-none {
    padding-left: 1.5rem; }
    .annotation-text.nan-none::before {
      content: "※";
      position: absolute;
      left: 0; }

main table.sustaina {
  border-color: #d5ead7; }
  main table.sustaina th, main table.sustaina td {
    border-color: #d5ead7; }
  main table.sustaina th {
    background-color: #f3f9f5; }
  main table.sustaina td {
    vertical-align: top;
    width: 50%; }
  main table.sustaina .standard_list .disc li::before {
    font-size: 0.5rem;
    position: relative;
    top: -0.3rem; }
main .back_txt_ttl.sustaina {
  font-weight: 500;
  font-size: 1.8rem;
  padding-left: 1.5rem;
  color: #333333; }
  main .back_txt_ttl.sustaina:not(:first-of-type) {
    margin-top: 2rem; }
  main .back_txt_ttl.sustaina::before {
    height: 1.5rem; }
  main .back_txt_ttl.sustaina::after {
    display: none; }
main .tcfd-list__item {
  border: 0.2rem solid #d5ead7; }
  main .tcfd-list__item:last-of-type {
    border-top: none; }
  main .tcfd-list__item dt {
    background-color: #f3f9f5;
    padding: 1.2rem 1.5rem; }
  main .tcfd-list__item dd {
    padding: 1.5rem; }
    main .tcfd-list__item dd .standard_list .disc {
      margin-bottom: 0; }
      main .tcfd-list__item dd .standard_list .disc li::before {
        font-size: 0.5rem;
        position: relative;
        top: -0.3rem; }
@media screen and (max-width: 768px) {
  main .pc {
    display: none; } }
@media screen and (min-width: 768px) {
  main .sp {
    display: none; } }
