@charset "utf-8";
/* CSS Document */

/*共通 *****************************************************************/
#recruit .fukidashi {
	background: var(--color-gr-01); border-radius: 12px; text-align: center; color: #fff; line-height: 1; position: relative; }
#recruit .fukidashi::before {
	content: ""; display: inline-block; width: 24px; height: 24px; background: url("images/icon-fukidashi.svg") bottom left / contain no-repeat; position: absolute; left: calc(100% - 15px); bottom: 1px; }
#recruit .fukidashi p { position: relative; z-index: 5; }





/*概要 *****************************************************************/
#summary { overflow: hidden; }
#summary > .bg-img { height: 35%; }
#summary .bg-img01 {
	background-image: url("images/summary-bg01.png"); left: 4%; }
#summary .bg-img02 {
	background-image: url("images/summary-bg02.png"); top: unset; bottom: 0; right: -32%; left: unset; }
#summary .cont-wrap {
	justify-content: center; flex-wrap: wrap; gap: 0 5%; max-width: 1200px; padding-bottom: 88px; }

/*人と接するのが～ --------------------*/
#summary .title-area { width: 100%; padding-left: 1%; }
#summary h2 {
	font-size: clamp(2.8rem, 1.5vw + 1.5rem, 3.5rem); letter-spacing: 0; color: var(--color-toto); text-shadow: 2px 2px 0 #FFF, -2px -2px 0 #FFF, -2px 2px 0 #FFF, 2px -2px 0 #FFF, 0px 2px 0 #FFF,  0 -2px 0 #FFF, -2px 0 0 #FFF, 2px 0 0 #FFF; }

/*ポイントリスト --------------------*/
#summary .text-area {
	flex-direction: column; width: 600px; position: relative; z-index: 5; }
#summary .point-list .item {
	align-items: flex-start; gap: 0 16px; margin-top: 32px; position: relative; }
#summary .point-list .fukidashi {
	padding: 4px 16px; font-size: var(--font-size-02); letter-spacing: .1em; }
#summary .point-list .text h3 { font-size: var(--font-size-04); }
#summary .point-list .text p { line-height: 1.5; font-size: var(--font-size-03); }

/*画像リスト --------------------*/
#summary .image-area { width: calc(95% - 600px); position: relative; z-index: -1; }
#summary .image-area .image {
	aspect-ratio: 1; clip-path: circle(50% at 50% 50%); position: absolute; }
#summary .image-area .image01 {
	width: 85%; min-width: 400px; top: -64%; right: -8%; }
#summary .image-area .image02 {
	width: 60%; min-width: 240px; bottom: -18%; left: -18%; z-index: 2; }
#summary .image-area .image01 .bg-img { background-image: url("images/summary-img01.webp"); }
#summary .image-area .image02 .bg-img { background-image: url("images/summary-img02.webp"); }

@media (min-width: 1921px) {
	#summary .bg-img02 { right: -24%; }
}

@media (max-width: 960px) {
	#summary > .bg-img { height: 168px; }
	#summary .bg-img01 { left: 0; background-position: left; }
	#summary h2 { font-size: clamp(2.6rem, 2.2vw + 1.5rem, 3.5rem); }
	#summary .text-area { width: 100%; max-width: 416px; }
	#summary .point-list .item { flex-wrap: wrap; }
	#summary .point-list .text { width: 100%; }
	#summary .title-area { margin-left: -2%; }
	#summary .cont-wrap { justify-content: flex-start; }
	#summary .image-area { width: 100%; position: unset; }
	#summary .image-area .image01 { width: 45%; min-width: 468px; top: -2%; right: -2%; }
	#summary .image-area .image02 {
		width: 24%; min-width: 264px; bottom: 8%; left: unset; right: 4%; }
}

@media (max-width: 834px) {
	#summary .point-list .text p br { display: none; }
}

