@charset "utf-8";

.p-home {
	position: relative;
	overflow: hidden;
	padding: 0;
}

.l-header.-home:not(.is-active) .title,
.l-header.-home:not(.is-active)::before {
	transform: translateY(-64px);
}
.l-header.is-anim .title,
.l-header.is-anim::before {
	transition: transform .4s cubic-bezier(.3,1,.7,1);)
}
@media screen and (max-width: 479px) {
	.l-header.-home:not(.is-active) .title,
	.l-header.-home:not(.is-active)::before {
		transform: translateY(-48px);
	}
}

/**
 * キービジュアル
 * ---------------------------------------- */
.p-kv {
	position: relative;
	padding-bottom: 96px;
	text-align: center;
	background: #27b53a url(../img/bg_title.png) center top / 125px 125px;
}
.p-kv::before {
	content: "";
	z-index: 1;
	position: absolute;
	inset: 0;
	background: radial-gradient(rgba(0,0,0,0) 50%, rgba(0,0,0,.3) 150%) center / 150% 100%;
	mix-blend-mode: color-burn;
}
.kv_main {
	position: relative;
	height: 770px;
	padding-top: 64px;
}
.kv_main .glitch {
	position: absolute;
}
.kv_main .title,
.kv_main .lead,
.kv_main .keyvisual {
	z-index: 1;
}
.kv_main .title {
	display: grid;
	place-items: center;
	position: relative;
	font-size: 1em;
	line-height: 1;
}
.kv_main .title .main {
	margin-top: 24px;
}
.kv_layer {
	will-change: transform;
}
/* システムを乗りこなせ。次の時代の騎手になれ。 */
.kv_main .lead {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	row-gap: 14px;
	position: absolute;
	top: calc(50% - 130px);
	right: calc(50% - 320px);
	line-height: 1;
	text-align: left;
	text-orientation: upright;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}
.kv_main .lead .l {
	position: relative;
	width: 20px;
}
.kv_main .lead .-l2 {
	margin-top: 1em;
}
.kv_main .lead .l::before {
	content: "";
	position: absolute;
	inset: 0;
	background: currentcolor;
}
/* 人物 */
.kv_main .keyvisual {
	position: absolute;
	top: 45%;
	left: calc(50% - 288px);
	width: 504px;
}
.kv_main .keyvisual .obj {
	position: absolute;
}
.kv_main .keyvisual .main {
	display: block;
	z-index: 1;
	position: relative;
	width: 100%;
}
.kv_main .keyvisual .effect {
	position: absolute;
	top: 10%;
	left: -23%;
	width: 104.8%;
	max-width: none;
}
.kv_main .keyvisual .sub {
	display: block;
	top: 0;
	width: 100%;
}
.kv_main .keyvisual .paper {
	top: -1.6%;
	right: 87%;
	width: 78.8%;
}
.kv_main .keyvisual .pc {
	top: 9.5%;
	right: 79%;
	width: 14.3%;
}
.kv_main .keyvisual .tablet {
	top: 7.9%;
	right: 99%;
	width: 6.35%;
}
/* パーティクル */
.kv_main .bg {
	position: absolute;
	inset: 0;
	background: #fafafa url(../img/bg_noise.png) center top / 125px 125px;
	-webkit-mask-image: url(../img/mask_kv.svg);
	-webkit-mask-size: 100% 100%;
	mask-image: url(../img/mask_kv.svg);
	mask-size: 100% 100%;
}
.kv_main .bg_canvas {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	height: 50%;
	-webkit-mask-image: url(../img/mask_grad.svg);
	-webkit-mask-size: 100% 100%;
	mask-image: url(../img/mask_grad.svg);
	mask-size: 100% 100%;
}
.kv_main .bg_canvas::after {
	content: "";
	position: absolute;
	inset: 0;
	background: url(../img/kv_pixel.svg) center bottom / 2000px 300px no-repeat;
	opacity: .4;
}
@media screen and (max-width: 767px) {
	.p-kv {
		padding-bottom: 40px;
	}
	.kv_main {
		height: calc(770vw / 7.68);
		min-height: 600px;
	}
	.kv_main .title .main {
		max-width: calc(400vw / 7.68);
		margin-top: calc(24vw / 7.68);
	}
	.kv_main .lead {
		row-gap: calc(14vw / 7.68);
		top: 48%;
		right: calc(64vw / 7.68);
		max-width: calc(55vw / 7.68);
	}
	.kv_main .lead .l {
		width: calc(20vw / 7.68);
	}
	.kv_main .keyvisual {
		top: 48%;
		left: calc(50% - 288vw / 7.68);
		width: calc(504vw / 7.68);
	}
	.kv_main .bg {
		-webkit-mask-image: url(../img/mask_kv_mb.svg);
		mask-image: url(../img/mask_kv_mb.svg);
	}
	.kv_main .bg_canvas::after {
		background-size: 1500px 225px;
	}
}
@media screen and (max-width: 479px) {
	.kv_main .title {
		position: absolute;
		bottom: 55%;
		left: 0;
		width: 100%;
	}
	.kv_main .title .main {
		max-width: calc(278vw / 3.75);
		margin-top: calc(16vw / 3.75);
	}
	.kv_main .lead {
		row-gap: calc(8vw / 3.75);
		right: calc(24vw / 3.75);
		max-width: calc(32vw / 3.75);
	}
	.kv_main .lead .l {
		width: calc(12vw / 3.75);
	}
	.kv_main .keyvisual {
		top: 50%;
		left: calc(50% - 154vw / 3.75);
		width: calc(264vw / 3.75);
	}
	.kv_main .bg_canvas::after {
		background-size: 1500px 225px;
	}
}
@media screen and (max-width: 374px) {
	.kv_main {
		height: calc(600vw / 3.75);
		min-height: 0;
		padding-top: 56px;
	}
}

