@charset "utf-8";

b {
  font-weight: 900 !important;
}
a {
  color: #000;
}
img {
  vertical-align: top;
  max-width: 100%;
}

.pb0 {
  padding-bottom: 0;
}
.pt0 {
  padding-top: 0;
}
.pb1 {
  padding-bottom: 1%;
}
.pt1 {
  padding-top: 1%;
}
.pb2 {
  padding-bottom: 2%;
}
.pt2 {
  padding-top: 2%;
}
.pb3 {
  padding-bottom: 3%;
}
.pt3 {
  padding-top: 3%;
}
.pb4 {
  padding-bottom: 4%;
}
.pt4 {
  padding-top: 4%;
}
.pb5 {
  padding-bottom: 5%;
}
.pt5 {
  padding-top: 5%;
}
.mb0 {
  margin-bottom: 0;
}
.mt0 {
  margin-top: 0;
}
.mt1 {
  margin-top: 1%;
}
.mb1 {
  margin-bottom: 1%;
}
.mt2 {
  margin-top: 2%;
}
.mb2 {
  margin-bottom: 2%;
}
.mt3 {
  margin-top: 3%;
}
.mb3 {
  margin-bottom: 3%;
}
.mt4 {
  margin-top: 4%;
}
.mb4 {
  margin-bottom: 4%;
}
.mt5 {
  margin-top: 5%;
}
.mb5 {
  margin-bottom: 5%;
}

.mt10 {
  margin-top: 10px !important;
}
.mt20 {
  margin-top: 20px !important;
}
.mt40 {
  margin-top: 40px !important;
}
.mt60 {
  margin-top: 60px !important;
}
.mt80 {
  margin-top: 80px !important;
}
.mt100 {
  margin-top: 100px !important;
}
.mt120 {
  margin-top: 120px !important;
}
.mt150 {
  margin-top: 150px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}
.mb20 {
  margin-bottom: 20px !important;
}
.mb60 {
  margin-bottom: 60px !important;
}
.mb40 {
  margin-bottom: 40px !important;
}
.mb80 {
  margin-bottom: 80px !important;
}
.mb100 {
  margin-bottom: 100px !important;
}
.mb120 {
  margin-bottom: 120px !important;
}
.mb150 {
  margin-bottom: 150px !important;
}

.x0_1 {
  font-size: 0.1em;
}
.x0_2 {
  font-size: 0.2em;
}
.x0_3 {
  font-size: 0.3em;
}
.x0_4 {
  font-size: 0.4em;
}
.x0_5 {
  font-size: 0.5em;
}
.x0_6 {
  font-size: 0.6em;
}
.x0_7 {
  font-size: 0.7em;
}
.x0_8 {
  font-size: 0.8em;
}
.x0_9 {
  font-size: 0.9em;
}

.x1_1 {
  font-size: 1.1em;
}
.x1_2 {
  font-size: 1.2em;
}
.x1_3 {
  font-size: 1.3em;
}
.x1_4 {
  font-size: 1.4em;
}
.x1_5 {
  font-size: 1.5em;
}
.x1_6 {
  font-size: 1.6em;
}
.x1_7 {
  font-size: 1.7em;
}
.x1_8 {
  font-size: 1.8em;
}
.x1_9 {
  font-size: 1.9em;
}

.op0 {
  opacity: 0;
}
.op1 {
  opacity: 1;
}

.flex {
  display: flex;
  width: 100%;
  flex-wrap: wrap;
}
.flex-ac {
  align-items: center;
}
.flex-jc {
  justify-content: center;
}
.flex-c {
  justify-content: center;
  align-items: center;
}
.flex-sb {
  justify-content: space-between;
}
.flex-fs {
  justify-content: flex-start;
}

.flex p {white-space: pre-line;}

.block-a {
  width: auto;
}
.block-1 {
  width: 100%;
}
.block-2 {
  width: 50%;
}
.block-3 {
  width: 33.3%;
}
.block-4 {
  width: 25%;
}
.block-5 {
  width: 20%;
}
.block-6 {
  width: 16.66%;
}
.block-8 {
  width: 12.5%;
}

.block-90 {
  width: 90%;
}
.block-80 {
  width: 80%;
}
.block-70 {
  width: 70%;
}
.block-60 {
  width: 60%;
}
.block-40 {
  width: 40%;
}
.block-30 {
  width: 30%;
}
.block-10 {
  width: 10%;
}

.flex > li {
  position: relative;
}
.flex > li > div {
  position: relative;
}
.flex > li > div.m30 {
  margin: 30px;
}
.flex > li > div.m20 {
  margin: 20px;
}
.flex > li > div.m10 {
  margin: 10px;
}
.flex > li > div.m5 {
  margin: 5px;
}

