@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@700&display=swap");
body, html {
  -webkit-font-smoothing: antialiased;
}

*::-moz-selection {
  background: #ff0351;
  color: #ffffff;
}

*::selection {
  background: #ff0351;
  color: #ffffff;
}

a {
  display: block;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); /* for removing the highlight */
}

img {
  display: block;
  width: 100%;
  height: auto;
}

body {
  font-family: "dnp-shuei-gothic-kin-std", sans-serif, Arial, Helvetica, "微軟正黑體", Microsoft JhengHei, Apple LiGothic, "蘋果儷中黑";
  padding-top: 1px;
  overflow: inherit !important;
}
body.noScroll {
  height: auto !important;
  overflow: hidden !important;
  padding-right: 1px;
}

.bg {
  background-image: url(../images/bg.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  z-index: 0;
}
.bg:after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(2, 6, 42, 0.2);
}

.dnp {
  font-family: "dnp-shuei-gothic-kin-std", sans-serif;
}

.dmSans {
  font-family: "DM Sans", serif;
}

.hiroSans {
  font-family: "hiragino-kaku-gothic-pron", serif;
}

.container {
  max-width: 1660px;
  margin: auto;
}

.container2 {
  max-width: 1920px;
  margin: auto;
}

.container3 {
  max-width: 2560px;
  margin: auto;
}

.container4 {
  max-width: 1220px;
  margin: auto;
}

* {
  outline: none;
}

#wrapper {
  overflow: hidden;
}

.scrollBox {
  overflow-y: scroll;
  scrollbar-color: rgba(0, 0, 0, 0.1) transparent;
  scrollbar-width: thin;
  padding-right: 0;
}
.scrollBox::-webkit-scrollbar {
  width: 3px;
  opacity: 0.3;
}
.scrollBox::-webkit-scrollbar-track {
  border-radius: 1em;
  background-color: #040732;
}
.scrollBox::-webkit-scrollbar-thumb {
  border-radius: 1em;
  background-color: rgba(0, 0, 0, 0.1);
}
.scrollBox .noDateTxt {
  font-size: 1.4em;
  margin-top: 2em;
}

/* loading */
.loading {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background-image: url(../images/bg.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-color: #040732;
  z-index: 9999;
}
.loading .box {
  -webkit-animation: spin 3s linear infinite;
          animation: spin 3s linear infinite;
}
.loading .loadingBall {
  border-radius: 50%;
  position: relative;
  -webkit-animation: jump 0.6s ease-out infinite alternate;
          animation: jump 0.6s ease-out infinite alternate;
}

@-webkit-keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(359deg);
            transform: rotate(359deg);
  }
}

@keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(359deg);
            transform: rotate(359deg);
  }
}
@-webkit-keyframes jump {
  0% {
    -webkit-transform: translateY(22%);
            transform: translateY(22%);
  }
  100% {
    -webkit-transform: translateY(-80%);
            transform: translateY(-80%);
  }
}
@keyframes jump {
  0% {
    -webkit-transform: translateY(22%);
            transform: translateY(22%);
  }
  100% {
    -webkit-transform: translateY(-80%);
            transform: translateY(-80%);
  }
}
.pointerDIV {
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  position: absolute;
  /* mix-blend-mode: difference; */
  z-index: 999;
}
.pointerDIV div {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #ffffff;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: 0.15s;
  transition: 0.15s;
}
.pointerDIV.multy {
  display: block;
  mix-blend-mode: difference;
  /* margin-top: -25px; */
}
.pointerDIV.multy div {
  width: 50px;
  height: 50px;
  background-color: #ff59b0;
}

.pointerChange {
  display: inline-block;
}
.pointerChange:not(a) {
  cursor: default;
}
.pointerChange.dmSans, .pointerChange.dnp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.pointerChange.dnp {
  padding: 0 1.2em;
}

.anchorBar {
  right: 0;
  z-index: 999;
  top: calc(50vh - 11rem);
  padding-right: 1rem;
  text-shadow: 0 3px 6px rgba(2, 6, 42, 0.5), 0 3px 6px rgba(2, 6, 42, 0.5), 0 3px 6px rgba(2, 6, 42, 0.5), 0 0px 2em rgba(2, 6, 42, 0.5);
}
.anchorBar.atTop {
  background-color: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
  text-shadow: none;
}
.anchorBar a {
  color: #ffffff;
  margin-bottom: 3rem;
  padding-left: 0.6em;
  position: relative;
  line-height: 1;
  white-space: nowrap;
}
.anchorBar a:last-child {
  margin-bottom: 0;
}
@media (hover: hover) {
  .anchorBar a:hover {
    opacity: 1;
  }
  .anchorBar a:hover .pName {
    opacity: 1;
    -webkit-transform: translate(0%, -50%);
            transform: translate(0%, -50%);
    pointer-events: inherit;
  }
  .anchorBar a:hover .dot {
    background-color: #ffffff;
  }
}
.anchorBar a.active .dot {
  background-color: #ffffff;
}
.anchorBar .pName {
  font-weight: bold;
  position: absolute;
  top: 40%;
  right: 100%;
  -webkit-transform: translate(50%, -50%);
          transform: translate(50%, -50%);
  opacity: 0;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  pointer-events: none;
}
.anchorBar .dot {
  width: 2.5rem;
  height: 0.4rem;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  border: 1px solid #ffffff;
  background-color: transparent;
}

/* FB 對話機器人 */
.fb_dialog_content > iframe:first-child {
  -webkit-box-shadow: 0px 0px 20px rgba(5, 183, 177, 0.9) !important;
          box-shadow: 0px 0px 20px rgba(5, 183, 177, 0.9) !important;
}
.fb_dialog_content > iframe {
  -webkit-transform: translateY(-10px) !important;
          transform: translateY(-10px) !important;
}

nav {
  display: none;
}

#main {
  max-width: 2560px;
}

.prvLink:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

body {
  background-color: #ffffff !important;
  padding-right: 0px !important;
}

#wrapper {
  overflow: inherit !important;
  background-color: #c8dfc2 !important;
  padding-top: 1px;
}

br.pcHide {
  display: none;
}

.notoSans {
  font-family: "Noto Sans TC", sans-serif;
  font-weight: 700;
}

