@charset "UTF-8";
@import url("https://fonts.googleapis.com/css?family=Noto+Serif+JP:400,600");
/*--------------- ▽ 変数設定 ▽ ---------------*/
/*メインカラー*/
/*フォント*/
/*--------------- △ 変数設定 △ ---------------*/
/*--------------- ▽ header ▽ ---------------*/
.header h1 span {
  display: block;
}
.header-logo {
  display: block;
  width: min(70vw, 350px);
}
.header-logo:hover {
  opacity: 0.7;
}
.header-inner {
  padding: 2%;
  box-sizing: border-box;
}

/*--------------- △ header △ ---------------*/
/*--------------- ▽ footer ▽ ---------------*/
.footer {
  border-top: 5px solid #ff5403;
}
.footer-logo {
  display: block;
  text-align: center;
  margin: 0 auto 5%;
  width: -moz-fit-content;
  width: fit-content;
  width: min(80%, 350px);
}
.footer-logo:hover {
  opacity: 0.7;
}
.footer-wrap {
  padding: 5% 0;
  box-sizing: border-box;
  margin: 0 auto;
}
.footer-tel-wrap {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 30px;
}
.footer-link-list {
  gap: 15px;
  flex-wrap: wrap;
  justify-content: center;
}
.footer-link-item img{
  height: 25px;
}
.footer-link-item:nth-child(1) {
  width: 100%;
}
.footer-mail-btn {
  width: 70%;
  margin: 0 auto;
}
.footer #copyright {
  text-align: center;
  padding: 5px 0;
  color: #ff5403;
  line-height: 1.2;
}
.footer #copyright small {
  color: #ff5403;
  font-size: 1rem;
}
.footer #copyright small a {
  color: #ff5403;
}

/*-------------------
nav
---------------------*/
.footer-nav {
  background: #ff5403;
  padding: 15px 0;
  box-sizing: border-box;
}
.footer-nav-item {
  border-right: 1px solid #fff;
}
.footer-nav-item:last-child {
  border: none;
}
.footer-nav-link {
  padding: 0 15px;
  box-sizing: border-box;
}
.footer-nav-link span {
  color: #fff;
}
.footer-nav-link:hover {
  opacity: 0.7;
}

/*--------------- △ footer △ ---------------*/
/*--------------- ▽ top-page ▽ ---------------*/
/*--------------- ▼ main-visual ▼ ---------------*/
.mv-img img {
  display: block;
  width: 100%;
}

/*--------------- ▲ main-visual ▲ ---------------*/
.top-section {
  padding: 20% 0;
  box-sizing: border-box;
}

/*--------------- ▼ top ▼ ---------------*/
/*-----------------
Greeting
-------------------*/
.top-greeting {
  overflow: hidden;
}
.top-greeting-wrap {
  display: block;
}
.top-greeting-text {
  margin-bottom: 40px;
}
.top-greeting-text-wrap {
  position: relative;
}
.top-greeting-text-wrap::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 150px;
  height: 100px;
  background-size: contain;
  bottom: 0;
  margin: auto;
  right: 0;
}
.top-greeting-more {
  margin: 0 auto 10%;
}
.top-greeting-img {
  position: relative;
  order: 1;
  margin: 0 auto;
}
.top-greeting-img .img:nth-of-type(1) {
  width: min(65%, 300px);
  height: min(40vw, 200px);
  z-index: 1;
  margin: 0 0 0 auto;
}
.top-greeting-img .img:nth-of-type(2) {
  width: min(60%, 250px);
  height: min(35vw, 150px);
  top: -50px;
  z-index: 0;
  margin: 0 auto 0 0;
}

