@charset "UTF-8"; /* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
汎用
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kugiri_m02 {
    padding: 20px 0;
}

.main_area {
    overflow: hidden;
}

.indent {
    padding-left: 1em;
    text-indent: -1em;
    display: block;
}

.cmn_lt01 {
    letter-spacing: 1em;
}

.cmn_entry {
    margin-top: 5rem;
}

.cmn_entry a {
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46rem;
    margin: 0 auto;
    background: #2da5f0;
    min-height: 14rem;
    flex-direction: column;
}

.cmn_entry a span {
    display: block;
}

.cmn_entry a span.en {
    font-size: 4.6rem;
    letter-spacing: .06em;
    font-weight: 400;
    font-family: "Lora", serif;
}

.cmn_entry a span.ja {
    font-size: 1.6rem;
}

.hstyle-pageBasic-black {
  font-size: 4.5rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 2rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}

@media print, screen and (min-width: 768px) {
	  .hstyle-pageBasic-black {
    font-size: 3rem;
    margin-bottom: 30px;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
プロモ
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.page_promo {
    position: relative;
    margin-top: 7rem;
	min-height: 100px;
}

/*採用情報*/
.page-recruit .page_promo::after {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    background: url(../images/page/page_bg_all.jpg) repeat left top / 100%;
    width: 100%;
    height: 100%;
    mix-blend-mode: multiply;
}
/*取扱商品*/
.page-product .page_promo::after {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    background: url("../images/page/page_prod_bg.jpg") repeat left top / 100%;
    width: 100%;
    height: 100%;
    mix-blend-mode: multiply;
}

.page_promo .promo_inner .ttl_wrap {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    z-index: 1;
}

.page_promo .promo_inner .promo_ttl {
    font-size: 2em;
    text-align: center;
    line-height: 1.2;
}

.page_promo .promo_inner h1 .slug, .page_promo .promo_inner p .slug {
    font-family: "Lato", sans-serif;
    font-size: 6.8rem;
    display: block;
    margin-bottom: 6px;
    color: #fff;
    letter-spacing: .08em;
}

.page_promo .promo_inner h1 .ja, .page_promo .promo_inner p .ja {
    font-size: 2.2rem;
    letter-spacing: .08em;
    color: #fff;
}

.page_main_img {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    padding: 70px 0 40px;
    margin-bottom: 20px;
}

.page_main_img::before, .page_main_img::after {
    position: absolute;
    content: "";
    background: no-repeat 50% /contain;
}

