@charset "utf-8";


/*　　Home / メインイメージ
-------------------------------------------------------*/
.main-img {
	position: relative;
	height: 100vh;
	overflow: hidden;
}
.slider-box {
  margin: 0 calc(50% - 50vw);
  max-width: 100vw;
  position: relative;
  overflow: hidden;
}
.main-title {
	position: absolute;
	bottom: 5.5vw;
	left: 6vw;
	width: 32.25%;
	z-index: 20;
}
.main-design01 {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-image: url("../images/pages/main_design.png");
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: 100% auto;
	z-index: 10;
}
.main-design02 {
	position: absolute;
	bottom: 5.5vw;
	right: -5%;
	padding-right: 5%;
	width: 59%;
	height: 5.3vw;
	text-align: center;
	background-color: #333;
	-webkit-transform-origin: 0 0;
	-moz-transform-origin: 0 0;
	transform-origin: 0 0;
	-webkit-transform: skewX(-30deg);
	-moz-transform: skewX(-30deg);
	-ms-transform: skewX(-30deg);
	-o-transform: skewX(-30deg);
	transform: skewX(-30deg);
	z-index: 10;
}
.main-design02::after {
	content: "";
	position: absolute;
	bottom: 1vw;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(to right, #18a1a0, #d42f71);
}
.main-design02-txt {
	display: inline-block;
	padding-top: 1.5vw;
	color: #18a1a0;
	font-size: 1.5vw;
	line-height: 1;
	letter-spacing: 0.2em;
  background: linear-gradient(to right, #18a1a0, #d42f71);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
	
	-webkit-transform-origin: 0 0;
	-moz-transform-origin: 0 0;
	transform-origin: 0 0;
	-webkit-transform: skewX(30deg);
	-moz-transform: skewX(30deg);
	-ms-transform: skewX(30deg);
	-o-transform: skewX(30deg);
	transform: skewX(30deg);
}

@keyframes zoom-in {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}

@keyframes zoom-out {
  0% {
    transform: scale(1.15);
  }
  100% {
    transform: scale(1);
  }
}

.main-img .swiper-slide-active .slide-img,
.main-img .swiper-slide-duplicate-active .slide-img,
.main-img .swiper-slide-prev .slide-img {
  animation: zoom-out 10s linear 0s 1 normal both;  
}
.main-img .slide-text {
  content: "";
	position: absolute;
	bottom: 3vw;
  left: 0;
	right: 0;
}
.main-img .slide-text img {
	width: 100%;
}
.main-img .slide-img img {
  object-fit: cover;
	object-position: center;
  width: 100vw;
	height: 100vh;
}
.main-img .slide-img span {
	content: "";
	display: block;
	width: 100%;
	height: 100vh;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.main-img {
	height: 45vh;
}
.main-img .slide-img img {
  height: 46vh;
}
.main-title {
	position: absolute;
	bottom: 10vw;
	left: 4vw;
	width: 60%;
}
.main-design02 {
	position: absolute;
	bottom: 3vw;
	right: auto;
	left: -8%;
	padding-right: 0;
	padding-left: calc(8% + 4vw);
	width: 85%;
	height: 44px;
	text-align: left;
	background-color: #333;
	z-index: 10;
}
.main-design02-txt {
	padding-top: 12px;
	font-size: 1.5rem;
	letter-spacing: 0.3em;
}
}

@media screen and (max-width: 767px){
.main-img {
	height: 141vw;
}
.main-img .slide-img img {
  height: 141vw;
}
.main-title {
	position: absolute;
	bottom: 60px;
	left: 15px;
	width: 70%;
	z-index: 20;
}
.main-design01 {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-image: url("../images/pages/main_design.png");
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: 100% auto;
	z-index: 10;
}
.main-design02 {
	position: absolute;
	bottom: 3vw;
	right: auto;
	left: -8%;
	padding-right: 0;
	padding-left: calc(8% + 15px);
	width: 105%;
	height: 40px;
	text-align: left;
	background-color: #333;
	z-index: 10;
}
.main-design02-txt {
	padding-top: 12px;
	font-size: 1.2rem;
	letter-spacing: 0.1em;
}
}


/*　　ページタイトルイメージ / パンクズ / ページナビ
-------------------------------------------------------*/
.page-img-design01 {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	width: 38%;
	z-index: -1;
	overflow: hidden;
}
.page-img-design01::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 200px;
	width: 100%;
	background: linear-gradient(rgba(255,255,255,0.3) 0%, rgba(255,255,255,0) 100%);
	z-index: 1;
}
.page-img-design01-tb-sp {
	display: none;
	height: 20vw;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.page-img-design01 .swiper-slide-active .slide-img,
.page-img-design01 .swiper-slide-duplicate-active .slide-img,
.page-img-design01 .swiper-slide-prev .slide-img {
  animation: zoom-out 10s linear 0s 1 normal both;  
}
.page-img-design01 .slide-img img {
  object-fit: cover;
	object-position: center;
  width: 100%;
	height: 100vh;
}
.page-img-design02 {
	height: 20vw;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.page-img-design02.page-interview {
	height: 37.5vw;
}
.page-img-design03 {
	position: fixed;
	width: 38%;
	height: 100vh;
	overflow: hidden;
	z-index: -1;
}
.page-img-design03 img {
  object-fit: cover;
	object-position: center;
  width: 100%;
	height: 100vh;
}
.page-img-design03 span.pc {
	width: 100%;
	height: 100vh;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.page-title {
	position: relative;
	margin: auto;
	padding: 140px 0 0;
	text-align: center;
}
.page-title .txt-en {
	display: inline-block;
	min-width: 730px;
	padding-bottom: 20px;
	font-size: min(3.8vw, 7.6rem);
	font-weight: 700;
	line-height: 1;
	border-bottom: 2px solid #333;
  border-image: linear-gradient(to right, #18a1a0, #d42f71);
  border-image-slice: 1;
}
.page-title .txt-jp {
	display: block;
	padding-top: 20px;
	font-size: min(1.5vw, 3rem);
	font-weight: 700;
	line-height: 1;
}
.pankuzu {
	margin-top: 5px;
	padding: 5px 0;
	font-size: 1.2rem;
}
.pankuzu.page-news {
	width: 100%;
	max-width: 730px;
	margin: 80px auto 0;
}
.pankuzu span {
	margin: 3px;
}
.pankuzu span:first-child {
	margin-left: 0;
}
.pankuzu a:hover {
	text-decoration: underline;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.page-img-design01 {
	display: none;
}
.page-img-design01-tb-sp {
	display: block;
	margin-top: 60px;
	height: 25vw;
}
.page-img-design02.page-interview {
	height: 45vw;
}
.page-img-design03 {
	position: relative;
	width: 100%;
	height: 76.315%;
}
.page-img-design03 img {
  object-fit: cover;
	object-position: center;
  width: 100%;
	height: 100%;
}
.page-title {
	padding: 120px 0 0;
}
.page-title.side {
	padding: 60px 0 0;
}
.page-title .txt-en {
	min-width: 70%;
	padding-bottom: 15px;
	font-size: 4rem;
}
.page-title .txt-jp {
	padding-top: 15px;
	font-size: 2rem;
}
.pankuzu {
	font-size: 1rem;
}
.pankuzu.page-news {
	max-width: none;
	margin: 10px auto 0;
}
}

@media screen and (max-width: 767px){
.page-img-design01 {
	display: none;
}
.page-img-design01-tb-sp {
	display: block;
	margin-top: 30px;
	height: 25vw;
}
.page-img-design02.page-interview {
	height: 55vw;
}
.page-img-design03 {
	position: relative;
	width: 100%;
	height: 76.315%;
}
.page-img-design03 img {
  object-fit: cover;
	object-position: center;
  width: 100%;
	height: 100%;
}
.page-title {
	padding: 90px 20px 0;
}
.page-title.side {
	padding: 60px 20px 0;
}
.page-title .txt-en {
	min-width: 70%;
	padding-bottom: 15px;
	font-size: 3rem;
}
.page-title .txt-jp {
	padding-top: 15px;
	font-size: 1.5rem;
}
.pankuzu {
	font-size: 1rem;
}
.pankuzu.page-news {
	margin: 10px auto 0;
}
}



/*　　Home / NEWS
-------------------------------------------------------*/
.news-list {
	margin-top: 50px;
}
.news-list li {
	padding: 30px 0;
	border-bottom: 1px dotted #ccc;
}
.news-list li a {
	display: block;
	color: #282828;
}
.news-list li a:hover .news-thumbnail .inner-thumbnail img {
	opacity: 0.7;
}
.news-list li a:hover .news-txt01 {
	text-decoration: underline;
}
.news-list.page-news {
	width: 100%;
	max-width: 730px;
	margin: 20px auto 0;
}
.news-list.page-news li {
	width: 100%;
}
.news-list .news-thumbnail {
	position: relative;
	width: 150px;
	margin-right: 30px;
}
.news-list .news-thumbnail .inner-thumbnail {
	position: relative;
	width: 100%;
	padding-top: 100%;
}
.news-list .news-thumbnail .inner-thumbnail img {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.news-list .icon-recruit,
.news-detail .icon-recruit {
	display: inline-block;
	margin-right: 20px;
	width: 100px;
	padding: 1px 0;
	color: #18a1a0;
	font-size: 1.4rem;
	text-align: center;
	border: 1px solid #18a1a0;
}
.news-list .icon-news,
.news-detail .icon-news {
	display: inline-block;
	margin-right: 20px;
	width: 100px;
	padding: 1px 0;
	color: #333;
	font-size: 1.4rem;
	text-align: center;
	border: 1px solid #333;
}
.news-list .news-date,
.news-detail .news-date {
	padding: 2px 0;
	color: #999;
	font-size: 1.4rem;
}
.news-list .news-txt01 {
	margin-top: 20px;
}

.news-detail .news-thumbnail {
	position: relative;
	width: 200px;
	margin-right: 30px;
}
.news-detail .news-thumbnail .inner-thumbnail {
	position: relative;
	width: 100%;
	padding-top: 100%;
}
.news-detail .news-thumbnail .inner-thumbnail img {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.news-detail-txt {
	flex: 1;
}
.news-detail-content h1 {
	margin-top: 2em;
	color: #282828;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.5;
}
.news-detail-content h2 {
	padding: 10px 0 10px 20px;
	margin-top: 2em;
	color: #282828;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.5;
	border-left: 4px solid #18a1a0;
}
.news-detail-content h3 {
	margin-top: 2em;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.5;
	color: #282828;
}
.news-detail-content h4 {
	margin-top: 2em;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.5;
	color: #282828;
}
.news-detail-content h5,
.news-detail-content h6 {
	margin-top: 2em;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.5;
	color: #282828;
}	
.news-detail-content p {
	margin-top: 20px;
}
.news-detail-content ul {
  list-style-type: disc;
  list-style-position: outside;
  margin-left: 20px;
}
.news-detail-content ol {
  list-style-type: decimal;
  list-style-position: outside;
  margin-left: 20px;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.news-list {
	margin-top: 20px;
}
.news-list .news-thumbnail {
	width: 120px;
	height: 120px;
	margin-right: 20px;
}
.news-list.page-news {
	max-width: none;
	margin: 50px auto 0;
}
.news-list .icon-recruit,
.news-detail .icon-recruit {
	margin-right: 10px;
}
.news-list .icon-news,
.news-detail .icon-news {
	margin-right: 10px;
}
.news-list .news-txt01 {
	margin-top: 10px;
}
.news-detail-content h1 {
	font-size: 2.6rem;
}
.news-detail-content h2 {
	font-size: 2rem;
}
.news-detail-content h3 {
	font-size: 2rem;
}
.news-detail-content h4 {
	font-size: 1.8rem;
}
.news-detail-content h5,
.news-detail-content h6 {
	font-size: 1.6rem;
}
}

@media screen and (max-width: 767px){
.news-list {
	margin-top: 0;
}
.news-list .news-thumbnail {
	width: 100%;
	margin-right: 0;
	margin-bottom: 10px;
}
.news-list .icon-recruit {
	margin-right: 0;
	width: 100%;
	padding: 1px 0;
	font-size: 1.2rem;
}
.news-list .icon-news {
	margin-right: 0;
	width: 100%;
	padding: 1px 0;
	font-size: 1.2rem;
}
.news-list .news-date {
	margin-top: 10px;
	font-size: 1.2rem;
}
.news-list .news-txt01 {
	margin-top: 5px;
	font-size: 1.2rem;
}
.news-list.page-news {
	margin: 20px auto 0;
}
.news-list.page-news li {
	width: 47.5%;
}
.news-detail .news-thumbnail {
	width: 80%;
	margin: 0 auto 20px;
}
.news-detail-txt {
	width: 100%;
}
.news-detail-content h1 {
	font-size: 2.2rem;
}
.news-detail-content h2 {
	font-size: 2rem;
}
.news-detail-content h3 {
	font-size: 2rem;
}
.news-detail-content h4 {
	font-size: 1.6rem;
}
.news-detail-content h5,
.news-detail-content h6 {
	font-size: 1.5rem;
}
}



/*　　Home / Company
-------------------------------------------------------*/
.home-company {
	position: relative;
	padding-bottom: 4.25vw;
}
.home-company-bgline01 {
	position: absolute;
	top: 5vw;
	bottom: 10px;
	left: 4vw;
	right: calc(4vw + 10px);
	overflow: hidden;
	z-index: -1;
}
.home-company-bgline01::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50px;
	padding: 1px;
	background: linear-gradient(to right, #18a1a0, #d42f71);
	-webkit-mask: linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
}
.home-company-bgline02 {
	position: absolute;
	top: calc(5vw + 10px);
	bottom: 0;
	left: calc(4vw + 10px);
	right: 4vw;
	overflow: hidden;
	z-index: -1;
}
.home-company-bgline02::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50px;
	padding: 1px;
	background: linear-gradient(to right, #18a1a0, #d42f71);
	-webkit-mask: linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
}
.home-company-title {
	position: relative;
	height: 14.6vw;
	padding: 2.2vw 0 0;
	background-image: url("../images/webp/company_bg01.webp");
	background-repeat: no-repeat;
	background-position: left top;
	background-size: auto 100%;
}
.home-company-box01 {
	width: 82%;
	margin: -5vw auto 0;
}
.home-company-cnt01 {
	position: relative;
}
.home-company-cnt01 li {
	width: 29.268%;
	margin-right: 6.097%;
	border-radius: 0 130px 0 0;
	background: #fff;
	overflow: hidden;
}
.home-company-cnt01 li:nth-child(3n) {
	margin-right: 0;
}
.home-company-cnt02 {
	width: 38%;
	margin-right: 30px;
}
.home-company-txt01 {
	font-size: min(2.3vw, 46px);
	font-weight: 700;
	line-height: 1.2;
}
.home-company-txt02 {
	font-size: min(1.2vw, 26px);
	font-weight: 700;
}
.home-company-box02 {
	width: 1050px;
	margin: 60px auto 0;
}


@media screen and (min-width: 768px) and (max-width: 1270px){
.home-company {
	padding-bottom: 5vw;
}
.home-company-bgline01 {
	position: absolute;
	top: 6vw;
	bottom: 5px;
	left: 4vw;
	right: calc(4vw + 5px);
	overflow: hidden;
	z-index: -1;
}
.home-company-bgline01::before {
	border-radius: 30px;
}			
.home-company-bgline02 {
	position: absolute;
	top: calc(6vw + 5px);
	bottom: 0;
	left: calc(4vw + 5px);
	right: 4vw;
	overflow: hidden;
	z-index: -1;
}
.home-company-bgline02::before {
	border-radius: 30px;
}	
.home-company-title .c-title01 {
	padding-left: 5%;
}
.home-company-box01 {
	width: 82%;
	margin: 5vw auto 0;
}
.home-company-cnt01 li {
	border-radius: 0 50px 0 0;
}
.home-company-box02 {
	width: 55%;
	margin: 50px auto 0;
}
.home-company-cnt02 {
	width: 100%;
	margin-right: 0;
	margin-bottom: 20px;
}
.home-company-txt01 {
	font-size: 2.4rem;
}
.home-company-txt02 {
	font-size: 1.6rem;
}
}

@media screen and (max-width: 767px){
.home-company {
	padding-bottom: 40px;
}
.home-company-bgline01 {
	position: absolute;
	top: 30px;
	bottom: 5px;
	left: 4vw;
	right: calc(4vw + 5px);
	overflow: hidden;
	z-index: -1;
}
.home-company-bgline01::before {
	border-radius: 20px;
}			
.home-company-bgline02 {
	position: absolute;
	top: calc(30px + 5px);
	bottom: 0;
	left: calc(4vw + 5px);
	right: 4vw;
	overflow: hidden;
	z-index: -1;
}
.home-company-bgline02::before {
	border-radius: 20px;
}	
.home-company-title {
	position: relative;
	height: 80px;
	padding: 10px 0 0;
	background-position: right 40px top;
	background-size: auto 100%;
}
.home-company-title .c-title01 {
	text-align: left;
}
.home-company-box01 {
	width: 74%;
	margin: 0 auto 0;
}
.home-company-cnt01 li {
	width: 100%;
	margin: 40px 0 0;
	border-radius: 0 70px 0 0;
}
.home-company-box02 {
	width: 74%;
	margin: 40px auto 0;
}
.home-company-cnt02 {
	width: 100%;
	margin-right: 0;
	margin-bottom: 20px;
}
.home-company-txt01 {
	font-size: 2.4rem;
}
.home-company-txt02 {
	font-size: 1.5rem;
}
}



/*　　Home / 先輩社員インタビュー
-------------------------------------------------------*/
.home-interview-box {
	position: relative;
	margin-top: 120px;
	padding: 80px 0 30px;
	background-color: #f7f7f7;
}
.home-interview-txt01 {
	position: absolute;
	top: -30px;
	left: 0;
	right: 0;
	line-height: 1;
	text-align: center;
	letter-spacing: 0.5em;
}
.home-interview-txt01 span {
	display: inline-block;
	transform: skewY(-15deg);
	font-size: 5.5rem;
	font-weight: 700;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.home-interview-box {
	margin-top: 80px;
	padding: 60px 0 30px;
}
.home-interview-txt01 {
	top: -20px;
	letter-spacing: 0.4em;
}
.home-interview-txt01 span {
	font-size: 3.6rem;
}
}

@media screen and (max-width: 767px){
.home-interview-box {
	margin-top: 50px;
	padding: 50px 0 20px;
}
.home-interview-txt01 {
	top: -12px;
	letter-spacing: 0.2em;
}
.home-interview-txt01 span {
	font-size: 2rem;
}
}



/*　　Home / 先輩社員インタビュー / swiper基本情報
-------------------------------------------------------*/
.interview-slide {
  overflow: hidden;
}
.interview-slide .swiper {
	padding-bottom: 80px;
  overflow: visible;
	/* max-width: 1200px; */
	margin: 0 4vw;
	/* pagination 表示の場合
	padding-bottom: 35px;
	*/
}
.interview-slide .slide {
  overflow: hidden;
  /*
	-webkit-transition: var(--transition), opacity 1s;
  transition: var(--transition), opacity 1s;
  -webkit-box-shadow: var(--box-shadow);
          box-shadow: var(--box-shadow);
	*/
}
a.swiper-slide {
	color: #282828;
}
a.swiper-slide:hover {
	color: #282828;
	text-decoration: underline;
}
a.swiper-slide:hover {
	opacity: 0.7;
}
.interview-slide .slide-img {
	position: relative;
	overflow: hidden;
	padding-top: 145.348%;
	clip-path: polygon(0 11.5%, 100% 0%, 100% 88.5%, 0 100%);
}
.interview-slide .slide-img img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.interview-slide .slide-img .txt-staff {
	position: absolute;
	top: 0;
	right: 0;
	padding: 1.5vw 15px;
	-ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
	font-size: min(0.9vw,1.6rem);
	line-height: 1;
	color: #fff;
	height: min(15vw, 250px);
	background-color: #333;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), 0 100%);
}
/* スライダーのはみだし部分　*/
.interview-slide .swiper-slide:not(.swiper-slide-visible) .slide {
  pointer-events: none;
  opacity: 1;
}
.interview-slide .slide-txt {
  padding: 10px 0 0;
	line-height: 1.6;
	text-align: center;
}
.swiper-button-prev,
.swiper-button-next {
  width: 50px;
	height: 50px;
	margin-top: 0;
}
.swiper-pagination {
	position: absolute;
	bottom: 0 !important;
}
.swiper-pagination-bullet {
  width: 12px;
  height: 8px;
	margin: 0 5px !important;
	border-radius: 0;
	background-color: #999;
}
.swiper-pagination-bullet-active {
  background-color: #18a1a0;
}
.interview-slide .swiper-button-prev {
	top: auto;
	bottom: 0;
	left: calc(50% - 80px);
}
.interview-slide .swiper-button-next {
	top: auto;
	bottom: 0;
	right: calc(50% - 80px);
}
.swiper-button-prev::after,
.swiper-button-next::after {
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  width: 50px;
	height: 50px;
	border-radius: 50%;
	background-color: rgba(51,51,51,0);
}
.swiper-button-prev::after {
  background-image: url("../images/common/arrow_03.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: auto 100%;
	transform: rotate(180deg);
}
.swiper-button-next::after {
  background-image: url("../images/common/arrow_03.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: auto 100%;
}
.swiper-button-prev:hover::after,
.swiper-button-next:hover::after {
	opacity: 0.5;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.interview-slide .swiper {
  padding: 0 3% 70px;
}
.swiper-button-prev,
.swiper-button-next {
  width: 40px;
	height: 40px;
}
.interview-slide .swiper-button-prev {
	left: calc(50% - 65px);
}
.interview-slide .swiper-button-next {
	right: calc(50% - 65px);
}
.swiper-button-prev::after,
.swiper-button-next::after {
  width: 35px;
	height: 35px;
}
.interview-slide .slide-img .txt-staff {
	padding: 15px 10px;
	font-size: 1.2rem;
	height: 170px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 6px), 0 100%);
}
}

@media screen and (max-width: 767px){
.interview-slide .swiper {
  padding: 0 3% 50px;
}
.swiper-button-prev,
.swiper-button-next {
  width: 30px;
	height: 30px;
}
.interview-slide .swiper-button-prev {
	left: calc(50% - 50px);
}
.interview-slide .swiper-button-next {
	right: calc(50% - 50px);
}
.swiper-button-prev::after,
.swiper-button-next::after {
  width: 30px;
	height: 30px;
}
.interview-slide .slide-img .txt-staff {
	padding: 15px 8px;
	font-size: .9rem;
	height: 150px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 5px), 0 100%);
}
}



/*　　Home / 仕事を知る　/　研修制度
-------------------------------------------------------*/
.home-jobs {
	position: relative;
	clip-path: polygon(0 11.5%, 100% 0%, 100% 88.5%, 0 100%);
}
.home-jobs-box01 {
	position: absolute;
	top: 30%;
	left: 0;
	right: 0;
	width: 73%;
	margin: 0 auto;
	text-align: center;
}
.home-jobs-title {
	color: #fff;
}
.home-jobs-title .txt-en {
	display: block;
	padding-bottom: 1.2vw;
	margin-bottom: 1.2vw;
	font-size: 4vw;
	font-weight: 700;
	line-height: 1;
	border-bottom: 2px solid;
  border-image: linear-gradient(to right, #18a1a0 50%, #d42f71 50%);
  border-image-slice: 1;
}
.home-jobs-title .txt-jp {
	display: block;
	font-size: 1.5vw;
	line-height: 1;
}
.home-jobs-txt01 {
	display: inline-block;
	width: 78%;
	margin-top: 2.5vw;
	padding: 1.2vw;
	font-size: 1.1vw;
	line-height: 1;
	color: #fff;
	border-radius: 50px;
	background: #18a1a0;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.home-jobs-box01 {
	top: 30%;
	width: 60%;
}
.home-jobs-title .txt-en {
	padding-bottom: 2.8vw;
	margin-bottom: 2.8vw;
	font-size: 6vw;
}
.home-jobs-title .txt-jp {
	font-size: 3vw;
	line-height: 1;
}
.home-jobs-txt01 {
	width: 78%;
	margin-top: 5vw;
	padding: 1.8vw;
	font-size: 1.8vw;
}
}

@media screen and (max-width: 767px){
.home-jobs-box01 {
	top: 30%;
	width: 85%;
}
.home-jobs-title .txt-en {
	padding-bottom: 3vw;
	margin-bottom: 3vw;
	font-size: 8vw;
}
.home-jobs-title .txt-jp {
	font-size: 4vw;
	line-height: 1;
}
.home-jobs-txt01 {
	width: 90%;
	margin-top: 5vw;
	padding: 2.5vw;
	font-size: 3vw;
}
}



/*　　Home / 採用情報 / バナー
-------------------------------------------------------*/
.home-recruit-btn01 {
	position: relative;
	display: block;
	padding: 16px 0 16px 20px;
	color: #282828;
	border-left: 4px solid #18a1a0;
	border-bottom: 1px solid #e5e5e5;
}
.home-recruit-btn01::after {
	content: "";
	position: absolute;
	top: calc(50% - 12px);
	right: 0;
	width: 24px;
	height: 24px;
	border-radius: 50px;
	background-color: #333;
	background-image: url("../images/common/arrow_01.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 6px auto;
}
.home-recruit-btn01:hover {
	color: #18a1a0;
}
.home-recruit-btn01:hover::after {
	background-color: #18a1a0;
}
.bn-mynavi2025 {
	display: block;
	border: 1px solid #e5e5e5;
}
.home-bn {
	padding-top: 60px;
	border-top: 1px solid #e5e5e5;
}
.home-bn li a {
	display: block;
	border: 1px solid #e5e5e5;
	text-align: center;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.home-bn {
	padding-top: 50px;
}
}

@media screen and (max-width: 767px){
.home-bn li {
	margin-top: 20px;
}
.home-bn {
	padding-top: 40px;
}
}



/*　　会社を知る / メッセージ / 会社概要 / 会社沿革　/　経営理念・行動指針　/　ハウス・トゥ・ハウスの強み
-------------------------------------------------------*/
.company-index {
	position: relative;
	padding: 4.25vw 0;
}
.company-index-bgline01 {
	position: absolute;
	top: 0;
	bottom: 10px;
	left: 4vw;
	right: calc(4vw + 10px);
	overflow: hidden;
	z-index: -1;
}
.company-index-bgline01::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50px;
	padding: 1px;
	background: linear-gradient(to right, #18a1a0, #d42f71);
	-webkit-mask: linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
}			
.company-index-bgline02 {
	position: absolute;
	top: 10px;
	bottom: 0;
	left: calc(4vw + 10px);
	right: 4vw;
	overflow: hidden;
	z-index: -1;
}
.company-index-bgline02::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 50px;
	padding: 1px;
	background: linear-gradient(to right, #18a1a0, #d42f71);
	-webkit-mask: linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
}	
.company-index-box01 {
	width: 82%;
	margin: 0 auto 0;
}
.company-index-txt01 {
	width: calc(100% - 150px);
}
.company-index-logo {
	padding-bottom: 30px;
	text-align: center;
	border-bottom: 1px solid;
	border-image: linear-gradient(to right, #18a1a0, #d42f71);
  border-image-slice: 1;
}
.company-index-haupi {
	width: 100px;
	margin-left: 50px;
}
.company-index-img {
	border-radius: 0 130px 0 0;
}
.message-txt01 {
	width: 100%;
	max-width: 730px;
	margin: 0 auto;
}
.company-overview-list {
	margin-top: -30px;
}
.company-overview-list li {
	width: 30%;
	margin-top: 60px;
	margin-right: 5%;
}
.company-overview-list li:nth-child(3n) {
	margin-right: 0;
}
.company-overview-list img {
	width: 100%;
	border-radius: 0 80px 0 0;
}
.company-overview-list .overview-txt01 {
	margin: 10px 0;
	font-weight: 700;
	padding-bottom: 10px;
	border-bottom: 1px solid;
	border-image: linear-gradient(to right, #18a1a0, #d42f71);
  border-image-slice: 1;
}
.history-table th {
	width: 25%;
	background: #f1fbfb;
	text-align: center !important;
	vertical-align: middle !important;
}
.history-table tr:nth-child(even) th {
	background: #fff4f9;
}
.history-list li {
	margin-top: 5px;
	padding-left: 100px;
}
.history-list li:first-child {
	margin-top: 0;
}
.history-date01 {
	display: inline-block;
	margin-left: -100px;
	margin-right: 10px;
	width: 90px;
	color: #fff;
	font-size: 1.4rem;
	text-align: center;
	border-radius: 3px;
	background: #666;
}
.philosophy-title01 {
	padding: 0 0 30px;
	letter-spacing: 0.3em;
	border-bottom: 1px solid;
	border-image: linear-gradient(to right, #18a1a0, #d42f71);
  border-image-slice: 1;
}
.philosophy-list {
	margin-top: 50px;
}
.philosophy-list li {
	display: inline-block;
	padding: 0 20px;
	transform: skewY(-15deg);
	font-size: 3rem;
	-ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
	vertical-align: top;
}
.philosophy-list li span {
	font-size: 5.5rem;
	font-weight: 700;
}
.strengths-img-box {
	position: relative;
}
.strengths-img-box::before {
	content: "";
	position: absolute;
	top: -6px;
	left: -6px;
	width: 40px;
	height: 40px;
	border-top: 12px solid #18a1a0;
	border-left: 12px solid #18a1a0;
	z-index: 100;
}
.strengths-img-box::after {
	content: "";
	position: absolute;
	bottom: -6px;
	right: -6px;
	width: 40px;
	height: 40px;
	border-bottom: 12px solid #d42f71;
	border-right: 12px solid #d42f71;
	z-index: 100;
}
.business-cnt01-txt {
	padding: 20px;
	border: 1px solid;
  border-image: linear-gradient(to right, #18a1a0, #d42f71);
  border-image-slice: 1;
	background: #fff;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.company-index {
	position: relative;
	padding: 50px 0;
}
.company-index-bgline01 {
	position: absolute;
	top: 0;
	bottom: 5px;
	left: 4vw;
	right: calc(4vw + 5px);
	overflow: hidden;
	z-index: -1;
}
.company-index-bgline01::before {
	border-radius: 30px;
}			
.company-index-bgline02 {
	position: absolute;
	top: 5px;
	bottom: 0;
	left: calc(4vw + 5px);
	right: 4vw;
	overflow: hidden;
	z-index: -1;
}
.company-index-bgline02::before {
	border-radius: 30px;
}
.company-index-img {
	border-radius: 0 50px 0 0;
}
.message-txt01 {
	width: 70%;
	margin: 0 auto;
}
.company-overview-list img {
	border-radius: 0 60px 0 0;
}
.history-list li {
	padding-left: 80px;
}
.history-date01 {
	margin-left: -80px;
	margin-right: 10px;
	width: 70px;
	font-size: 1.2rem;
}
.philosophy-title01 {
	padding: 0 0 20px;
}
.philosophy-list {
	margin-top: 40px;
}
.philosophy-list li {
	padding: 0 10px;
	font-size: 2.2rem;
}
.philosophy-list li span {
	font-size: 4rem;
}
.strengths-img-box {
	margin: 0 10%;
	margin-bottom: 30px;
}
}

@media screen and (max-width: 767px){
.company-index {
	position: relative;
	padding: 40px 0;
}
.company-index-bgline01 {
	position: absolute;
	top: 0;
	bottom: 5px;
	left: 4vw;
	right: calc(4vw + 5px);
	overflow: hidden;
	z-index: -1;
}
.company-index-bgline01::before {
	border-radius: 20px;
}			
.company-index-bgline02 {
	position: absolute;
	top: 5px;
	bottom: 0;
	left: calc(4vw + 5px);
	right: 4vw;
	overflow: hidden;
	z-index: -1;
}
.company-index-bgline02::before {
	border-radius: 20px;
}
.company-index-box01 {
	width: 74%;
	margin: 0 auto 0;
}
.company-index-txt01 {
	width: 100%;
}
.company-index-haupi {
	margin: 30px auto 0;
}
.company-index-img {
	border-radius: 0 70px 0 0;
}
.message-txt01 {
	width: 100%;
}
.company-overview-list li {
	margin-top: 40px;
	width: 47.5%;
}
.company-overview-list li:nth-child(3n) {
	margin-top: 40px;
	margin-right: 5%;
}
.company-overview-list li:nth-child(even) {
	margin-right: 0;
}
.company-overview-list img {
	border-radius: 0 30px 0 0;
}
.history-table th {
	padding: 10px !important;
	border-bottom: 1px solid #dedede !important;
}
.history-table td {
	padding: 10px 10px 20px !important;
}
.history-list li {
	padding-left: 80px;
}
.history-date01 {
	margin-left: -80px;
	margin-right: 10px;
	width: 70px;
	font-size: 1.2rem;
}
.philosophy-title01 {
	padding: 0 0 15px;
}
.philosophy-list {
	margin-top: 30px;
}
.philosophy-list li {
	padding: 0 15px;
	font-size: 1.8rem;
}
.philosophy-list li span {
	font-size: 3rem;
}
.strengths-img-box {
	margin-bottom: 20px;
}
.strengths-img-box::before {
	top: -3px;
	left: -3px;
	width: 25px;
	height: 25px;
	border-top: 6px solid #18a1a0;
	border-left: 6px solid #18a1a0;
}
.strengths-img-box::after {
	bottom: -3px;
	right: -3px;
	width: 25px;
	height: 25px;
	border-bottom: 6px solid #d42f71;
	border-right: 6px solid #d42f71;
}
.business-cnt01-txt {
	padding: 15px;
}
}



/*　　仕事を知る
-------------------------------------------------------*/
.job-list-img01 {
	position: relative;
	padding-top: 75%;
	clip-path: polygon(0 11.5%, 100% 0%, 100% 88.5%, 0 100%);
	overflow: hidden;
}
.job-list-img01 img {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
  object-position: center;
}
.job-img01 {
	position: relative;
	padding-top: 68.75%;
}
.job-img01::before {
	content: "";
	position: absolute;
	top: -6px;
	left: -6px;
	width: 40px;
	height: 40px;
	border-top: 12px solid #18a1a0;
	border-left: 12px solid #18a1a0;
	z-index: 100;
}
.job-img01::after {
	content: "";
	position: absolute;
	bottom: -6px;
	right: -6px;
	width: 40px;
	height: 40px;
	border-bottom: 12px solid #d42f71;
	border-right: 12px solid #d42f71;
	z-index: 100;
}
.job-img01 img {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
  object-position: center;
}
.job-txt01 {
	padding: 20px;
	border: 1px solid;
  border-image: linear-gradient(to right, #18a1a0, #d42f71);
  border-image-slice: 1;
}
.job-img02 {
	position: relative;
	padding-top: 56.25%;
}
.job-img02 img {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
  object-position: center;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.job-img01::before {
	top: -4px;
	left: -4px;
	width: 30px;
	height: 30px;
	border-top: 8px solid #18a1a0;
	border-left: 8px solid #18a1a0;
}
.job-img01::after {
	bottom: -4px;
	right: -4px;
	width: 30px;
	height: 30px;
	border-bottom: 8px solid #d42f71;
	border-right: 8px solid #d42f71;
}
}

@media screen and (max-width: 767px){
.job-list-img01 {
	padding-top: 68.75%;
	clip-path: none;
}
.job-img01 {
	margin-bottom: 20px;
}
.job-img01::before {
	top: -3px;
	left: -3px;
	width: 25px;
	height: 25px;
	border-top: 6px solid #18a1a0;
	border-left: 6px solid #18a1a0;
}
.job-img01::after {
	bottom: -3px;
	right: -3px;
	width: 25px;
	height: 25px;
	border-bottom: 6px solid #d42f71;
	border-right: 6px solid #d42f71;
}
.job-txt01 {
	padding: 15px;
}
}



/*　　先輩社員インタビュー
-------------------------------------------------------*/
.interview-txt01 {
	line-height: 1;
	text-align: center;
	letter-spacing: 0.5em;
}
.interview-txt01 span {
	display: inline-block;
	transform: skewY(-15deg);
	font-size: 5.5rem;
	font-weight: 700;
}
.bg-dot01 {
	background-image: url("../images/common/bg_dot01.png");
	background-repeat: repeat-y;
	background-position: center top;
	background-size: 100% auto;
}
.bg-dot02 {
	background-image: url("../images/common/bg_dot02.png");
	background-repeat: repeat-y;
	background-position: center top;
	background-size: 100% auto;
}
.interview-list li {
	width: 30%;
	margin-right: 5%;
}
.interview-list li:nth-child(3n) {
	margin-right: 0;
}
.interview-list li a {
	color: #282828;
}
.interview-list li a:hover {
	color: #282828;
	text-decoration: underline;
}
.interview-list li a:hover img,
.interview-list li a:hover .txt-staff{
	opacity: 0.7;
}
.interview-thumbnail {
	position: relative;
	overflow: hidden;
	padding-top: 145.348%;
	background-color: #fff;
	clip-path: polygon(0 11.5%, 100% 0%, 100% 88.5%, 0 100%);
}
.interview-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.interview-thumbnail .txt-staff {
	position: absolute;
	top: 0;
	right: 0;
	padding: 1.5vw 15px;
	-ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
	font-size: min(0.9vw,1.6rem);
	line-height: 1;
	color: #fff;
	height: min(15vw, 250px);
	background-color: #333;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 10px), 0 100%);
}
.interview-thumbnail-txt {
  padding: 10px 0 0;
	line-height: 1.6;
	text-align: center;
}
.interview-detail-mainimg {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	width: 38%;
	z-index: -1;
}
.interview-detail-mainimg::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 150px;
	width: 100%;
	background: linear-gradient(rgba(255,255,255,0.3) 0%, rgba(255,255,255,0) 100%);
	z-index: 1;
}
.interview-detail-mainimg-tb-sp {
	display: none;
	height: 20vw;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.interview-detail-mainimg-txt {
	position: absolute;
	top: 13vh;
	right: -0.8em;
	font-size: 3.4vh;
	font-weight: 700;
	line-height: 1.5;
	-ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
	transform: skewY(-15deg);
	text-shadow: #fff 1px 1px 12px;
	z-index: 100;
}
.interview-detail-mainimg .swiper {
	overflow: hidden;
}
.interview-detail-mainimg .swiper-slide-active .slide-img,
.interview-detail-mainimg .swiper-slide-duplicate-active .slide-img,
.interview-detail-mainimg .swiper-slide-prev .slide-img {
  animation: zoom-out 10s linear 0s 1 normal both;  
}
.interview-detail-mainimg .slide-img img {
  object-fit: cover;
	object-position: center;
  width: 100%;
	height: 100vh;
}
.interview-detail-box01 {
	position: absolute;
	bottom: 4vh;
	right: -10px;
	text-align: right;
	z-index: 100;
}
.interview-detail-txt01 {
	display: inline-block;
	padding: 1vw 1.5vw;
	color: #fff;
	font-size: min(2.5vw, 5rem);
	line-height: 1;
	background: linear-gradient(to right, #18a1a0, #d42f71);
}
.interview-detail-txt02 {
	position: relative;
	display: inline-block;
	padding: 1vw 1.5vw;
	color: #fff;
	font-weight: 700;
	line-height: 1;
	background: #333;
}
.interview-detail-txt02::before {
	content: "";
	position: absolute;
	right: 0;
	bottom: -10px;
	width: 10px;
	height: 10px;
	background: #606060;
	clip-path: polygon(0 0, 100% 0, 0 100%);	
}
.interview-detail-icon {
	width: 150px;
	margin-right: 30px;
}
.interview-detail-icon-img {
	position: relative;
	padding-top: 100%;
	border-radius: 50px;
	overflow: hidden;
}
.interview-detail-icon-img img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.interview-detail-txt-q {
	position: relative;
	padding-left: 40px;
}
.interview-detail-txt-q::before {
	content: "";
	position: absolute;
	top: 17px;
	left: 0;
	width: 30px;
	height: 3px;
	background: linear-gradient(to right, #18a1a0, #d42f71);
}


@media screen and (min-width: 768px) and (max-width: 1270px){
.interview-txt01 {
	letter-spacing: 0.4em;
}
.interview-txt01 span {
	font-size: 3.6rem;
}
.bg-dot01,
.bg-dot02 {
	background-size: 115% auto;
}
.interview-thumbnail .txt-staff {
	padding: 15px 10px;
	font-size: 1.2rem;
	height: 170px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 6px), 0 100%);
}

.interview-detail-mainimg {
	position: relative;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 76.315vw;
	z-index: 1;
}
.interview-detail-mainimg .slide-img img {
  object-fit: cover;
	object-position: center;
  width: 100%;
	height: 76.315vw;
}
.interview-detail-mainimg-txt {
	top: 12vw;
	right: 8vw;
	font-size: 3.2vw;
}
.interview-detail-box01 {
	bottom: 3vw;
	right: auto;
	left: 0;
	text-align: left;
}
.interview-detail-txt01 {
	padding: 2vw 3vw;
	font-size: 5vw;
}
.interview-detail-txt02 {
	padding: 2vw 3vw;
}
.interview-detail-txt02::before {
	display: none;
}
.interview-detail-txt-q::before {
	top: 13px;
}
}

@media screen and (max-width: 767px){
.interview-txt01 {
	letter-spacing: 0.2em;
}
.interview-txt01 span {
	font-size: 2rem;
}
.bg-dot01,
.bg-dot02 {
	background-size: 200% auto;
}
.interview-list li,
.interview-list li:nth-child(3n) {
	width: 47.5%;
	margin-right: 5%;
}
.interview-list li:nth-child(even) {
	margin-right: 0;
}
.interview-thumbnail .txt-staff {
	padding: 15px 8px;
	font-size: .9rem;
	height: 150px;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - 5px), 0 100%);
}
.interview-detail-mainimg {
	position: relative;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 76.315vw;
	z-index: 1;
}
.interview-detail-mainimg .slide-img img {
  object-fit: cover;
	object-position: center;
  width: 100%;
	height: 76.315vw;
}
.interview-detail-mainimg-tb-sp {
	display: block;
	margin-top: 60px;
	height: 25vw;
}
.interview-detail-mainimg-txt {
	top: 15vw;
	right: 12px;
	font-size: 1.3rem;
}
.interview-detail-box01 {
	bottom: -20px;
	right: auto;
	left: 0;
	text-align: left;
}
.interview-detail-txt01 {
	padding: 2vw 3vw;
	font-size: 5.5vw;
}
.interview-detail-txt02 {
	padding: 2vw 3vw;
	font-size: 1.2rem;
}
.interview-detail-txt02::before {
	display: none;
}
.interview-detail-txt-q::before {
	top: 13px;
}
.interview-detail-icon {
	width: 100px;
	margin-right: 20px;
}
.interview-detail-icon-img {
	border-radius: 30px;
}
}



/*　　働く環境を知る / 研修制度
-------------------------------------------------------*/
.workplace-box01 {
	position: relative;
	padding-top: 120px;
}
.workplace-img01 {
	content: "";
	position: absolute;
	top: 60px;
	bottom: 60px;
	left: 0;
	width: 48.5%;
	border-radius: 0 120px 0 0;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
.workplace-cnt01 {
	width: 62%;
	padding: 60px 6vw 60px 13.5vw;
	margin-left: auto;
	background: #f7f7f7;
}
.workplace-cnt01-img {
	width: 20vw;
	margin-right: 1.5vw;
}
.workplace-cnt01-img img {
	width: 100%;
	height: auto;
	border-radius: 6px;
}
.workplace-cnt01-txt {
	padding: 20px;
	border: 1px solid;
  border-image: linear-gradient(to right, #18a1a0, #d42f71);
  border-image-slice: 1;
	background: #fff;
}
.training-img01 {
	width: 30%;
	margin-right: 30px;
}
.training-img01 img {
	width: 100%;
	height: auto;
	border-radius: 6px;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.workplace-box01 {
	padding-top: 30px;
}
.workplace-img01 {
	position: relative;
	top: 0;
	bottom: auto;
	left: 5%;
	width: 90%;
	border-radius: 0;
	padding-top: 40%;
}
.workplace-cnt01 {
	width: 100%;
	padding: 120px 5% 60px;
	margin: -60px 0 0;
}
.workplace-cnt01-img {
	width: 35%;
	margin-bottom: 20px;
	margin-right: 30px;
}
}

@media screen and (max-width: 767px){
.workplace-box01 {
	padding-top: 30px;
}
.workplace-img01 {
	position: relative;
	top: 0;
	bottom: auto;
	left: 0;
	width: 100%;
	border-radius: 0;
	padding-top: 40%;
}
.workplace-cnt01 {
	width: 100%;
	padding: 10% 5% 5%;
	margin: 0;
}
.workplace-cnt01-img {
	width: 100%;
	margin-right: 0;
	margin-bottom: 20px;
}
.workplace-cnt01-txt {
	padding: 15px;
}
.training-img01 {
	width: 100%;
	margin: 0 0 20px
}
}



/*　　新卒採用 / キャリア採用 / 障がい者採用
-------------------------------------------------------*/
.recruit-pagenav {
	padding: 30px 0 0;
	color: #fff;
	text-align: center;
	background: linear-gradient(to right, #18a1a0, #d42f71);
}
.recruit-pagenav ul {
	margin-top: 30px;
}
.recruit-pagenav ul li {
	width: 15%;
	margin: 0 5px;
}
.recruit-pagenav ul li.torikumi {
	width: 25%;
}
.recruit-pagenav ul li a {
	display: block;
	padding: 20px;
	color: #fff;
	font-weight: 700;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
	border-right: 1px solid #fff;
	text-align: center;
	border-radius: 20px 20px 0 0;
	background-image: url("../images/common/arrow_01.png");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 6px auto;
}
.recruit-pagenav ul li a:hover {
	background-color: rgba(255,255,255,0.2);
}
.recruit-pagenav ul li a.act {
	color: #282828;
	background-color: #fff;
	background-image: url("../images/common/arrow_down02.png");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 12px auto;
}
.recruit-img01 {
	position: relative;
	padding-top: 56.25%;
}
.recruit-img01 img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.process-list li {
	padding: 30px 0 73px;
	background-image: url("../images/common/arrow_process.png");
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: auto 43px;
}
.process-list li:last-child {
	padding: 30px 0 0;
	background-image: none;
}
.process-table th {
	background-color: #f1fbfb !important;
}
.faq-box {
	margin-top: 30px;
}
.faq-box dt {
	display: block;
	position: relative;
	padding: 15px 60px 15px 60px;
	color: #282828;
	font-weight: 700;
	border-radius: 8px;
	border: 1px solid #f7f7f7;
	background: #f7f7f7;
	cursor: pointer;
}
.faq-box dt:hover {
	color: #282828;
	background: #e4f9f9;
}
.faq-box dt .icon-q {
	position: absolute;
	top: 12px;
	left: 10px;
	width: 40px;
	height: 40px;
	line-height: 40px;
	font-size: 1.8rem;
	font-weight: 700;
	color: #fff;
	text-align: center;
	border-radius: 5px;
	background-color: #18a1a0;
}
.faq-box dt:hover::before,
.faq-box dt.active::before {
	color: #fff;
}
.faq-box dt::after {
	content: "";
	position: absolute;
	top: 24px;
	right: 15px;
	width: 20px;
	height: 20px;
	border-radius: 25px;
	background-image: url("../images/common/icon_toggle01.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 20px auto;
}
.faq-box dt.active {
	color: #282828;
	border: 1px solid #18a1a0;
	border-bottom: 0;
	border-radius: 8px 8px 0 0;
	background: #e4f9f9;
}
.faq-box dt.active::after {
	background-image: url("../images/common/icon_toggle02.png");
}
.faq-box dd {
	position: relative;
	display: none;
	padding: 15px 20px 20px 60px;
	border: 1px solid #18a1a0;
	border-top: 0;
	border-radius: 0 0 8px 8px;
	background-color: rgba(255,255,255,0.5);
}
.faq-box dd .icon-a {
	position: absolute;
	top: 12px;
	left: 10px;
	width: 40px;
	height: 40px;
	line-height: 40px;
	font-size: 1.8rem;
	font-weight: 700;
	color: #fff;
	text-align: center;
	border-radius: 5px;
	background-color: #d42f71;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.recruit-pagenav {
	padding: 20px 0 20px;
}
.recruit-pagenav ul {
	margin-top: 10px;
}
.recruit-pagenav ul li {
	width: 48%;
	margin: 10px 0;
}
.recruit-pagenav ul li.torikumi {
	width: 48%;
	margin: 10px 0;
}
.recruit-pagenav ul li a {
	padding: 10px;
	border-radius: 6px;
	border-bottom: 1px solid #fff;
	background-size: 5px auto;
}
.faq-box dt .icon-q {
	position: absolute;
	top: 12px;
	left: 10px;
	width: 34px;
	height: 34px;
	line-height: 34px;
	font-size: 1.4rem;
}
.faq-box dt::after {
	top: 19px;
	right: 10px;
	background-size: 16px auto;
}
.faq-box dd .icon-a {
	position: absolute;
	top: 12px;
	left: 10px;
	width: 34px;
	height: 34px;
	line-height: 34px;
	font-size: 1.4rem;
}
}

@media screen and (max-width: 767px){
.recruit-pagenav {
	padding: 10px 0 10px;
}
.recruit-pagenav ul {
	margin-top: 10px;
}
.recruit-pagenav ul li {
	width: 48%;
	margin: 5px 0;
}
.recruit-pagenav ul li.torikumi {
	width: 100%;
}
.recruit-pagenav ul li a {
	padding: 10px;
	border-radius: 6px;
	border-bottom: 1px solid #fff;
	background-size: 5px auto;
}
.process-list li {
	padding: 20px 0 50px;
	background-size: auto 30px;
}
.process-list li:last-child {
	padding: 20px 0 0;
	background-image: none;
}
.process-table th {
	text-align: center !important;
}
.faq-box {
	margin-top: 20px;
}
.faq-box dt {
	padding: 10px 45px 10px 56px;
}
.faq-box dt .icon-q {
	position: absolute;
	top: 6px;
	left: 10px;
	width: 34px;
	height: 34px;
	line-height: 34px;
	font-size: 1.4rem;
}
.faq-box dt::after {
	top: 14px;
	right: 10px;
	background-size: 16px auto;
}
.faq-box dd {
	padding: 15px 20px 10px 56px;
}
.faq-box dd .icon-a {
	position: absolute;
	top: 6px;
	left: 10px;
	width: 34px;
	height: 34px;
	line-height: 34px;
	font-size: 1.4rem;
}
}



/*　	サイトマップ
-------------------------------------------------------*/
.sitemap-list li {
	margin-top: 30px;
}
.sitemap-list a {
	display: block;
	padding: 15px;
	color: #282828;
	border-bottom: 1px solid #dedede;
	background: url("../images/common/arrow_03.png");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 6px auto, 100%;
	transition-duration: 0.2s;
}
.sitemap-list a:hover {
	color: #fff;
	border-bottom: 0;
	background:  url("../images/common/arrow_01.png"), linear-gradient(to right, #18a1a0, #d42f71);
	background-repeat: no-repeat, no-repeat;
	background-position: right 12px center, center;
	background-size: 6px auto, 100%;
	transform: scale(1.05);
}

@media screen and (min-width: 768px) and (max-width: 1270px){
}

@media screen and (max-width: 767px){
.sitemap-list li {
	margin-top: 15px;
}
.sitemap-list a {
	display: block;
	padding: 10px;
	color: #282828;
	border-bottom: 1px solid #dedede;
	background: url("../images/common/arrow_03.png");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 6px auto, 100%;
	transition-duration: 0.2s;
}
}


/*　　お問い合わせフォーム
-------------------------------------------------------*/
.privacy-box {
	width: 100%;
	height: 200px;
  padding: 10px;
  border: 1px solid #ccc;
}
.icon-required {
	display: inline-block;
	font-size: 12px; font-size: 1.2rem;
  font-weight: 400;
	line-height: 1.5;
	margin-right: 10px;
	padding: 2px 8px 2px;
	background-color: #cf1126;
	color: #fff;
	vertical-align:middle;
	border-radius: 3px;
}
.form-initialize {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.contactForm {
}
.contactForm th,
.contactForm td {
	font-size: 1.6rem;
}
.confirm-box .confirm-text {
	display: none;
}
.contactForm input {
	padding: 10px;
	font-size: 1.6rem;
	vertical-align:middle;
	border: 1px solid #ccc;
	border-radius: 0;
}
.required-bgcolor {
	background-color: #fff7f7;
}
.contactForm input[type="radio"] {
	vertical-align: baseline;
}
.contactForm input[type="file"] {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
	border: 0;
	padding: 0;
}
.contactForm .select-menu {
	height: 40px;
	font-size: 1.6rem;
	line-height:1.6;
	padding: 3px;
	border: 1px solid #ccc;
	background: #fff;
}
.contactForm textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
  padding: 10px;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px; font-size: 1.6rem;
  border: 1px solid #ccc;
	border-radius: 0;
}
.contactForm .btn-box {
	padding-top: 50px;
	text-align: center;
}
.contactForm .btn-send {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: relative;
	font-size: 2.4rem;
	font-weight: 700;
	padding: 22px;
	width: 720px;
	margin: 20px auto 0;
	cursor: pointer;
	color: #fff;
	border: 0;
	border-radius: 0;
	background: url("../images/common/arrow_01.png"), linear-gradient(to right, #18a1a0, #d42f71);
	background-repeat: no-repeat, no-repeat;
	background-position: right 12px center, center;
	background-size: 6px auto, 100%;
	transition-duration: 0.2s;
}
.contactForm .btn-send:hover {
  color: #fff;
	background: url("../images/common/arrow_01.png"), linear-gradient(to right, #23cdcc, #ff458f);
	background-repeat: no-repeat, no-repeat;
	background-position: right 12px center, center;
	background-size: 6px auto, 100%;
	transform: scale(1.05);
}
.contactForm .btn-modify {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: relative;
	font-weight: 700;
	font-size: 2.4rem;
	padding: 22px;
	width: 720px;
	margin: 30px auto 0;
	cursor: pointer;
	color: #fff;
	border: 0;
	border-radius: 0;
	background-color: #333;
	transition-duration: 0.2s;
}
.contactForm .btn-modify:hover {
  color: #fff;
	background-color: #999;
	transform: scale(1.05);
}
#form-error-message {
	padding: 20px;
	font-weight: bold;
	color: #fff;
	background: #cc0000;
	text-align: center;
	margin: 20px 0;
}

@media screen and (min-width: 768px) and (max-width: 1270px){
.contactForm .btn-box {
	padding-top: 20px;
}
.contactForm .btn-send,
.contactForm .btn-modify {
	width: 80%;
	padding: 20px;
	font-size: 1.6rem;
}
}

@media screen and (max-width: 767px){
.privacy-box {
  padding: 10px;
}
.contactForm .btn-box {
	padding-top: 10px;
}
.contactForm .btn-send {
	padding: 20px;
	width: 90%;
	font-size: 1.6rem;
}
.contactForm .btn-modify {
	padding: 20px;
	width: 90%;
	font-size: 1.6rem;
}
}

