.titleContainer {
  background-image: url(../images/nurture-policy/main.jpg); }
  @media screen and (max-width: 769px) {
    .titleContainer {
      background-image: url(../images/nurture-policy/sp/main.jpg); } }
  @media screen and (max-width: 769px) {
    .titleContainer h1 {
      line-height: 1.75; } }

@media screen and (max-width: 769px) {
  .outlineContainer,
  .block03 {
    margin-top: 9.16667vw;
    margin-bottom: 8.33333vw; } }

@media screen and (max-width: 769px) {
  .outlineContainer .h2,
  .block03 .h2 {
    line-height: 1.54545; } }

@media screen and (max-width: 769px) {
  .outlineContainer .h2 small,
  .block03 .h2 small {
    padding-top: 0.8em; } }

.outlineContainer strong,
.block03 strong {
  max-width: 800px; }
  @media screen and (max-width: 769px) {
    .outlineContainer strong,
    .block03 strong {
      margin-top: 8.33333vw; } }

.outlineContainer p,
.block03 p {
  font-weight: normal; }

#bgImg01 {
  background-image: url(../images/nurture-policy/block01_01.jpg); }
  @media screen and (max-width: 769px) {
    #bgImg01 {
      background-image: url(../images/nurture-policy/sp/block01_01.jpg); } }

#bgImg02 {
  background-image: url(../images/nurture-policy/block01_02.jpg); }
  @media screen and (max-width: 769px) {
    #bgImg02 {
      background-image: url(../images/nurture-policy/sp/block01_02.jpg); } }

#bgImg03 {
  background-image: url(../images/nurture-policy/block01_03.jpg); }
  @media screen and (max-width: 769px) {
    #bgImg03 {
      background-image: url(../images/nurture-policy/sp/block01_03.jpg); } }

#bgImg04 {
  background-image: url(../images/nurture-policy/block01_04.jpg); }
  @media screen and (max-width: 769px) {
    #bgImg04 {
      background-image: url(../images/nurture-policy/sp/block01_04.jpg); } }

#bgImg05 {
  background-image: url(../images/nurture-policy/block03_01.jpg); }
  @media screen and (max-width: 769px) {
    #bgImg05 {
      background-image: url(../images/nurture-policy/sp/block03_01.jpg); } }

#bgImg06 {
  background-image: url(../images/nurture-policy/block03_02.jpg); }
  @media screen and (max-width: 769px) {
    #bgImg06 {
      background-image: url(../images/nurture-policy/sp/block03_02.jpg); } }

