@charset "UTF-8";

/*---ページタイトル---*/
.recruit-header{
  	background: #E50012;
	background-image: 
     linear-gradient(135deg, transparent 6%, #fff 6%, #fff 11%, transparent 11%), 
     linear-gradient(-45deg, transparent 6%, #fff 6%, #fff 11%, transparent 11%); 
  	color: #fff;
  	text-align: center;
  	padding: 12% 0;
}

.recruit-title{
  	font-family: "Big Shoulders Stencil", sans-serif;
  	font-optical-sizing: auto;
  	font-weight: 900%;
  	font-style: normal;
	font-size: 450%;
	color: rgba(255, 255, 255, 0.7); /* 白文字＋70%不透明 */
	letter-spacing: 3px;
}

.recruit-subtitle{
  	margin-top: 5%;
	font-weight: 700;
	font-size: 240%;
}


@media screen and (min-width:768px){
	.recruit-header{
		padding: 6% 0;
	}
	
	.recruit-title{
		font-size: 48px;
	}
	
	.recruit-subtitle{
		margin-top: 3%;
		font-size: 28px;
	}
}


@media screen and (min-width:980px){
	.recruit-header{
		background-image: 
     linear-gradient(135deg, transparent 6%, #fff 6%, #fff 10%, transparent 10%), 
     linear-gradient(-45deg, transparent 6%, #fff 6%, #fff 10%, transparent 10%); 
	}
	
	.recruit-header{
		padding: 4% 0;
	}
	
	.recruit-title{
		font-size: 48px;
	}
	
	.recruit-subtitle{
		margin-top: 1.5%;
		font-size: 28px;
	}
}


/*--- パンくず ---*/
.breadcrumb {
  	width: 94%;
  	margin: 5% auto 0;
  	font-size: 140%;
}

.breadcrumb ul {
  	display: flex;
  	flex-wrap: wrap;
  	align-items: center;
  	list-style: none;
  	padding: 0;
  	margin: 0;
}

.breadcrumb li {
  	display: flex;
  	align-items: center;
}

/* liの後ろに「|」を表示する */
.breadcrumb li + li::before {
  	content: "|";
  	margin: 0 0.5em;
}

@media (min-width: 768px){
  .breadcrumb {
    	width: 80%;
    	margin: 5% auto 0;
    	font-size: 16px;
  	}
}

@media (min-width: 980px){
  .breadcrumb {
    	width: 70%;
    	margin: 3% auto 0;
    	font-size: 18px;
  	}
}


/*---コンテンツ---*/
.recruit-list{
	width: 94%;
	margin: 0 auto;
	text-align: center;
}

.recruit-list-title{
	margin-top: 10%;
	font-weight: 600;
	font-size: 220%;
	color: #7FBE26;
	line-height: 1.6;
}

.recruit-list img{
	width: 17%;
	margin-top: 7%;
}


@media (min-width: 768px){
	.recruit-list{
		width: 80%;
	}
	
	.recruit-list-title{
		margin-top: 8%;
		font-size: 28px;
	}
	
	.recruit-list img{
		width: 13%;
		margin-top: 7%;
	}
}


@media (min-width: 980px){
	.recruit-list{
		width: 70%;
	}
	
	.recruit-list-title{
		margin-top: 8%;
		font-size: 32px;
	}
	
	.recruit-list img{
		width: 10%;
		margin-top: 5%;
	}
}


/*---メッセージ---*/
.recruitment-message{
	width: 94%;
	margin: 0% auto 0;
}

.message-text{
	margin-top: 8%;
	text-align: justify;
	font-size: 140%;
	line-height: 1.8;
}

.recruitment-message .flex{
	width: 95%;
	margin: 10% auto 0;
	display: flex;
  	flex-direction: column; /* モバイルでは縦並び */
	
}

.point p{
	font-size: 140%;
	line-height: 1.8;
	color: #e50012;
}

.js-slider-common{
	width: 90%;
	margin: 10% auto 0;
}

.js-slider-common img{
	width: 100%;
	height: auto;
  	display: block;
}


@media (min-width: 768px){
	.recruitment-message{
		width: 80%;
		margin: 0% auto 0;
	}
	
	.message-text{
		margin-top: 8%;
		font-size: 16px;
	}
	
	.recruitment-message .flex{
		width: 95%;
		margin: 8% auto 0;
		text-align: center;
	}
	
	.point p{
		font-size: 16px;
	}
	
	.js-slider-common{
		width: 90%;
		margin: 8% auto 0;
	}
}


@media (min-width: 980px){
	.recruitment-message{
		width: 70%;
		margin: 0% auto 0;
	}
	
	.message-text{
		margin-top: 8%;
		font-size: 18px;
	}
	
	.recruitment-message .flex{
		width: 95%;
		margin: 3% auto 0;
		align-items: center;
		flex-direction: row; /* PCでは横並び */
    	gap: 20px; /* セクション同士に適度な間隔をあけると良い */
	}
	
	.point{
		width: 55%;
	}
	
	.point p{
		font-size: 18px;
	}
	
	.js-slider-common{
		width: 45%;
		margin: 3% auto 0;
	}
}


/*---募集要項---*/
#recruitment-requirements{
	width: 94%;
	margin: 0% auto 0;
}

#recruitment-requirements h3{
	margin: 20% auto 0;
	font-weight: 600;
	font-size: 220%;
	text-align: center;
}

.recruit-box dl {
	width: 100%;
	margin: 10% auto 0;
}
	  
.recruit-box dl div{
	margin-top: 4%;
	border-bottom: 2px solid #d9d9d9;
}
	  
.recruit-box dl div:first-of-type{
	padding-top: 4%;
	border-top: 2px solid #d9d9d9;
}

.recruit-box dt {
	width: 5em;
    color: #84bc3d;
    float: left;
	text-align: center;
	font-weight: 600;
	font-size: 140%;
	line-height: 1.8;
}

.recruit-box dt .break-text {
	display: block; /* これで折り返しを実現 */
}

.recruit-box dt .dot {
	display: inline-block;
	margin: 0 0.2em;
}

.recruit-box dd{
    margin: 0 0 4% 0;
	/*margin-left: 25%;*/
	margin-left: 23%;
	font-weight: 400;
	font-size: 140%;
	line-height: 1.8;
}

.recruit-box dd p {
	/*margin: 0 0 4% 0;*/
	margin: 4% 0 0 0;
	line-height: 1.8;
}

.recruit-box dd p:first-of-type {
	margin: 0% 0 0 0;
	line-height: 1.8;
}

.recruit-box dd ul li {
	text-indent: -1em;
  	padding-left: 1em;
	line-height: 1.8;
}

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

.list-note {
  list-style: none; /* デフォルトマーカーを消す */
  padding-left: 1em;
}

.list-note li::before {
  content: '※';
  position: absolute;
  margin-left: -1em;
	
}
.list-note li {
  position: relative;
  line-height: 1.8;
	text-indent: 0em!important;
  	padding-left: 0em!important;
}


@media (min-width: 768px){
	#recruitment-requirements{
		width: 80%;
		margin: 0% auto 0;
	}
	
	#recruitment-requirements h3{
		margin: 10% auto 0;
		font-size: 26px;
	}
	
	.recruit-box dl {
		width: 100%;
		margin: 8% auto 0;
	}
	
	.recruit-box dl div{
		margin-top: 3%;
	}
	  
	.recruit-box dl div:first-of-type{
		padding-top: 3%;
	}
	
	.recruit-box dt {
		width: 5em;
		padding-left: 1em;
		font-size: 16px;
	}
	
	.recruit-box dd {
    	margin: 0 0 3% 0;
		margin-left: 25%;
		font-size: 16px;
	}
}


