@charset "UTF-8";
/* ---------------------------------------
  TOA-TONEの仕事
-----------------------------------------*/
/* page_ttl
--------------------------------*/
#page_ttl .page_head {
	background-color: #FFE41B;
}
#page_ttl .ttl .en .deco::before {
	width: 7.15rem;
	height: 6.65rem;
	background-image: url(../../img/recruit/work/works_ttl_deco.png);
	right: 0.8rem;
	top: -1rem;
}
@media screen and (max-width: 767px) {
	#page_ttl .ttl .en .deco::before {
		width: 4.1rem;
		height: 3.85rem;
		right: 0.4rem;
		top: -0.8rem;
	}
}

/* sec_works
--------------------------------*/
#sec_works .works_nav {
	padding: 6.4rem 0 1.6rem;
	background-color: #FEFEFE;
	z-index: 10;
}
@media screen and (min-width: 768px) {
	#sec_works .works_nav {
		position: sticky;
		top: 0;
	}
}
@media screen and (max-width: 767px) {
	#sec_works .works_nav {
		padding: 6.3rem 2.4rem 2rem;
		transition: transform 0.3s ease-in-out;
	}
	#sec_works .works_nav.is-clone {
		padding-top: 9.6rem;
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		z-index: 10;
		transform: translateY(-100%);
		transition: transform 0.3s ease-in-out;
	}
	#sec_works .works_nav.is-clone.is-fixed.is-show {
		transform: translateY(0);
	}
}
#sec_works .works_nav .list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 4rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_nav .list {
		flex-direction: column;
		gap: 2rem 0;
	}
}
#sec_works .works_nav .list li {
	font-family: "Dela Gothic One", sans-serif;
	font-size: 3.2rem;
	line-height: 1.3125;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
	#sec_works .works_nav .list li {
		font-size: 2rem;
		line-height: 1;
		letter-spacing: 0.1em;
	}
}
#sec_works .works_nav .list li a {
	display: block;
	padding-left: 7.6rem;
	position: relative;
}
@media screen and (max-width: 767px) {
	#sec_works .works_nav .list li a {
		padding-left: 4rem;
	}
}
#sec_works .works_nav .list li a::before {
	content: "";
	width: 6.4rem;
	height: 2.5rem;
	background-color: #1A1A1A;
	mask-image: url(../../img/recruit/work/pagenav_arw_bg.svg);
	-webkit-mask-image: url(../../img/recruit/work/pagenav_arw_bg.svg);
	mask-repeat: no-repeat;
	-webkit-mask-repeat: no-repeat;
	mask-size: 100% 100%;
	-webkit-mask-size: 100% 100%;
	mask-position: center;
	-webkit-mask-position: center;
	position: absolute;
	left: 0;
	top: 0.9rem;
	transition: background-color 0.3s ease-out;
}
@media screen and (max-width: 767px) {
	#sec_works .works_nav .list li a::before {
		width: 3.2rem;
		height: 1.2rem;
		top: 0.4rem;
	}
}
#sec_works .works_nav .list li a::after {
	content: "";
	width: 1.8rem;
	height: 1.1rem;
	background: url(../../img/recruit/work/pagenav_arw.svg) no-repeat center/contain;
	position: absolute;
	left: 2.3rem;
	top: 1.7rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_nav .list li a::after {
		width: 0.5rem;
		height: 0.9rem;
		margin-left: 0.8rem;
	}
}
#sec_works .works_nav .list li a:hover::before, #sec_works .works_nav .list li a.is-current::before, #sec_works .works_nav .list li a.is-active::before {
	background-color: #FD7D05;
}
#sec_works .works_contents {
	position: relative;
	z-index: 1;
	margin-top: 10rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_contents {
		margin-top: 6.5rem;
	}
}
#sec_works .works_section {
	padding: 8.5rem 7.7rem 10rem;
	border: 0.3rem solid #1A1A1A;
	border-radius: 3.2rem;
	position: relative;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section {
		padding: 4.1rem 2.1rem 4.5rem;
		border-radius: 2.4rem;
	}
}
#sec_works .works_section + .works_section {
	margin-top: 11rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section + .works_section {
		margin-top: 5rem;
	}
}
#sec_works .works_section::before {
	content: "";
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	position: absolute;
	z-index: -1;
}
#sec_works .works_section .mascot {
	position: absolute;
}
#sec_works .works_section .intro {
	display: flex;
	align-items: flex-start;
	gap: 0 3.2rem;
	padding: 0 0 6.4rem;
	border-bottom: 0.4rem dotted #C1C1C1;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .intro {
		flex-direction: column;
		gap: 3.2rem 0;
		padding: 0 0 3.2rem;
		border-width: 0.2rem;
	}
}
#sec_works .works_section .intro .ttl_wrap {
	width: 56rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .intro .ttl_wrap {
		width: 100%;
	}
}
#sec_works .works_section .intro .ttl_wrap .sec_ttl {
	font-size: 5.6rem;
	line-height: 1.3035714286;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .intro .ttl_wrap .sec_ttl {
		font-size: 3.2rem;
		line-height: 1.3125;
	}
}
#sec_works .works_section .intro .ttl_wrap .txt_lead {
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.4166666667;
	margin-top: 1em;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .intro .ttl_wrap .txt_lead {
		font-size: 2rem;
		line-height: 1.5;
		margin-top: 1.6rem;
	}
}
#sec_works .works_section .intro .txt_wrap {
	flex: 1;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .intro .txt_wrap {
		width: 100%;
	}
}
#sec_works .works_section .intro .txt_wrap .txt {
	font-size: 2rem;
	line-height: 2.1;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .intro .txt_wrap .txt {
		font-size: 1.5rem;
		line-height: 1.7333333333;
	}
}
#sec_works .works_section .works_list {
	margin-top: 6.4rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list {
		margin-top: 3.2rem;
	}
}
#sec_works .works_section .works_list .item {
	display: flex;
	align-items: flex-start;
	gap: 0 4.8rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item {
		flex-direction: column;
		gap: 1.6rem 0;
	}
}
#sec_works .works_section .works_list .item + .item {
	margin-top: 8rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item + .item {
		margin-top: 4rem;
	}
}
#sec_works .works_section .works_list .item .txt_wrap {
	width: 62.4rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item .txt_wrap {
		width: 100%;
	}
}
#sec_works .works_section .works_list .item .txt_wrap .department_label {
	display: inline-block;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.2;
	letter-spacing: 0.05em;
	padding: 0.4rem 1.2rem 0.5rem;
	border-radius: 100vh;
	margin-top: 0.9rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item .txt_wrap .department_label {
		font-size: 1.5rem;
		line-height: 1.2;
		padding: 0.5rem 0.8rem;
	}
}
#sec_works .works_section .works_list .item .txt_wrap .ttl {
	font-size: 4.8rem;
	line-height: 1.3958333333;
	letter-spacing: 0.05em;
	margin-top: 1.2rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item .txt_wrap .ttl {
		font-size: 2.8rem;
		line-height: 1;
		letter-spacing: 0.1em;
	}
}
#sec_works .works_section .works_list .item .txt_wrap .ttl .fukidashi {
	display: inline-block;
	width: 9.5rem;
	position: absolute;
	translate: -6.5rem -5.6rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item .txt_wrap .ttl .fukidashi {
		width: 8rem;
		translate: -4rem -3.8rem;
	}
}
#sec_works .works_section .works_list .item .txt_wrap .txt {
	font-size: 1.8rem;
	margin-top: 2.4rem;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item .txt_wrap .txt {
		font-size: 1.5rem;
		line-height: 1.7333333333;
		margin-top: 1.6rem;
	}
}
#sec_works .works_section .works_list .item .img {
	flex: 1;
	aspect-ratio: 480/416;
	border-radius: 2.4rem;
	overflow: hidden;
}
@media screen and (max-width: 767px) {
	#sec_works .works_section .works_list .item .img {
		width: 100%;
		border-radius: 1.6rem;
	}
}
#sec_works .works_section .works_list .item .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
#sec_works #works01::before {
	width: 28.8rem;
	height: 28.8rem;
	background-image: url(../../img/recruit/work/works01_ob.svg);
	left: -6rem;
	top: -10rem;
}
@media screen and (max-width: 767px) {
	#sec_works #works01::before {
		width: 12rem;
		height: 12rem;
		left: -3.4rem;
		top: -5.7rem;
	}
}
#sec_works #works01 .mascot {
	width: 23.9rem;
	right: 2.8rem;
	top: -6.8rem;
}
@media screen and (max-width: 767px) {
	#sec_works #works01 .mascot {
		width: 15.6rem;
		right: -1rem;
		top: -5.7rem;
	}
}
#sec_works #works02::before {
	width: 27.7rem;
	height: 27.7rem;
	background-image: url(../../img/recruit/work/works02_ob.svg);
	left: -5rem;
	top: -10rem;
}
@media screen and (max-width: 767px) {
	#sec_works #works02::before {
		width: 12.6em;
		height: 12.6em;
		left: -3.4rem;
		top: -3.6rem;
	}
}
#sec_works #works02 .mascot {
	width: 18.6rem;
	right: 2.5rem;
	top: -7.1rem;
}
@media screen and (max-width: 767px) {
	#sec_works #works02 .mascot {
		width: 11.2rem;
		right: 1.2rem;
		top: -4.3rem;
	}
}
#sec_works #works03::before {
	width: 24.4rem;
	height: 24.4rem;
	background-image: url(../../img/recruit/work/works03_ob.svg);
	left: -9rem;
	top: -7rem;
}
@media screen and (max-width: 767px) {
	#sec_works #works03::before {
		width: 14.3rem;
		height: 14.3rem;
		left: -5.4rem;
		top: -3.7rem;
	}
}
#sec_works #works03 .mascot {
	width: 23.95rem;
	right: 2.5rem;
	top: -9.1rem;
}
@media screen and (max-width: 767px) {
	#sec_works #works03 .mascot {
		width: 16.5rem;
		right: 1.2rem;
		top: -5.2rem;
	}
}