/*-----------------
Movie
-------------------*/
.top-movie {
  position: relative;
  background: #ff5403;
  padding: 0 0 20%;
  box-sizing: border-box;
  overflow: hidden;
}
.top-movie::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 30px;
  background: #fff;
  left: 0;
  margin: auto;
  right: 0;
  top: 0;
}
.top-movie .inbox {
  position: relative;
}
.top-movie .inbox::before {
  position: absolute;
  content: "";
  background: url(../img/top/movie-deco-l.png) no-repeat;
  background-size: contain;
  width: 100px;
  height: 100px;
  top: 50px;
  left: 0;
  margin: auto;
}
.top-movie .inbox::after {
  position: absolute;
  content: "";
  background: url(../img/top/movie-deco-r.png) no-repeat;
  background-size: contain;
  width: 100px;
  height: 100px;
  bottom: -50px;
  right: 0;
  margin: auto;
}
.top-movie-ttl {
  text-align: center;
  margin: 0 auto 30px;
}
.top-movie-ttl .ttl-en {
  margin: 0 auto 30px;
}
.top-movie-ttl .ttl-ja {
  position: relative;
  color: #fff;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
  padding: 0 40px;
  box-sizing: border-box;
  margin: 0 auto;
}
.top-movie-ttl .ttl-ja::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco02.png) no-repeat;
  background-size: contain;
  width: 20px;
  height: 50px;
  bottom: 0;
  left: 0;
  margin: auto;
  top: 0;
}
.top-movie-ttl .ttl-ja::after {
  position: absolute;
  content: "";
  background: url(../img/common/deco02.png) no-repeat;
  background-size: contain;
  width: 20px;
  height: 50px;
  bottom: 0;
  right: 0;
  margin: auto;
  top: 0;
  transform: scale(-1, 1);
}
.top-movie-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  z-index: 1;
  max-width: 700px;
  margin: 0 auto;
}
.top-movie-wrap iframe {
  width: 100%;
  height: 100%;
  border: 7px solid #fff;
  box-sizing: border-box;
}

/*-----------------
Service
-------------------*/
.top-service {
  padding: 20% 0 25%;
}
.top-service-text-wrap {
  display: block;
  margin-bottom: 10%;
}
.top-service-list {
  display: block;
  margin: 0 auto;
}
.top-service-item {
  width: min(100%, 400px);
  margin: 0 auto 5%;
}
.top-service-item:last-child {
  margin: 0 auto;
}
.top-service-item figure {
  width: 100%;
  display: flex;
}
.top-service-item .img {
  width: 40%;
  height: 100px;
}
.top-service-item figcaption {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60%;
  background: #ff5403;
  color: #fff;
  font-size: 1.7rem;
  font-weight: 500;
  text-align: center;
  padding: 10px;
  box-sizing: border-box;
  border-bottom: 5px solid #fff323;
  line-height: 1.5;
}
.top-service-item:nth-child(odd) .img {
  order: 2;
}
.top-service-item:nth-child(odd) figcaption {
  order: 1;
}

/*-----------------
top-bnr
-------------------*/
.top-bnr {
  padding: 0;
}
.top-bnr-list {
  display: block;
}
.top-bnr-item {
  width: 100%;
  height: min(50vw, 350px);
  transition: all 0.3s ease;
  position: relative;
}
.top-bnr-item::before {
  position: absolute;
  content: "";
  background: url(../img/common/arw01-wh.png) no-repeat;
  width: 11px;
  height: 12px;
  bottom: 15px;
  margin: auto;
  right: 15px;
}
.top-bnr-item:nth-child(1) {
  background: url(../img/top/bnr-img01.jpg) no-repeat center center/cover;
}
.top-bnr-item:nth-child(2) {
  background: url(../img/top/bnr-img02.jpg) no-repeat center center/cover;
}
.top-bnr-item .ttl .ttl-ja {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 15px auto 0;
}
.top-bnr-item .link {
  position: relative;
  width: 100%;
  height: 100%;
}

/*-----------------
Joinus
-------------------*/
.top-recruit {
  background: url(../img/common/deco-top01.png) no-repeat right top/contain, url(../img/common/deco-top02.png) no-repeat left top/contain;
}
.top-recruit-wrap {
  position: relative;
  display: block;
}
.top-recruit-wrap::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 257px;
  height: 161px;
  bottom: -50px;
  left: -200px;
  margin: auto;
}
.top-recruit-ttl .ttl-en .deco {
  white-space: nowrap;
}
.top-recruit-textbox {
  position: relative;
  display: block;
  box-sizing: border-box;
  text-align: center;
}
.top-recruit-text {
  margin-bottom: 40px;
}
.top-recruit-btn-list {
  gap: 20px;
}
.top-recruit-btn-item {
  width: 47%;
}
.top-recruit-btn-item .link {
  width: 100%;
  min-width: auto;
}
.top-recruit-img {
  position: relative;
  width: min(100%, 500px);
  height: min(50vw, 350px);
  margin: 0 auto 8%;
}

/*-----------------
お知らせ
-------------------*/
.top-news-ttl {
  display: block;
  margin-bottom: 8%;
}
.top-news .inbox {
  position: relative;
}
.top-news-more {
  margin: 0 auto;
}
.top-news .news-list {
  margin-bottom: 10%;
}