/* header ****************************/
.logo svg {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.logo svg .st0 {
  -webkit-clip-path: url(#SVGID_2_);
          clip-path: url(#SVGID_2_);
  fill: #005e66;
  -webkit-transition: 0.3s 0s;
  transition: 0.3s 0s;
}
.logo.isGreen svg .st0 {
  fill: #005e66 !important;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.overEsg5 header {
  height: 9rem;
  background-color: rgba(255, 255, 255, 0.9);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

/* anchorBar ****************************/
.anchorBar {
  -webkit-transform: translateX(110%);
          transform: translateX(110%);
  -webkit-transition: 0.4s;
  transition: 0.4s;
  pointer-events: none;
}
.anchorBar.isGreen a {
  color: #005e66;
}
.anchorBar.isGreen a.active .dot, .anchorBar.isGreen a:hover .dot {
  background-color: #005e66;
}
.anchorBar.isGreen .dot {
  border-color: #005e66;
}
.anchorBar a.onFocus {
  opacity: 1;
}
.anchorBar a.onFocus .pName {
  opacity: 1;
  -webkit-transform: translate(0%, -50%);
          transform: translate(0%, -50%);
  pointer-events: inherit;
}
.anchorBar a.onFocus .dot {
  background-color: #ffffff;
}

.navBtn div {
  -webkit-transition: 0.3s !important;
  transition: 0.3s !important;
}
.navBtn div:before, .navBtn div:after {
  -webkit-transition: 0.3s !important;
  transition: 0.3s !important;
}
.navBtn.isGreen div {
  background-color: #005e66 !important;
}
.navBtn.isGreen div:before, .navBtn.isGreen div:after {
  background-color: #005e66 !important;
}

.notTop .anchorBar {
  -webkit-transform: translateX(0%);
          transform: translateX(0%);
  pointer-events: inherit;
}
.notTop .esg01Menu {
  -webkit-transform: translateY(-110%);
          transform: translateY(-110%);
  opacity: 0;
  -webkit-transition: 0.3s 0.05s;
  transition: 0.3s 0.05s;
}
.notTop .logo svg .st0 {
  fill: #ffffff;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
.notTop .navBtn div {
  background-color: #ffffff;
}
.notTop .navBtn div:before, .notTop .navBtn div:after {
  background-color: #ffffff;
}
.notTop .midB {
  top: 100vh;
  -webkit-transition: 0s;
  transition: 0s;
}
.notTop .toTest {
  bottom: 2.25rem;
}

.midB {
  -webkit-transition: 0s;
  transition: 0s;
}

.toTest {
  -webkit-transition: bottom 0s, background-color 0.3s, color 0.3s;
  transition: bottom 0s, background-color 0.3s, color 0.3s;
}

/* main ****************************/
.deco_slash {
  width: 100vw;
  height: 1rem;
  position: absolute;
  background-image: url(../images/ESG/slash_green.png);
  background-repeat: repeat-x;
  background-position: left top;
  background-size: auto 100%;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}

.cloud {
  aspect-ratio: 478/260;
  position: absolute;
  background-image: url(../images/ESG/cloud1.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.cloud01 {
  left: 34%;
  top: 0;
  opacity: 0.8;
}

.cloud02 {
  width: 18rem;
  left: 67%;
  top: 19%;
  opacity: 0.8;
  z-index: 10;
}

.cloud03 {
  width: 29.875rem;
  left: 10%;
  top: 64%;
  z-index: 10;
}

.cloud04 {
  width: 21rem;
  left: 20%;
  top: 5%;
  opacity: 0.95;
  z-index: 10;
}

/* footer ****************************/
footer {
  position: relative;
  background-color: #dcdfde;
  color: #182716;
  z-index: 10;
}

.footent {
  max-width: 1370px;
  margin: auto;
}

.copyright {
  letter-spacing: 0.13em;
}

.footMedia a {
  background-repeat: no-repeat;
  background-position: center;
  background-size: 2rem auto;
}
.footMedia a:hover {
  background-color: #d3d86b;
}

.esgFB {
  background-color: #4a94c5;
  background-image: url(../images/ESG/icon_FB_white.svg);
}
.esgFB:hover {
  background-image: url(../images/ESG/icon_FB.svg);
}

.esgIG {
  background-color: #ee93ca;
  background-image: url(../images/ESG/icon_IG_white.svg);
}
.esgIG:hover {
  background-image: url(../images/ESG/icon_IG.svg);
}

.esgYT {
  background-color: #ef868c;
  background-image: url(../images/ESG/icon_YT_white.svg);
}
.esgYT:hover {
  background-image: url(../images/ESG/icon_YT.svg);
}

.esgWeb {
  background-image: url(../images/ESG/icon_home_white.svg);
  background-color: #358188;
}
.esgWeb:hover {
  background-image: url(../images/ESG/icon_home.svg);
}

.navMedia a {
  background-repeat: no-repeat;
  background-position: center;
  background-size: 4rem auto;
}
.navMedia a:hover {
  background-color: #d3d86b;
}

/* loading */
.loading {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  text-align: center;
  background-color: #62ad78 !important;
  background-image: none;
  z-index: 9990;
}

.loading .box {
  font-size: 1.5em;
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-animation: opac 2s infinite linear;
          animation: opac 2s infinite linear;
}

.loading span {
  width: 8em;
  height: 8em;
  display: block;
  position: absolute;
  top: calc(50% - 4em);
  left: calc(50% - 4em);
  border: 2px solid;
  border-color: #ffffff transparent #ffffff transparent;
  border-radius: 50%;
  -webkit-animation: spin 2s infinite linear;
          animation: spin 2s infinite linear;
}

@keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(359deg);
            transform: rotate(359deg);
  }
}
@-webkit-keyframes opac {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.4;
  }
  100% {
    opacity: 1;
  }
}
@keyframes opac {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.4;
  }
  100% {
    opacity: 1;
  }
}
.esg01Menu {
  height: 9rem;
  color: #005e66;
  overflow: hidden;
  z-index: 90;
  -webkit-transition: 0.3s 0s;
  transition: 0.3s 0s;
}
.esg01Menu a {
  padding: 0 0.3em;
  position: relative;
}
.esg01Menu a span {
  position: relative;
}
.esg01Menu a:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0.1em;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.esg01Menu a.active:before, .esg01Menu a:hover:before {
  background-color: #d3d86b;
}
.esg01Menu a:first-child:after {
  content: "";
  display: block;
  width: 100vw;
  height: 1rem;
  position: absolute;
  left: -0.2em;
  top: calc(100% + 0.6em);
  background-image: url(../images/ESG/slash_green.png);
  background-repeat: repeat-x;
  background-position: left top;
  background-size: auto 100%;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}

#esg_01 {
  margin-top: 10.5rem;
  overflow: hidden;
  z-index: 5;
}
#esg_01 .deco01 {
  background-image: url(../images/ESG/slash_white.png);
  background-position: right top;
  top: 0;
  right: 65%;
}
#esg_01 .deco02 {
  background-image: url(../images/ESG/slash_green_L.png);
  background-position: right top;
  top: calc(50% - 0.5rem);
  right: calc(100% + 0.8em);
}
#esg_01 .deco03 {
  background-image: url(../images/ESG/slash_green.png);
  background-position: right top;
  top: calc(50% - 0.5rem);
  left: calc(100% + 0.8em);
}

.running {
  overflow: hidden;
  padding-top: 1.5rem;
}

.pjBox {
  overflow: hidden;
}
.pjBox .runnerImg {
  cursor: pointer;
}

.runnerBlock {
  width: auto;
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.runnerImg {
  margin: 1em 0.4rem;
  width: 16.25rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  aspect-ratio: 1;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  background-color: rgba(255, 255, 255, 0.5);
}
.runnerImg:hover {
  -webkit-transform: scale(1.02);
          transform: scale(1.02);
}
.runnerImg img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}

.pjdowner {
  -webkit-transition: 0.3s 0s;
  transition: 0.3s 0s;
}
.pjdowner .pjTent {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

/* popUp ****************************/
.popUp {
  background-color: rgba(0, 0, 0, 0.9);
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.popUp * {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.popUp .closeBtn {
  width: 3.3125rem;
  position: absolute;
  bottom: 100%;
  left: calc(100% + 4rem);
}

.pop_slider {
  opacity: 0;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
  -webkit-transition: 0.25s;
  transition: 0.25s;
}
.pop_slider.show {
  -webkit-transition: 0.5s;
  transition: 0.5s;
  opacity: 1;
  -webkit-user-select: inherit;
     -moz-user-select: inherit;
      -ms-user-select: inherit;
          user-select: inherit;
  pointer-events: inherit;
}
.pop_slider .tentBox {
  width: 53.5rem;
  max-width: 850px;
}

.prjSlider {
  overflow: hidden;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.prjSliderBtnBox {
  position: absolute;
  left: 0;
  top: 50%;
  width: 100%;
}
.prjSliderBtnBox a {
  position: absolute;
  width: 3rem;
  top: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  padding: 0.5rem;
}
.prjSliderBtnBox .prjSliderBtn_L {
  left: 2rem;
}
.prjSliderBtnBox .prjSliderBtn_R {
  right: 2rem;
}

.prj_L {
  width: 22.5rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  aspect-ratio: 1;
}
.prj_L img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}

.prj_R {
  width: calc(100% - 24.25rem);
  font-weight: 300;
}

.symBox {
  height: 6.5rem;
}

.symIcon {
  width: 2.5rem;
  max-width: 50px;
}

.prjClient,
.prjTitle {
  line-height: 1.7;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 100%;
}

.prjDescript {
  line-height: 1.4;
  max-width: 440px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
  height: 5.6em;
}

.prjLink {
  width: 6.3rem;
  position: absolute;
  left: 0;
  bottom: 0;
}
.prjLink .dmSans {
  position: absolute;
  left: 0;
  bottom: 5%;
}
.prjLink img {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.prjLink:hover img {
  -webkit-transform: translateX(40%);
          transform: translateX(40%);
}

@media screen and (max-width: 767px) {
  .esg01Menu {
    height: 8rem;
  }
  .esg01Menu .container2 {
    display: none;
  }
  #esg_01 {
    margin-top: 11rem;
    margin-bottom: 1rem;
  }
  #esg_01 .deco01 {
    background-image: url(../images/ESG/slash_white.png);
    background-position: left top;
    left: 39.5%;
  }
  #esg_01 .deco02 {
    top: calc(50% - 0.65rem);
    right: calc(100% + 0.2em);
  }
  #esg_01 .deco03 {
    top: calc(50% - 0.65rem);
    left: calc(100% + 0.2em);
  }
  .running {
    overflow: hidden;
    padding-top: 3rem;
  }
  .runnerImg {
    width: 25rem;
    margin: 1em 0.6rem;
  }
  /* popUp ****************************/
  .popUp .closeBtn {
    width: 3rem;
    bottom: auto;
    top: 1rem;
    left: calc(100% + 1rem);
  }
  .pop_slider .tentBox {
    width: calc(66% + 3rem);
    max-height: 100%;
    height: 67rem;
  }
  .prjSlider {
    height: 100%;
  }
  .prjSliderBtnBox {
    top: 35%;
  }
  .prjSliderBtnBox a {
    width: 6rem;
    padding: 10vh 2rem;
  }
  .prjSliderBtnBox .prjSliderBtn_L {
    left: 0;
  }
  .prjSliderBtnBox .prjSliderBtn_R {
    right: 0;
  }
  .prjSro {
    padding-top: 5%;
    height: 100%;
    overflow-y: auto;
    padding-right: 1.5rem;
    padding-left: 1.5rem;
    padding-bottom: 5px;
  }
  .prjSro::-webkit-scrollbar {
    width: 0px;
    opacity: 0;
    height: 0px;
  }
  .prjSro::-webkit-scrollbar-track {
    background-color: transparent;
    border-radius: 1em;
    background-color: transparent;
    opacity: 0;
  }
  .prjSro::-webkit-scrollbar-thumb {
    border-radius: 1em;
    background-color: rgba(0, 0, 0, 0);
    opacity: 0;
  }
  .prjSro:-webkit-scrollbar-track-piece {
    background-color: transparent;
  }
  .prjSro:-webkit-scrollbar-thumb:horizontal {
    height: 0px;
    background-color: transparent;
  }
  .prjSro:-webkit-scrollbar-thumb:vertical {
    height: 0px;
    background-color: transparent;
  }
  .prj_L {
    width: auto;
  }
  .prj_R {
    width: auto;
    padding-bottom: 5rem;
  }
  .symBox {
    height: auto;
    margin-top: 2rem;
    margin-bottom: 0.5rem;
  }
  .symIcon {
    width: 3.125rem;
  }
  .prjDescript {
    max-width: inherit;
    height: auto;
    max-height: 5.6em;
  }
  .prjLink {
    width: 8rem;
    position: absolute;
    left: auto;
    right: 0;
    bottom: 1rem;
  }
}
.midDeco {
  height: 5rem;
  z-index: 4;
}
.midDeco .deco {
  background-image: url(../images/ESG/slash_white_R.png);
  background-position: left top;
  width: 65.2%;
  top: 2.5rem;
  left: 22%;
}