.block01,
.block03 {
  padding-top: 0;
  padding-bottom: 85px; }
  @media screen and (max-width: 769px) {
    .block01,
    .block03 {
      margin: 0;
      padding-bottom: 0;
      padding-top: 8.88889vw; } }
  .block01 > .h3,
  .block03 > .h3 {
    margin-top: 60px;
    margin-bottom: 46px; }
    @media screen and (max-width: 769px) {
      .block01 > .h3,
      .block03 > .h3 {
        margin-top: 0;
        margin-bottom: 0;
        line-height: 1.75; } }
  .block01 > div,
  .block03 > div {
    overflow: visible;
    position: relative;
    min-height: 580px;
    margin-top: 58px;
    padding-top: 0;
    background: right 64px no-repeat;
    background-size: 1000px; }
    @media screen and (max-width: 769px) {
      .block01 > div,
      .block03 > div {
        min-height: inherit;
        margin: 0;
        margin-top: 8.88889vw;
        padding: 0 0 50vw;
        background: right bottom no-repeat;
        background-size: 94% auto; } }
    .block01 > div .bgWhite95,
    .block03 > div .bgWhite95 {
      max-width: 700px;
      margin-top: 0; }
      @media screen and (max-width: 769px) {
        .block01 > div .bgWhite95,
        .block03 > div .bgWhite95 {
          margin: 0 5.7vw; } }
      .block01 > div .bgWhite95 .tit,
      .block03 > div .bgWhite95 .tit {
        position: relative;
        padding-left: 66px;
        color: #298948;
        font-size: 14px;
        margin-bottom: 20px; }
        @media screen and (max-width: 769px) {
          .block01 > div .bgWhite95 .tit,
          .block03 > div .bgWhite95 .tit {
            padding-left: 11.66667vw;
            margin-bottom: 5.55556vw;
            font-size: 3.33333vw; } }
        .block01 > div .bgWhite95 .tit small,
        .block03 > div .bgWhite95 .tit small {
          font-size: 26px; }
          @media screen and (max-width: 769px) {
            .block01 > div .bgWhite95 .tit small,
            .block03 > div .bgWhite95 .tit small {
              font-size: 3.88889vw; } }
          .block01 > div .bgWhite95 .tit small span,
          .block03 > div .bgWhite95 .tit small span {
            position: absolute;
            left: 0;
            top: 50%;
            -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
            margin: 0;
            width: 42px;
            height: 42px;
            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;
            font-size: 26px; }
            @media screen and (max-width: 769px) {
              .block01 > div .bgWhite95 .tit small span,
              .block03 > div .bgWhite95 .tit small span {
                width: 7.22222vw;
                height: 7.22222vw;
                font-size: 3.33333vw; } }
      .block01 > div .bgWhite95 .stit,
      .block03 > div .bgWhite95 .stit {
        font-size: 30px;
        margin-bottom: -10px; }
        @media screen and (max-width: 769px) {
          .block01 > div .bgWhite95 .stit,
          .block03 > div .bgWhite95 .stit {
            margin-bottom: -0.8em;
            margin-right: -0.5em;
            font-size: 4.44444vw; } }
      .block01 > div .bgWhite95 .h3,
      .block03 > div .bgWhite95 .h3 {
        margin-bottom: 30px;
        text-align: left;
        font-size: 14px;
        letter-spacing: 0.1em; }
        @media screen and (max-width: 769px) {
          .block01 > div .bgWhite95 .h3,
          .block03 > div .bgWhite95 .h3 {
            margin-bottom: 1.3em;
            font-size: 3.33333vw; } }
        .block01 > div .bgWhite95 .h3 small,
        .block03 > div .bgWhite95 .h3 small {
          display: block;
          margin-bottom: 0.8em;
          font-size: 26px;
          letter-spacing: 0.1em;
          text-decoration: none; }
          @media screen and (max-width: 769px) {
            .block01 > div .bgWhite95 .h3 small,
            .block03 > div .bgWhite95 .h3 small {
              font-size: 3.88889vw; } }
          .block01 > div .bgWhite95 .h3 small:after,
          .block03 > div .bgWhite95 .h3 small:after {
            content: none; }
      .block01 > div .bgWhite95 p,
      .block03 > div .bgWhite95 p {
        padding-top: 2em;
        letter-spacing: 0.05em;
        line-height: 1.83333; }
        @media screen and (max-width: 769px) {
          .block01 > div .bgWhite95 p,
          .block03 > div .bgWhite95 p {
            font-size: 3.33333vw; } }
      .block01 > div .bgWhite95 .btn,
      .block03 > div .bgWhite95 .btn {
        position: absolute;
        left: 50%;
        bottom: 17px;
        width: 250px;
        -webkit-transform: translateX(-50%) translateY(50%);
        transform: translateX(-50%) translateY(50%); }
        @media screen and (max-width: 769px) {
          .block01 > div .bgWhite95 .btn,
          .block03 > div .bgWhite95 .btn {
            position: static;
            width: auto;
            margin-top: 7.22222vw;
            -webkit-transform: none;
            transform: none; } }
    .block01 > div.right,
    .block03 > div.right {
      padding-top: 80px;
      background-position: left top; }
      @media screen and (max-width: 769px) {
        .block01 > div.right,
        .block03 > div.right {
          padding-top: 0;
          background-position: left bottom; } }
      .block01 > div.right .bgWhite95,
      .block03 > div.right .bgWhite95 {
        margin-left: auto; }
        @media screen and (max-width: 769px) {
          .block01 > div.right .bgWhite95,
          .block03 > div.right .bgWhite95 {
            margin: 0 5.7vw; } }
    .block01 > div#bgImg01,
    .block03 > div#bgImg01 {
      margin-top: 0; }
      @media screen and (max-width: 769px) {
        .block01 > div#bgImg01,
        .block03 > div#bgImg01 {
          margin-top: 5.55556vw; } }