@media (max-width: 767px) {
	#summary .title-area { order: 1; margin-bottom: 48px; }
	#summary .text-area { order: 3; }
	#summary .point-list .fukidashi { font-size: var(--font-size-04); }
	#summary .image-area { order: 2; }
	#summary .image-area .image01 { width: 65%; right: -5%; }
	#summary .image-area .image02 { width: 34%; min-width: auto; top: 43%; bottom: unset; right: -2%; }
}
@media (max-width: 600px) {
	#summary h2 { margin-top: 0; }
	#summary .image-area .image01 { min-width: 360px; }
	#summary .image-area .image02 { min-width: 200px; top: 35%; right: 3%; }
}
@media (max-width: 428px) {
	#summary .cont-wrap { padding-top: 88px; }
	#summary .title-area { margin-bottom: 8px; }
	#summary .image-area .image01 { min-width: 280px; top: -2%; right: -8%; }
	#summary .image-area .image02 { min-width: 160px; top: 28%; right: -2%; }
}





/*仕事の内容・流れ *****************************************************************/
#detail > .bg-img { background-image: url("../assets/images/bg-white-wave.webp"); }
#detail .cont-wrap {
	justify-content: space-between; align-items: flex-start; padding-bottom: 88px; }

/*画像リスト --------------------*/
#detail .image-area { flex-wrap: wrap; width: 32%; }
#detail .image-area .bg-box {
	width: 100%; aspect-ratio: 1.5 / 1; margin-bottom: 16px; }
#detail .image-area .bg-box:last-child { margin-bottom: 0; }
#detail .image-area .image01 .bg-img {
	background-image: url("images/detail-img01.webp"); }
#detail .image-area .image02 .bg-img {
	background-image: url("images/detail-img02.webp"); }
#detail .image-area .image03 .bg-img {
	background-image: url("images/detail-img03.webp"); }

/*本文エリア --------------------*/
#detail .text-area { width: 64%; }
#detail .text-area h3 {
	display: inline-block; padding: 4px 8%; background: var(--color-toto); font-size: var(--font-size-04);  color: #fff; }
#detail .text-area .inner {
	padding: 24px 6% 32px; border-radius: var(--border-radius-reg); background: #ffffffcc; }
/*仕事内容 -----*/
#detail .text-area .inner01 { margin-bottom: 24px; }
#detail .text-area .inner01 h3 { margin-bottom: 16px; }
#detail .text-area .text { text-align: justify; }
/*入社後の流れ -----*/
#detail .text-area .inner02 .item {	justify-content: space-between; }
#detail .text-area .inner02 .flow01 .circle,
#detail .text-area .inner02 .flow01 .text { padding-top: 32px; }
#detail .text-area .inner02 .flow01 .fukidashi-area { padding-top: 20px; }
#detail .text-area .inner02 .flow02 .circle,
#detail .text-area .inner02 .flow02 .text { padding-top: 16px; }
#detail .text-area .inner02 .flow02 .fukidashi-area { padding-top: 4px; }
#detail .text-area .inner02 .flow03 .circle,
#detail .text-area .inner02 .flow03 .text {
	padding-top: 48px; padding-bottom: 48px; }
#detail .text-area .inner02 .flow04 .circle,
#detail .text-area .inner02 .flow04 .text { margin-top: -8px; }
#detail .text-area .inner02 .flow04 .fukidashi-area { margin-top: -32px; }
/*吹き出し*/
#detail .text-area .inner02 .fukidashi-area { width: 80px; }
#detail .text-area .inner02 .fukidashi {
	padding: 6px 8px 8px; font-size: var(--font-size-02); }
#detail .text-area .inner02 .flow04 .fukidashi {
	padding-top: 8px; line-height: 1.2; }
#detail .text-area .inner02 .fukidashi .text-strong {
	font-size: var(--font-size-06); }
/*丸と線*/
#detail .text-area .inner02 .circle {
	width: 3px; margin: 0 32px 0 24px;  background: var(--color-font-reg); position: relative; }
#detail .text-area .inner02 .flow04 .circle { background: transparent; }
#detail .text-area .inner02 .circle::before {
	content: ""; display: block; width: 20px; height: 20px; aspect-ratio: 1; margin: 2px 4% 0 3%; border-radius: 40px; background: var(--color-font-reg); position: absolute; left: 50%; translate: -50%; }
/*本文*/
#detail .text-area .inner02 .text { width: calc(100% - 139px); }
#detail .text-area .inner02 h4 {
	margin-bottom: 4px; font-size: var(--font-size-04); line-height: 1.4; }

