@charset "UTF-8";
body main .sustainability-link {
  width: 100%;
  margin: auto;
  max-width: 980px;
  background-color: #f0f5f5;
  padding: 48px 30px 40px;
}
body main .sustainability-link-head {
  color: #1e277e;
  font-size: 1rem;
  line-height: 1.25rem;
  letter-spacing: 0.05rem;
  font-weight: 500;
  max-width: 530px;
  width: 100%;
  margin: 0 auto 18px;
}
body main .sustainability-link-head::before {
  content: "■";
  color: #00afec;
}
body main .sustainability-link-ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 530px;
  width: 100%;
  margin: auto;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: auto;
}
body main .sustainability-link-li {
  width: 29.8113207547%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  margin: 16px 0;
}
body main .sustainability-link-a {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #1e277e;
  padding: 0 9px 11px 0;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  font-size: 0.9375rem;
  line-height: 1.25rem;
  letter-spacing: 0.1rem;
  position: relative;
}
body main .sustainability-link-a:before {
  content: "";
  display: block;
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  height: 1px;
  width: 100%;
  background: #1e277e;
  -webkit-transition: background 0.2s, height 0.2s;
  transition: background 0.2s, height 0.2s;
  position: absolute;
  left: 0;
  bottom: 0;
}
body main .sustainability-link-a:hover {
  opacity: 1;
}
body main .sustainability-link-a:hover:before {
  height: 4px;
  background: #00afec;
}
body main .sustainability-link-a::after {
  content: "";
  background-image: url(../image/sustainability/top/footer-arrow.svg);
  background-size: 6px 12px;
  width: 6px;
  height: 12px;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}