.box01 {
  border: 1px solid #298948;
  text-align: center;
  min-height: inherit !important;
  padding: 0 5.7vw 40px; }
  @media screen and (max-width: 769px) {
    .box01 {
      margin: 5.7vw !important;
      padding: 5.7vw !important; } }
  .box01 .inner {
    margin: 35px auto 0;
    max-width: 800px; }
    @media screen and (max-width: 769px) {
      .box01 .inner {
        margin: 0; } }
    .box01 .inner .h3 {
      margin-bottom: 30px;
      line-height: 1.75; }
      @media screen and (max-width: 769px) {
        .box01 .inner .h3 {
          font-size: 4.44444vw;
          margin-bottom: 2.77778vw;
          text-align: left; } }
    .box01 .inner p {
      text-align: left;
      margin-bottom: 30px;
      line-height: 1.75; }
    .box01 .inner .column {
      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; }
      @media screen and (max-width: 769px) {
        .box01 .inner .column {
          display: block; } }
      .box01 .inner .column .img {
        position: relative;
        width: 47.5%;
        height: 0;
        padding-top: 40%;
        background: url(../images/nurture-policy/img02.jpg) left top no-repeat;
        background-size: contain; }
        @media screen and (max-width: 769px) {
          .box01 .inner .column .img {
            width: 100%;
            padding-top: 88%; } }
        .box01 .inner .column .img + .img {
          background-image: url(../images/nurture-policy/img03.jpg); }
          @media screen and (max-width: 769px) {
            .box01 .inner .column .img + .img {
              margin-top: 2.77778vw; } }
        .box01 .inner .column .img .stit {
          position: absolute;
          top: 78%;
          left: 50%;
          -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
          font-size: 16px;
          font-weight: 700;
          color: #298948; }
          @media screen and (max-width: 769px) {
            .box01 .inner .column .img .stit {
              top: 75%;
              font-size: 3.88889vw; } }
          .box01 .inner .column .img .stit span {
            display: block;
            font-weight: normal;
            color: #3E3735;
            font-size: 14px;
            margin-top: 1em; }
            @media screen and (max-width: 769px) {
              .box01 .inner .column .img .stit span {
                font-size: 3.33333vw; } }

.box01 .inner .column .img_zh {
        position: relative;
        width: 47.5%;
        height: 0;
        padding-top: 40%;
        background: url(../images/nurture-policy/img02.jpg) left top no-repeat;
        background-size: contain; }
        @media screen and (max-width: 769px) {
          .box01 .inner .column .img_zh {
            width: 100%;
            padding-top: 88%; } }
        .box01 .inner .column .img_zh + .img_zh {
          background-image: url(../images/nurture-policy/img03_zh.jpg); }
          @media screen and (max-width: 769px) {
            .box01 .inner .column .img_zh + .img_zh {
              margin-top: 2.77778vw; } }
        .box01 .inner .column .img_zh .stit {
          position: absolute;
          top: 78%;
          left: 50%;
          -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
          font-size: 16px;
          font-weight: 700;
          color: #298948; }
          @media screen and (max-width: 769px) {
            .box01 .inner .column .img_zh .stit {
              top: 75%;
              font-size: 3.88889vw; } }
          .box01 .inner .column .img_zh .stit span {
            display: block;
            font-weight: normal;
            color: #3E3735;
            font-size: 14px;
            margin-top: 1em; }
            @media screen and (max-width: 769px) {
              .box01 .inner .column .img_zh .stit span {
                font-size: 3.33333vw; } }

.box01 .inner .column .img_en {
        position: relative;
        width: 47.5%;
        height: 0;
        padding-top: 40%;
        background: url(../images/nurture-policy/img02.jpg) left top no-repeat;
        background-size: contain; }
        @media screen and (max-width: 769px) {
          .box01 .inner .column .img_en {
            width: 100%;
            padding-top: 88%; } }
        .box01 .inner .column .img_en + .img_en {
          background-image: url(../images/nurture-policy/img03_en.jpg); }
          @media screen and (max-width: 769px) {
            .box01 .inner .column .img_en + .img_en {
              margin-top: 2.77778vw; } }
        .box01 .inner .column .img_en .stit {
          position: absolute;
          top: 78%;
          left: 50%;
          -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
          font-size: 16px;
          font-weight: 700;
          color: #298948; }
          @media screen and (max-width: 769px) {
            .box01 .inner .column .img_en .stit {
              top: 75%;
              font-size: 3.88889vw; } }
          .box01 .inner .column .img_en .stit span {
            display: block;
            font-weight: normal;
            color: #3E3735;
            font-size: 14px;
            margin-top: 1em; }
            @media screen and (max-width: 769px) {
              .box01 .inner .column .img_en .stit span {
                font-size: 3.33333vw; } }


.block02 {
  min-width: 100%;
  background-color: #F0F0F0;
  padding-bottom: 110px;
  margin-top: 0; }
  @media screen and (max-width: 769px) {
    .block02 {
      padding: 0;
      margin-bottom: 0;
      padding-bottom: 6.66667vw;
      margin-top: 13.88889vw; } }
  .block02 strong {
    margin-top: 30px; }
    @media screen and (max-width: 769px) {
      .block02 strong {
        text-align: left;
        margin-top: 5.55556vw;
        margin-bottom: 2.77778vw; } }
  .block02 .innerContainer:nth-of-type(1) {
    background-color: #F0F0F0; }
    @media screen and (max-width: 769px) {
      .block02 .innerContainer:nth-of-type(1) {
        background: #fff;
        margin: 0 0 6.66667vw;
        padding: 0 5.7vw 8.33333vw; } }
  .block02 .innerContainer:nth-of-type(2) {
    background: #fff;
    margin: 0 auto;
    padding: 40px 20px; }
    @media screen and (max-width: 769px) {
      .block02 .innerContainer:nth-of-type(2) {
        padding-top: 6.66667vw;
        padding-bottom: 6.66667vw;
        margin: 0 5.7vw; } }
    .block02 .innerContainer:nth-of-type(2) .h3 {
      line-height: 1.75; }
    .block02 .innerContainer:nth-of-type(2) .ability {
      position: relative;
      background: #fff;
      background-size: 100%;
      margin: 40px auto 0; }
      @media screen and (max-width: 769px) {
        .block02 .innerContainer:nth-of-type(2) .ability {
          background: none;
          margin: 0;
          height: auto;
          width: auto; } }
      @media screen and (max-width: 769px) {
        .block02 .innerContainer:nth-of-type(2) .ability .list {
          text-align: center;
          margin: 7.22222vw auto 0; } }
      .block02 .innerContainer:nth-of-type(2) .ability .list li {
        display: none; }
        @media screen and (max-width: 769px) {
          .block02 .innerContainer:nth-of-type(2) .ability .list li {
            display: inline-block;
            padding-bottom: 26.11111vw;
            margin-bottom: 6.66667vw;
            background: center bottom no-repeat;
            background-size: 22.22222vw; }
            .block02 .innerContainer:nth-of-type(2) .ability .list li:nth-of-type(1) {
              background-image: url(../images/nurture-policy/sp/ico01.png); }
            .block02 .innerContainer:nth-of-type(2) .ability .list li:nth-of-type(2) {
              background-image: url(../images/nurture-policy/sp/ico02.png); }
            .block02 .innerContainer:nth-of-type(2) .ability .list li:nth-of-type(3) {
              background-image: url(../images/nurture-policy/sp/ico03.png); }
            .block02 .innerContainer:nth-of-type(2) .ability .list li:nth-of-type(4) {
              background-image: url(../images/nurture-policy/sp/ico04.png); }
            .block02 .innerContainer:nth-of-type(2) .ability .list li:nth-of-type(5) {
              background-image: url(../images/nurture-policy/sp/ico05.png); }
            .block02 .innerContainer:nth-of-type(2) .ability .list li:nth-of-type(6) {
              background-image: url(../images/nurture-policy/sp/ico06.png); } }
        @media screen and (max-width: 769px) {
          .block02 .innerContainer:nth-of-type(2) .ability .list li small {
            position: relative;
            z-index: 1;
            font-size: 3.33333vw;
            color: #298948;
            display: block; } }
        @media screen and (max-width: 769px) {
          .block02 .innerContainer:nth-of-type(2) .ability .list li span {
            position: relative;
            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: 61.11111vw;
            height: 16.66667vw;
            margin-top: -3px;
            background-color: #F0F0F0;
            border-radius: 10px;
            font-size: 2.88889vw;
            line-height: 1.64286;
            font-weight: 700;
            letter-spacing: 0.1em; } }
        .block02 .innerContainer:nth-of-type(2) .ability .list li span:before {
          content: '';
          display: block;
          position: absolute;
          left: 50%;
          bottom: -31px;
          width: 0;
          height: 0;
          -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
          border-style: solid;
          border-width: 31px 6.5px 0 6.5px;
          border-color: #F0F0F0 transparent transparent transparent; }
  .block02 .btn {
    position: absolute;
    bottom: -115px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 250px;
    height: 40px; }
    @media screen and (max-width: 769px) {
      .block02 .btn {
        position: static;
        margin: 0 5.7vw;
        width: auto;
        height: auto;
        -webkit-transform: none;
        transform: none; } }

@media screen and (max-width: 769px) {
  .block03 {
    padding-bottom: 13.88889vw; } }

.block03 > div:first-child {
  margin-top: -20px; }
  @media screen and (max-width: 769px) {
    .block03 > div:first-child {
      margin-top: 8.88889vw; } }