@media (min-width: 980px){
	#recruitment-requirements{
		width: 70%;
		margin: 0% auto 0;
	}
	
	#recruitment-requirements h3{
		margin: 8% auto 0;
		font-size: 28px;
	}
	
	.recruit-box dl {
		width: 80%;
		margin: 5% auto 0;
	}
	
	.recruit-box dl div{
		margin-top: 2%;
	}
	  
	.recruit-box dl div:first-of-type{
		padding-top: 2%;
	}
	
	.recruit-box dt {
		width: 5em;
		padding-left: 1em;
		font-size: 16px;
	}
	
	.recruit-box dd {
    	margin: 0 0 2% 0;
		margin-left: 17%;
		font-size: 16px;
	}
}


/*---.mail_form---*/
@keyframes underlinePulse {
  0%   { width: 0; opacity: 0; }
  50%  { width: 100%; opacity: 1; }
  100% { width: 0; opacity: 0; }
}

.mail_form {
  position: relative;
  /*display: inline-block;*/
	display: inline;
  color: #7fbe26!important;
  text-decoration: none;
  font-weight: 600;
  padding-bottom: 2px;
}

.mail_form::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  height: 2px;
  background-color: #7fbe26;
  animation: underlinePulse 2.5s ease-in-out infinite;
}