.flex > li > div .before {
  background: #bfbfbf;
  padding: 6px 10px;
  width: 100%;
  text-align: center;
}
.flex > li > div .after {
  background: #284881;
  color: #fff;
  padding: 6px 10px;
  width: 100%;
  text-align: center;
}

.pt100 {
  padding-top: 100px !important;
}

.box-shadow {
  box-shadow: rgba(0, 0, 0, 0.16) 0px 10px 36px 0px, rgba(0, 0, 0, 0.06) 0px 0px 0px 1px;
}
.box-shadow2 {
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}
.dib {
  display: inline-block;
}

.br20 {
  border-radius: 20px;
}
.br100 {
  border-radius: 100%;
}

.w100 {
  width: 100%;
}
.h100 {
  height: 100%;
}

.lh0-7 {
  line-height: 0.7;
}
.lh0-8 {
  line-height: 0.8;
}
.lh0-9 {
  line-height: 0.9;
}
.lh1 {
  line-height: 1;
}
.lh1-1 {
  line-height: 1.1;
}
.lh1-2 {
  line-height: 1.2;
}
.lh1-3 {
  line-height: 1.3;
}
.lh1-4 {
  line-height: 1.4;
}
.lh1-6 {
  line-height: 1.6;
}
.lh1-7 {
  line-height: 1.7;
}
.lh1-8 {
  line-height: 1.8;
}

.maxall {
  max-width: 100%;
  margin: 0 auto;
}

.max1600 {
  max-width: 1600px;
  margin: 0 auto;
}
.max1400 {
  max-width: 1400px;
  margin: 0 auto;
}
.max1100 {
  max-width: 1100px;
  margin: 0 auto;
}
.max1000 {
  max-width: 1000px;
  margin: 0 auto;
}
.max900 {
  max-width: 900px;
  margin: 0 auto;
}
.max800 {
  max-width: 800px;
  margin: 0 auto;
}
.max700 {
  max-width: 700px;
  margin: 0 auto;
}
.max600 {
  max-width: 600px;
  margin: 0 auto;
}