/*--------------- ▲ top ▲ ---------------*/
/*--------------- ▽ sub-page ▽ ---------------*/
.sub-section {
  padding: 20% 0;
  box-sizing: border-box;
  position: relative;
}

/*--------------- ▼ sub-visual ▼ ---------------*/
.sv {
  position: relative;
  width: 100%;
  height: min(50vw, 300px);
}
.sv::before {
  position: absolute;
  content: "";
  background: #ffca03;
  width: min(25vw, 200px);
  height: 100%;
  bottom: 0;
  left: 0;
  margin: auto;
  top: 0;
  -webkit-clip-path: polygon(0 0, 40% 0, 100% 100%, 0% 100%);
          clip-path: polygon(0 0, 40% 0, 100% 100%, 0% 100%);
}
.sv::after {
  position: absolute;
  content: "";
  background: url(../img/sv/sv-deco.png) no-repeat;
  background-size: contain;
  width: 150px;
  height: 100px;
  bottom: 30px;
  left: 0;
  margin: auto;
}
.svbox {
  width: 100%;
  max-width: 1380px;
  margin: 0 auto;
}
.sv-ttl {
  text-align: left;
  margin: 0 auto 0 6%;
  z-index: 1;
  white-space: nowrap;
}

/*---------------------
各ページの画像設定
-----------------------*/
.sv-concept {
  background: url(../img/sv/sv-concept-bg.jpg) no-repeat center center/cover;
}

.sv-product {
  background: url(../img/sv/sv-product-bg.jpg) no-repeat center center/cover;
}

.sv-recruit {
  background: url(../img/sv/sv-recruit-bg.jpg) no-repeat center center/cover;
}

.sv-company {
  background: url(../img/sv/sv-company-bg.jpg) no-repeat center center/cover;
}

.sv-service {
  background: url(../img/sv/sv-service-bg.jpg) no-repeat center center/cover;
}

.sv-news {
  background: url(../img/sv/sv-news-bg.jpg) no-repeat center center/cover;
}

.sv-contact {
  background: url(../img/sv/sv-contact-bg.jpg) no-repeat center center/cover;
}

.sv-complete {
  background: url(../img/sv/sv-complete-bg.jpg) no-repeat center center/cover;
}

.sv-site {
  background: url(../img/sv/sv-site-bg.jpg) no-repeat center center/cover;
}

.sv-privacy {
  background: url(../img/sv/sv-privacy-bg.jpg) no-repeat center center/cover;
}

.sv-notfound {
  background: url(../img/sv/sv-notfound-bg.jpg) no-repeat center center/cover;
}

/*--------------- ▼ ぱんくず ▼ ---------------*/
#bread-clumb {
  width: 100%;
  position: relative;
  margin: 0 auto;
  padding: 2% 0;
  z-index: 100;
  line-height: 1;
}
#bread-clumb li {
  position: relative;
  color: #000000;
  font-size: 14px;
  float: left;
  margin-right: 20px;
}
#bread-clumb li:after {
  content: ">";
  position: absolute;
  display: block;
  right: -15px;
  top: 0;
}
#bread-clumb li:last-child {
  margin-right: 0;
}
#bread-clumb li:last-child:after {
  display: none;
}
#bread-clumb li a {
  color: #000000;
  border-bottom: 1px solid;
  display: block;
}
#bread-clumb li a:hover {
  opacity: 0.7;
}

/*--------------- ▲ ぱんくず ▲ ---------------*/
/*--------------- ▼ sub02_concept ▼ ---------------*/
/*---------------------
Philosphy
-----------------------*/
.concept-c {
  padding: 20% 0 0;
  overflow: hidden;
}
.concept-philosphy-ttl{
  margin: 0 auto 20%;
}
.concept-philosphy-list{
  width: 90%;
  margin: 0 auto;
}
.concept-philosphy-item{
  position: relative;
  padding: 5%;
  color: #fff;
  font-size: 1.5rem;
  background: #ff5403;
  margin: 0 auto 15%;
}
.concept-philosphy-item:last-child{
  margin: 0 auto;
}