.page_main_img img {
    border-radius: 20px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
採用情報
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.indent {
}

.rec_about {
    padding-bottom: 6rem;
}

.rec_about h2.main_ttl {
    font-size: 4.2rem;
    color: #009fe8;
    letter-spacing: .12em;
    text-align: center;
    margin-bottom: 35px;
}

.rec_about p.main_txt {
    text-align: center;
    font-weight: bold;
    font-size: 2rem;
    line-height: 2.5;
}

.rec_about p.img {
    text-align: center;
    margin-top: -13rem;
    position: relative;
    z-index: -1;
}

.rec_about p.img img {
}

.rec_reason {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.rec_reason .inner {
    counter-increment: ol_cnt;
    width: 100%;
    max-width: 1500px;
    justify-content: center;
    gap: 90px;
    margin: 0 auto 6rem;
}

.rec_reason .inner .img_area {
    width: 37%;
    max-width: 547px;
}

.rec_reason .inner .img_area p {
}

.rec_reason .inner .img_area p img {
}

.rec_reason .inner .txt_area {
    width: 50%;
    max-width: 694px;
}

.rec_reason .inner .txt_area h3.ttl {
    font-size: 3rem;
    line-height: 1.5;
    margin-bottom: 5rem;
    position: relative;
    padding-left: 9rem;
}

.rec_reason .inner .txt_area h3.ttl::before {
    position: absolute;
    content: "";
    background: no-repeat 50% / contain;
    width: 36px;
    height: 8.2rem;
    top: 0;
    left: 0;
}

.rec_reason .inner:nth-child(1) .txt_area h3.ttl::before {
    background-image: url(../images/page/recruit/num01.svg);
}

.rec_reason .inner:nth-child(2) .txt_area h3.ttl::before {
    background-image: url(../images/page/recruit/num02.svg);
}

.rec_reason .inner:nth-child(3) .txt_area h3.ttl::before {
    background-image: url(../images/page/recruit/num03.svg);
}

.rec_reason .inner .txt_area p.txt {
    max-width: 670px;
    line-height: 2;
}

.rec_info {
}

.rec_info .info_wrap {
    max-width: 940px;
    margin: 0 auto;
}

.rec_info .info_wrap h2.main_ttl {
    font-size: 3rem;
    text-align: center;
    margin-bottom: 5rem;
    letter-spacing: .06em;
}

.rec_info .info_wrap .box dl {
    display: flex;
}

.rec_info .info_wrap .box dl > * {
    padding: 3rem 0;
}

.rec_info .info_wrap .box dl dt {
    color: #2da5f0;
    font-weight: bold;
    border-bottom: 1px solid #2da5f0;
    width: 220px;
    display: flex;
    align-items: center;
}

.rec_info .info_wrap .box dl:first-child dt {
    border-top: 1px solid #2da5f0;
}

.rec_info .info_wrap .box dl dd {
    border-bottom: 1px solid #cccccc;
    line-height: 1.7;
    width: calc(100% - 220px);
}

.rec_info .info_wrap .box dl:first-child dd {
    border-top: 1px solid #cccccc;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
会社概要
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
section.gaiyo {
    padding: 13rem 7.5rem 4rem;
}

table.style-01 {
    width: 100%;
}

table.style-01 th, table.style-01 td {
    display: block;
}

table.style-01 th {
    color: #0b41a0;
    font-weight: bold;
    font-size: 2.8rem;
    text-align: left;
    border-bottom: 1px solid #0b41a0;
    padding: 3rem 0;
}

table.style-01 td {
    padding: 3rem 0;
    border-bottom: 1px solid #c8c8c8;
    font-size: 2.8rem;
}

table.style-01 dl:not(:first-of-type) {
    margin-top: 3rem;
}

table.style-01 dl dt {
    font-weight: bold;
    margin-bottom: .5rem;
}

table.style-01 dl dt::before {
    content: "■";
    color: #0b41a0;
}

table.style-01 dl dd p {
    line-height: 1.7;
}

table.style-01 dl dd a {
    color: #005bac;
    display: block;
}

table.style-01 ul li {
    position: relative;
    padding-left: 1.2em;
}

table.style-01 ul li::before {
    content: "■";
    color: #0b41a0;
    position: absolute;
    left: 0;
    top: 0;
}

ul.rinen {
    background: #fff;
    padding: 6rem 4rem;
    -webkit-box-shadow: 0px 0px 10px -4px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 0px 10px -4px rgba(0, 0, 0, 0.2);
    margin-top: 5rem;
}

ul.rinen li {
    font-family: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", YuMincho, "MS P明朝", "MS PMincho", serif;
}

ul.rinen li:not(:first-of-type) {
    margin-top: 2rem;
}

ul.rinen-bottom {
    margin-top: 7rem;
}

ul.rinen-bottom li {
    border-bottom: 1px solid #0b41a0;
    padding: 3rem 0;
}

ul.rinen-bottom .hstyle-rinen {
    color: #0b41a0;
    font-weight: bold;
    font-size: 3.3rem;
    margin-bottom: 1.5rem;
}

ul.rinen-bottom p {
    font-size: 2.7rem;
    line-height: 1.6;
}

section.enkaku {
    padding: 13rem 7.5rem 4rem;
}

/**********************************************************************

 * Media Query For PC

 ***********************************************************************/
@media print, screen and (min-width: 768px) {
    section.gaiyo {
        padding: 80px 50px 40px;
    }

    table.style-01 {
        max-width: 940px;
        margin: 0 auto;
    }

    table.style-01 th, table.style-01 td {
        display: table-cell;
    }

    table.style-01 th {
        font-size: 1.8rem;
        width: calc(220 / 940 * 100%);
        padding: 30px 0;
        vertical-align: top;
    }

    table.style-01 td {
        padding: 30px;
        font-size: 1.8rem;
    }

    table.style-01 dl:not(:first-of-type) {
        margin-top: 20px;
    }

    table.style-01 dl dt {
        font-weight: bold;
        margin-bottom: 5px;
        font-size: 1.8rem;
    }

    table.style-01 dl dt::before {
        content: "■";
        color: #0b41a0;
    }

    table.style-01 dl dd p {
        line-height: 1.7;
    }

    table.style-01 dl dd a {
        color: #005bac;
        display: block;
    }

    table.style-01 ul li {
        position: relative;
        padding-left: 1.2em;
    }

    table.style-01 ul li::before {
        content: "■";
        color: #0b41a0;
        position: absolute;
        left: 0;
        top: 0;
    }

    section.bg-gray .inner {
        max-width: 940px;
        margin: 0 auto;
    }

    ul.rinen {
        padding: 60px 40px;
        -webkit-box-shadow: 0px 0px 10px -4px rgba(0, 0, 0, 0.2);
        box-shadow: 0px 0px 10px -4px rgba(0, 0, 0, 0.2);
        margin-top: 30px;
    }

    ul.rinen li {
        font-size: 2.8rem;
        max-width: 500px;
        margin: 0 auto;
    }

    ul.rinen li:not(:first-of-type) {
        margin-top: 20px;
    }

    ul.rinen-bottom {
        margin-top: 60px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    ul.rinen-bottom li {
        border-bottom: none;
        border-left: 1px solid #0b41a0;
        padding: 15px 30px;
        width: 33.33%;
    }

    ul.rinen-bottom .hstyle-rinen {
        font-size: 2.2rem;
        margin-bottom: 10px;
    }

    ul.rinen-bottom p {
        font-size: 1.8rem;
        line-height: 1.6;
    }

    section.enkaku {
        padding: 100px 50px 40px;
    }
}

section.bg-gray {
    margin-top: 5rem;
    padding: 10rem 7.5rem 16rem;
    position: relative;
}

section.bg-gray::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: #f3f4f5;
    position: absolute;
    left: 0;
    top: 0;
    z-index: -1;
}
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
私たちの想い
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.msg_president {
    background: url("../images/page/message/japan.png") no-repeat right calc(50% - 52rem) bottom 40px / 759px 519px, url("../images/page/message/factory.png") no-repeat left 150px bottom 0 / 552px 170px;
    padding-bottom: 215px;
}

.msg_president h2.main_ttl {
    font-size: 4.2rem;
    letter-spacing: .12em;
    color: #009fe8;
    text-align: center;
    line-height: 1.9047619;
    margin-bottom: 25px;
}

.msg_president p.main_txt {
    text-align: center;
    margin-bottom: 45px;
    font-size: 2rem;
    line-height: 2.5;
}

.msg_president .name_wrap {
    font-family: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", YuMincho, "MS P明朝", "MS PMincho", serif;
    text-align: center;
    margin-right: 70px;
	font-weight: bold;
}

.msg_president .name_wrap p.com {
    font-size: 1.6rem;
}

.msg_president .name_wrap p.names {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    margin-top: -5px;
    margin-left: 25px;
}

.msg_president .name_wrap p.names .ceo {
    font-size: 1.8rem;
}

.msg_president .name_wrap p.names .name {
    font-size: 2.8rem;
    letter-spacing: .8em;
}

.msg_biz {
    background-image: linear-gradient( to top, rgba(80,180,240,0) 0%, rgba(80,180,240,.15) 30%, rgba(10,85,170,.15) 100% );
    padding: 180px 0 180px 120px;
}

.msg_biz h2.main_ttl {
    font-size: 3.4rem;
    letter-spacing: .12em;
    color: #009fe8;
    margin-bottom: 30px;
    line-height: 1.823529;
}

.msg_biz p.main_txt {
    letter-spacing: .12em;
    line-height: 2.5;
    max-width: 870px;
    font-size: 2rem;
    margin-bottom: 155px;
}

.msg_biz .box h2.main_ttl02 {
    color: #009fe8;
    font-size: 4.4rem;
    letter-spacing: .12em;
    text-align: center;
    margin-bottom: 60px;
}

.msg_biz .box .biz_box {
    position: relative;
    width: 90rem;
    height: 97.4rem;
}

.msg_biz .box .biz_box .biz_model {
    width: 62.2rem;
    height: 62.2rem;
    position: absolute;
    border-radius: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    background: #fff;
}

.msg_biz .box .biz_box .biz_model::after {
	position: absolute;
	content: "";
	background: url("../images/page/message/biz_model.png") no-repeat 50% / contain;
	width: 12.8rem;
	height: 20.2rem;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.msg_biz .box .biz_box p.biz_ttl {
    width: 24.7rem;
    height: 24.7rem;
    position: absolute;
    border-radius: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    background: #009fe8;
    font-size: 2.5rem;
    letter-spacing: .06em;
    line-height: 1.6;
    text-align: center;
}

.msg_biz .box .biz_box p.biz_ttl.biz_ttl01 {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.msg_biz .box .biz_box p.biz_ttl.biz_ttl02 {
    top: 25%;
    right: 0;
    transform: translateY(-25%);
}

.msg_biz .box .biz_box p.biz_ttl.biz_ttl03 {
    bottom: 25%;
    right: 0;
    transform: translateY(25%);
}

.msg_biz .box .biz_box p.biz_ttl.biz_ttl04 {
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

.msg_biz .box .biz_box p.biz_ttl.biz_ttl05 {
    bottom: 25%;
    left: 0;
    transform: translateY(25%);
}

.msg_biz .box .biz_box p.biz_ttl.biz_ttl06 {
    top: 25%;
    left: 0;
    transform: translateY(-25%);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
プライバシーポリシー
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.page_privacy p.main_lead {
    margin-bottom: 130px;
}

.page_privacy .box {
    margin-bottom: 40px;
}

.page_privacy .box h3.ttl {
    color: var(--theme_m_color);
    font-size: 2.8rem;
    font-weight: 700;
    margin-bottom: 10px;
}

.page_privacy .box p {
    padding-left: 26px;
    margin-bottom: 15px;
    line-height: 2;
}

.page_privacy ul.indent {
    padding-left: 26px;
    margin-bottom: 0;
}

.page_privacy ul.indent li {
    text-indent: -1em;
    padding-left: 1em;
    margin-bottom: 0;
    line-height: 2;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
404
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.page_promo.letter404 {
    padding-top: 212px;
}

.page_promo.letter404::after {
    width: 35vw;
    top: 85%;
}

@media (min-width: 751px) and (max-width: 1800px) {
    .page_promo.letter404::after {
        right: calc(50% - 888px);
        z-index: -1;
    }
}

.page_promo.letter404 .promo_inner h1 .slug {
    font-size: 11rem;
}

.page_404 h2 {
    font-size: 4.2rem;
    text-align: center;
    margin-bottom: 32px;
}

.page_404 p.txt {
    font-size: 2.2rem;
    letter-spacing: .1em;
    text-align: center;
    line-height: 2.25;
    margin-bottom: 65px;
}

.page_404 p.btn a {
    margin: 0 auto;
    text-align: center;
}

.page_404 p.btn a:hover {
    background: #00a99d;
    color: #fff;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
サイトマップ
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
section.sitemap {
  padding: 8rem 7.5rem 0;
}

.wrap-sitemap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.wrap-sitemap .box {
  width: 49%;
}
.wrap-sitemap .box a.parent {
  width: 100%;
  border: 1px solid #0b41a0;
  color: #0b41a0;
  font-weight: bold;
  font-size: 2.3rem;
  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;
  height: 8rem;
  padding: 1rem;
  margin-top: 2rem;
}
.wrap-sitemap .box a.child {
  font-size: 2.2rem;
  display: block;
  margin-top: 1.6rem;
  position: relative;
  padding-left: 2.4rem;
}
.wrap-sitemap .box a.child::before, .wrap-sitemap .box a.child::after {
  position: absolute;
  top: 1rem;
  bottom: 0;
  left: 0;
  content: "";
  vertical-align: middle;
}
.wrap-sitemap .box a.child::before {
  left: 0;
  width: .6rem;
  height: .6rem;
  border-top: 2px solid #0b41a0;
  border-right: 2px solid #0b41a0;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media print, screen and (min-width: 768px) {
  section.sitemap {
    padding: 120px 50px 0;
    max-width: 790px;
    margin: 0 auto;
  }

  .wrap-sitemap .box {
    width: calc(380 / 790 * 100%);
  }
  .wrap-sitemap .box a.parent {
    width: 100%;
    border: 1px solid #0b41a0;
    color: #0b41a0;
    font-weight: bold;
    font-size: 18px;
    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;
    height: 60px;
    padding: 10px;
    margin-top: 20px;
    position: relative;
  }
  .wrap-sitemap .box a.parent:hover {
    background: #0b41a0;
    color: #fff;
  }
  .wrap-sitemap .box a.parent:hover::before {
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
  .wrap-sitemap .box a.parent::before, .wrap-sitemap .box a.parent::after {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
  }
  .wrap-sitemap .box a.parent::before {
    right: 22px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #0b41a0;
    border-right: 2px solid #0b41a0;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .wrap-sitemap .box a.parent.no-arrow {
    margin-bottom: 20px;
    pointer-events: none;
  }
  .wrap-sitemap .box a.parent.no-arrow::before, .wrap-sitemap .box a.parent.no-arrow::after {
    display: none;
  }
  .wrap-sitemap .box a.child {
    font-size: 14px;
    display: block;
    margin-top: 6px;
    position: relative;
    padding-left: 15px;
  }
  .wrap-sitemap .box a.child:hover {
    text-decoration: underline;
  }
  .wrap-sitemap .box a.child::before, .wrap-sitemap .box a.child::after {
    position: absolute;
    top: 10px;
    bottom: 0;
    left: 0;
    margin: 0;
    content: "";
    vertical-align: middle;
  }
  .wrap-sitemap .box a.child::before {
    left: 0;
    width: 6px;
    height: 6px;
    border-top: 2px solid #0b41a0;
    border-right: 2px solid #0b41a0;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
}

@media print, screen and (max-width: 768px) {
	.wrap-sitemap .box a.child{
		font-size: 2rem;
		
	}
	
	.wrap-sitemap .box a.child::before{
		width: 1rem;
		height: 1rem;
	}
}