.df {
  display: flex;
  justify-content: center;
  align-items: center;
}
.df-sb {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.bxs1 {
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
}

.namepen {
  width: fit-content;
  padding: 0 0.25%;
  position: relative;
  z-index: 1;
  margin: 0 auto;
}
.namepen::after {
  position: absolute;
  display: block;
  content: "\00a0";
  width: 100%;
  left: 0;
  right: 0;
  top: 50%;
  height: 60%;
  background-color: #c6d7e8;
  transform: skew(-5deg);
  z-index: -1;
}


.bg-gray {
  background-color: #fbfbfb;
  margin-top: 120px;
  padding-bottom: 120px;
}

.m_br {
  display: none;
}
.m_br380 {
  display: none;
}
.m_br425 {
  display: none;
}
.m_br600 { 
	display: none;
}
.m_br1200 {
  display: none;
}
.m-area {
  display: none;
}

.pre {
  white-space: pre-line;
}


.db-1200, .df-1200 {
  display: none !important;
}
.db-1025, .df-1025 {
	display: none !important;
}
.db-769, .df-769 {
  display: none !important;
}
.db-600, .df-600 {
  display: none !important;
}
.db-425, .df-425 {
  display: none !important;
}

@media screen and (max-width: 1500px) {
}


@media screen and (max-width: 1200px) {
  .m_br1200 {
    display: block;
  }

  .b-block-1 {
    width: 100%;
  }
  .b-block-2 {
    width: 50%;
  }
  .b-block-3 {
    width: 33.3%;
  }
  .b-block-4 {
    width: 25%;
  }
  .b-block-5 {
    width: 20%;
  }
  .b-block-6 {
    width: 16.6%;
  }

  .db-1200 {
    display: block !important;
  }
	.df-1200 {
    display: flex !important;
  }
  .dn-1200 {
    display: none !important;
  }
}

@media screen and (max-width: 1024px) {
	.db-1025 {
    display: block !important;
  }
	.df-1025 {
    display: flex !important;
  }
  .dn-1025 {
    display: none !important;
  }
}

@media screen and (max-width: 769px) {
  .bg-gray {
    margin-top: 80px;
    padding-bottom: 80px;
  }
  .m_br {
    display: block !important;
  }
  .pc-area {
    display: none;
  }
  .m-area {
    display: block;
  }

  .mt60 {
    margin-top: 40px !important;
  }
  .mt80 {
    margin-top: 40px !important;
  }
  .mt100 {
    margin-top: 50px !important;
  }
  .mt120 {
    margin-top: 60px !important;
  }
  .mt150 {
    margin-top: 70px !important;
  }

  .mb60 {
    margin-bottom: 40px !important;
  }
  .mb80 {
    margin-bottom: 40px !important;
  }
  .mb100 {
    margin-bottom: 50px !important;
  }
  .mb120 {
    margin-bottom: 60px !important;
  }
  .mb150 {
    margin-bottom: 70px !important;
  }

  .m-block-1 {
    width: 100%;
  }
  .m-block-2 {
    width: 50%;
  }
  .m-block-3 {
    width: 33.3%;
  }
  .m-block-4 {
    width: 25%;
  }
  .m-block-5 {
    width: 20%;
  }
  .m-block-6 {
    width: 16.6%;
  }

  .db-769 {
    display: block !important;
  }
	.df-769 {
    display: flex !important;
  }
  .dn-769 {
    display: none !important;
  }
}

@media screen and (max-width: 600px) {
	.db-600 {
    display: block !important;
  }
	.df-600 {
    display: flex !important;
  }
  .dn-600 {
    display: none !important;
  }
	.m_br600 {display: block;}
}


@media screen and (max-width: 425px) {
  .bg-gray {
    margin-top: 60px;
    padding-bottom: 60px;
  }

  .mpb0 {
    padding-bottom: 0;
  }
  .mpt0 {
    padding-top: 0;
  }
  .mpb1 {
    padding-bottom: 1%;
  }
  .mpt1 {
    padding-top: 1%;
  }
  .mpb2 {
    padding-bottom: 2%;
  }
  .mpt2 {
    padding-top: 2%;
  }
  .mpb3 {
    padding-bottom: 3%;
  }
  .mpt3 {
    padding-top: 3%;
  }
  .mpb4 {
    padding-bottom: 4%;
  }
  .mpt4 {
    padding-top: 4%;
  }
  .mpb5 {
    padding-bottom: 5%;
  }
  .mpt5 {
    padding-top: 5%;
  }
  .mpb6 {
    padding-bottom: 6%;
  }
  .mpt6 {
    padding-top: 6%;
  }
  .mpb7 {
    padding-bottom: 7%;
  }
  .mpt7 {
    padding-top: 7%;
  }
  .mmb0 {
    margin-bottom: 0;
  }
  .mmt0 {
    margin-top: 0;
  }
  .mmt1 {
    margin-top: 1%;
  }
  .mmb1 {
    margin-bottom: 1%;
  }
  .mmt2 {
    margin-top: 2%;
  }
  .mmb2 {
    margin-bottom: 2%;
  }
  .mmt3 {
    margin-top: 3%;
  }
  .mmb3 {
    margin-bottom: 3%;
  }
  .mmt4 {
    margin-top: 4%;
  }
  .mmb4 {
    margin-bottom: 4%;
  }
  .mmt5 {
    margin-top: 5%;
  }
  .mmb5 {
    margin-bottom: 5%;
  }
  .mmt6 {
    margin-top: 6%;
  }
  .mmb6 {
    margin-bottom: 6%;
  }
  .mmt7 {
    margin-top: 7%;
  }
  .mmb7 {
    margin-bottom: 7%;
  }

  .mt20 {
    margin-top: 10px !important;
  }
  .mt40 {
    margin-top: 20px !important;
  }
  .mt60 {
    margin-top: 30px !important;
  }

  .mb20 {
    margin-bottom: 10px !important;
  }
  .mb40 {
    margin-bottom: 20px !important;
  }
  .mb60 {
    margin-bottom: 30px !important;
  }

  .m_br425 {
    display: block !important;
  }

  .pt100 {
    padding-top: 60px !important;
  }

  .s-block-1 {
    width: 100%;
  }
  .s-block-2 {
    width: 50%;
  }
  .s-block-3 {
    width: 33.3%;
  }
  .s-block-4 {
    width: 25%;
  }
  .s-block-5 {
    width: 20%;
  }
  .s-block-6 {
    width: 16.6%;
  }

  .db-425 {
    display: block !important;
  }
	.df-425 {
    display: flex !important;
  }
  .dn-425 {
    display: none !important;
  }
}

@media screen and (max-width: 380px) {
	.m_br380 {display: block !important;}
}



/* ======================================================================================================================================================= */
/* ======================================================================================================================================================= */

.point-color-w {color: #fff;}

.imp-plus-area1 ul.flex > li {width: 25%;}
.imp-plus-area1 ul.flex > li > div {margin: 5px; text-align: center;}
.imp-plus-area1 ul.flex .img {position: relative; display: flex; align-items: center; justify-content: center; height: 270px;}
.imp-plus-area1 ul.flex .img::before {position: absolute; content: ''; top: 50%; right: -20px; transform: translateY(-50%); width: 30px; height: 4px; background: #ccc;}
.imp-plus-area1 ul.flex .img::after {position: absolute; content: ''; top: 50%; right: -8px; transform: translateY(-50%); width: 4px; height: 30px; background: #ccc;}
.imp-plus-area1 ul.flex > li:nth-child(3) .img::before {top: 52%; background: #ffbf4f;}
.imp-plus-area1 ul.flex > li:nth-child(3) .img::after {top: 48%; background: #ffbf4f; right: -20px; width: 30px; height: 4px;}
.imp-plus-area1 ul.flex > li:last-child .img::before,
.imp-plus-area1 ul.flex > li:last-child .img::after {display: none;}
.imp-plus-area1 ul.flex .txt h5 {font-weight: 500;}
.imp-plus-area1 ul.flex .txt p {margin-top: 10px;}
.imp-plus-area1 ul.flex article {display: flex; align-items: center; justify-content: center; flex-direction: column; margin-top: 30px; text-align: center; color: #fff; padding: 20px 10px; background: #333;}
.imp-plus-area1 ul.flex article h6 {font-weight: 700; margin-top: 5px;}
.imp-plus-area1 ul.flex > li:last-child article {background: #ffbf4f; color: #333;}

.imp-plus-area2 ul.flex {border: 1px solid #cecece;}
.imp-plus-area2 ul.flex .tit {padding: 15px 10px; background: #fbfbfb; font-weight: 500; text-align: center; border-bottom: 1px solid #cecece;}
.imp-plus-area2 ul.flex .img {border-bottom: 1px solid #cecece;}
.imp-plus-area2 ul.flex .txt {display: flex; justify-content: center; align-items: center; height: 200px;}
.imp-plus-area2 ul.flex .txt ul > li:not(:first-child) {margin-top: 10px;}
.imp-plus-area2 ul.flex .txt p {position: relative; padding-left: 20px; font-weight: 500;}
.imp-plus-area2 ul.flex .txt p::before {position: absolute; content: ''; left: 0; top: 12px; width: 4px; height: 4px; border-radius: 50%; background: #333;}
.imp-plus-area2 ul.flex > li:last-child .tit {background: #ffbf4f; font-weight: 700;}
.imp-plus-area2 ul.flex > li > div > div {border-right: 1px solid #cecece;}

.imp-plus-area3 {background: url(../img/sub/imp_plus_bg1.jpg) center/cover no-repeat; color: #fff;}
.imp-plus-area3 .title-text {color: #fff;}
.imp-plus-area3 .sub-tit {text-align: center; font-style: italic;}
.imp-plus-area3 .sub-tit h4 {display: inline-block; padding-bottom: 5px; border-bottom: 1px solid #fff;}
.imp-plus-area3 article {margin-top: 40px; text-align: center;}
.imp-plus-area3 article .tit {padding: 5px 10px; background: #fff; font-weight: 700; color: #333;}
.imp-plus-area3 article .txt {margin-top: 10px; padding: 30px 20px; border: 1px solid #fff;}
.imp-plus-area3 article .txt h6 {font-weight: 700; margin-bottom: 20px;}
.imp-plus-area3 article .txt p {white-space: pre-line;}
.imp-plus-area3 article ul.flex {flex-wrap: nowrap;}
.imp-plus-area3 article ul.flex > li > div {margin: 5px;}

.imp-plus-area4 table {max-width: 1000px; width: 100%; margin: 0 auto; border-spacing: 5px; border-collapse: inherit;}
.imp-plus-area4 table td {border: 1px solid #ccc; text-align: center;}
.imp-plus-area4 table thead td:nth-child(2) {border: 0;}
.imp-plus-area4 table tbody td {padding: 12px 10px; vertical-align: middle;}
.imp-plus-area4 table tbody td h6 {font-weight: bold;}
.imp-plus-area4 table tbody td p {white-space: pre-line; font-weight: 500;}
.imp-plus-area4 table tbody tr:first-child td:first-child {background: #ccc;}
.imp-plus-area4 table tbody tr:first-child td:nth-child(2) {background: #333; color: #fff;}
.imp-plus-area4 table tbody tr:first-child td:last-child {background: #ffbf4f;}
.imp-plus-area4 table tbody td:nth-child(2) {background: #f5f5f5;}

.imp-plus-area5 {padding: 120px 0 !important; background: url(../img/sub/imp_plus_bg2.jpg) center/cover no-repeat; color: #fff;}
.imp-plus-area5 .tit {position: relative; margin-bottom: 40px;}
.imp-plus-area5 .tit::before {position: absolute; content: ''; left: -30px; top: 50%; transform: translateY(-50%); width: 5px; height: 80%; background: #ffbf4f;}
.imp-plus-area5 .tit h3 {font-weight: 300; white-space: pre-line; line-height: 1.3;}
.imp-plus-area5 .txt p {white-space: pre-line;}

.imp-plus-area6 ul.flex {flex-wrap: nowrap;}
.imp-plus-area6 ul.flex > li:nth-child(2) > div {margin: 0 15px;}

.imp-plus-area7 .basic-box li h4 {margin: 0 0 20px;}

.ems-area article {position: relative; z-index: -2; padding: 0px 40px; text-align: center; border: 4px solid #ccc; max-width: 1000px; margin: 60px auto 0; width: 100%;}
.ems-area article > div {position: relative; padding: 30px 0; background: #fff;}
.ems-area article > div::before {position: absolute; content: ''; left: 0; top: 50%; width: 100%; background: #fff; height: calc(100% + 10px); z-index: -1; transform: translateY(-50%);}
.ems-area article img {display: block; margin: 0 auto;}
.ems-area article p {white-space: pre-line; font-weight: 500;}
.ems-area article p.tit {display: inline-block; padding: 5px 12px; margin: 15px 0; background: #ffbf4f;}


@media screen and (max-width: 1200px) {
.imp-plus-area5 .tit::before {width: 80px; height: 4px; top: -15px; transform: none; left: 0;}
}

@media screen and (max-width: 1024px) {
.imp-plus-area2 ul.flex .txt p {padding-left: 15px;}
.imp-plus-area2 ul.flex .txt p::before {top: 10px;}
}

@media screen and (max-width: 900px) {
.imp-plus-area1 ul.flex > li {width: 50%;}
.imp-plus-area1 ul.flex > li > div {padding: 30px 0 0 0; border: 2px solid #333;}
.imp-plus-area1 ul.flex > li:last-child > div {border: 2px solid #ffbf4f;}
.imp-plus-area1 ul.flex .img {height: 200px;}
.imp-plus-area1 ul.flex .img img {width: 25%;}
.imp-plus-area1 ul.flex > li:nth-child(2) .img img {width: 30%;}
.imp-plus-area1 ul.flex > li:nth-child(3) .img img {width: 35%;}
.imp-plus-area1 ul.flex .img::before,
.imp-plus-area1 ul.flex .img::after {display: none;}
}

@media screen and (max-width: 769px) {
.imp-plus-area1 ul.flex .img {height: 140px;}

.imp-plus-area2 ul.flex {max-width: 600px; margin: 0 auto; width: 100%;}
.imp-plus-area2 ul.flex > li {width: 100%;}
.imp-plus-area2 ul.flex .img {text-align: center;}
.imp-plus-area2 ul.flex .txt {height: auto; padding: 30px 10px;}

.imp-plus-area4 table {border-spacing: 2px;}

.imp-plus-area7 .basic-box li h4 {margin: 30px 0 10px;}

.ems-area article {margin-top: 40px;}
}

@media screen and (max-width: 600px) {
	
}

@media screen and (max-width: 425px) {
.imp-plus-area1 ul.flex > li > div {padding: 20px 0 0 0; border: 1px solid #333;}
.imp-plus-area1 ul.flex .img {height: 80px;}
.imp-plus-area1 ul.flex .txt p {margin-top: 5px;}
.imp-plus-area1 ul.flex article {margin-top: 20px;}

.imp-plus-area2 ul.flex .tit {padding: 12px 10px;}
.imp-plus-area2 ul.flex .txt p {padding-left: 12px;}
.imp-plus-area2 ul.flex .txt p::before {top: 7px;}

.imp-plus-area5 {padding: 80px 0 !important;}
.imp-plus-area5 .tit {margin-bottom: 20px;}
.imp-plus-area5 .tit::before {width: 50px; height: 3px;}

.imp-plus-area6 ul.flex {flex-direction: column; max-width: 300px; margin: 0 auto;}
.imp-plus-area6 ul.flex > li:nth-child(2) > div {margin: 40px 0; transform: rotate(90deg);}

.ems-area article {padding: 0 20px;}
.ems-area article img {max-width: 220px;}
}