.sctimg {
  position: absolute;
  left: 1.5rem;
  top: 2rem;
  z-index: 10;
}

@-webkit-keyframes moveDown {
  0% {
    -webkit-transform: translateY(-5%);
            transform: translateY(-5%);
  }
  100% {
    -webkit-transform: translateY(20%);
            transform: translateY(20%);
  }
}

@keyframes moveDown {
  0% {
    -webkit-transform: translateY(-5%);
            transform: translateY(-5%);
  }
  100% {
    -webkit-transform: translateY(20%);
            transform: translateY(20%);
  }
}
.midB {
  position: sticky;
  top: calc(100vh - 1.75rem);
  z-index: 99;
}

.toTest {
  position: absolute;
  background-color: #005e66;
  border-radius: 99em;
  padding: 0.4em 2em;
  bottom: 0.5rem;
  font-weight: bold;
}
.toTest:hover {
  background-color: #d3d86b;
  color: #005e66;
}

#esg_02 {
  padding-top: 1rem;
  padding-bottom: 9rem;
  z-index: 4;
}
#esg_02 h2 {
  color: #005e66;
  display: inline-block;
  position: relative;
}
#esg_02 h2:before {
  content: "";
  display: block;
  background-color: #005e66;
  position: absolute;
  height: 2px;
  width: 0.8em;
  left: -0.4em;
  bottom: -0.1em;
}

.esgSlider {
  width: 63.75rem;
  overflow: hidden;
  margin: auto;
  color: #005e66;
}
.esgSlider .swiper-slide {
  padding: 0 1rem;
}
@media screen and (min-width: 768px) {
  .esgSlider {
    -webkit-transition: 0.6s;
    transition: 0.6s;
  }
  .esgSlider.beforeCG {
    -webkit-transition: 0s;
    transition: 0s;
    opacity: 0;
  }
}

.esgSWimg {
  aspect-ratio: 1;
}
.esgSWimg img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}

.esgDate {
  position: relative;
  font-weight: 500;
  line-height: 2;
  margin-top: 0.5em;
}
.esgDate:before {
  content: "";
  display: block;
  background-color: #005e66;
  position: absolute;
  height: 1px;
  width: 1.5em;
  left: -0.7em;
  bottom: -0.1em;
}

.esgTitle {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  line-height: 1.32;
  height: 2.64em;
  margin: 0.4em 0;
}

.esgSliderBtn {
  background-color: #62ad78;
  text-align: center;
  line-height: 2.4;
  margin-top: 0.8em;
  padding-right: 1em;
  background-image: url(../images/ESG/icon_arrow_sm.svg);
  background-repeat: no-repeat;
  background-position: center left calc(50% + 2.4em);
  background-size: 1.85em auto;
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
}
.esgSliderBtn:hover {
  -webkit-transition: 0.4s ease-out;
  transition: 0.4s ease-out;
  background-position: center left calc(50% + 3.4em);
}

.esgSlider_pagination {
  text-align: center;
  font-size: 1.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  height: 4rem;
  margin-top: 0.5rem;
  color: #005e66;
}
.esgSlider_pagination div {
  display: block;
  line-height: 1;
  width: 1.5rem;
  height: auto;
  background-color: transparent !important;
  opacity: 1 !important;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  margin: 0 0.6rem !important;
  border-radius: 0;
  cursor: pointer;
}
.esgSlider_pagination div.swiper-pagination-bullet-active {
  font-size: 1.583em;
  -webkit-transform: translateY(0.1em);
          transform: translateY(0.1em);
}

@media screen and (max-width: 767px) {
  .midDeco {
    height: 6rem;
  }
  .midDeco .deco {
    background-position: right top;
    width: 70vw;
    top: 2.5rem;
    left: auto;
    right: 30%;
  }
  .sctimg {
    top: 6rem;
  }
  .midB {
    top: calc(100vh - 1rem);
  }
  #esg_02 {
    padding-bottom: 12rem;
    padding-top: 3rem;
  }
  .esgSlider {
    width: 100%;
    padding-left: 3rem;
  }
  .esgSlider .swiper-slide {
    padding: 0 1rem;
  }
  .esgSlider_pagination {
    font-size: 1.9375rem;
    margin-top: 4rem;
    line-height: 1;
  }
  .esgSlider_pagination .swiper-pagination-current {
    font-size: 1.62em;
  }
  .esgSlider_pagination span {
    display: inline-block;
    margin: 0 1rem;
  }
}
.noEsg #esg_03 {
  background-color: #c8dfc2;
}
.noEsg #esg_03 .greenT {
  color: #62ad78;
}
.noEsg #esg_03 .dot {
  color: #62ad78;
}
.noEsg .e3tlt3 {
  color: #62ad78;
}
.noEsg .e3hr {
  border-color: #62ad78;
}
.noEsg .btf02 {
  -webkit-transform: translateY(40%);
          transform: translateY(40%);
}
.noEsg .cloud04 {
  display: block;
}

.esg3Tent {
  z-index: 4;
}

.butterfly {
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.btf01 {
  aspect-ratio: 257/175;
  background-image: url(../images/ESG/Butterfly1.png);
  width: 16rem;
  left: 48%;
  top: 0;
  -webkit-transform: translateY(-25%);
          transform: translateY(-25%);
}

.btf02 {
  aspect-ratio: 171/146;
  background-image: url(../images/ESG/Butterfly2.png);
  width: 10.625rem;
  left: 37%;
  bottom: 0;
  -webkit-transform: translateY(5%);
          transform: translateY(5%);
}

#esg_03 {
  background-color: #62ad78;
}
#esg_03 > .flex {
  height: 61rem;
}

.esg03Tent {
  padding-right: 7rem;
}

.e3tlt1 {
  color: #182716;
  font-weight: bold;
  line-height: 1.3;
  width: 30rem;
  margin-left: 0.4em;
}

.e3tlt2 {
  font-weight: 600;
  color: #ffffff;
  line-height: 1.3;
  letter-spacing: 0.04em;
}
.e3tlt2 .dot {
  opacity: 0.6;
  font-size: 0.9em;
  margin: 0 0.05em;
  -webkit-transform: translateY(-10%);
          transform: translateY(-10%);
}

.greenT {
  color: #d3d86b;
}

.e3tlt3 {
  color: #c8dfc2;
  letter-spacing: 0.1em;
  line-height: 1.5;
  padding-left: 2.2em;
}

.e3hr {
  border-top: 2px dotted #c8dfc2;
  margin: 1rem 0 1.2rem 0;
  -webkit-transform: translateX(-8%);
          transform: translateX(-8%);
}

