@charset "UTF-8";
/* --------------------------------------------------
  shared/css/esg.css
--------------------------------------------------- */
/* ------------- common -------------- */
body > main > div.csrnone {
  display: none; }

.soaText {
  padding: 30px 0 10px;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  font-weight: 700;
  text-align: center; }

table.esg-table th, table.esg-table td {
  padding: 5px 10px; }

/* ------------- シミズ・オープン・アカデミー -------------- */
.soa-wrapper--green {
  background-color: #f3f9ef; }
  .soa-wrapper--green .card .card-body .hd {
    border-color: #96b536; }
    .soa-wrapper--green .card .card-body .hd > span {
      color: #96b536; }
      .soa-wrapper--green .card .card-body .hd > span:after {
        color: #96b536; }
  .soa-wrapper--green .button--fixed {
    background-color: #ffffff;
    border-color: #96b536;
    color: #96b536; }

.soa-carousel {
  /*  display: none;*/
  max-width: 910px;
  width: 100%;
  margin: auto;
  margin-bottom: 34px;
  position: relative; }
  .soa-carousel:before, .soa-carousel:after {
    content: "";
    display: block;
    position: absolute;
    width: 2000px;
    top: 0;
    bottom: 0;
    background-color: #eff3f9;
    z-index: 3; }
  .soa-carousel:before {
    left: -2915px; }
  .soa-carousel:after {
    right: -2915px; }
  .soa-carousel .slick-list {
    overflow: visible;
    position: relative; }
    .soa-carousel .slick-list:before, .soa-carousel .slick-list:after {
      content: "";
      display: block;
      position: absolute;
      width: 1000px;
      top: 0;
      bottom: 0;
      background-color: rgba(255, 255, 255, 0.5);
      z-index: 2; }
    .soa-carousel .slick-list:before {
      left: -1005px; }
    .soa-carousel .slick-list:after {
      right: -1005px; }
  .soa-carousel .soa-carousel-item {
    max-width: 910px;
    width: 100%; }
  .soa-carousel .soa-carousel-item-image {
    padding: 0 5px;
    position: relative;
    z-index: 1; }
    .soa-carousel .soa-carousel-item-image > img {
      max-width: 900px;
      width: 100%;
      height: auto; }
  .soa-carousel .slick-prev {
    left: -25px; }
    .soa-carousel .slick-prev:before {
      content: "";
      margin-left: -0.6rem; }
  .soa-carousel .slick-next {
    right: -25px; }
    .soa-carousel .slick-next:before {
      content: "";
      margin-left: -0.4rem; }
  .soa-carousel .slick-list {
    z-index: 1; }
  .soa-carousel .slick-arrow {
    font-size: 0;
    position: absolute;
    top: 50%;
    z-index: 2;
    width: 50px;
    height: 50px;
    margin-top: -25px;
    border-radius: 25px;
    background-color: #ffffff;
    box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.25);
    cursor: pointer; }
    .soa-carousel .slick-arrow:before {
      display: inline-block;
      font-style: normal;
      font-variant: normal;
      font-weight: normal;
      line-height: 1;
      font-family: glyphs;
      text-rendering: auto;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      color: #356cb6;
      display: block;
      position: absolute;
      top: 50%;
      left: 50%;
      margin-top: -0.5rem;
      font-size: 1rem;
      z-index: 3; }
  .soa-carousel .slick-dots {
    position: absolute;
    width: 100%;
    bottom: -34px;
    text-align: center;
    font-size: 1rem;
    line-height: 1;
    margin-top: 20px; }
    .soa-carousel .slick-dots > li {
      display: inline-block;
      margin: 0 5px; }
      .soa-carousel .slick-dots > li > button {
        font-size: 0;
        display: inline-block;
        height: 10px;
        width: 10px;
        border-radius: 5px;
        background-color: #eeeeee;
        cursor: pointer;
        padding: 0; }
      .soa-carousel .slick-dots > li.slick-active > button {
        background-color: #356cb6; }

/* ------------- ESG経営 -------------- */
.csrImg {
  background-image: url("https://www.shimz.co.jp/company/csr/images/img_01.jpg"); }

.csrTitle {
  font-size: 2.0rem;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 500px;
  z-index: 5;
  color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  text-align: center;
  text-shadow: 2px 2px 5px #000000,1px 1px 10px #000000,2px 2px 10px #000000,-2px -2px 10px #000000,0 0 0 #000000;
  line-height: 1.8;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  -webkit-flex-direction: column;
  flex-direction: column; }

.corpreportWrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%; }

.corpreportWrap-mini {
  position: relative;
  margin: 0 auto;
  height: 0;
  max-width: 1200px; }

.reportMsg {
  min-width: 320px;
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
  width: 500px;
  height: 320px;
  text-shadow: none;
  color: #ffffff;
  background: #356cb6;
  padding: 35px; }
  .reportMsg h3 {
    font-size: 24px;
    font-wight: 500;
    margin: 5px 0 30px 0; }
    .reportMsg h3 + p {
      font-size: 15px;
      line-height: 2.0; }

.reportMsg-innerWrap {
  width: 100%;
  position: relative;
  height: auto; }

.reportmore {
  font-size: 14px;
  width: 80%; }
  .reportmore > a {
    padding: 15px;
    margin: 40px 0 10px;
    display: inline-block;
    color: #ffffff;
    border: 1px solid #ffffff;
    padding: 8px 12px 8px 38px;
    position: relative;
    font-weight: 400;
    text-align: center;
    border-radius: 0 !important;
    -webkit-transition: all 0.3s;
    transition: all 0.3s; }
    .reportmore > a:hover {
      background-color: rgba(255, 255, 255, 0.2); }
    .reportmore > a:before {
      position: absolute;
      top: 50%;
      left: 10px;
      margin-top: -0.7rem;
      display: inline-block;
      font-style: normal;
      font-variant: normal;
      font-weight: 400;
      line-height: 1;
      font-family: glyphs;
      text-rendering: auto;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      content: "";
      margin-right: 5px;
      vertical-align: bottom; }

.corpreportWrapper-file {
  width: 100%;
  z-index: 2;
  overflow: hidden;
  height: 320px;
  min-height: 320px;
  max-height: 320px;
  position: relative;
  background-color: #f2f2f2;
  background-size: cover; }

.reportWrapper-box {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  height: auto;
  height: 560px; }

.reportWrapper-file {
  background: url(https://www.shimz.co.jp/company/csr/images/img_11.jpg) no-repeat 0 0;
  position: absolute;
  right: 200px;
  z-index: -1;
  width: 203px;
  height: 288px;
  top: 16px;
  background-size: 203px; }

.csr-listbox.grid-wrap-box {
  padding: 0; }

.category-intro--gray {
  background-color: #f2f2f2 !important; }
  .category-intro--gray .category-intro-body {
    background-color: #f2f2f2 !important;
    color: #000 !important; }
  .category-intro--gray .category-intro-body::after {
    background: -webkit-linear-gradient(right, #f2f2f2 0%, transparent 100%) !important;
    background: linear-gradient(to left, #f2f2f2 0%, transparent 100%) !important; }
  .category-intro--gray .category-intro-body .link > a {
    color: #000 !important;
    border: 1px solid #000 !important; }

.icon-box .icon-box-text a:hover {
  background: #ffffff; }

/* ------------- 株主・投資家情報から転記 -------------- */
.noLinktext {
  margin: 20px 0 0 15px; }

.esgTopimgWrapper {
  width: 100%;
  overflow: hidden;
  position: relative; }

.esgTopimgWrapper--fixing img {
  width: 100%;
  max-width: 1200px;
  margin: auto;
  display: block; }

.esgTopimgWrapper-inner {
  position: absolute;
  top: 20%;
  left: 0;
  width: 100%; }

.esgTopimgWrapper-ttl {
  color: #ffffff;
  font-weight: 700;
  text-shadow: 2px 2px 5px #000000,1px 1px 10px #000000;
  letter-spacing: 0.1em;
  position: absolute;
  padding-left: 450px;
  padding-left: 50px; }

.esgTopimgWrapper-ttl-label {
  border: 1px solid #ffffff;
  padding: 2px 10px 0;
  display: inline-block; }

.esgTopimgWrapper-ttl-big {
  font-size: 3.3rem;
  display: block;
  line-height: 1.4;
  margin-top: 5px; }

.esgTopimgWrapper-txt {
  color: #ffffff;
  font-size: 1.2em;
  font-weight: 700;
  text-shadow: 2px 2px 5px #000000,1px 1px 10px #000000;
  padding-top: 150px;
  padding-left: 560px; }

.card-thumb-esg, .card-thumb .card-thumb-esg > img {
  position: relative; }

.card-thumb-esg > .card-thumb-esg-text {
  position: absolute;
  width: 95%;
  background: #fff;
  opacity: 0.9;
  padding: 13px;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%); }

/*.card-esg{
  border: 1px solid #e2e6e8;
  border-right: none;
}
.card-esg:nth-child(4){
  border: 1px solid #e2e6e8;
}*/
.esg-news {
  background-color: #ffffff;
  color: #356cb6;
  border: 1px solid #356cb6;
  vertical-align: middle;
  height: 25px;
  border-radius: 15px;
  line-height: 23px;
  font-size: 1.2rem;
  display: block;
  float: right; }

.card-esg .btn-sytle01 {
  font-size: 1.3rem;
  border: 1px solid #356cb6;
  width: 250px;
  line-height: 32px; }

.grid--layout.grid--4col > div:nth-child(odd) > .card {
  border-left: 1px solid #e2e6e8;
  border-right: 1px solid #e2e6e8; }
.grid--layout.grid--4col > div:nth-child(3) > .card {
  border-left: none; }

#irp-library-latest-zip {
  max-width: 100%; }

.card .card-body > .esg-hd {
  font-weight: 700;
  font-size: 1.8rem;
  padding-bottom: 0;
  border-bottom: none;
  margin-bottom: 0; }
  .card .card-body > .esg-hd > span {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
    position: relative;
    padding-right: 15px;
    line-height: 1.3; }
    .card .card-body > .esg-hd > span:after {
      position: absolute;
      top: 50%;
      right: 0;
      margin-top: -0.5rem;
      display: inline-block;
      font-style: normal;
      font-variant: normal;
      font-weight: normal;
      line-height: 1;
      font-family: glyphs;
      text-rendering: auto;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      content: "";
      color: #356cb6;
      font-size: 1.0rem; }

span.new {
  color: #ffffff;
  font-size: 1.2rem;
  font-weight: bold;
  background-color: #ff0000;
  margin-left: 1em;
  padding: 2px 8px 3px; }

.esgMasWrapper-ttl {
  color: #ffffff;
  font-size: 2.8rem;
  font-weight: 700;
  text-shadow: 2px 2px 5px #000000,1px 1px 10px #000000;
  letter-spacing: 0.07em;
  position: absolute;
  margin-top: 28px;
  left: 2%; }

.esgMasWrapper-ttl-big {
  font-size: 2.9rem;
  display: block;
  line-height: 1.4;
  margin-top: 5px; }

/* ------------- リスクマネジメント -------------- */
.riskLevel {
  width: 100%;
  margin-top: 20px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start; }
  .riskLevel span {
    font-size: 12px; }

.riskOrange {
  width: 10%;
  height: 20px;
  background-color: #eebe19;
  margin-left: 20px;
  margin-right: 10px; }

.riskYellow {
  width: 10%;
  height: 20px;
  background-color: #d5f021;
  margin-left: 20px;
  margin-right: 10px; }

.riskRed {
  width: 10%;
  height: 20px;
  background-color: #df5316;
  margin-left: 20px;
  margin-right: 10px; }

/* ------------- テクニカルツアー / 環境経営 -------------- */
.downCircle {
  width: 30px;
  height: 30px;
  margin: 30px auto; }

/* ------------- エコロジー・ミッション2030-2050 / 資源循環・汚染防止・水使用 -------------- */
.ecoflexbox dd .ecogreen {
  color: #78c072;
  font-size: 30px;
  font-weight: 700;
  margin: 0 5px; }
.ecoflexbox dd .ecogreen2 {
  color: #78c072;
  font-weight: 700; }
.ecoflexbox dd .ecoblue {
  color: #356cb6;
  font-size: 30px;
  font-weight: 700;
  margin: 0 5px; }
.ecoflexbox dd .ecoblue2 {
  color: #356cb6;
  font-weight: 700; }
.ecoflexbox dd .ecoorange {
  color: #f39800;
  font-size: 30px;
  font-weight: 700;
  margin: 0 5px; }
.ecoflexbox dd .ecoorange2 {
  color: #f39800;
  font-weight: 700; }

/* ------------- 環境経営 -------------- */
.earthmarginCut {
  margin-top: 0; }

/* ------------- シミズ・オープン・アカデミー -------------- */
#N0165 {
  z-index: 0; }
  #N0165 .soa-icon {
    position: absolute;
    width: 15%;
    max-width: 145px;
    top: -80px;
    right: 80px; }
  #N0165 .soa-icon-wrap {
    position: relative;
    z-index: 2; }

.soaRegist {
  background-color: #ffffff; }

/* ------------- ESG情報開示 -------------- */
.esg-inline a {
  text-decoration: none; }
  .esg-inline a:hover {
    text-decoration: underline; }
.esg-inline ul li {
  text-decoration: none !important;
  position: relative;
  padding-left: 15px !important; }
  .esg-inline ul li a:hover {
    text-decoration: underline !important; }
  .esg-inline ul li:before {
    position: absolute;
    left: 0;
    top: 5px;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    font-weight: normal;
    line-height: 1;
    font-family: glyphs;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    content: "";
    color: #356cb6;
    font-size: 1.0rem; }
.esg-inline > table.table td p {
  position: relative;
  margin-top: 0;
  padding-left: 15px !important; }
  .esg-inline > table.table td p a {
    text-decoration: none !important; }
  .esg-inline > table.table td p a:hover {
    text-decoration: underline !important; }
  .esg-inline > table.table td p:before {
    position: absolute;
    left: 0;
    top: 5px;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    font-weight: normal;
    line-height: 1;
    font-family: glyphs;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    content: "";
    color: #356cb6;
    font-size: 1.0rem; }
  .esg-inline > table.table td p.noarrow {
    padding-left: 0 !important; }
    .esg-inline > table.table td p.noarrow:before {
      display: none; }

/* ------------- マテリアリティ -------------- */
#materiality .ma01 {
  background: #fff4fd; }
  #materiality .ma01 h3 {
    border-bottom: 2px solid #e7c5e0; }
    #materiality .ma01 h3::before {
      border-bottom: 2px solid #a42f8b; }
  #materiality .ma01 h4 {
    border-left: 4px solid #a42f8b; }
#materiality .ma02 {
  background: #fff0dc; }
  #materiality .ma02 h3 {
    border-bottom: 2px solid #f4dbb9; }
    #materiality .ma02 h3::before {
      border-bottom: 2px solid #f08c00; }
  #materiality .ma02 h4 {
    border-left: 4px solid #f08c00; }
#materiality .ma03 {
  background: #f4ffdc; }
  #materiality .ma03 h3 {
    border-bottom: 2px solid #dfefbf; }
    #materiality .ma03 h3::before {
      border-bottom: 2px solid #8dc21f; }
  #materiality .ma03 h4 {
    border-left: 4px solid #8dc21f; }

@media screen and (max-width: 1200px) {
  /* ------------- 株主・投資家情報から転記 -------------- */
  .esgTopimgWrapper-ttl-big > br {
    display: none !important; }

  .esgTopimgWrapper-ttl {
    padding-left: 50px;
    max-width: 690px; }

  .esgTopimgWrapper-txt {
    padding-top: 150px;
    padding-left: 50px; } }
@media screen and (max-width: 1024px) {
  /* ------------- 株主・投資家情報から転記 -------------- */
  .esgTopimgWrapper-ttl {
    padding-left: 10px;
    font-size: 1.4rem;
    max-width: 540px; }

  .esgTopimgWrapper-ttl-big {
    font-size: 2.7rem;
    margin-top: 5px; }

  .esgTopimgWrapper-txt {
    display: none; } }
@media (max-width: 991px) and (min-width: 768px) {
  /* ------------- 株主・投資家情報から転記 -------------- */
  .esgTopimgWrapper-ttl {
    padding-left: 20px; }

  .esgTopimgWrapper-ttl-big {
    font-size: 2.7rem; }

  .esgTopimgWrapper-txt {
    padding-top: 170px;
    padding-left: 260px; }

  .esgMasimgWrapper-ttl-big {
    font-size: 2.2rem;
    margin-top: 5px; } }
@media (max-width: 767px) {
  /* ------------- シミズ・オープン・アカデミー -------------- */
  .soa-carousel .slick-prev {
    left: -40px; }
  .soa-carousel .slick-next {
    right: -40px; }
  .soa-carousel .slick-arrow {
    width: 80px;
    height: 80px;
    margin-top: -40px;
    border-radius: 40px; }

  #N0165 .soa-icon {
    width: 20%;
    max-width: 115px;
    top: -40px; } }
@media screen and (max-width: 768px) {
  /* ------------- common -------------- */
  body > main > div.csrnone {
    display: block; }

  /* ------------- ESG経営 -------------- */
  .csrTitle {
    margin-top: 130px;
    width: 100%;
    font-size: 1.8rem;
    display: relative;
    width: 80%;
    color: #ffffff;
    height: 120px;
    padding: 0 30px; }

  .csrImg {
    background: url("https://www.shimz.co.jp/company/csr/images/img_01.jpg") no-repeat -130px 0;
    background-size: auto 368px;
    margin-bottom: 0; }

  .corpreportWrap {
    position: static;
    width: 100%;
    margin: 0 auto;
    left: 0;
    right: 0;
    height: 300px; }
    .corpreportWrap.tune {
      min-height: 400px;
      height: auto; }

  .reportMsg {
    position: relative;
    width: auto;
    height: auto;
    padding: 24px;
    margin: 24px;
    margin-top: -24px;
    text-shadow: initial; }
    .reportMsg h3 {
      font-size: 20px; }

  .reportmore {
    width: 100%;
    text-align: left;
    border: none; }

  .reportWrapper-file {
    position: relative;
    right: inherit;
    margin: 0 auto;
    background-size: 186px; }

  .csr-listbox.grid-wrap-box {
    padding: 15px; }
  .csr-listbox .card > .card-body {
    padding: 10px;
    font-size: 90%; } }
@media (max-width: 479px) {
  /* ------------- ESG経営 -------------- */
  .reportMsg {
    margin: 0; }

  /* ------------- シミズ・オープン・アカデミー -------------- */
  #N0165 .soa-icon {
    display: none; } }
@media (max-width: 991px) {
  /* ------------- シミズ・オープン・アカデミー -------------- */
  .soa-carousel .slick-prev {
    left: -50px; }
    .soa-carousel .slick-prev:before {
      content: "";
      left: 70%; }
  .soa-carousel .slick-next {
    right: -50px; }
    .soa-carousel .slick-next:before {
      content: "";
      left: 30%; }
  .soa-carousel .slick-arrow {
    width: 100px;
    height: 100px;
    margin-top: -50px;
    border-radius: 50px; }
    .soa-carousel .slick-arrow:before {
      margin-top: -0.8rem;
      font-size: 1.6rem; }

  #N0165 .soa-icon {
    top: -60px;
    right: 20px; } }
@media (max-width: 900px) {
  /* ------------- シミズ・オープン・アカデミー -------------- */
  .soa-carousel {
    width: 100%; }
    .soa-carousel .soa-carousel-item {
      width: 100%; }
    .soa-carousel .soa-carousel-item-image {
      padding: 0; } }
@media (max-width: 768px) {
  /* ------------- ESG経営 -------------- */
  .reportmore > a {
    min-width: auto;
    width: 100%; } }
@media (max-width: 480px) {
  /* ------------- 株主・投資家情報から転記 -------------- */
  .grid--wrap.grid--break-sp > .card-esg {
    padding: 0;
    width: auto;
    max-width: inherit;
    margin-top: 18px; } }
@media screen and (max-width: 768px) and (min-width: 320px) {
  /* ------------- ESG経営 -------------- */
  .csrImg {
    background-image: url("https://www.shimz.co.jp/company/csr/images/img_01.jpg"); } }
@media screen and (max-width: 1123px) and (min-width: 769px) {
  /* ------------- ESG経営 -------------- */
  .reportWrapper-box {
    width: 50%;
    margin-left: 50%; }

  .reportWrapper-file {
    left: 140px; } }
@media screen and (max-width: 780px) and (min-width: 381px) {
  /* ------------- ESG経営 -------------- */
  .reportWrapper-box {
    width: 100%;
    height: auto;
    background: none;
    min-height: 320px;
    max-height: 320px;
    min-width: 320px; } }


