@charset "UTF-8";

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 10px; }
body { color: #111;  font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; font-size: 1.6rem; line-height: 1.6; -webkit-text-size-adjust: 100%;}
img { max-width: 100%; border: 0; vertical-align: top; transition: all .3s ease; -ms-interpolation-mode: bicubic; }
button { background: transparent; border: none; appearance: none; cursor: pointer; outline: none; }
a { transition: all .3s ease; }
a:link { color: #; text-decoration: none; }
a:visited { color: #; text-decoration: none; }
a:hover { color: #; text-decoration: underline; }
a:hover img { opacity: 0.8; }

/* --------------------------------------------------
  汎用クラス
-------------------------------------------------- */

.d-block { display: block; }
.d-flex { display: flex; }
.d-none { display: none; }
.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.clearfix::after { content: ''; display: block; clear: both; }

/* --------------------------------------------------
  header
-------------------------------------------------- */
.header{
  width: 1360px;
  max-width: 90%;
  /*
  width: 100%;
  max-width: 1360px;
  */
  background: white;
  border-radius: 10px;
  padding: 20px 25px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: fixed;
  top: 40px;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 999;
  box-shadow: 0 0 8px #005bac;
}
.header strong{
  display: block;
}
.header h1 , .header strong a{
  font-size: 1.6rem;
}
h1 a , .header strong a{
  display: flex;
}
h1 a img , .header strong a img{
  width: 200px;
}
#globalNavi{
  display: flex;
}
#globalNavi ul{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
}
#globalNavi li{
  list-style: none;
}
#globalNavi .border-none{
  border: none;
  padding: 0;
}
#globalNavi a { color: #106cc6; font-size: 18px; position: relative; }
#globalNavi a::after { content: ''; width: 0; height: 2px; background: #106cc6; display: block; position: absolute; left: 0; bottom: -2px; transition: all .3s; }
#globalNavi a:hover { text-decoration: none; }
#globalNavi a:hover::after { width: 100%; }



.header-button{
  display: none;
}
/* --------------------------------------------------
  動画
-------------------------------------------------- */

#s01 video { width: 100%; height: auto; }
#s01 .pc { display: block; }
#s01 .sp { display: none; }

@media screen and (max-width: 767px) {
  #s01 .pc { display: none; }
  #s01 .sp { display: block; }
}

/* --------------------------------------------------
  新着情報
-------------------------------------------------- */

#s02 { padding: 120px 40px; }
#s02 .inner { margin: 0 auto; max-width: 1000px; }
#s02 .d-flex { display: flex; justify-content: space-between; gap: 80px; }
#s02 .title { margin-bottom: 120px; line-height: 1.2; display: flex; flex-direction: column; }
#s02 .title h2 { color: #106cc6; font-size: 3.8rem; white-space: nowrap; }
#s02 .title div { color: #96c4dd; font-size: 2.8rem; }
#s02 #news-list { width: 750px; }
#s02 #news-list ul { margin-bottom: 30px; border-top: solid 1px #ccc; list-style: none; }
#s02 #news-list li { padding: 20px; border-bottom: solid 1px #ccc; }
#s02 #news-list .meta { margin-bottom: 10px; display: flex; gap: 10px; align-items: center; }
#s02 #news-list .meta time {}
#s02 #news-list .meta span { padding: 2px 20px; background: #fff100; border-radius: 100vw; display: inline-block; }
#s02 #news-list .button { display: flex; justify-content: center; }
#s02 #news-list .button a { padding: 16px; min-width: 255px; background: #106cc6; border: solid 2px #106cc6; border-radius: 100vw; color: #fff; display: flex; align-items: center; justify-content: center; gap: 10px; transition: all .3s ease; }
#s02 #news-list .button a i { transition: all .3s; }
#s02 #news-list .button a:hover { background: #fff; color: #106cc6; text-decoration: none; }
#s02 #news-list .button a:hover i { transform: translateX(5px); }