.concept-philosphy-item::after{
  position: absolute;
  content: "";
  background:url(../img/common/pat03.png)repeat;
  width: 100%;
  height: 100%;
  right: 5px;
  bottom: 5px;
  margin: auto;
  z-index: -1;
  opacity: 0.8;
}
.concept-philosphy-item .wrap{
  display: block;
}
.concept-philosphy-item .img{
  position: relative;
  margin-top: -70px;
  width: min(80%,400px);
  aspect-ratio: 91 / 58;
  display: block;
  margin: -50px auto 5%;

}
.concept-philosphy-item .text{
  position: relative;
  font-weight: 500;
}

.concept-philosphy-item:nth-child(even){
  color: #333;
  background: #ffca03;
}
.concept-philosphy-item:nth-child(even) .img{
  order: 2;
}
.concept-philosphy-item:nth-child(even) .text{
  order: 1;
}
.concept-philosphy-item:nth-child(even)::after{
  left: 5px;
  right: auto;
  background:url(../img/common/pat02.png)repeat;
}
.concept-philosphy-item:nth-child(even) .text::before{
  position: absolute;
  content: "";
  background: url(../img/common/deco10.png)no-repeat;
  width: 100px;
  height: 60px;
  margin: auto;
  background-size: contain;
  right: 0;
  bottom: 0;
}
.concept-philosphy-item:nth-child(even) .text::after{
  position: absolute;
  content: "";
  background: url(../img/common/deco11.png)no-repeat;
  width: 80px;
  height: 100px;
  margin: auto;
  background-size: contain;
  left: -50px;
  bottom: 0;
}
.concept-philosphy-item:nth-child(odd) .text::after{
  position: absolute;
  content: "";
  background: url(../img/common/deco09.png)no-repeat;
  width: 150px;
  height: 100px;
  margin: auto;
  background-size: contain;
  right: -50px;
  bottom: 0;
}
/*---------------------
Philosphy
-----------------------*/
.concept-policy {
  overflow: hidden;
}
.concept-policy-img {
  width: min(90%, 400px);
  height: min(40vw, 280px);
  margin: 0 auto 5%;
}
.concept-policy-wrap {
  position: relative;
  display: block;
}
.concept-policy-wrap::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco03.png) no-repeat;
  background-size: contain;
  width: 250px;
  height: 200px;
  left: -200px;
  margin: auto;
  top: -150px;
  z-index: -1;
}
.concept-policy-text-wrap {
  position: relative;
}
.concept-policy-text-wrap::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  background-size: contain;
  width: 150px;
  height: 100px;
  bottom: -30px;
  margin: auto;
  right: 0;
}
.concept-policy-text {
  margin-top: 6%;
}

/*---------------------
Message
-----------------------*/
.concept-message {
  overflow: hidden;
  background: url(../img/common/deco-top03.png) no-repeat right top/80%, url(../img/common/deco-top02.png) no-repeat left top/100%;
}
.concept-message-wrap {
  display: block;
}
.concept-message-text-wrap {
  margin-bottom: 10%;
}
.concept-message-text{
  margin: 6% auto 0;
}
.concept-message-img {
  position: relative;
  margin: 0 auto;
  text-align: center;
}
.concept-message-img .img {
  position: relative;
  display: block;
  margin: 0 auto;
  text-align: center;
  width: min(80%, 350px);
}
.concept-message-img .img::after {
  position: absolute;
  content: "";
  background: url(../img/common/pat03.png) repeat;
  width: 100%;
  height: 100%;
  left: 10px;
  margin: auto;
  top: 10px;
}
.concept-message-img .img .img-wrap {
  display: block;
  position: relative;
  width: 100%;
  height: min(50vw, 250px);
  z-index: 1;
  margin: 0 auto;
  text-align: center;
}
.concept-message-img .img:nth-last-of-type(1) {
  left: -80px;
  top: 0;
  top: -50px;
  width: 70%;
}
.concept-message-img .img:nth-last-of-type(2) {
  z-index: 2;
}
.concept-message-text .name{
  text-align: right;
  margin-top: 5%;
}
.concept-message-text .name span{
  margin-right: 10px;
}
/*--------------- ▲ sub02_concept ▲ ---------------*/
/*--------------- ▼ sub03_service ▼ ---------------*/
/*---------------------
Service
-----------------------*/
.service-lead {
  position: relative;
}
.service-lead::before {
  position: absolute;
  content: "";
  background: #ffca03;
  width: 100%;
  height: 480px;
  bottom: 0;
  left: 0;
  margin: auto;
  right: 0;
  -webkit-clip-path: polygon(0 65%, 100% 0, 100% 100%, 0% 100%);
          clip-path: polygon(0 65%, 100% 0, 100% 100%, 0% 100%);
  z-index: -1;
}
.service-lead-text-wrap {
  display: block;
  margin: 0 auto 8%;
}
.service-lead-text {
  position: relative;
}