/* PC（hover対応デバイス）ではアニメーションを停止し、hover演出に切替 */
@media screen and (hover: hover) {
  .mail_form::after {
    width: 0;
    animation: none;
    transition: width 0.3s ease;
  }

  .mail_form:hover::after {
    width: 100%;
  }

  .mail_form:hover {
    color: #5fae20;
  }
}
	
	
/*---リクルートサイトへのボタン---*/
.recruit-button-wrapper {
  	text-align: center;
  	margin-top: 10%;
}

.recruit-button {
	display: inline-flex;
  	align-items: center;
  	gap: 0.5em;
  	padding: 1em 2em;
  	border: 2px solid #7fbe26;
  	background: transparent;
  	color: #7fbe26!important;
  	border-radius: 30px;
	font-weight: 600;
  	font-size: 120%;
  	position: relative;
  	overflow: hidden;
  	transition: all 0.3s ease;
}

.recruit-button span {
  	z-index: 1;
  	position: relative;
}

.recruit-button::before {
  	content: '';
  	position: absolute;
  	left: 0;
  	bottom: 0;
  	width: 100%;
  	height: 0%;
  	background: #7fbe26;
  	z-index: 0;
  	transition: height 0.3s ease;
}

.recruit-button:hover {
  	color: #fff!important;
 	transform: translateY(-2px);
  	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
}

.recruit-button:hover::before {
  	height: 100%;
}

.recruit-button svg {
  	transition: transform 0.3s ease;
}

.recruit-button:hover svg {
  	transform: translateX(4px);
}

/* レスポンシブ対応 */
@media (min-width: 768px){
	.recruit-button-wrapper {
  		margin-top: 7%;
	}
	
	.recruit-button {
    	font-size: 16px;
    	padding: 1em 2.5em;
  	}
}

@media (min-width: 980px){
	.recruit-button-wrapper {
  		margin-top: 5%;
	}
	
	.recruit-button {
    	font-size: 16px;
    	border-radius: 50px;
  	}
}




/*---ページ下部常時表示---*/
.sp-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: #fff; /* 必要に応じて背景色を設定 */
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 5px 0;
  z-index: 9999;
  box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.1); /* 上にうっすら影 */
}

.sp-nav a {
  flex: 1;
  text-align: center;
}

.sp-nav img {
  width: 100%;
  max-width: 120px; /* 必要に応じてサイズ調整 */
  height: auto;
}


@media (min-width: 768px){
	.sp-nav {
    	padding: 8px 0;
  	}
	
	.sp-nav img {
  		max-width: 160px; /* 必要に応じてサイズ調整 */
	}
}


/* PC表示では非表示 */
@media (min-width: 980px) {
  .sp-nav {
    display: none;
  }
}