@media (max-width: 834px) {
	#detail .cont-wrap { flex-wrap: wrap; justify-content: center; }
	#detail .image-area,
	#detail .text-area { width: 100%; max-width: 640px; }
	
	#detail .image-area { order: 2; }
	#detail .image-area { gap: 0 2%; margin-top: 40px; }
	#detail .image-area .bg-box { width: 49%; }
	
	#detail .text-area { order: 1; }
	#detail .text-area .inner { position: relative; }
	#detail .text-area .inner h3 {
    margin-bottom: 16px; position: absolute; left: 50%; top: 0; translate: -50% 0; }
	#recruit #detail .fukidashi::before { scale: -1 1; left: -10px; }
	
	#detail .text-area .inner01 { padding-top: 64px; }
	#detail .text-area .inner02 { padding-top: 0; }
	
	#detail .text-area .inner02 .item  { position: relative; }
	#detail .text-area .inner02 .fukidashi-area { position: absolute; left: 304px; }
	#detail .text-area .inner02 .flow01 .fukidashi-area {
		padding-top: 0; bottom: 8px; }
	#detail .text-area .inner02 .flow01 .circle,
	#detail .text-area .inner02 .flow01 .text { padding-top: 72px; }
	#detail .text-area .inner02 .flow02 .fukidashi-area { padding-top: 0; }
	#detail .text-area .inner02 .flow04 .fukidashi-area {
		margin-top: 0; top: -36px; }
	#detail .text-area .inner02 .circle { margin-left: 0; margin-right: 20px; }
	#detail .text-area .inner02 .text { width: calc(100% - 23px); }
}
@media (max-width: 600px) {
	#detail .cont-wrap { padding-top: 48px; padding-bottom: 56px; }
	#detail .text-area .inner02 .fukidashi-area { right: -4px; left: unset; }
}
@media (max-width: 520px) {
	#detail .image-area { gap: 0; }
	#detail .image-area .bg-box { width: 100%; }
	#detail .text-area .inner02 .flow02 .fukidashi-area { top: 24px; }
}




/*募集要項 *****************************************************************/
#requirements > .bg-img { background-image: url("images/requirements-bg.webp"); }
#requirements > .bg-img::after { 
	content: ""; display: block; width: 100%; height: 100%; background: #00000088; position: absolute; left: 0; top: 0; z-index: -1; }

#requirements .cont-wrap { padding-bottom: 88px; }
#requirements .inner {
	justify-content: space-between; padding: 56px 6%; border-radius: var(--border-radius-reg); background: #ffffffd5; }
#requirements .table-area { width: 65%; }
#requirements .table-area h2 { margin-top: 0; }
#requirements .table-parts {
	padding: 16px 0; border-bottom: 2px solid #fff; }
#requirements .table-title { width: 120px; padding-left: 8px; letter-spacing: .1em; }
#requirements .table-text { width: calc(100% - 120px); padding-right: 8px; }

#requirements .image-area { width: 30%; }
#requirements .image-area .bg-img {
	background-image: url("images/requirements-img.webp"); background-position: center top; z-index: 0; }

@media (max-width: 834px) {
	#requirements > .bg-img { display: none; }
	#requirements .cont-wrap { width: 100%; }
	#requirements .inner { padding-top: 0; padding-bottom: 0; background: none; }
	#requirements .table-parts { border-bottom: 1px solid var(--color-gy-01); }
}
@media (max-width: 767px) {
	#requirements .inner { flex-wrap: wrap; justify-content: center; }
	#requirements .table-area,
	#requirements .image-area { width: 100%; }
	#requirements .image-area {
		width: 300px; aspect-ratio: 1 / 1.5; margin-top: 32px; }
}
@media (max-width: 600px) {
	#requirements .cont-wrap { padding-top: 48px; }
}
@media (max-width: 520px) {
	#requirements .cont-wrap { max-width: 480px; }
	#requirements .table-area h2 { text-align: center; }
	#requirements .table-parts { flex-wrap: wrap; padding: 8px 0; }
	#requirements .table-title,
	#requirements .table-text { width: 100%; }
	#requirements .table-title { font-weight: bold; }
	#requirements .table-title br { display: none; }
	#requirements .table-text { padding-left: 24px; }
}