@media screen and (max-width: 767px) {
  #s02 { padding: 80px 20px; }
  #s02 .d-flex { flex-direction: column; gap: 0; }
  #s02 .title { margin-bottom: 40px; }
  #s02 .title h2 { font-size: 2.8rem; }
  #s02 .title div { font-size: 2rem; }
  #s02 #news-list { width: 100%; }
}

/* --------------------------------------------------
  数字で見る野口印刷所
-------------------------------------------------- */

#s03 { padding: 120px 40px 50px; background: #106cc6; }
#s03 .inner { margin: 0 auto; max-width: 1200px; }
#s03 .title { margin-bottom: 20px; }
#s03 .title h2 { font-size: 3.8rem; line-height: 1.2; }
#s03 .title div { color: #96c4dd; font-size: 2.8rem; }
#s03 ul { list-style: none; display: flex; flex-wrap: wrap; justify-content: space-between; }
#s03 li { margin: 70px 0; padding: 40px 20px; width: 32%; background: #fff; color: #106cc6; text-align: center; position: relative; }
#s03 li:first-child { background: none; color: #fff; text-align: left; }
#s03 a { color: #106cc6; }
#s03 a:hover { text-decoration: none; }
#s03 h3 { margin-bottom: 20px; font-size: 3.2rem; font-weight: 500; position: relative; z-index: 2; }
#s03 .icon { margin: 0 auto; width: 180px; height: 180px; background: #fff; border-radius: 100vw; display: flex; align-items: center; justify-content: center; position: absolute; left: 0; right: 0; top: -90px; }
#s03 .icon img { margin-bottom: 60px; width: 50%; }
#s03 .data { display: flex; align-items: flex-end; justify-content: center; overflow: hidden; }
#s03 .data img { height: 200px; transition: all 1s; }
#s03 .data span { font-size: 3.2rem; font-weight: 500; }
#s03 .view { width: 40px; position: absolute; right: 15px; bottom: 15px; }
#s03 a:hover .data img { transform: rotateY(360deg); }
#s03 .modal { margin: 20px auto; padding: 20px 40px 0; width: 500px; background: #fff; border-radius: 20px; display: none; position: relative; }
#s03 .modal.on { display: block; }
#s03 .modal .title { margin-bottom: 10px; color: #106cc6; font-size: 2.4rem; }
#s03 .modal .title strong { color: #106cc6; font-size: 2.4rem; position: relative; z-index: 2; }
#s03 .modal .title strong::after { content: ''; width: 100%; height: 20px; background: rgba(255,241,0,.5); display: block; position: absolute; left: 0; bottom: 0; z-index: -1; }
#s03 .modal .title span { margin: 0 4px; font-size: 4.8rem; }
#s03 .modal .close { width: 50px; height: 50px; background: #fff; border-radius: 100vw; display: flex; align-items: center; justify-content: center; position: absolute; right: -50px; top: -50px; }
#s03 .modal .close::before, #s03 .modal .close::after { content: ''; width: 30px; height: 3px; background: #106cc6; display: block; position: absolute; }
#s03 .modal .close::before { transform: rotate(45deg); }
#s03 .modal .close::after { transform: rotate(-45deg); }
#overlay { height: 0; overflow: hidden; transition: all .3s; }
body.modal { overflow: hidden; }
body.modal #overlay { width: 100vw; height: 100vh; background: rgba(16,108,198,.95); display: flex; align-items: center; justify-content: center; position: fixed; left: 0; top: 0; z-index: 1000; }

@media screen and (max-width: 767px) {
  #s03 { padding: 80px 20px; }
  #s03 .title h2 { font-size: 2.8rem; }
  #s03 .title div { font-size: 2rem; }
  #s03 ul { flex-direction: column; gap: 100px; }
  #s03 li { margin: 0; width: 100%; }
  #s03 h3 { font-size: 2.8rem; }
  #s03 .icon { width: 150px; height: 150px; top: -75px; }
  #s03 .data img { height: 150px; }
  #s03 .data span { font-size: 2.8rem; font-weight: 500; }
  #s03 .modal { padding: 20px; width: 90%; border-radius: 10px; }
  #s03 .modal .close { width: 40px; height: 40px; right: 0; }
  #s03 .modal .close::before, #s03 .modal .close::after { width: 20px; }
}