@media (max-width: 768px) {
  body main .sustainability-link {
    padding: 7.5vw 10vw;
  }
  body main .sustainability-link-head {
    color: #1e277e;
    font-size: 4vw;
    line-height: 5vw;
    margin: 0 auto 4.5vw;
  }
  body main .sustainability-link-head::before {
    content: "■";
    color: #00afec;
  }
  body main .sustainability-link-ul {
    max-width: none;
  }
  body main .sustainability-link-li {
    width: 36vw;
    margin: 3vw 0;
  }
  body main .sustainability-link-a {
    padding: 0 2.25vw 2vw 0;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    font-size: 3.5vw;
    line-height: 5vw;
  }
  body main .sustainability-link-a::after {
    content: "";
    background-image: url(../image/sustainability/top/footer-arrow.svg);
    background-size: 1.5vw 3vw;
    width: 1.5vw;
    height: 3vw;
  }
}
.page-health-management {
  position: relative;
}
.page-health-management [class*=text]:not(.map-text), .page-health-management .goal-preface, .page-health-management .inner-right, .page-health-management .task-body, .page-health-management .establishment-body, .page-health-management .content-preface {
  text-align: justify;
  text-justify: inter-ideograph;
}
.page-health-management .main {
  margin: 0 auto 167px;
}
.page-health-management .page-header-small {
  padding: 0 40px;
  width: 1060px;
  max-width: 100%;
  margin: 40px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.page-health-management .page-header-left {
  width: 43.8775510204%;
}
.page-health-management .page-header-right {
  width: 46.8571428571vw;
  right: 0;
  position: absolute;
}
.page-health-management .page-header-right img {
  display: inline-block;
  width: 100%;
}
.page-health-management .page-title {
  color: #1e277e;
  margin-bottom: 75px;
}
.page-health-management .page-title .en {
  font-family: "Roboto Slab", serif;
  font-weight: bold;
  font-size: 1.75rem;
  letter-spacing: 0.1em;
  margin-bottom: 15px;
}
.page-health-management .page-title .ja {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.2em;
}
.page-health-management .page-catch {
  color: #00afec;
  font-size: 1.375rem;
  line-height: 2.1875rem;
  letter-spacing: 0.2em;
  font-weight: 500;
  margin-bottom: 38px;
}
.page-health-management .page-lead {
  font-size: 0.9375rem;
  line-height: 1.875rem;
  letter-spacing: 0.05em;
}
.page-health-management .content-main {
  position: relative;
}
.page-health-management .goal {
  max-width: 1060px;
  width: 100%;
  margin: auto;
  padding: 0 40px;
}
.page-health-management .goal-header {
  border-bottom: 1px solid #1e277e;
  margin: 0 auto 44px;
  padding-bottom: 25px;
}
.page-health-management .goal-header .ja {
  color: #1e277e;
  font-size: 1.375rem;
  font-weight: 500;
  letter-spacing: 0.2em;
}
.page-health-management .goal-header .en {
  margin-left: 10px;
  color: #808080;
  font-family: "Roboto Slab", serif;
  font-size: 0.9375rem;
  letter-spacing: 0.1em;
}
.page-health-management .goal-inner {
  padding: 0 44px;
  margin: auto;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.page-health-management .goal-left {
  width: 47.0588235294%;
}
.page-health-management .goal-left img {
  width: 100%;
  display: block;
}
.page-health-management .goal-right {
  width: 43.9572192513%;
}
.page-health-management .goal-subject {
  color: #1e277e;
  font-size: 1rem;
  line-height: 1.25rem;
  letter-spacing: 0.05em;
  font-weight: 500;
  margin-bottom: 30px;
}
.page-health-management .goal-subject::before {
  content: "■";
  color: #00afec;
}
.page-health-management .goal-preface {
  font-size: 0.9375rem;
  line-height: 1.875rem;
  letter-spacing: 0.05em;
  padding-left: 1em;
}
.page-health-management .task {
  max-width: 890px;
  width: 100%;
  margin: auto;
  margin-top: 55px;
}
.page-health-management .establishment {
  max-width: 890px;
  width: 100%;
  margin: auto;
  margin-top: 29px;
}
.page-health-management .task,
.page-health-management .establishment {
  background-color: #f0f5f5;
  padding: 28px 30px 33px;
}
.page-health-management .task-head,
.page-health-management .establishment-head {
  text-align: center;
  color: #1e277e;
  font-size: 1.0625rem;
  letter-spacing: 0.1em;
  padding-bottom: 15px;
  margin-bottom: 25px;
  border-bottom: 1px solid #1e277e;
  font-weight: 500;
}
.page-health-management .task-body,
.page-health-management .establishment-body {
  font-size: 0.9375rem;
  line-height: 1.875rem;
  letter-spacing: 0.05em;
}
.page-health-management .policy {
  max-width: 890px;
  width: 100%;
  margin: auto;
  margin-top: 30px;
  background-color: #e0f5fd;
  padding: 34px 38px;
  counter-reset: num;
}
.page-health-management .policy-head {
  text-align: center;
  color: #1e277e;
  font-size: 1.0625rem;
  letter-spacing: 0.2em;
  font-weight: 500;
  padding: 14px 0;
  margin-bottom: 32px;
  border-bottom: 1px solid #1e277e;
}
.page-health-management .policy-ol {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 35px;
}
.page-health-management .policy-ol-item {
  width: 28.3251231527%;
  font-size: 0.9375rem;
  line-height: 1.75rem;
  position: relative;
  z-index: 1;
}
.page-health-management .policy-ol-item::before {
  font-size: 4.75rem;
  line-height: 4.75rem;
  display: block;
  position: absolute;
  content: "0" counter(num);
  counter-increment: num;
  width: 100%;
  text-align: center;
  height: 1rem;
  color: #fff;
  z-index: 0;
  font-weight: bold;
}
.page-health-management .policy-ol-item .text {
  position: relative;
  z-index: 1;
  padding-top: 32px;
  display: block;
}
.page-health-management .policy-ol .border {
  display: block;
  width: 2px;
  padding-bottom: 33.3333333333;
  border-left: dotted 2px #00afec;
}
.page-health-management .policy-dl {
  width: 95.4433497537%;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: stretch;
      -ms-flex-pack: stretch;
          justify-content: stretch;
}
.page-health-management .policy-dl:not(:first-child) {
  margin-top: 12px;
}
.page-health-management .policy-dl-head {
  color: #1e277e;
  font-size: 1rem;
  line-height: 1.25rem;
  letter-spacing: 0.05em;
  font-weight: 500;
  margin-bottom: 22px;
}
.page-health-management .policy-dl-head::before {
  content: "■";
  color: #00afec;
}
.page-health-management .policy-dl-dt {
  background-color: #00afec;
  color: #fff;
  padding: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 32%;
  font-size: 1rem;
  line-height: 1.75rem;
  letter-spacing: 0.05em;
  font-weight: 500;
  text-align: center;
}
.page-health-management .policy-dl-dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #fff;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 20px;
  width: 70.5806451613%;
  font-size: 0.9375rem;
  line-height: 1.4375rem;
  letter-spacing: 0.05em;
}
.page-health-management .content-item {
  max-width: 970px;
  width: 100%;
  margin: auto;
  padding: 0 40px;
}
.page-health-management .content-item a {
  color: #00afec;
  text-decoration: underline;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.page-health-management .content-item a:hover {
  opacity: 0.6;
}
.page-health-management .content-item:not(:first-child) {
  margin-top: 60px;
}
.page-health-management .content-item .more {
  background-color: #00afec;
  color: #fff;
  width: 100%;
  font-family: "Roboto Slab", serif;
  font-size: 1.0625rem;
  letter-spacing: 0.1em;
  padding: 9px 20px;
  border-radius: 18px;
  margin-top: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.page-health-management .content-item .more::after {
  content: "";
  background-image: url(../image/sustainability/top/arrow.svg);
  background-size: 22px 13px;
  background-position: center;
  background-repeat: no-repeat;
  width: 22px;
  height: 13px;
}
.page-health-management .content-item .more:hover {
  opacity: 0.6;
}
.page-health-management .content-header {
  color: #1e277e;
  border-bottom: 1px solid #1e277e;
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: 0.1em;
  margin: 72px auto 35px;
  padding-bottom: 15px;
  text-align: center;
}
.page-health-management .content-head {
  margin-bottom: 23px;
  color: #1e277e;
  font-weight: 500;
  letter-spacing: 0.05em;
  font-size: 1rem;
}
.page-health-management .content-head::before {
  content: "■";
  color: #00afec;
}
.page-health-management .content-preface {
  padding-left: 1rem;
  margin-bottom: 32px;
  font-size: 0.9375rem;
  line-height: 1.875rem;
  letter-spacing: 0.05em;
}
.page-health-management .box-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 1rem;
  padding-bottom: 50px;
  margin-bottom: 44px;
  border-bottom: 2px dotted #00afec;
}
.page-health-management .box-left, .page-health-management .box-right {
  width: 44.7880870561%;
}
.page-health-management .box-left img, .page-health-management .box-right img {
  display: block;
  width: 100%;
}
.page-health-management .box-left-head, .page-health-management .box-right-head {
  background-color: #e0f5fd;
  color: #00afec;
  margin-bottom: 20px;
  padding: 11px 0;
  text-align: center;
  font-size: 1rem;
  line-height: 1.25rem;
  letter-spacing: 0.05em;
}
.page-health-management .box-left-body, .page-health-management .box-right-body {
  font-size: 0.875rem;
  line-height: 1.5625rem;
  letter-spacing: 0.025em;
}
.page-health-management .box-right {
  width: 46.8609865471%;
}
.page-health-management .box-right-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.page-health-management .box-right-image {
  width: 30.3827751196%;
}
.page-health-management .box-right-text {
  width: 61.961722488%;
  font-size: 0.875rem;
  line-height: 1.5625rem;
  letter-spacing: 0.025em;
}
.page-health-management .box-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.page-health-management .box-inner .inner-left {
  width: 41.2359550562%;
}
.page-health-management .box-inner .inner-left img {
  width: 100%;
  display: block;
}
.page-health-management .box-inner .inner-right {
  width: 58.0898876404%;
  font-size: 0.9375rem;
  line-height: 1.875rem;
  letter-spacing: 0.05em;
}
.page-health-management .map {
  margin: 87px auto 0;
  border: 1px solid #1e277e;
  padding: 31px 36px;
  width: 422px;
  text-align: center;
}
.page-health-management .map-head {
  font-size: 1.0625rem;
  line-height: 1.25rem;
  color: #1e277e;
  border-bottom: 1px solid #1e277e;
  font-weight: 500;
  padding-bottom: 17px;
  margin-bottom: 27px;
}
.page-health-management .map-text {
  font-size: 1rem;
  color: #1e277e;
  letter-spacing: 0.05rem;
  margin-bottom: 21px;
}
.page-health-management .map-text::before {
  content: "■";
  color: #00afec;
}
.page-health-management .map-body .map-pdf {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: auto;
  width: 234px;
  border-radius: 18px;
  padding: 7px 29px;
  color: #fff;
  background-color: #00afec;
  text-decoration: none;
  -webkit-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
.page-health-management .map-body .map-pdf::before {
  content: "";
  background-image: url(../image/sustainability/health-management/icon-pdf.svg);
  background-size: 16px 21px;
  width: 16px;
  height: 21px;
  background-position: center;
  background-repeat: no-repeat;
}
.page-health-management .map-body .map-pdf:hover {
  background-color: #1e277e;
  opacity: 1;
}
.page-health-management .sustainability-link {
  margin-top: 144px;
}

@media (max-width: 768px) {
  .page-health-management .main {
    margin: 0 auto 17.5vw;
  }
  .page-health-management .content-main {
    max-width: none;
    padding: 0;
  }
  .page-health-management .page-header-small {
    display: block;
    padding: 0;
    margin: 8.75vw auto 0;
  }
  .page-health-management .page-header-left {
    width: 100%;
    margin: auto;
  }
  .page-health-management .page-header-right {
    width: 80vw;
    margin: auto;
    position: relative;
  }
  .page-health-management .page-header .pc-none img {
    display: block;
    width: 100%;
  }
  .page-health-management .page-title {
    width: 80vw;
    margin: auto;
    margin-bottom: 12.5vw;
  }
  .page-health-management .page-title .en {
    font-size: 6vw;
    line-height: 7.5vw;
    margin-bottom: 2.5vw;
  }
  .page-health-management .page-title .ja {
    font-size: 4vw;
    line-height: 5vw;
  }
  .page-health-management .goal {
    max-width: none;
    padding: 0;
  }
  .page-health-management .goal-header {
    width: 80vw;
    margin: auto;
    margin-bottom: 6.25vw;
    padding-bottom: 2.5vw;
  }
  .page-health-management .goal-header .ja {
    margin: 0 0 2vw;
    display: block;
    font-size: 4.25vw;
    display: block;
  }
  .page-health-management .goal-header .en {
    font-size: 3.25vw;
    line-height: 5.75vw;
    margin: 0;
    display: block;
  }
  .page-health-management .goal-inner {
    display: block;
    width: 80vw;
    margin: auto;
    padding: 0;
  }
  .page-health-management .goal-left {
    width: 100%;
  }
  .page-health-management .goal-right {
    margin-top: 7.5vw;
    width: 100%;
  }
  .page-health-management .goal-subject {
    font-size: 4.25vw;
    line-height: 7.5vw;
    margin-bottom: 2vw;
  }
  .page-health-management .goal-preface {
    font-size: 3.5vw;
    line-height: 6.5vw;
    margin-bottom: 13.5vw;
    padding-left: 0;
  }
  .page-health-management .task {
    margin-top: 12.5vw;
  }
  .page-health-management .establishment {
    margin-top: 10vw;
  }
  .page-health-management .task,
.page-health-management .establishment {
    padding: 10.5vw 10vw 11vw;
  }
  .page-health-management .task-head,
.page-health-management .establishment-head {
    font-size: 4.25vw;
    line-height: 5.25vw;
    padding: 0 0 3.5vw;
    margin-bottom: 8.75vw;
  }
  .page-health-management .task-body,
.page-health-management .establishment-body {
    font-size: 3.5vw;
    line-height: 6.5vw;
  }
  .page-health-management .task-foot,
.page-health-management .establishment-foot {
    font-size: 3.5vw;
    line-height: 6.5vw;
    text-align: left;
  }
  .page-health-management .policy {
    margin-top: 7.75vw;
    padding: 9.5vw 10.5vw;
  }
  .page-health-management .policy-head {
    margin: 0 auto;
    font-size: 4.25vw;
    line-height: 5.25vw;
  }
  .page-health-management .policy-ol {
    display: block;
    margin-bottom: 13vw;
  }
  .page-health-management .policy-ol-item {
    width: 100%;
    padding: 5vw 0 0;
    font-size: 3.5vw;
    line-height: 6.5vw;
  }
  .page-health-management .policy-ol-item:not(:last-child) {
    border-bottom: 2px dotted #00afec;
    padding-bottom: 7.25vw;
  }
  .page-health-management .policy-ol-item::before {
    font-size: 19vw;
  }
  .page-health-management .policy-ol-head {
    font-size: 4.25vw;
    line-height: 5.25vw;
  }
  .page-health-management .policy-ol .text {
    font-size: 3.5vw;
    line-height: 6.5vw;
    padding-top: 9.5vw;
  }
  .page-health-management .policy-dl {
    display: block;
    width: 100%;
  }
  .page-health-management .policy-dl:not(:first-child) {
    margin-top: 4.25vw;
  }
  .page-health-management .policy-dl-head {
    font-size: 4vw;
  }
  .page-health-management .policy-dl-dt {
    width: 100%;
    margin: 0;
    font-size: 3.75vw;
    line-height: 5vw;
    padding: 2.75vw;
  }
  .page-health-management .policy-dl-dd {
    width: 100%;
    font-size: 3.5vw;
    line-height: 6.5vw;
    padding: 4.25vw;
  }
  .page-health-management .content-item {
    width: 80vw;
    margin: auto;
    padding: 0;
  }
  .page-health-management .content-item:not(:first-child) {
    margin-top: 16.25vw;
  }
  .page-health-management .content-header {
    margin: 15vw auto 7.5vw;
    padding-bottom: 3.5vw;
    font-size: 4vw;
    line-height: 5.75vw;
  }
  .page-health-management .content-head {
    margin-bottom: 6.5vw;
    font-size: 4vw;
    line-height: 5.75vw;
  }
  .page-health-management .content-preface {
    padding: 0;
    font-size: 3.5vw;
    line-height: 6.5vw;
    margin-bottom: 8.75vw;
  }
  .page-health-management .content-box .box-wrapper {
    padding: 0;
    display: block;
    margin-bottom: 9vw;
  }
  .page-health-management .content-box .box-left {
    width: 100%;
    margin-bottom: 8.75vw;
  }
  .page-health-management .content-box .box-left-head {
    font-size: 3.75vw;
    line-height: 5vw;
    padding: 2.25vw;
  }
  .page-health-management .content-box .box-left-body {
    font-size: 3.5vw;
    line-height: 6.5vw;
  }
  .page-health-management .content-box .box-right {
    width: 100%;
    text-align: center;
  }
  .page-health-management .content-box .box-right-head {
    font-size: 3.75vw;
    line-height: 5vw;
    padding: 2.25vw;
  }
  .page-health-management .content-box .box-right-body {
    display: block;
  }
  .page-health-management .content-box .box-right-image {
    width: 26vw;
    margin: 0 auto 6vw;
  }
  .page-health-management .content-box .box-right-text {
    width: 100%;
    font-size: 3.5vw;
    line-height: 6.5vw;
    margin-bottom: 10vw;
  }
  .page-health-management .content-box .box-inner {
    display: block;
  }
  .page-health-management .content-box .inner-left {
    width: 100%;
  }
  .page-health-management .content-box .inner-left img {
    width: 100%;
  }
  .page-health-management .content-box .inner-right {
    width: 100%;
    margin-bottom: 16.75vw;
    font-size: 3.5vw;
    line-height: 6.5vw;
  }
  .page-health-management .map {
    width: 80vw;
    margin: auto;
  }
  .page-health-management .map-head {
    font-size: 4.25vw;
  }
  .page-health-management .map-text {
    font-size: 4vw;
    line-height: 5.75vw;
  }
  .page-health-management .map-body .map-pdf {
    font-size: 4.25vw;
    border-radius: 4.5vw;
    width: 58.5vw;
    padding: 2.25vw 6.75vw;
  }
  .page-health-management .map-body .map-pdf::before {
    width: 4vw;
    height: 5.25vw;
    background-size: 4vw 5.25vw;
  }
  .page-health-management .sustainability-link {
    margin-top: 21.5vw;
  }
}