/*---------------------
当社の強み
-----------------------*/
.service-strengths {
  overflow: hidden;
}
.service-strengths-item {
  position: relative;
  margin-bottom: 10%;
  flex-wrap: wrap;
}
.service-strengths-item:last-child {
  margin-bottom: 0;
}
.service-strengths-item .img {
  width: min(75%, 340px);
  height: min(40vw, 220px);
  margin: 0 auto 5%;
  order: 2;
}
.service-strengths-item .text-wrap {
  width: 100%;
  margin: 0 auto 5%;
}
.service-strengths-item .ttl {
  font-size: 1.8rem;
  line-height: 1.5;
  border-bottom: 2px solid #ff5403;
  margin-bottom: 5%;
}
.service-strengths-item .ttl .text {
  padding-left: 15px;
}
.service-strengths-item .ttl .num {
  position: relative;
  width: 60px;
  height: 60px;
  background: #ff5403;
  color: #fff323;
  font-size: 2.2rem;
  padding: 15px 0 0 0;
  box-sizing: border-box;
}
.service-strengths-item .ttl .num::before {
  position: absolute;
  content: "Strengths";
  font-size: 1rem;
  color: #fff;
  bottom: 0;
  left: 0;
  margin: auto;
  right: 0;
  top: 10px;
  text-align: center;
}
.service-strengths-item:nth-child(even) .img {
  order: 2;
}
.service-strengths-item:nth-child(even) .text {
  order: 1;
}
.service-strengths-item:nth-child(1)::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco03.png) no-repeat;
  width: 250px;
  height: 200px;
  background-size: contain;
  left: -50px;
  margin: auto;
  top: -150px;
}
.service-strengths-item:nth-child(2)::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 200px;
  height: 150px;
  background-size: contain;
  right: -250px;
  margin: auto;
  top: -50px;
}
.service-strengths-item:nth-child(3)::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 250px;
  height: 200px;
  background-size: contain;
  left: -100px;
  margin: auto;
  top: -100px;
}
.service-strengths-item:nth-child(3)::after {
  position: absolute;
  content: "";
  background: url(../img/common/deco05.png) no-repeat;
  width: 150px;
  height: 100px;
  background-size: contain;
  right: -30px;
  margin: auto;
  bottom: -50px;
}

/*--------------- ▲ sub03_service ▲ ---------------*/
/*--------------- ▼ sub04_product ▼ ---------------*/
/*---------------------
一覧
-----------------------*/
.product {
  overflow: hidden;
}
.product-list {
  position: relative;
  gap: 30px 5%;
}
.product-list::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco03.png) no-repeat;
  width: 348px;
  height: 271px;
  left: -200px;
  margin: auto;
  top: -180px;
}
.product-list::after {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 257px;
  height: 161px;
  bottom: -50px;
  margin: auto;
  right: -100px;
}
.product-item {
  width: 47%;
}
.product-item .link {
  position: relative;
  bottom: 0;
}
.product-item .link:hover {
  bottom: 10px;
  opacity: 0.7;
}
.product-item .img {
  width: min(100%, 300px);
  height: min(28vw, 200px);
  margin-bottom: 15px;
}
.product-item .ttl {
  border-bottom: 1px solid #ff5403;
  font-size: 1.5rem;
  display: block;
  padding-bottom: 2%;
}
.product-item .ttl time {
  background: #ff5403;
  color: #fff;
  font-size: 1.2rem;
  line-height: 1;
  padding: 2px 5px;
  box-sizing: border-box;
  margin-right: 10px;
}
.product-item .ttl .text {
  display: block;
}