/* --------------------------------------------------
  私たちの仕事
-------------------------------------------------- */

#s04 { padding: 120px 40px; background: #f2f2f2; }
#s04 .inner { margin: 0 auto; max-width: 1200px; }
#s04 .title { margin-bottom: 120px; line-height: 1.2; display: flex; flex-direction: column; }
#s04 .title h2 { color: #106cc6; font-size: 3.8rem; }
#s04 .title div { color: #96c4dd; font-size: 2.8rem; }
#s04 ol { list-style: none; display: flex; justify-content: space-between; }
#s04 li { width: 30%; background: #fff; }
#s04 section div { position: relative; }
#s04 figure div .no { width: 40%; position: absolute; left: 5%; bottom: 70%; }
#s04 figcaption { padding: 20px 20px 30px; }
#s04 h3 { margin-bottom: 20px; color: #106cc6; font-size: 3.6rem; font-weight: 500; line-height: 1.2; display: flex; flex-direction: column; align-items: center; }
#s04 h3::after { color: #96c4dd; font-size: 2.4rem; }
#s04 #s04-01_ h3::after { content: 'Sales'; }
#s04 #s04-02_ h3::after { content: 'Design'; }
#s04 #s04-03_ h3::after { content: 'Printing'; }

@media screen and (max-width: 767px) {
  #s04 { padding: 80px 20px; }
  #s04 .title h2 { font-size: 2.8rem; }
  #s04 .title div { font-size: 2rem; }
  #s04 ol { flex-direction: column; gap: 90px; }
  #s04 li { width: 100%; }
  #s04 h3 { font-size: 2.8rem; }
  #s04 h3::after { font-size: 2rem; }
  #s04 figure div .no{ width: 32%;}
}

/* --------------------------------------------------
  求人情報
-------------------------------------------------- */

#s05 { padding: 120px 40px; }
#s05 .inner { margin: 0 auto; max-width: 1200px; }
#s05 .title { margin-bottom: 60px; line-height: 1.2; display: flex; flex-direction: column; }
#s05 .title h2 { color: #106cc6; font-size: 3.8rem; }
#s05 .title div { color: #96c4dd; font-size: 2.8rem; }
#s05 .d-flex { display: flex; justify-content: space-between;  position: relative;}
/*#s05 .d-flex::after{ content: "※営業職の募集は終了いたしました"; width: 550px; color: red; font-size: 20px; text-align: center; position: absolute; bottom: -65px; right: 0; }*/
#s05 .d-flex .txt{ width: 550px; color: red; font-size: 20px; font-weight: bold; text-align: center; position: absolute; bottom: -65px; right: 0; }
#s05 section { padding: 40px 40px 120px; width: 100%; max-width: 550px; background: #e0edf5; border: solid 2px #106cc6; border-radius: 15px; position: relative; }
#s05 section:nth-child(2){ filter: grayscale(100%); }
#s05 section .title { margin-bottom: 40px; line-height: 1.2; display: flex; flex-direction: column; align-items: center; justify-content: center; }
#s05 section .title h3 { color: #106cc6; font-size: 3.6rem; font-weight: 500; }
#s05 section .title div { color: #96c4dd; font-size: 2.4rem; }
#s05 section ul { margin-left: 20px; }
#s05 section img { height: 280px; position: absolute; right: -20px; bottom: -20px; }
#s05 section .button { position: absolute; left: 0; bottom: 40px; }
#s05 section .button a { padding: 10px 20px; width: 280px; background: #106cc6; border-radius: 0 100vw 100vw 0; color: #fff; font-size: 2.8rem; display: flex; align-items: center; justify-content: center; gap: 10px; }
#s05 section:nth-child(2) .button a{ pointer-events: none; }
#s05 section .button a i { transition: all .3s; }
#s05 section .button a:hover { text-decoration: none; }
#s05 section .button a:hover i { transform: translateX(5px); }