@media screen and (max-width: 767px) {
  .noEsg #esg_03 {
    margin-top: 10rem;
    background-color: #62ad78;
  }
  .noEsg #esg_03 .greenT {
    color: #d3d86b;
  }
  .noEsg #esg_03 .dot {
    color: #c8dfc2;
  }
  .noEsg .btf02 {
    -webkit-transform: translateY(5%);
            transform: translateY(5%);
  }
  .noEsg .e3tlt3 {
    color: #c8dfc2;
  }
  .noEsg .e3hr {
    border-color: #c8dfc2;
  }
  #esg_03 {
    height: 65rem;
  }
  #esg_03 > .flex {
    height: 51.5rem;
    min-height: 51.5rem;
    padding-top: 8rem;
  }
  .cloud02 {
    left: auto;
    right: 0;
    top: 10%;
  }
  .cloud03 {
    left: -35%;
    top: 115%;
  }
  .cloud04 {
    display: none !important;
  }
  .btf01 {
    left: 20%;
  }
  .btf02 {
    left: 20%;
    bottom: -10%;
  }
  .esg03Tent {
    padding-right: 0rem;
  }
  .e3tlt1 {
    width: auto;
    margin-left: 0;
  }
  .e3tlt1 div {
    text-align: center;
  }
  .e3tlt3 {
    padding-left: 0;
  }
  .e3hr {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
}
#esg_04 {
  background-color: #62ad78;
  min-height: 100vh;
  z-index: 3;
}
#esg_04:after {
  content: "";
  display: block;
  width: 99%;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: #fff;
}

.e4BgBox {
  position: sticky;
  left: 0;
  top: 0;
  width: 100%;
  height: 0;
  z-index: 0;
}

.overEsg5 .e4BG {
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}
.overEsg5 .e4BG::after {
  bottom: 3px;
}