/*---------------------
詳細
----------------------*/
.product-post .product-post-container {
  display: block;
  padding: 7% 5%;
  box-sizing: border-box;
  background: #ffca03;
}
.product-post-img-container {
  margin-bottom: 7%;
  display: block;
}
.product-post-ttl{
  font-size: 1.8rem;
  display: block;
  padding-bottom: 10px;
  border-bottom: 1px solid #ff5403;
  margin-bottom: 30px;
  line-height: 1.6;
}
.product-post-ttl time{
  display: block;
  line-height: 1;
  padding: 5px 10px;
  box-sizing: border-box;
  color: #fff;
  background: #ff5403;
  font-size: 1.4rem;
  width: fit-content;
  margin-bottom: 10px;
}
.product-post-img-container .main-img {
  width: min(100%, 470px);
  height: min(50vw, 350px);
  margin-bottom: 6%;
}
.product-post-list {
  gap: 15px;
  width: 100%;
  max-height: 220px;
  overflow: auto;
}
.product-post-item {
  width: min(47%, 230px);
}
.product-post-item .img {
  width: 100%;
  height: min(25vw, 150px);
}
.product-post-textbox {
  display: block;
  padding: 30px;
  box-sizing: border-box;
  background: #fff;
  color: #000000;
}
/*--------------- ▲ sub04_product ▲ ---------------*/
/*--------------- ▼ sub05_recruit ▼ ---------------*/
/*---------------------
仕事内容
-----------------------*/
.recruit-work {
  overflow: hidden;
}
.recruit-work-item {
  flex-wrap: wrap;
  margin-bottom: 15%;
}
.recruit-work-item:last-child {
  margin-bottom: 0;
}
.recruit-work-item .img {
  width: min(80%, 400px);
  height: min(40vw, 200px);
  order: 2;
  margin: 0 auto;
}
.recruit-work-item .text-wrap {
  position: relative;
  order: 1;
}
.recruit-work-item .text {
  margin-bottom: 5%;
}
.recruit-work-item:nth-child(1) .text-wrap::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco03.png) no-repeat;
  background-size: contain;
  width: 257px;
  height: 161px;
  bottom: 0;
  right: -200px;
  margin: auto;
}
.recruit-work-item:nth-child(2) .text-wrap::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 257px;
  height: 161px;
  background-size: contain;
  bottom: 0;
  left: -200px;
  margin: auto;
  transform: scale(-1, 1);
}
.recruit-work-item:nth-child(3) .text-wrap::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 257px;
  height: 161px;
  background-size: contain;
  bottom: 0;
  right: -200px;
  margin: auto;
}
.recruit-work-item .list {
  margin-bottom: 30px;
}
.recruit-work-item .more-btn {
  margin: 0 auto 10%;
}

/*---------------------
働く魅力
-----------------------*/
.recruit-attractive {
  background: #ffca03;
  position: relative;
  padding: 0 0 15%;
}
.recruit-attractive::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 50px;
  background: #fff;
  left: 0;
  margin: auto;
  right: 0;
  top: 0;
}
.recruit-attractive-list {
  gap: 30px 5%;
  justify-content: center;
}
.recruit-attractive-item {
  width: 47%;
  background: #fff;
  padding: 5% 3%;
  box-sizing: border-box;
  text-align: center;
  margin: 0 auto;
}
.recruit-attractive-item .img {
  display: block;
  width: min(20vw, 150px);
  margin: 0 auto 5%;
}
.recruit-attractive-item figcaption {
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.5;
}

/*---------------------
求める人物像
-----------------------*/
.recruit-ideal {
  overflow: hidden;
}
.recruit-ideal-wrap {
  display: block;
}
.recruit-ideal-ttl .deco-line-right::before {
  content: none;
}
.recruit-ideal-img {
  width: min(100%, 400px);
  height: min(50vw, 250px);
  margin: 0 auto 5%;
}