@media screen and (max-width: 767px) {
  #s05 { padding: 80px 20px 100px; width: 100%; overflow: hidden; }
  #s05 .title { margin-bottom: 40px; }
  #s05 .title h2 { font-size: 2.8rem; }
  #s05 .title div { font-size: 2rem; }
  #s05 .d-flex { flex-direction: column; gap: 40px; }
  /*#s05 .d-flex::after{ width: 100%; bottom: -80px; }*/
  #s05 .d-flex .txt{ width: 100%; font-size: 18px; }
  #s05 section { padding: 20px 20px 100px; }
  #s05 section .title { margin-bottom: 20px; }
  #s05 section .title h3 { font-size: 2.8rem; }
  #s05 section .title div { font-size: 1.8rem; }
  #s05 section li:first-child br { display: none; }
  #s05 section img { height: 180px; }
  #s05 section .button { bottom: 20px; }
  #s05 section .button a  { width: 200px; font-size: 2rem; }
}



/* --------------------------------------------------
  フッター
-------------------------------------------------- */
#globalFooter{
  background: #106cc6;
}
#globalFooter .inner{
  width: 1200px;
  margin: 0 auto;
  padding: 90px 0px;
}
#globalFooter h2{
  font-size: 3.8rem;
  font-weight:normal ;
  color: white;
  margin-bottom: 3.0rem;
  position: relative;
}
#globalFooter h2::after{
  content: "";
  width: 354px;
  height: 2px;
  background-color: white;
  position: absolute;
  top: 50%;
  left: 14%;
}
#globalFooter .contact{
  display: flex;
  align-items: start;
  gap: 100px;
}
#globalFooter img{
  width: 75%;
  margin-bottom: 20px;
}
#globalFooter p{
  color: white;
  letter-spacing: 2px;
}
#globalFooter .tel{
  /*margin-top: 20px;*/
  display: flex;
  align-items: center;
  gap: 35px;
}
#globalFooter .telephone {
  font-size: 40px;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: 1;
}
#globalFooter .telephone .number{
  font-size: 4.8rem;
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: 4px;
}


#globalFooter .telephone .number a {
  color: #fff;
  pointer-events: none;
}
#globalFooter .telephone .number a:hover {
  text-decoration: none;
}


#globalFooter .telephone p{
  font-size: 3.8rem;
}

#globalFooter .button{
  display: none;
}


#globalFooter .button a{
  color: white;
  text-decoration: none;
  border: solid white 2px;
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 20px;
}
#globalFooter .button a::before{
  content: "";
  width: 50px;
  height: 50px;
  background: url(/img/common/mail-01.png) no-repeat left center / contain;
}
#globalFooter .button a:hover{
  background-color: #96c4dd;
}

/*
#globalFooter .button a{
  color: white;
  text-decoration: none;
  border: solid white 2px;
  padding: 20px 20px 20px 90px;
  position: relative;
}
#globalFooter .button .mail::before{
  content: "";
  width: 50px;
  height: 50px;
  background: url(../img/common/mail-01.png) no-repeat center / contain;
  position: absolute;
  left: 20px;
  bottom: 0;
}
#globalFooter .button a:hover{
  background-color: #96c4dd;
}
*/



.copyright{
  font-size: 16px;
  text-align: center;
  color: white;
  background: #106cc6;
  padding: 20px;
}