/* :::::: opening :::::: */
.kv_main .title:not(.is-active) {
	opacity: 0;
	transform: translateX(-120px);
}
.kv_main .title.is-active .main {
	position: relative;
}
.kv_main .title.is-anim {
	transition: opacity 1s, transform 1s;
}
.kv_main .title.is-anim .glitch {
	animation: glitchAnim 1s steps(1) 1 alternate;
}

.kv_main .lead .l::before {
	transform-origin: center bottom;
}
.kv_main .lead:not(.is-active) .l {
	clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
}
.kv_main .lead.is-active .l {
	clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.kv_main .lead.is-active .l::before {
	transform: scaleY(0);
}
.kv_main .lead.is-anim .l {
	transition: clip-path .4s cubic-bezier(.3,1,.7,1);
}
.kv_main .lead.is-anim .l::before {
	transition: transform .5s cubic-bezier(.3,1,.7,1);
}
.kv_main .lead.is-anim .l.-l1 { transition-delay: .3s; }
.kv_main .lead.is-anim .l.-l2 { transition-delay: .4s; }
.kv_main .lead.is-anim .l.-l1::before { transition-delay: .6s; }
.kv_main .lead.is-anim .l.-l2::before { transition-delay: .7s; }
.kv_main .lead.is-glitch .glitch {
	animation: glitchAnim 1s steps(1) 1 alternate;
}

.kv_main .keyvisual:not(.is-active) .main,
.kv_main .keyvisual:not(.is-active) .effect {
	opacity: 0;
}
.kv_main .keyvisual:not(.is-active) .main {
	transform: translateX(-200px);
}
.kv_main .keyvisual:not(.is-active) .effect {
	transform: translateX(-80px);
}
.kv_main .keyvisual.is-anim .main .glitch {
	animation: glitchAnim 1s steps(1) 2;
}
.kv_main .keyvisual.is-active .main .effect img {
	animation: blinkEffect 2s steps(2) 1 alternate;
}
.kv_main .keyvisual:not(.is-active) .paper,
.kv_main .keyvisual:not(.is-active) .tablet,
.kv_main .keyvisual:not(.is-active) .pc {
	opacity: 0;
}
.kv_main .keyvisual:not(.is-active) .paper {
	transform: translateX(-120px);
}
.kv_main .keyvisual:not(.is-active) .tablet {
	transform: translateX(-140px);
}
.kv_main .keyvisual:not(.is-active) .pc {
	transform: translateX(-160px);
}
.kv_main .keyvisual.is-anim .main,
.kv_main .keyvisual.is-anim .effect,
.kv_main .keyvisual.is-anim .pc,
.kv_main .keyvisual.is-anim .tablet ,
.kv_main .keyvisual.is-anim .paper{
	transition: opacity 1s, transform 1s cubic-bezier(.3,1,.7,1);
}
.kv_main .keyvisual.is-anim .effect { transition-delay: .2s; }
.kv_main .keyvisual.is-anim .pc { transition-delay: .4s; }
.kv_main .keyvisual.is-anim .tablet { transition-delay: .45s; }
.kv_main .keyvisual.is-anim .paper { transition-delay: .5s; }

.kv_main .bg:not(.is-active) .bg_canvas {
	opacity: 0;
	transform: translateY(80px);
}
.kv_main .bg.is-anim .bg_canvas {
	transition: opacity 3s, transform 3s cubic-bezier(.3,1,.7,1);
}
@keyframes blinkEffect {
	from { opacity: .6; }
	28%{ opacity: .8; }
	30% { opacity: .2; }
	31%,
	50% { opacity: .6; }
	52% { opacity: .4; }
	56%,
	90% { opacity: 1; }
	91% { opacity: .5; }
	96% { opacity: 1; }
	to { opacity: .9; }
}
@keyframes glitchAnim {
	0% { clip: rect(80px,1000px,90px,0); }
	5% { clip: rect(24px,1000px,24px,0); transform: translate(-6px,6px); }
	6% { clip: rect(48px,1000px,48px,0); opacity: .5; }
	10% { clip: rect(48px,1000px,56px,0); opacity: .6; }
	15% { clip: rect(40px,1000px,48px,0); }
	20% { clip: rect(64px,1000px,64px,0); }
	25% { clip: rect(68px,1000px,72px,0); transform: translate(3px,-3px); }
	30% { clip: rect(82px,1000px,88px,0); }
	34% { clip: rect(160px,1000px,184px,0); }
	35% { clip: rect(32px,1000px,40px,0); transform: translate(-8px,8px); }
	40% { clip: rect(48px,1000px,56px,0); opacity: .3; }
	45% { clip: rect(24px,1000px,32px,0); transform: translate(-5px,5px); }
	50% { clip: rect(52px,1000px,56px,0); opacity: .8; }
	55% { clip: rect(8px,1000px,16px,0); }
	60% { clip: rect(160px,1000px,176px,0); }
	65% { clip: rect(48px,1000px,56px,0); transform: translate(4px,-4px); }
	70% { clip: rect(28px,1000px,32px,0); }
	75% { clip: rect(80px,1000px,88px,0); transform: translate(2px,-2px); }
	80% { clip: rect(20px,1000px,24px,0); }
	84% { clip: rect(24px,1000px,32px,0); opacity: 1; }
	85% { clip: rect(48px,1000px,56px,0);  opacity: .4;}
	90% { clip: rect(92px,1000px,96px,0); opacity: .2; }
	95% { clip: rect(32px,1000px,40px,0); transform: translate(-2px,2px); }
	to { clip: rect(4px,1000px,8px,0); }
}

/* :::::: Message :::::: */
.p-kv .label_title {
	margin-top: 80px;
}
.kv_copy {
	z-index: 1;
	position: relative;
	margin: 40px auto 0;
	font-feature-settings: "pkna";
	text-align: left;
	text-orientation: upright;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	white-space: nowrap;
}
.kv_copy .catchcopy {
	font-size: 39px;
	line-height: 1.4;
	font-family: "Midashi Go MB31", sans-serif;
	font-weight: 700;
}
.kv_copy .copy {
	font-size: 18px;
	line-height: 1.8;
	font-family: "Midashi Go MB31", sans-serif;
}
@media screen and (min-width: 768px) {
	.kv_copy {
		width: 672px;
	}
	.kv_copy .catchcopy {
		margin-block-end: 1em;
	}
	.kv_copy .copy {
		margin-block: 1.5em;
		padding-inline-start: 1.5em;
	}
}
@media screen and (max-width: 767px) {
	.kv_copy {
		display: grid;
		grid-template: repeat(5, auto) / auto auto;
		column-gap: 1em;
		width: 436px;
	}
	.kv_copy .catchcopy {
		grid-row: 1 / 6;
		align-self: center;
	}
	.kv_copy .copy {
		grid-column: 2 / 3;
		margin-block: .5em;
		line-height: 1.6;
	}
}
@media screen and (max-width: 479px) {
	.kv_copy {
		width: 339px;
	}
	.kv_copy .catchcopy {
		font-size: 30px;
	}
	.kv_copy .copy {
		font-size: 14px;
	}
}
@media screen and (max-width: 374px) {
	.kv_copy {
		width: 290px;
	}
	.p-kv {
		overflow: hidden;
	}
	.kv_copy .copy {
		font-size: 12px;
	}
}
/* inview */
.kv_copy.js-inview:not(.is-inview) {
	transform: none;
}
.kv_copy.js-inview .catchcopy .l,
.kv_copy.js-inview .copy .l {
	display: inline-block;
	position: relative;
	line-height: 1;
}
.kv_copy.js-inview:not(.is-inview) .catchcopy .l,
.kv_copy.js-inview:not(.is-inview) .copy .l {
	clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
}
.kv_copy.js-inview .catchcopy .l::after {
	content: "";
	position: absolute;
	inset: 0;
	background: white;
	transform-origin: center bottom;
}
.kv_copy.is-inview .catchcopy .l,
.kv_copy.is-inview .copy .l {
	clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.kv_copy.is-inview .catchcopy .l::after {
	transform: scaleY(0);
}
.kv_copy.js-inview.is-anim .catchcopy .l,
.kv_copy.js-inview.is-anim .copy .l {
	transition: clip-path .4s cubic-bezier(.3,1,.7,1);
}
.kv_copy.js-inview.is-anim .catchcopy .l::after {
	transition: transform .6s cubic-bezier(.3,1,.7,1);
}
.kv_copy.js-inview.is-anim .catchcopy .-l1 { transition-delay: .1s; }
.kv_copy.js-inview.is-anim .catchcopy .-l2 { transition-delay: .2s; }
.kv_copy.js-inview.is-anim .catchcopy .-l3 { transition-delay: .3s; }
.kv_copy.js-inview.is-anim .catchcopy .-l1::after { transition-delay: .6s; }
.kv_copy.js-inview.is-anim .catchcopy .-l2::after { transition-delay: .7s; }
.kv_copy.js-inview.is-anim .catchcopy .-l3::after { transition-delay: .8s; }

.kv_copy.js-inview.is-anim .copy .-l1 { transition-delay: 1s; }
.kv_copy.js-inview.is-anim .copy .-l2 { transition-delay: 1.05s; }
.kv_copy.js-inview.is-anim .copy .-l3 { transition-delay: 1.1s; }
.kv_copy.js-inview.is-anim .copy .-l4 { transition-delay: 1.15s; }
.kv_copy.js-inview.is-anim .copy .-l5 { transition-delay: 1.2s; }
.kv_copy.js-inview.is-anim .copy .-l6 { transition-delay: 1.25s; }
.kv_copy.js-inview.is-anim .copy .-l7 { transition-delay: 1.3s; }
.kv_copy.js-inview.is-anim .copy .-l8 { transition-delay: 1.35s; }
.kv_copy.js-inview.is-anim .copy .-l9 { transition-delay: 1.4s; }
.kv_copy.js-inview.is-anim .copy .-l10 { transition-delay: 1.45s; }
.kv_copy.js-inview.is-anim .copy .-l11 { transition-delay: 1.5s; }
.kv_copy.js-inview.is-anim .copy .-l12 { transition-delay: 1.55s; }



/**
 * コンテンツ
 * ---------------------------------------- */
.home_contents {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	padding-bottom: 104px;
	text-align: center;
}
:where(.home_contents) .main_section {
	padding: 80px;
}
.home_contents::before {
	content: "";
	position: absolute;
	top: 0;
	right: calc(50% - 50vw);
	bottom: 0;
	left: calc(50% - 50vw);
	background: #fafafa url(../img/bg_noise.png) center top / 125px 125px;
}
:where(.home_contents) .label_title {
	display: block;
	z-index: 2;
	width: 166px;
	margin: 0 auto;
}
:where(.home_contents) .label_title::after {
	content: "";
	z-index: -1;
	position: absolute;
	right: -16px;
	bottom: -4px;
	left: -16px;
	height: 24px;
	background: #fafafa url(../img/bg_noise.png) center top / 125px 125px;
}
.home_contents::after {
	content: "";
	z-index: 0;
	position: absolute;
	inset: 104px 56px;
	pointer-events: none;
	box-shadow: 0 0 0 1px #27b53a, 0 0 0 4px white, 0 0 0 6px #27b53a;
	mix-blend-mode: multiply;
}
@media screen and (max-width: 1024px) {
	.home_contents::after {
		right: 24px;
		left: 24px;
	}
	.home_contents .main_section {
		padding-right: 40px;
		padding-left: 40px;
	}
}
@media screen and (max-width: 767px) {
	.home_contents {
		padding-bottom: 64px;
	}
	.home_contents::after {
		top: 80px;
		bottom: 64px;
	}
	:where(.home_contents) .main_section {
		padding: 64px;
	}
}

.p-home_primary .section_bg {
	z-index: 1;
}
.p-home_primary .section_bg .-bg1 {
	top: 0;
	right: -6%;
	opacity: .1;
	clip-path: polygon(50% 0, 100% 0, 50% 100%, 0 100%);
}
.p-home_primary .section_bg .-bg2 {
	top: 21%;
	left: -9%;
	opacity: .1;
	clip-path: polygon(0 0, 45% 0, 100% 100%, 55% 100%);
}
.p-home_primary .section_bg .-bg3 {
	bottom: 0;
	right: -5%;
	clip-path: polygon(40% 0, 100% 0, 60% 100%, 0 100%);
}
.p-home_special .section_bg .-bg4 {
	top: 0;
	left: 0;
	opacity: .15;
	clip-path: polygon(0 0, 100% 80%, 100% 140%, 0 60%);
}
.p-home_special .section_bg .-bg5 {
	bottom: 0;
	right: -5%;
	opacity: .15;
	clip-path: polygon(90% 0, 150% 0, 60% 100%, 0 100%);
}
@media screen and (max-width: 767px) {
	.p-home_primary .section_bg .-bg1 {
		right: -24%;
	}
	.p-home_primary .section_bg .-bg2 {
		top: 32%;
		left: -24%;
	}
}


/**
 * Job / Interview
 * ---------------------------------------- */
.p-home_primary {
	position: relative;
	max-width: none;
	padding-top: 104px;
	padding-bottom: 168px;
}
.p-home_primary .label_title {
	z-index: 1;
	margin-top: -64px;
}
.home_panel {
	z-index: 2;
	position: relative;
	max-width: 944px;
	margin: 0 auto;
	padding: 24px;
	border-radius: 10px;
	background: white;
	box-shadow: 10px 10px 10px rgba(0,0,0,.1), 24px 24px 0 rgba(0,0,0,.1);
}
.p-home_primary .home_panel {
	box-shadow: 10px 10px 10px rgba(0,0,0,.1), 24px 24px 0 rgba(0,0,0,.04);
}
.home_panel .panel_title {
	z-index: 0;
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%);
}
.home_panel .panel_title::before,
.home_panel .panel_title::after {
	content: "";
	z-index: -1;
	position: absolute;
}
.home_panel .panel_title::before {
	right: -16px;
	bottom: -16px;
	left: -16px;
	height: 30px;
	background: #27b53a url(../img/bg_title.png) center top / 125px 125px;
}
.home_panel .panel_title::after {
	right: calc(100% + 15px);
	bottom: 0;
	width: 90px;
	height: 30px;
	background: #27b53a url(../img/bg_title.png) center top / 125px 125px;
	-webkit-mask-image: url(../img/mask_pixel.svg);
	-webkit-mask-size: 100% 100%;
	mask-image: url(../img/mask_pixel.svg);
	mask-size: 100% 100%;
}
.home_panel .more {
	position: absolute;
	font-size: 10px;
	line-height: 1;
}
.home_panel .more .arr {
	margin-left: 8px;
}
@media (hover: hover) {
	.p-home_job.home_panel,
	.spacial_contents .home_panel {
		transition: transform .6s cubic-bezier(.3,1,.7,1), box-shadow .6s cubic-bezier(.3,1,.7,1);
	}
	.p-home_job.home_panel:hover,
	.spacial_contents .home_panel:hover {
		transform: translateY(-4px);
		transition-duration: .2s;
	}
	.p-home_job.home_panel:hover {
		box-shadow: 10px 14px 14px rgba(0,0,0,.1), 24px 28px 0 rgba(0,0,0,.04);
	}
	.spacial_contents .home_panel:hover {
		box-shadow: 10px 14px 14px rgba(0,0,0,.1), 24px 28px 0 rgba(0,0,0,.1);
	}
}
@media screen and (min-width: 768px) {
	.home_panel .more {
		top: 24px;
		right: 24px;
	}
}
@media screen and (max-width: 767px) {
	.p-home_primary {
		padding-bottom: 120px;
	}
	.p-home_primary .label_title {
		margin-top: -80px;
	}
	.home_panel {
		padding-top: 32px;
		padding-bottom: 48px;
		box-shadow: 10px 10px 10px rgba(0,0,0,.1), 16px 16px 0 rgba(0,0,0,.1);
	}
	.p-home_primary .home_panel {
		box-shadow: 10px 10px 10px rgba(0,0,0,.1), 16px 16px 0 rgba(0,0,0,.04);
	}
	.home_panel .panel_title img {
		width: auto;
		height: 32px;
	}
	.home_panel .more {
		right: 20px;
		bottom: 16px;
	}
}
@media screen and (max-width: 479px) {
	.home_panel {
		box-shadow: 5px 5px 5px rgba(0,0,0,.1), 8px 8px 0 rgba(0,0,0,.1);
	}
	.p-home_primary .home_panel {
		box-shadow: 5px 5px 5px rgba(0,0,0,.1), 8px 8px 0 rgba(0,0,0,.04);
	}
}

.p-home_job {
	margin-top: 96px;
}
.p-home_job .panel_title {
	padding: 0 16px;
}
.p-home .job_image {
	position: relative;
}
.p-home .job_image img {
	position: relative;
}
.p-home .job_image .badge {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 16px;
	right: -16px;
	width: 7.4em;
	height: 7.4em;
	border-radius: 7.4em;
	color: white;
	font-size: 17px;
	line-height: 1.5;
	font-family: "Midashi Go MB31", sans-serif;
	background: black;
}

.p-home_interview {
	margin-top: 144px;
	padding-top: 48px;
	padding-bottom: 64px;
}
.p-home_interview .title {
	display: grid;
	row-gap: 8px;
}
@media screen and (min-width: 768px) {
	.p-home_job {
		display: flex;
		justify-content: center;
		align-items: center;
		column-gap: 40px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1000px) {
	.p-home .job_image .badge {
		font-size: calc(17vw / 10);
	}
 }
@media screen and (max-width: 767px) {
	.p-home_job {
		margin-top: 56px;
		padding-top: 24px;
	}
	.p-home .job_image {
		display: flex;
		justify-content: center;
		overflow: hidden;
		margin: 0 -24px;
		padding-top: 16px;
	}
	.p-home .job_image img {
		min-width: 480px;
	}
	.p-home .job_image .badge {
		top: 0;
		right: 16%;
		font-size: 12px;
	}
	.p-home_interview {
		margin-top: 96px;
		padding-bottom: 40px;
	}
	.jockeys_container::before {
		right: 56px;
		left: 56px;
	}
}
@media screen and (max-width: 479px) {
	.p-home .job_image {
		display: block;
	}
	.p-home .job_image img {
		left: calc(50% - 272px);
	}
	.p-home .job_image .badge {
		right: calc(12vw / 3.75);
	}
	.p-home_job .catch {
		margin-top: -8px;
	}
}


/**
 * Special Contents
 * ---------------------------------------- */
.p-home_special {
	position: relative;
}
.p-home_special::before {
	content: "";
	position: absolute;
	top: 0;
	right: calc(50% - 50vw);
	bottom: 0;
	left: calc(50% - 50vw);
	background: #27b53a url(../img/bg_title.png) center top / 125px 125px;
}
.p-home_special .section_title {
	position: absolute;
	top: -54px;
	left: calc(50% - 176px);
	padding: 22px 24px 18px;
}
.p-home_special .section_title::before,
.p-home_special .section_title::after {
	content: "";
	position: absolute;
	right: 0;
	left: 0;
	height: 2px;
	margin: 0 auto;
	background: linear-gradient(to right, transparent, #000 30%, #000 70%, transparent);
}
.p-home_special .section_title::before {
	top: 0;
}
.p-home_special .section_title::after {
	bottom: 0;
}
:where(.p-home_special) .home_panel {
	max-width: 848px;
	border-top-left-radius: 112px;
}
:where(.p-home_special) .home_panel::before {
	content: "";
	z-index: -1;
	position: absolute;
	top: 0;
	left: 0;
	width: 120px;
	height: 120px;
	background: left top / cover no-repeat;
}
@media screen and (max-width: 767px) {
	.p-home_special .section_title {
		top: -40px;
		left: calc(50% - 139px);
		padding: 14px 24px 12px;
	}
	.p-home_special .section_title img {
		width: 230px;
	}
}
@media screen and (max-width: 479px) {
	:where(.p-home_special) .home_panel {
		border-top-left-radius: 72px;
	}
	:where(.p-home_special) .home_panel::before {
		width: 80px;
		height: 80px;
	}
}

/* :::::: CrossTalk :::::: */
.p-home_crosstalk::before {
	background-image: url(../../img/home_special_n1.svg);
}
.p-home .crosstalk_image {
	position: relative;
}
.p-home .crosstalk_image .image_title {
	position: absolute;
	top: -16px;
	width: 100%;
}
.p-home .crosstalk_image > img {
	-webkit-mask-image: url(../img/mask_crosstalk.svg);
	-webkit-mask-size: 100% 100%;
	mask-image: url(../img/mask_crosstalk.svg);
	mask-size: 100% 100%;
}
@media screen and (min-width: 768px) {
	.p-home_crosstalk {
		display: flex;
		justify-content: center;
		align-items: center;
		padding-top: 64px;
		padding-bottom: 40px;
	}
	.p-home .crosstalk_image {
		margin-left: 48px;
	}
}
@media screen and (max-width: 767px) {
	.p-home_crosstalk .title img {
		width: 182px;
	}
	.p-home .crosstalk_image {
		margin: 32px -12px 0;
	}
	.p-home .crosstalk_image .image_title img {
		width: 118px;
	}
}

/* :::::: 数字でみるJRASS :::::: */
.p-home_numbers::before {
	background-image: url(../../img/home_special_n2.svg);
}
.p-home_numbers .title {
	margin-top: -64px;
}
.p-home .numbers_image {
	margin-top: 24px;
}
@media screen and (min-width: 768px) {
	.p-home_numbers {
		margin-top: 80px;
		padding-bottom: 48px;
	}
}
@media screen and (max-width: 767px) {
	.p-home_numbers {
		margin-top: 48px;
	}
	.p-home_numbers .title {
		margin-top: -48px;
	}
	.p-home_numbers .title img {
		width: 198px;
	}
	.p-home .numbers_image {
		margin-top: 16px;
	}
	.p-home .numbers_image img {
		width: calc(100% - 12vw / 3.75);
		max-width: 400px;
	}
}


/**
 * WorkStyle / FAQ / Information
 * ---------------------------------------- */
.p-home_banner {
	z-index: 2;
	position: relative;
	max-width: calc(944px + 112px);
	margin: 0 auto;
}
.p-home .main_banner {
	position: relative;
	background: #27b53a url(../img/bg_title.png) center top / 125px 125px;
	box-shadow: 10px 10px 10px rgba(0,0,0,.1), 24px 24px 0 rgba(0,0,0,.04);
}
.p-home .main_banner .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.p-home .main_banner .title {
	position: relative;
	padding: 6px 0;
	font-size: 1em;
	line-height: 1;
}
.p-home .main_banner .title::before,
.p-home .main_banner .title::after {
	content: "";
	position: absolute;
	right: 0;
	left: 0;
	width: 4em;
	height: 1px;
	margin: 0 auto;
	background: linear-gradient(to right, transparent, #000 30%, #000 70%, transparent);
}
.p-home .main_banner .title::before {
	top: 0;
}
.p-home .main_banner .title::after {
	bottom: 0;
}
.p-home .main_banner .lead {
	margin-top: 1.2em;
	font-size: 14px;
	line-height: 1.4;
	font-family: "Midashi Go MB31", sans-serif;
}
.p-home .main_banner .lead .arr {
	position: relative;
	top: -.1em;
	margin-left: 16px;
}
@media (hover: hover) {
	.p-home .main_banner {
		transition: transform .6s cubic-bezier(.3,1,.7,1), box-shadow .6s cubic-bezier(.3,1,.7,1);
	}
	.p-home .main_banner:hover {
		transform: translateY(-4px);
		box-shadow: 10px 14px 14px rgba(0,0,0,.1), 24px 28px 0 rgba(0,0,0,.04);
		transition-duration: .2s;
	}
}
@media screen and (min-width: 768px) {
	.p-home_banner {
		display: flex;
		justify-content: space-between;
		padding-top: 104px;
	}
	.p-home .main_banner {
		flex-basis: calc(33.3333% - 80px / 3);
		padding-bottom: 32px;
		border-radius: 10px 10px 5px 5px;
	}
	.p-home .main_banner .photo {
		margin-bottom: 32px;
	}
	.p-home .main_banner .photo img {
		border-radius: 10px 10px 0 0;
	}
}
@media screen and (max-width: 767px) {
	.p-home_banner {
		padding-bottom: 48px;
	}
	.p-home .main_banner {
		display: grid;
		grid-template: repeat(2, auto) / 52% 48%;
		border-radius: 10px;
		box-shadow: 10px 10px 10px rgba(0,0,0,.1), 16px 16px 0 rgba(0,0,0,.04);
	}
	.p-home .main_banner:nth-child(n+2) {
		margin-top: 24px;
	}
	.p-home .main_banner .photo {
		grid-row: 1 / 3;
	}
	.p-home .main_banner .photo img {
		border-radius: 10px 0 0 10px;
	}
	.p-home .main_banner .title {
		grid-column: 2 / 3;
		align-self: flex-end;
	}
	.p-home .main_banner .lead {
		grid-row: 2 / 3;
		grid-column: 2 / 3;
		align-self: flex-start;
	}
}
@media screen and (max-width: 479px) {
	.p-home .main_banner {
		box-shadow: 5px 5px 5px rgba(0,0,0,.1), 8px 8px 0 rgba(0,0,0,.04);
	}
	.p-home .main_banner .title {
		padding: 4px 0;
	}
	.p-home .main_banner .title img {
		width: auto;
		height: 32px;
	}
	.p-home .main_banner .lead {
		position: relative;
		font-size: 12px;
	}
	.p-home .main_banner .lead .arr {
		position: absolute;
		top: .4em;
		right: 12px;
		height: 4px;
	}
}


/**
 * デコレーション
 * ---------------------------------------- */
.deco_interview .deco {
	top: -192px;
	left: calc(50% - 520px);
}
.deco_banner .deco {
	top: -152px;
	right: calc(50% - 680px);
}
@media screen and (max-width: 767px) {
	.deco_interview .deco {
		top: -120px;
		left: -40px;
		width: 192px;
	}
	.deco_banner .deco {
		top: -80px;
		right: -96px;
		width: 280px;
	}
}
@media screen and (max-width: 479px) {
	.deco_interview .deco {
		width: calc(160vw / 3.75);
	}
	.deco_banner .deco {
		width: calc(240vw / 3.75);
	}
}
/* inview */
.deco_interview .deco.js-inview:not(.is-inview) {
	transform: translateX(-80px);
}
.deco_banner .deco.js-inview:not(.is-inview) {
	transform: translateX(80px);
}