/*---------------------
仕事内容
-----------------------*/
.recruit-summary {
  position: relative;
}
.recruit-summary::before {
  position: absolute;
  content: "";
  background: #ff5403;
  width: 100%;
  height: 100px;
  left: 0;
  margin: auto;
  right: 0;
  top: 0;
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
          clip-path: polygon(0 0, 100% 100%, 100% 0);
  z-index: -1;
}
.recruit-summary::after {
  position: absolute;
  content: "";
  background: #ffca03;
  width: 100%;
  height: 100px;
  left: 0;
  margin: auto;
  right: 0;
  top: 0;
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 0);
          clip-path: polygon(0 0, 0 100%, 100% 0);
  z-index: -2;
}
.recruit-summary-ttl .ttl-ja {
  color: #000000;
}
.recruit-summary-item {
  margin-bottom: 10%;
}
.recruit-summary-item:last-child {
  margin-bottom: 0;
}
.recruit-summary-item .ttl {
  font-size: 1.8rem;
  line-height: 1.4;
  margin-bottom: 5%;
}
.recruit-summary-item .ttl .ttl-wrap {
  position: relative;
  display: block;
  padding-left: 30px;
}
.recruit-summary-item .ttl .ttl-wrap::before {
  position: absolute;
  content: "";
  width: 15px;
  height: 15px;
  bottom: 0;
  left: 0;
  margin: auto;
  top: 0;
  background: #ff5403;
  border-radius: 50%;
}
.recruit-summary-item:nth-child(3n-1) .ttl .ttl-wrap::before {
  background: #ffca03;
}
.recruit-summary-item:nth-child(3n-1) .recruit-summary-table {
  border: #ffca03 1px solid;
}
.recruit-summary-item:nth-child(3n-1) .recruit-summary-table th {
  background: #ffca03;
  color: #000000;
}
.recruit-summary-item:nth-child(3n-1) .recruit-summary-table td {
  border-bottom: 1px solid #ffca03;
}
.recruit-summary-item:nth-child(3n) .ttl .ttl-wrap::before {
  background: #1eaa38;
}
.recruit-summary-item:nth-child(3n) .recruit-summary-table {
  border: #1eaa38 1px solid;
}
.recruit-summary-item:nth-child(3n) .recruit-summary-table th {
  background: #1eaa38;
}
.recruit-summary-item:nth-child(3n) .recruit-summary-table td {
  border-bottom: 1px solid #1eaa38;
}
.recruit-summary-table {
  position: relative;
  width: 100%;
  border: 1px solid #ff5403;
  font-size: 1.3rem;
}
.recruit-summary-table tbody, .recruit-summary-table tr {
  width: 100%;
}
.recruit-summary-table tr:last-of-type th {
  border: none;
}
.recruit-summary-table th {
  background: #ff5403;
  color: #fff;
  width: 35%;
  padding: 4% 3%;
  line-height: 1.5;
  box-sizing: border-box;
  border-bottom: 1px solid #fff;
  text-align: center;
  vertical-align: middle;
}
.recruit-summary-table td {
  width: 65%;
  padding: 4% 3%;
  line-height: 1.5;
  box-sizing: border-box;
  border-bottom: 1px solid #ff5403;
  background: #fff;
  vertical-align: middle;
}

/*--------------- ▲ sub04_recruit ▲ ---------------*/
/*--------------- ▼ sub05_company ▼ ---------------*/
/*---------------------

-----------------------*/
.company-info {
  overflow: hidden;
}
.company-info-table {
  position: relative;
  margin-bottom: 10%;
}
.company-info-table::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco01.png) no-repeat;
  width: 200px;
  height: 100px;
  background-size: contain;
  left: -100px;
  margin: auto;
  top: -150px;
  z-index: -1;
  transform: scale(-1, 1);
}
.company-info-table::after {
  position: absolute;
  content: "";
  background: url(../img/common/deco03.png) no-repeat;
  width: 348px;
  height: 271px;
  background-size: contain;
  right: -250px;
  margin: auto;
  bottom: -150px;
  z-index: -1;
}
.company-info-map-list {
  display: block;
}
.company-info-map-item {
  width: 100%;
  margin-bottom: 10%;
}
.company-info-map-item:last-child {
  margin-bottom: 0;
}
.company-info-map-item .ttl {
  font-size: 1.8rem;
  background: #ffca03;
  text-align: center;
  line-height: 1.5;
  padding: 3%;
  box-sizing: border-box;
  color: #fff;
  margin-bottom: 10px;
}
.company-info-map-item .map {
  width: 100%;
  height: 300px;
}
.company-info-map-item .map iframe {
  width: 100%;
  height: 300px;
}
.company-info-map-item:nth-child(2) .ttl {
  background: #1eaa38;
}

/*---------------------
沿革
-----------------------*/
.company-history {
  overflow: hidden;
  padding: 10% 0 0;
}
.company-history .maxbox {
  position: relative;
  background: #ffca03;
  width: 90%;
  padding: 110px 0 100px;
  box-sizing: border-box;
  top: -90px;
}
.company-history-ttl {
  z-index: 1;
}
.company-history-list {
  position: relative;
}
.company-history-list::before {
  position: absolute;
  content: "";
  background: url(../img/common/deco08.png) no-repeat;
  width: 271px;
  height: 127px;
  background-size: contain;
  bottom: -30px;
  margin: auto;
  right: -200px;
}
.company-history-list::after {
  position: absolute;
  content: "";
  background: url(../img/common/deco07.png) no-repeat;
  width: 300px;
  height: 200px;
  background-size: contain;
  top: -50px;
  margin: auto;
  left: -150px;
}
.company-history-item {
  position: relative;
  margin-bottom: 20px;
  background: #fff;
  padding: 3%;
  box-sizing: border-box;
  z-index: 1;
  font-weight: 500;
  display: block;
}
.company-history-item:last-child {
  margin-bottom: 0;
}
.company-history-item .day {
  color: #ff5403;
}