@media screen and (max-width: 767px) {
  /*
  #globalFooter .inner{
    width: 100%;
    padding: 60px 50px;
  }
  */
  #globalFooter .inner { padding: 40px 20px; width: 100%; }
  #globalFooter h2{
    font-size: 3.6rem;
    margin-bottom: 25px;
  }
  #globalFooter h2::after{
    width: 145px;
    top: 55%;
    left: 150px;
  }
  #globalFooter .contact{
    flex-direction: column;
    align-items: start;
    gap:0px;
  }
  #globalFooter img{
    width:200px;
    margin-bottom: 10px;
  }
  /*
  #globalFooter p{
    font-size: 1.8rem;
    letter-spacing: unset;
  }
  */
  #globalFooter p { letter-spacing: unset; }
  #globalFooter .tel{
    margin: 0;
  }
  /*
  #globalFooter .telephone {
    margin: 40px 0 0;
  }
  */
  #globalFooter .telephone { margin: 30px 0 30px; }
  #globalFooter .telephone .number{
    font-size: 3.8rem;
  }
  
  #globalFooter .telephone .number a {
    pointer-events: auto;
  }
  
  #globalFooter .telephone p{
    font-size: 2.8rem;
  }
  
  
  #globalFooter .button { display: none; }
  
  
  #globalFooter .button a{
    font-size: ;
    padding: 10px;
  }
  #globalFooter .button a::before {
  }
  
  /*
  #globalFooter .button a{
    font-size: 16px;
    padding: 10px 10px 10px 70px;
  }
  #globalFooter .button a::before{
    left: 10px;
    bottom: -10px;
  }
  */
  
  #globalFooter .copyright p{
    font-size: 11px;
  }
}



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

@media screen and (max-width: 768px) {
/* --------------------------------------------------
  header
-------------------------------------------------- */
.header{
  width: 360px;
  padding: 10px;
  background: white;
  align-items: center;
  flex-direction: row;
  justify-content: space-around;
  gap: 60px;
  top: 10px;
}
h1 a img , .header strong a img{
  width: 180px;
}
.header-button{
  display:flex;
  gap: 20px;
}
.header-button img{
  width: 50px;
}
#globalNavi{
  width: 100%;
  height: 100%;
  display: none;
  background:#106cc6;
  position: fixed;
  top: 130px;
  left: 0;
  z-index: 999;
}
#globalNavi ul{
  padding: 20px;
  flex-direction: column;
}
#globalNavi li{
  list-style: none;
  border: none;
}
#globalNavi a{
  color: white;
}
body.on #globalNavi{
  display: block;
}
/* --------------------------------------------------
  バーガーメニュー
-------------------------------------------------- */
.z{
  width: 50px;
  height: 50px;
  background:#106cc6;
  border-radius: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.a{
  width: 30px;
  height: 2px;
  background: white;
  border-radius: 5px;
  transition: .5s;
  position: absolute;
  top: 35%;
}
.b{
  width: 30px;
  height: 2px;
  background: white;
  border-radius: 5px;
  transition: .5s;
}
.c{
  width: 30px;
  height: 2px;
  background: white;
  border-radius: 5px;
  transition: .5s;
  position: absolute;
  bottom:35%;
}

body.on .a{
  width: 30px;
  height: 2px;
  background: white;
  transform: rotate(45deg);
  transition: .5s;
  position: absolute;
  top: auto;
}
body.on .b{
  display: none;
}
body.on .c{
  width: 30px;
  height: 2px;
  background: white;
  transform: rotate(-45deg);
  transition: .5s;
  position: absolute;
  bottom:auto;
}


}





/* --------------------------------------------------
  採用ボタン
-------------------------------------------------- */

#recruit-button { width: 160px; height: 160px; position: fixed; right: 20px; bottom: 50px; z-index: 999; }
#recruit-button a { width: 100%; height: 100%; background: #fff100; border-radius: 50%; color: #005bac; font-size: 1.8rem; font-weight: bold; text-align: center; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; }
#recruit-button a::after { content: ''; width: 50px; height: 50px; background: url(../img/common/mail-02.png) no-repeat center / contain; display: inline-block; }
#recruit-button a:hover { text-decoration: none; }
#recruit-button span { line-height: 1.2; display: block; }

@media screen and (max-width: 767px) {
  #recruit-button { width: 100px; height: 100px; bottom: 40px; }
  #recruit-button a { font-size: 1.2rem; gap: 5px; }
  #recruit-button a::after { width: 30px; height: 30px; }
}


/* --------------------------------------------------
  ページネーション
-------------------------------------------------- */
.bs-blog-contents-navi{
  display: flex;
  justify-content: space-around;
}
@media screen and (max-width: 767px) {
  .bs-blog-contents-navi{
    align-items: center;
    flex-direction: column;
    gap: 10px;
  }
}