.e4BG {
  position: absolute;
  left: 0%;
  bottom: -100vh;
  width: 100%;
  height: auto;
  overflow: hidden;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.e4BG > picture {
  display: block;
  position: relative;
  left: 49%;
  height: auto;
  width: 260rem;
  max-width: none;
  -webkit-transform: translateX(-51.5%);
          transform: translateX(-51.5%);
}
.e4BG::after {
  content: "";
  display: block;
  width: 100%;
  height: 30vh;
  background-image: url(../images/ESG/gradient_b2.png);
  background-repeat: repeat-x;
  background-position: bottom left;
  background-size: 100% 100%;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
  position: absolute;
  left: 0;
  bottom: 0px;
  opacity: 0.8;
}

.treeBack {
  position: absolute;
  left: 0;
  bottom: 13%;
  aspect-ratio: 1920/576;
  width: 100%;
  background-image: url(../images/ESG/tree_back.png);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 100% auto;
}

.treeFront {
  position: absolute;
  left: 0;
  bottom: 0%;
  aspect-ratio: 1920/947;
  width: 100%;
  background-image: url(../images/ESG/tree_front.png);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 100% auto;
}

.arrorrrr {
  position: absolute;
  left: -2rem;
  top: 41vh;
  aspect-ratio: 184/70;
  width: 11.5rem;
  background-image: url(../images/ESG/icon_arrow2.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.e4Tent {
  min-height: 100vh;
  position: relative;
}

.e4T_L {
  -ms-flex-item-align: self-start;
      -ms-grid-row-align: self-start;
      align-self: self-start;
  margin-right: -6rem;
}

.e4T_M {
  aspect-ratio: 412/508;
  width: 25.75rem;
  margin-top: 2rem;
  margin-bottom: 13rem;
}
.e4T_M img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
}

.e4T_R {
  -ms-flex-item-align: self-end;
      -ms-grid-row-align: self-end;
      align-self: self-end;
  margin-left: -11.1rem;
}

.e4rD {
  color: #c8dfc2;
  letter-spacing: 0.1em;
}

.parallaxBox {
  z-index: 10;
  position: sticky;
  top: 0;
  overflow-x: scroll;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
  scrollbar-width: none !important;
}
.parallaxBox::-webkit-scrollbar {
  width: 0px;
  height: 0px;
  opacity: 0;
}
.parallaxBox::-webkit-scrollbar-track {
  background-color: transparent;
  border-radius: 1em;
  background-color: transparent;
}
.parallaxBox::-webkit-scrollbar-thumb {
  border-radius: 1em;
  background-color: rgba(0, 0, 0, 0);
}

.parallaxTent {
  min-height: 100vh;
  padding-left: 120vw;
  width: auto;
  overflow: hidden;
  -webkit-transition: 0.5s ease-out;
  transition: 0.5s ease-out;
}
.parallaxTent.upperESG4 {
  -webkit-transform: translateX(0px) !important;
          transform: translateX(0px) !important;
  -webkit-transition: 0.1s ease-in;
  transition: 0.1s ease-in;
}

.paraB {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 100vw;
  min-height: 100vh;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-left: 7vw;
}
.paraB .esgPrallax {
  position: relative;
  margin-top: 1rem;
  z-index: 6;
}
.paraB:before, .paraB:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  height: 100%;
}
.paraB:after {
  background-repeat: no-repeat;
  background-position: center left;
  background-size: 100% 100%;
  left: -5%;
  width: 120%;
}

.para01:before {
  width: 400%;
  background-image: url(../images/ESG/dots.png);
  background-repeat: repeat-x;
  background-position: center left;
  background-size: auto 100%;
  left: 0;
  z-index: 5;
}
.para01:after {
  background-image: url(../images/ESG/esg4_bg1.png);
}
.para01 .esgInTent {
  border: 1px solid #62ad78;
  background-color: #cae3cc;
}
.para01 .esgCube {
  width: 11.4em;
}

.para02:after {
  background-image: url(../images/ESG/esg4_bg2.png);
}
.para02 .esgInTent {
  color: #fffaf7;
  border: 1px solid #fffaf7;
  background-color: #8abf93;
}
.para02 .esgInTent:before {
  content: "2";
  color: #fffaf7;
  padding-left: 0;
  left: -0.1em;
}
.para02 .esgInTent::after {
  background-color: #fffaf7;
  left: 20.5rem;
}
.para02 .dddts div {
  border: 1px solid #fffaf7;
}
.para02 .dddts div.active {
  background-color: #fffaf7;
}
.para02 .slashDiv {
  background-color: #fffaf7;
}
.para02 .smSTTxt {
  max-width: 25.8em;
}
.para02 .esgCube {
  border-color: #fffaf7;
  padding-left: 1.3em;
  padding-right: 1.3em;
}
.para02 .esgCube:before {
  background-color: #8abf93;
}

.para03:after {
  background-image: url(../images/ESG/esg4_bg3.png);
}
.para03 .esgInTent {
  color: #d3d86b;
  border: 1px solid #d3d86b;
  background-color: #62ad78;
}
.para03 .esgInTent:before {
  content: "3";
  color: #d3d86b;
  padding-left: 0;
  left: -0.09em;
}
.para03 .esgInTent::after {
  background-color: #d3d86b;
  left: 22rem;
}
.para03 .dddts div {
  border: 1px solid #d3d86b;
}
.para03 .dddts div.active {
  background-color: #d3d86b;
}
.para03 .slashDiv {
  background-color: #d3d86b;
}
.para03 .smSTTxt {
  -ms-flex-item-align: end;
      align-self: flex-end;
  width: 28.7em;
  margin-right: 2rem;
}
.para03 .esgDescribe {
  padding-left: 0rem;
}
.para03 .esgCube {
  border-color: #d3d86b;
  padding-left: 1.3em;
  padding-right: 1.3em;
}
.para03 .esgCube:before {
  background-color: #62ad78;
}

.para04 {
  padding-left: 3vw;
}
.para04:after {
  background-image: url(../images/ESG/esg4_bg4.png);
  left: -5%;
  width: 105%;
}
.para04 .esgInTent {
  color: #005e66;
  border: 1px solid #005e66;
  background-color: #d3d86b;
}
.para04 .esgInTent:before {
  content: "4";
  color: #005e66;
  padding-left: 0;
  left: -0.08em;
}
.para04 .esgInTent::after {
  background-color: #005e66;
  left: 23rem;
}
.para04 .dddts div {
  border: 1px solid #005e66;
}
.para04 .dddts div.active {
  background-color: #005e66;
}
.para04 .slashDiv {
  background-color: #005e66;
}
.para04 .smSTTxt {
  -ms-flex-item-align: end;
      align-self: flex-end;
  width: 27em;
  margin-right: 4rem;
}
.para04 .esgCubeBox {
  width: 56%;
  margin-left: 9rem;
}
.para04 .esgCube {
  border-color: #005e66;
  width: 11.4em;
}
.para04 .esgCube:before {
  background-color: #d3d86b;
}

.dddts {
  position: absolute;
  left: 50%;
  top: calc(100% + 2rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.dddts div {
  width: 10px;
  aspect-ratio: 1;
  border: 1px solid #62ad78;
  margin: 0 1em;
  border-radius: 99em;
}
.dddts div.active {
  background-color: #62ad78;
}

.esgInTent {
  padding: 1.6rem 1.4rem;
  color: #62ad78;
  aspect-ratio: 1020/630;
  width: 63.75rem;
  position: relative;
  overflow: hidden;
}
@media screen and (-webkit-min-device-pixel-ratio: 0) and (-webkit-min-device-pixel-ratio: 0), screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: 0.001dpcm) {
  .esgInTent {
    min-width: 520px;
  }
}
.esgInTent:before {
  font-family: "DM Sans", serif;
  content: "1";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  font-size: 42.5rem;
  line-height: 0.68;
  width: 1em;
  padding-left: 0.05em;
  opacity: 0.6;
  color: #62ad78;
}
.esgInTent::after {
  content: "";
  display: block;
  position: absolute;
  left: 14.5rem;
  bottom: 0;
  width: 2rem;
  aspect-ratio: 1;
  border-radius: 99em;
  opacity: 0.6;
  background-color: #62ad78;
}

.slashDiv {
  position: absolute;
  width: 1px;
  height: 230%;
  background-color: #62ad78;
  top: 0.2em;
  -webkit-transform-origin: 100% 0%;
          transform-origin: 100% 0%;
  -webkit-transform: rotate(40deg);
          transform: rotate(40deg);
  left: 3.3em;
}

.bigSTTxt {
  font-weight: 900;
  position: absolute;
  top: 2rem;
  left: 12.2rem;
}

.esgDescribe {
  margin-top: 3.5em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-left: 7.5rem;
}

.esgCube {
  font-size: 1.5625rem;
  font-weight: 600;
  padding: 0.7em;
  border: 1px solid #62ad78;
  margin-bottom: 0.6em;
  position: relative;
  z-index: 5;
}
.esgCube:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #cae3cc;
  opacity: 0.6;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .esgInTent {
    min-width: 0 !important;
    width: 90vw;
  }
  .e4BG > picture {
    left: 47%;
    width: 370%;
    -webkit-transform: translate(-50%, -3rem);
            transform: translate(-50%, -3rem);
  }
  .treeBack {
    left: -50%;
    bottom: 15%;
    width: 200%;
  }
  .treeFront {
    left: -25%;
    bottom: 0%;
    width: 150%;
  }
  .arrorrrr {
    display: none;
  }
  .e4Tent {
    min-height: 0;
  }
  .e4Tent .e4TentIn {
    padding-top: 0rem;
    padding-bottom: 4rem;
  }
  .e4T_L {
    margin-right: 0;
    margin-left: 1em;
  }
  .e4T_M {
    width: 27.66rem;
    margin-top: 1rem;
    margin-bottom: 3rem;
    margin-left: 2rem;
  }
  .e4T_R {
    margin-left: 0;
    text-align: center;
  }
  .e4rD {
    color: #c8dfc2;
    letter-spacing: 0.1em;
  }
  .paraB {
    padding-left: 3vw;
  }
  .paraB .esgPrallax {
    margin-top: 0;
    margin-bottom: 2rem;
  }
  @supports (-webkit-touch-callout: none) {
    .paraB .esgPrallax {
      /* CSS specific to iOS devices */
      margin-bottom: 14rem;
    }
  }
  .smSTTxt {
    letter-spacing: 0.1em;
  }
  .para01:before {
    background-repeat: repeat;
    background-size: 50% auto;
  }
  .para01:after {
    background-image: url(../images/ESG/esg4_bg1_m.png);
    left: -15%;
    width: 140%;
  }
  .para01 .esgCube {
    width: 11.6em;
  }
  .para02:after {
    background-image: url(../images/ESG/esg4_bg2_m.png);
    left: -10%;
    width: 140%;
  }
  .para02 .esgInTent::after {
    left: 20rem;
  }
  .para02 .smSTTxt {
    max-width: none;
  }
  .para02 .esgCubeBox {
    padding-right: 2rem;
    margin-top: 2.5rem;
    padding-left: 0;
  }
  .para02 .esgCube {
    margin-right: 0;
  }
  .para03:after {
    background-image: url(../images/ESG/esg4_bg3_m.png);
    left: -3%;
  }
  .para03 .esgInTent::after {
    left: 20rem;
  }
  .para03 .smSTTxt {
    -ms-flex-item-align: inherit;
        -ms-grid-row-align: inherit;
        align-self: inherit;
    width: auto;
    margin-right: 0;
  }
  .para03 .esgDescribe {
    padding-left: 0rem;
  }
  .para03 .esgCubeBox {
    padding-right: 2rem;
    margin-top: 1.5rem;
    padding-left: 0;
  }
  .para03 .esgCube {
    margin-right: 0;
  }
  .para04 {
    padding-left: 3vw;
  }
  .para04:after {
    background-image: url(../images/ESG/esg4_bg4_m.png);
  }
  .para04 .esgInTent::after {
    left: 22rem;
  }
  .para04 .smSTTxt {
    -ms-flex-item-align: inherit;
        -ms-grid-row-align: inherit;
        align-self: inherit;
    width: auto;
    margin-right: 0;
  }
  .para04 .esgCubeBox {
    width: auto;
    margin-left: 0;
    margin-top: 5rem;
  }
  .para04 .esgCube {
    width: 11.6em;
    margin-bottom: 1em;
  }
  .para04 .esgCube:nth-child(2) {
    margin-right: 3rem;
  }
  .para04 .esgCube:nth-child(3) {
    margin-right: 1.5rem;
  }
  .para04 .esgCube:nth-child(4) {
    margin-right: 3rem;
  }
  .dddts div {
    width: 6px;
  }
  .esgInTent {
    padding: 2rem 0 0 0;
    aspect-ratio: 644/1040;
    width: 85vw;
  }
}
@media screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 0) and (-webkit-min-device-pixel-ratio: 0), screen and (max-width: 767px) and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: 0.001dpcm) {
  .esgInTent {
    min-width: 0;
  }
}
@media screen and (max-width: 767px) {
  .esgInTent:before {
    font-size: 40rem;
    padding-left: 0;
    left: -0.075em;
    bottom: -2px;
  }
  .esgInTent::after {
    left: 10.5rem;
  }
  .slashDivB {
    position: absolute;
    top: 49%;
    left: 1.4rem;
  }
  .slashDiv {
    height: 200%;
    top: 0.2em;
    left: 3.1em;
    opacity: 0.5;
  }
  .bigSTTxt {
    position: relative;
    top: auto;
    left: auto;
    text-align: center;
  }
  .esgDescribe {
    margin-top: 1em;
    display: block;
    padding-left: 0;
  }
  .esgCubeBox,
  .textBox {
    padding-left: 15%;
  }
  .esgCubeBox {
    margin-top: 4rem;
  }
  .esgCube {
    font-size: 1.625rem;
    margin-left: auto;
    margin-right: auto;
  }
  .esgCube:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: #cae3cc;
    opacity: 0.6;
    z-index: -1;
  }
  .textBox {
    margin-top: 3.5rem;
  }
}
@media screen and (max-width: 767px) and (max-height: 120vw) {
  .e4Tent {
    padding-top: 0;
  }
  .e4Tent .e4TentIn {
    padding-top: 0;
  }
  .e4T_L {
    -webkit-transform: translate(-40%, 100%);
            transform: translate(-40%, 100%);
  }
  .e4T_M {
    width: 12rem;
    margin-bottom: 0;
    margin-top: 0;
  }
  .paraB {
    min-height: 0 !important;
    height: 100vh !important;
  }
  .paraB .esgPrallax {
    margin-bottom: 0 !important;
  }
  .esgInTent {
    aspect-ratio: 850/644;
    width: 60vw;
    min-height: 0;
  }
  .bigSTTxt {
    font-size: 3rem;
  }
  .smSTTxt {
    padding: 0 1em;
  }
  .smSTTxt br {
    display: none !important;
  }
  .esgDescribe {
    margin-top: 0.5rem;
  }
  .esgCubeBox {
    margin-top: 1rem !important;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .esgCube {
    margin-bottom: 0.5em !important;
    line-height: 1.2;
  }
  .para01 .esgCubeBox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .para01 .esgCube {
    margin-left: auto;
    margin-right: auto;
  }
  .para01 .textBox {
    margin-top: 0;
  }
  .para01 .textBox * {
    font-size: 1.5rem;
    font-weight: 500;
    margin-top: 0;
    margin-bottom: 0;
  }
  .para02 .esgCubeBox {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.vHtml {
  line-height: 1.4;
}

.swal2-popup .swal2-styled:focus {
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}

div:where(.swal2-container).swal2-center > .swal2-popup {
  border-radius: 0 !important;
  outline: none !important;
}

div:where(.swal2-container) button:where(.swal2-styled).swal2-confirm {
  background-color: #005e66 !important;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  border-radius: 0 !important;
  width: 9.5em;
}
div:where(.swal2-container) button:where(.swal2-styled).swal2-confirm:hover {
  background-color: #f39643 !important;
}

#esg_05 {
  padding-top: 9rem;
  color: #005e66;
  z-index: 10;
  margin-top: -1px;
}

.esg5Tent {
  max-width: 1260px;
  margin: auto;
}

.esg5subTlt {
  position: relative;
  line-height: 1;
  margin-top: 0.3em;
  margin-right: -0.5em;
}
.esg5subTlt:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 2px;
  right: 13.5em;
  height: 2px;
  width: calc(100% - 14.5em);
  background-color: #005e66;
}

.esg5stepBar {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.esg5_step {
  position: relative;
  width: 25%;
  padding-left: 2em;
  z-index: 5;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.esg5_step:before {
  content: "";
  display: block;
  width: calc(100% - 8px);
  height: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: #bfc9c5;
  -webkit-transform-origin: 0% 100%;
          transform-origin: 0% 100%;
  -webkit-transform: skew(-50deg, 0deg);
          transform: skew(-50deg, 0deg);
  z-index: -1;
}
.esg5_step.active {
  color: #005e66;
}
.esg5_step.active:before, .esg5_step.active:after {
  background-color: #d3d86b;
}

.esg5_step1:after,
.esg5_step4:after {
  content: "";
  display: block;
  width: 50%;
  height: 100%;
  background-color: #bfc9c5;
  position: absolute;
  z-index: -1;
}

.esg5_step1 {
  padding-left: 1.2em;
}
.esg5_step1:after {
  top: 0;
  left: 0;
}

.esg5_step4 {
  overflow: hidden;
}
.esg5_step4:after {
  bottom: 0;
  right: 0;
}

/**********/
.questionBlock {
  width: 100%;
  overflow: hidden;
}
.questionBlock .qqqBx {
  -webkit-transition: 0.5s;
  transition: 0.5s;
  width: 100%;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.questionBlock .step1 {
  -webkit-transform: translateX(0%);
          transform: translateX(0%);
}
.questionBlock .step2 {
  -webkit-transform: translateX(calc(-100% - 1px));
          transform: translateX(calc(-100% - 1px));
}
.questionBlock .step3 {
  -webkit-transform: translateX(calc(-200% - 1px));
          transform: translateX(calc(-200% - 1px));
}
.questionBlock .step4 {
  -webkit-transform: translateX(calc(-300% - 1px));
          transform: translateX(calc(-300% - 1px));
}

.questionBox {
  width: 100%;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding-left: 2px;
}

.qBox {
  color: #358188;
}

.qaSubmitBtn {
  background-color: #005e66;
  width: 14.64em;
  text-align: center;
  line-height: 2.15;
  color: #ffffff;
  position: relative;
  z-index: 5;
}
.qaSubmitBtn.finished {
  -webkit-filter: grayscale(1);
          filter: grayscale(1);
  opacity: 0.8;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.qaSubmitBtn span {
  font-size: 0.7em;
  display: inline-block;
  line-height: 1;
  -webkit-transform: translateY(-10%);
          transform: translateY(-10%);
  margin-left: 1em;
}
.qaSubmitBtn.disabled {
  -webkit-filter: grayscale(1);
          filter: grayscale(1);
  opacity: 0.8;
}
.qaSubmitBtn:hover {
  background-color: #f39643;
}

.inp input {
  display: none;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.inp label {
  display: inline-block;
  position: relative;
  padding-left: 2.2em;
  margin-left: 0.8em;
  cursor: pointer;
}
.inp label:before, .inp label:after {
  content: "";
  display: block;
  position: absolute;
  aspect-ratio: 1;
  width: 1em;
  border-radius: 99em;
  right: 1.4em;
  top: calc(50% - 0.5em);
}
.inp label:before {
  border: 1px solid #358188;
  z-index: 2;
}
.inp label::after {
  z-index: 1;
  background-color: #358188;
  border: 3px solid #ffffff;
  opacity: 0;
}
.inp input:checked + label::after {
  opacity: 1;
}

.part1 .q {
  padding: 0.8em 1em 0.8em 0;
  border-bottom: 2px dotted #bfc9c5;
}
.part1 .qT {
  position: relative;
  padding-left: 1.5em;
}
.part1 .qT:before {
  content: "◆";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}

.q.alert {
  color: #ef868c;
}
.q.alert .inp label:before {
  border-color: #ef868c;
}
.q.alert .inp label:after {
  background-color: #ef868c;
}

.tips {
  color: #EF868C;
  position: absolute !important;
  left: 0;
  top: calc(100% + 0.8em);
  display: none;
}

/*****************/
.pink {
  color: #EF868C;
  font-size: 1.1em;
}

.part2 .q {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 32%;
  max-width: 350px;
}
.part2 .q:not(:nth-child(3)) {
  border-right: 2px dotted #bfc9c5;
}
.part2 .inp {
  margin-bottom: 0.2em;
}
.part2 .inp label {
  margin-left: 0;
  padding-left: 1.8em;
}
.part2 .inp label:before, .part2 .inp label:after {
  left: 0;
  top: calc(50% - 0.5em);
}

.q2Tent {
  position: relative;
  padding-left: 1.3em;
}
.q2Tent:before {
  content: "◆";
  display: block;
  position: absolute;
  left: -0.5em;
  top: 0.7rem;
}
.q2Tent.tips {
  padding-left: 1.8em;
  left: 50%;
  -webkit-transform: translateX(-58%);
          transform: translateX(-58%);
  top: calc(100% + 2em);
}
.q2Tent.tips:before {
  left: 0em;
  top: 0em;
}

/*****************/
.part3 .inp {
  margin-bottom: 0.2em;
}
.part3 .inp label {
  margin-left: 0;
  padding-left: 2.5em;
  line-height: 1;
}
.part3 .inp label:before, .part3 .inp label:after {
  left: 0;
  top: 0rem;
  width: 1.625rem;
}
.part3 .inp label:before {
  border-width: 2px;
}
.part3 .inp label:after {
  border-width: 4px;
}
.part3 .q {
  width: calc(33.333% - 4px);
}
.part3 .q:nth-child(2) .stepBar .dmSans {
  background-color: #56989e;
}
.part3 .q:nth-child(3) .stepBar .dmSans {
  background-color: #358188;
}

.qBox.overLv1 .q:nth-child(2) .stepBar, .qBox.overLv1 .q:nth-child(3) .stepBar {
  -webkit-user-select: inherit;
     -moz-user-select: inherit;
      -ms-user-select: inherit;
          user-select: inherit;
  pointer-events: inherit;
}
.qBox.overLv1 .q:nth-child(2) .stepBar .inpBox, .qBox.overLv1 .q:nth-child(3) .stepBar .inpBox {
  opacity: 1;
  -webkit-filter: none;
          filter: none;
}
.qBox:not(.overLv1) .q:nth-child(1) .stepBar {
  -webkit-user-select: inherit;
     -moz-user-select: inherit;
      -ms-user-select: inherit;
          user-select: inherit;
  pointer-events: inherit;
}
.qBox:not(.overLv1) .q:nth-child(1) .stepBar .inpBox {
  opacity: 1;
  -webkit-filter: none;
          filter: none;
}

.greenWhite {
  color: #e9f5ef;
}

.stepBar {
  position: relative;
  line-height: 1.92;
  margin-top: 7rem;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.stepBar .dmSans {
  background-color: #6ca9af;
}
.stepBar .inpBox {
  left: 0;
  top: 0;
  -webkit-transform: translateY(-150%);
          transform: translateY(-150%);
  white-space: nowrap;
  -webkit-filter: grayscale(1);
          filter: grayscale(1);
  opacity: 0.4;
}
.stepBar .inpBox:before {
  content: "";
  display: block;
  width: 0;
  height: 100%;
  border-left: 2px dotted #bfc9c5;
  position: absolute;
  left: 0.82rem;
  top: 2.4rem;
  z-index: -1;
}
.stepBar .inpBox:nth-child(2) {
  left: 45%;
  top: auto;
  bottom: 0;
  -webkit-transform: translateY(190%);
          transform: translateY(190%);
}
.stepBar .inpBox:nth-child(2):before {
  top: auto;
  bottom: calc(100% + 0.8rem);
}

/*****************/
.part4 .qBox {
  color: #005e66;
}
.part4 .stepTLT {
  position: relative;
}
.part4 .stepTLT:before {
  content: "";
  display: block;
  width: calc(100% - 10em);
  height: 0;
  position: absolute;
  right: 0;
  top: calc(50% + 0.3em);
  border-top: 2px dotted #bfc9c5;
}
.part4 .inp {
  margin-bottom: 0.3em;
  margin-right: 1.5em;
}
.part4 .inp.last {
  margin-right: 0;
}
.part4 .inp label {
  margin-left: 0;
  padding-left: 1.5em;
  line-height: 1;
}
.part4 .inp label:before, .part4 .inp label:after {
  left: 0;
  top: 0rem;
}
.part4 .alert {
  color: #EF868C;
}
.part4 .alert input {
  border-color: #EF868C;
}
.part4 .alert label:before {
  border-color: #EF868C;
}
.part4 .alert label::after {
  background-color: #EF868C;
}
.part4 .alert .inpPlusBtn {
  background-image: url(../images/ESG/plus_red.svg);
  background-repeat: no-repeat;
  background-position: center left;
  background-size: contain;
}
.part4 .alert .inpPlusBtn img {
  opacity: 0;
}
.part4 .qT {
  padding-left: 1.5em;
  top: calc(100% - 6rem);
  left: 0%;
}
.part4 .qT:before {
  content: "◆";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}

.result_L {
  aspect-ratio: 1;
  background-color: #000000;
  border-radius: 99em;
  width: 15rem;
}
.result_L img {
  -o-object-fit: contain;
     object-fit: contain;
  height: 100%;
}

.result_R {
  max-width: 35rem;
  margin-left: 2.5rem;
}

.formHead {
  text-align: center;
  background-color: #358188;
  line-height: 2;
  letter-spacing: 0.1em;
}
.formHead span {
  font-size: 0.6em;
  display: inline-block;
  -webkit-transform: scale(1.2, 0.8);
          transform: scale(1.2, 0.8);
  margin: 0 1em;
}

.formBox {
  width: 46.875rem;
  color: #358188;
  min-width: 560px;
  position: relative;
}

.fr {
  padding: 1.8rem 0;
}

.fr1, .fr2 {
  border-bottom: 2px dotted #bfc9c5;
}

.inpTxt {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: 0.3em;
}
.inpTxt:before {
  content: "◆";
  display: block;
  position: absolute;
  left: 0em;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.inpTxt input {
  padding: 0 0.3em;
  line-height: 1.7;
  border-bottom: 1px solid #358188;
  margin-left: 0.3em;
  border-radius: 0;
}

.q4checkb {
  padding-left: 1.5em;
}

.otherInp {
  display: block;
  padding: 0 0.3em;
  line-height: 1.7;
  border-bottom: 1px solid #358188;
  margin-left: 0.5em;
  margin-bottom: 0.3em;
  width: 9.5em;
  border-radius: 0;
}

.fr3 .inpBox {
  margin-top: -0.1em;
}
.fr3 input {
  width: 100%;
  padding: 0 0.3em;
  line-height: 1.7;
  border-bottom: 1px solid #358188;
  margin-bottom: 0.3em;
  position: relative;
  border-radius: 0;
}
.fr3 input::-webkit-input-placeholder {
  color: #c2cdc8;
}
.fr3 input::-moz-placeholder {
  color: #c2cdc8;
}
.fr3 input:-ms-input-placeholder {
  color: #c2cdc8;
}
.fr3 input::-ms-input-placeholder {
  color: #c2cdc8;
}
.fr3 input::placeholder {
  color: #c2cdc8;
}

.inpPlusBtn {
  position: absolute;
  aspect-ratio: 1;
  width: 1.4em;
  bottom: calc(0.3em + 0px);
  right: 0;
  background-color: #fff;
}

.result1_goTop {
  position: absolute;
  right: 0;
  bottom: 0rem;
  width: 6.375rem;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: 0.3s 0.3s;
  transition: 0.3s 0.3s;
}
.result1_goTop.delayShow {
  pointer-events: inherit;
  opacity: 1;
}

@media screen and (max-width: 767px) {
  .esg5subTlt {
    line-height: 1.2;
    margin-top: 0.5em;
    padding-top: 0.5em;
    margin-right: 0;
  }
  .esg5subTlt:before {
    bottom: auto;
    top: 0;
    right: 50%;
    height: 1px;
    width: 50vw;
    -webkit-transform: translateX(50%);
            transform: translateX(50%);
  }
  .esg5_step {
    line-height: 1.7;
  }
  .esg5_step:before {
    width: calc(100% - 5px);
  }
  .esg5_step2 {
    padding-left: 2.5em;
    width: 33%;
  }
  .esg5_step3 {
    width: 25%;
  }
  .esg5_step1,
  .esg5_step4 {
    width: 22%;
  }
  .esg5_step1:after,
  .esg5_step4:after {
    bottom: auto;
    top: 0;
    height: 99%;
  }
  /**********/
  .questionBox {
    padding-left: 5%;
    padding-right: 5%;
    padding-bottom: 5rem;
  }
  .part1 .q {
    display: block;
    padding: 0.8em 0em 0.8em 0;
  }
  .part1 .inpBox {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 1.3rem;
  }
  /*****************/
  .part2 .qBox {
    display: block;
  }
  .part2 .q {
    display: block;
    width: auto;
    max-width: none;
    padding-bottom: 2em;
    margin-bottom: 2em;
  }
  .part2 .q:not(:nth-child(3)) {
    border-right: none;
    border-bottom: 2px dotted #bfc9c5;
  }
  .part2 .inpBox {
    margin-top: 0.5em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .part2 .inp {
    width: 45%;
  }
  .part2 .inp:nth-child(odd) {
    margin-right: 8%;
  }
  .q2Tent {
    padding-left: 2.2em;
  }
  .q2Tent:before {
    left: 0em;
  }
  .q2Tent.tips {
    -webkit-transform: translate(-50%, 110%);
            transform: translate(-50%, 110%);
    top: auto;
    bottom: 0;
  }
  /*****************/
  .part3 .inp label {
    display: block;
    line-height: 1.3;
    padding-left: 2em;
  }
  .part3 .inp label:before, .part3 .inp label:after {
    left: 0;
    top: -2em;
    width: 1.9rem;
  }
  .part3 .q {
    width: auto;
  }
  .stepBar {
    line-height: 1;
    margin-top: 0;
    margin-bottom: 1.5rem;
  }
  .stepBar .dmSans {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 15.375rem;
    aspect-ratio: 246/348;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: auto;
  }
  .stepBar .inpBox {
    width: 13rem;
    left: calc(50% - 21.7rem);
    top: 2em;
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  .stepBar .inpBox:before {
    width: 100%;
    height: 0;
    border-left: none;
    border-top: 1px dotted #dcdfde;
    left: 1.8rem;
    top: -1.1em;
  }
  .stepBar .inpBox:nth-child(2) {
    left: calc(50% + 7.5rem);
    bottom: auto;
    top: 50%;
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  .stepBar .inpBox:nth-child(2):before {
    bottom: auto;
    top: -1.1em;
    left: 0;
    width: calc(100% - 1.8rem);
  }
  .stepBar .inpBox:nth-child(2) label:before, .stepBar .inpBox:nth-child(2) label:after {
    left: auto;
    right: 0;
  }
  .stepBar .inpBox label:before {
    border-width: 1px;
  }
  .stepBar .inpBox label:after {
    border-width: 3px;
  }
  /*****************/
  .part4 {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 9rem;
  }
  .part4 .stepTLT:before {
    display: none;
  }
  .part4 .qBox {
    padding-left: 5%;
    padding-right: 5%;
  }
  .part4 .qT {
    top: calc(100% - 9rem);
    left: 5%;
  }
  .formBlock .stepTLT {
    text-align: center;
    overflow: hidden;
    margin-bottom: 0;
  }
  .formBlock .stepTLT:before, .formBlock .stepTLT:after {
    content: "";
    display: block;
    width: calc(50% - 0em);
    height: 0;
    position: absolute;
    top: 50%;
    border-top: 1px dotted #bfc9c5;
  }
  .formBlock .stepTLT:before {
    right: calc(50% + 5.5em);
  }
  .formBlock .stepTLT:after {
    left: calc(50% + 5.5em);
  }
  .result_L {
    width: 50%;
    margin: auto;
  }
  .result_R {
    max-width: none;
    width: 95%;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    margin-top: 4rem;
  }
  .formHead {
    line-height: 2.2;
  }
  .formHead span {
    -webkit-transform: scale(1, 0.6);
            transform: scale(1, 0.6);
  }
  .formBox {
    width: 100vw;
    padding-left: 5%;
    padding-right: 5%;
    min-width: 0;
  }
  .formBox .fr {
    padding: 3.5rem 0 3rem 0;
  }
  .formBox .fr1, .formBox .fr2 {
    border-bottom: 1px dotted #bfc9c5;
  }
  .formBox .inpTxt {
    display: block;
    padding-left: 0em;
    margin-bottom: 1em;
  }
  .formBox .inpTxt:before {
    left: 0em;
    top: 0.5em;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .formBox .inpTxt .inpT {
    line-height: 1;
    padding-left: 1.5em;
  }
  .formBox .inpTxt input {
    padding: 0.3em 0.3em 0 0.3em;
    line-height: 2;
    margin-left: 0;
  }
  .fr2 .inpTxt, .fr3 .inpTxt {
    padding-left: 1.5em;
    line-height: 1;
  }
  .q4checkb {
    padding-left: 1.5em;
  }
  .q4checkb .inp {
    width: 45%;
    margin-right: 0;
  }
  .q4checkb .inp label {
    padding-left: 1.3em;
  }
  .q4checkb .inp:nth-child(odd) {
    margin-right: 7%;
  }
  .q4checkb .inp.last {
    width: 100%;
    margin-right: 0;
  }
  .otherInp {
    padding: 0 0.3em 0 0.3em;
    line-height: 2;
    margin-left: 0em;
    margin-bottom: 0.3em;
    width: 100%;
  }
  .fr3 {
    margin-top: 1.5rem;
  }
  .fr3 .inpBox {
    margin-top: 0;
  }
  .fr3 input {
    line-height: 2;
    margin-top: 1em;
  }
  .inpPlusBtn {
    bottom: 0;
  }
  .result1_goTop {
    right: 2.5rem;
    bottom: 0.5rem;
    width: 9.125rem;
  }
}
@media screen and (max-width: 1660px) {
  body, html {
    font-size: 0.964vw;
  }
}
@media screen and (max-width: 1660px) and (min-width: 768px) and (max-height: 595px) {
  body, html {
    font-size: 0.94vw;
  }
}
@media screen and (max-width: 767px) {
  body, html {
    font-size: 2.1333vw;
  }
  body {
    height: auto !important;
    overflow: inherit !important;
    background-color: #040732;
  }
  #wrapper {
    overflow: hidden;
  }
  br.pcHide {
    display: inherit;
  }
  br.mHide {
    display: none;
  }
  header .logo {
    z-index: 99;
  }
  nav {
    display: block;
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    z-index: 10;
    background-color: #060c35;
    -webkit-transform: translateY(-110%);
            transform: translateY(-110%);
    -webkit-transition: 0.4s;
    transition: 0.4s;
  }
  nav > .flex {
    min-height: 100%;
    padding: 2rem 0;
  }
  .open nav {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  .logo {
    width: 8rem;
  }
  .open ~ .navBtn {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .open ~ .navBtn div:after {
    display: none;
  }
  .open ~ .navBtn div:before {
    bottom: 0;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .navBtn {
    width: 34px;
    right: 1.5rem;
    top: 2.2rem;
    z-index: 55;
    padding: 1px;
    -webkit-transition: 0.2s;
    transition: 0.2s;
    z-index: 999;
  }
  .navBtn div {
    height: 2px;
    background-color: #fff;
    margin-top: 10px;
    margin-bottom: 10px;
    position: relative;
    -webkit-box-shadow: 2px 2px 3px rgba(0, 53, 100, 0.1);
            box-shadow: 2px 2px 3px rgba(0, 53, 100, 0.1);
  }
  .navBtn div:before, .navBtn div:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    background-color: #fff;
    -webkit-transition: 0.2s;
    transition: 0.2s;
    -webkit-box-shadow: 2px 2px 3px rgba(0, 53, 100, 0.1);
            box-shadow: 2px 2px 3px rgba(0, 53, 100, 0.1);
  }
  .navBtn div:before {
    bottom: calc(100% + 6px);
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  .navBtn div:after {
    top: calc(100% + 6px);
  }
  .anchorBar {
    display: none;
  }
  .pointerDIV {
    display: none;
  }
  /* FB 對話機器人 */
}
@media screen and (max-width: 767px) and (max-height: 120vw) {
  body, html {
    font-size: 1.2vw;
  }
  nav {
    -webkit-transform: translateY(-200%);
            transform: translateY(-200%);
  }
  .kvSlider .swiper-pagination {
    top: 80%;
  }
  .marqueeBox {
    padding-top: 4rem;
  }
  .marquee {
    height: 1.8rem;
  }
  .aboutSliderBox {
    height: calc(100% - 2rem);
  }
  .aboutSlider {
    height: calc(100% - 3rem);
    margin-top: 1rem;
    margin-bottom: 0;
    padding-bottom: 2rem;
  }
  .aboutSlider .swiper-pagination {
    top: auto;
    bottom: 1.5rem;
  }
  .aboutSliderBox {
    display: block;
  }
  .aboutBox {
    margin-top: 0;
    padding-left: 25%;
    height: auto;
  }
  .aboutBox .aboutTlt {
    bottom: auto;
    top: 25%;
    left: 0%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .aboutTlt {
    font-size: 2.8rem;
    padding-bottom: 0;
  }
  .abcT {
    font-size: 2rem;
    margin-bottom: 2rem;
  }
  .abcT .dot {
    width: 1.2rem;
    height: 1.2rem;
    top: calc(100% + 0.5rem);
  }
  .aboutContent {
    height: 30rem;
    padding-top: 2rem;
  }
  .aboutContent .text-27 {
    line-height: 1.4;
    font-size: 1.4rem;
  }
  .sec_02 .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .universeBox {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .universeIntro h3 {
    text-align: left;
  }
  .insertTXT {
    width: 100%;
    position: static;
    text-align: left;
    margin-top: 3rem;
    -webkit-transform: none;
            transform: none;
  }
  .ballPool {
    width: calc(100% - 24rem);
    height: 86%;
    margin: 0;
  }
  .sec_04 h3 {
    font-size: 4rem;
    margin-right: 2rem;
  }
  .projectSlider .swiper-slide {
    max-width: 30rem;
  }
  .projectSlider .swiper-slide.project .pjImg {
    opacity: 1;
  }
  .projectSlider .swiper-slide.project .pjTxt {
    opacity: 1;
    background-color: transparent !important;
    -webkit-transition: 0s !important;
    transition: 0s !important;
  }
  .projectSlider .swiper-slide.project .m_graden {
    opacity: 1 !important;
    -webkit-transition: 0s !important;
    transition: 0s !important;
  }
  .projectSlider .swiper-slide.project .pjArr {
    opacity: 1;
    bottom: 2.75rem;
    -webkit-transition: 0s !important;
    transition: 0s !important;
  }
  .sec_05 h3 {
    font-size: 3.2rem;
  }
  .jbb {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .box_104 {
    width: 33%;
    margin: 0;
  }
  .box_email {
    width: 50%;
    margin: 0;
    margin-left: 2rem;
    margin-top: 8rem;
  }
  .box_email .ringImg {
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
  }
}
@media screen and (max-width: 767px) {
  br.pcHide {
    display: inherit;
  }
  br.mHide {
    display: none;
  }
  /* header ****************************/
  .overEsg5 header {
    height: 7.5rem;
  }
  nav {
    background-color: #62ad78;
  }
  .open .logo svg .st0 {
    fill: #fff !important;
  }
  .open ~ .navBtn div {
    background-color: #fff !important;
  }
  .open ~ .navBtn div:before, .open ~ .navBtn div:after {
    background-color: #fff !important;
  }
  .navBtn div {
    background-color: #005e66;
  }
  .navBtn div:before, .navBtn div:after {
    background-color: #005e66;
  }
  .notTop .midB {
    top: 100vh;
    -webkit-transition: 0s;
    transition: 0s;
  }
  .notTop .toTest {
    bottom: 1.5rem;
    -webkit-transition: bottom 0s;
    transition: bottom 0s;
  }
  .midB {
    -webkit-transition: 0s;
    transition: 0s;
  }
  .toTest {
    -webkit-transition: bottom 0s;
    transition: bottom 0s;
  }
  @supports not (-webkit-touch-callout: none) {
    /* CSS for other than iOS devices */
    .notTop .midB {
      top: calc(100% - 0rem);
      -webkit-transition: 0s;
      transition: 0s;
    }
    .notTop .toTest {
      bottom: 1.5rem;
      -webkit-transition: bottom 0s;
      transition: bottom 0s;
    }
    .midB {
      top: calc(100% - 1.5rem);
      -webkit-transition: 0s;
      transition: 0s;
    }
    .toTest {
      bottom: 0rem;
      -webkit-transition: bottom 0s;
      transition: bottom 0s;
    }
  }
  /* main ****************************/
  .navOPP #main {
    -webkit-filter: blur(20px);
            filter: blur(20px);
    opacity: 0.5;
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
  }
  .deco_slash {
    height: 1.5rem;
  }
  .footMedia {
    position: absolute;
    top: 4rem;
    right: 0;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 10rem;
  }
  .footMedia a {
    margin-bottom: 1.5rem;
  }
  .footMedia .esgIG {
    margin-left: 0;
  }
}