/*---------------------
よくあるご質問
-----------------------*/
.company-faq {
  padding: 0 0 100px;
}
.company-faq-ttl {
  display: block;
}
.company-faq-ttl .deco-line-left::before {
  right: max(30vw, 120px);
}
.company-faq-item {
  margin-bottom: 10%;
}
.company-faq-item:last-child {
  margin-bottom: 0;
}
.company-faq-q {
  background: #ffca03;
  padding: 15px 20px;
  line-height: 1.6;
  box-sizing: border-box;
}
.company-faq-q .icon {
  position: relative;
  display: block;
  padding-left: 50px;
}
.company-faq-q .icon::before {
  position: absolute;
  content: "Q";
  width: 30px;
  height: 30px;
  background: #fff;
  color: #ff5403;
  border-radius: 50px;
  text-align: center;
  line-height: 1.8;
  font-weight: 600;
  left: 0;
  margin: auto;
  top: 0;
}
.company-faq-a {
  padding: 15px 20px;
  line-height: 1.6;
  box-sizing: border-box;
}
.company-faq-a .icon {
  position: relative;
  display: block;
  padding-left: 50px;
}
.company-faq-a .icon::before {
  position: absolute;
  content: "A";
  width: 30px;
  height: 30px;
  background: #ff5403;
  color: #fff;
  border-radius: 50px;
  text-align: center;
  line-height: 1.8;
  font-weight: 600;
  left: 0;
  margin: auto;
  top: 0;
}

/*--------------- ▲ sub05_company ▲ ---------------*/
/*--------------- ▼ お知らせ ▼ ---------------*/
.post-wrp .tag-change {
  text-align: center;
  flex-wrap: nowrap;
  overflow-x: scroll;
  margin-bottom: 30px;
  justify-content: start;
}
.post-wrp .tag-change li {
  flex: 0 0 30%;
  margin: 2% 1% 0 0;
}
.post-wrp .tag-change li a {
  border: solid 1px #ff5403;
  padding: 5px 0;
  display: block;
  color: #ff5403;
  background: #fff;
  font-size: 3vw;
}
.post-wrp .tag-change .current a {
  background: #ff5403;
}
.post-wrp .tag-change .current a span {
  color: #fff;
}

/*タグ一覧
-------------------------------*/
.tag-select-box {
  position: relative;
  width: 40%;
  margin: 0 0 20px auto;
  max-width: 230px;
}
.tag-select-box:before {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 0;
  right: 0.8em;
  width: 0;
  height: 0;
  padding: 0;
  content: "";
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid #000000;
  pointer-events: none;
}
.tag-select-box #tag-select {
  width: 100%;
  padding: 5% 20% 5% 5%;
  box-sizing: border-box;
  font-size: 1.2rem;
  margin-left: auto;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  border: none;
  border-bottom: 2px solid #333;
  cursor: pointer;
  border-radius: 0;
  background: none;
  color: #333;
  font-weight: 700;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}
.tag-select-box #tag-select option {
  padding: 10px;
  box-sizing: border-box;
  cursor: pointer;
  box-sizing: border-box;
}

.post-wrp .tag-change {
  margin-bottom: 10%;
}
.post-wrp .tag-change li {
  text-align: center;
  margin: 10px 10px 0 0;
  min-width: 190px;
  display: inline-block;
  vertical-align: middle;
}
.post-wrp .tag-change li a {
  border: solid 1px #ff5403;
  color: #ff5403;
  background: #fff;
  padding: 10px 15px;
  display: block;
}
.post-wrp .tag-change .current a {
  background: #ff5403;
}
.post-wrp .tag-change .current a span {
  color: #fff;
}

/*詳細
-------------------------------*/
/*--------------- ▲ お知らせ ▲ ---------------*/
/*--------------- ▽ ドロワー ▽ ---------------*/
/*--------------- △ ドロワー △ ---------------*//*# sourceMappingURL=style_sp.css.map */