@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Barlow:wght@700&display=swap);
/* Reset */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	background: transparent;
	font-weight: inherit;
	font-size: inherit;
	font-style: inherit;
	-webkit-tap-highlight-color: transparent;
}

article,
aside,
details,
figcaption,
figure,
picture,
main,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

ul,
ol {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote::before,
blockquote::after,
q::before,
q::after {
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	empty-cells: show;
}

button {
	font-family: inherit;
}

/*----------
	vars
----------*/
:root {
	/* color */
	--color-prim: #009FE8;
	--color-seco: #1D1D1D;
	--color-txt: #1D1D1D;
	--color-hover: #007AB3;
	--color-border: #ddd;
	--color-bg: #F7F7F7;
	/* font family */
	--font-sans: "Noto Sans JP", "ヒラギノ角ゴシック", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", Hiragino Sans, "メイリオ", Meiryo, sans-serif;
	--font-barlow: "Barlow", sans-serif;
	/* line height */
	--line-height-s: 1.4;
	--line-height-m: 1.6;
	--line-height-l: 1.8;
	/* icons */
	--icon-arrow1-r: "";
	--icon-arrow2-r: "";
	--icon-arrow3-r: "";
	--icon-arrow4-r: "";
	--icon-blank: "";
	--icon-title1: "";
	--icon-title2: "";
}

/*----------
	base
----------*/
html {
	width: 100%;
	font-size: 62.5%;
	background-color: #fff;
}
html.is-locked {
	position: absolute;
	overflow-y: hidden;
}
@media (max-width: 767px) {
	html.is-locked {
		overflow: hidden;
	}
}

body {
	font-size: 1.6rem;
	line-height: var(--line-height-l);
	font-family: var(--font-sans);
	letter-spacing: 0;
	color: var(--color-txt);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
}
@media (max-width: 767px) {
	body {
		font-size: 1.4rem;
	}
}
@media print {
	body {
		min-width: 1240px;
		zoom: 0.8;
	}
}

a {
	text-decoration: none;
	color: var(--color-txt-link);
}
@media (min-width: 768px), print {
	a:hover {
		text-decoration: none;
	}
}

img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

sup {
	vertical-align: top;
	font-size: 0.7em;
}

sub {
	vertical-align: baseline;
	font-size: 0.7em;
}

input[type=text],
textarea,
select {
	font-family: inherit;
	font-size: 1.6rem;
}

/*----------
	main header
----------*/
@media print {
	header {
		display: none;
	}
}

.l-mainheader {
	position: absolute;
	top: 0;
	width: 100%;
	height: 62px;
	background-color: #fff;
	border-bottom: 1px solid #F2F2F2;
	z-index: 100;
	transition: 0.2s background-color;
}
.l-mainheader__inner {
	height: 100%;
}
.l-mainheader__logo {
	padding: 24px 0 0 10px;
}
.l-mainheader__logo a {
	display: flex;
	align-items: center;
}
.l-mainheader__logo span {
	color: var(--color-prim);
	font-size: 1.2rem;
	font-family: var(--font-barlow);
	letter-spacing: 0.02em;
	line-height: 1;
}
.l-mainheader__logo img {
	width: 45%;
	margin-right: 17px;
}
.l-mainheader__navtoggle {
	display: block;
	width: 59px;
	height: 61px;
	background-color: #2E3133;
	border-left: 1px solid #fff;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 20;
	cursor: pointer;
	transition: background-color 0.2s;
}
.l-mainheader__navtoggle .l-mainheader__bars {
	position: relative;
	display: block;
	width: 23px;
	height: 16px;
	margin: 0 auto;
}
.l-mainheader__navtoggle .l-mainheader__bartop,
.l-mainheader__navtoggle .l-mainheader__barmiddle,
.l-mainheader__navtoggle .l-mainheader__barbottom {
	position: absolute;
	display: block;
	width: 23px;
	height: 2px;
	background-color: #fff;
	transition: all 0.15s linear;
}
.l-mainheader__navtoggle .l-mainheader__bartop {
	transform: translateY(-8px) rotate(0deg);
}
.l-mainheader__navtoggle .l-mainheader__barbottom {
	transform: translateY(8px) rotate(0deg);
}
.l-mainheader__navtoggle .l-mainheader__toggletext {
	display: block;
	position: absolute;
	bottom: 10px;
	width: 100%;
	color: #fff;
	font-family: var(--font-barlow);
	font-size: 1rem;
	font-weight: 700;
	text-align: center;
	line-height: 1;
}
.l-mainheader__nav {
	display: none;
	position: absolute;
	top: 62px;
	left: 0;
	right: 0;
	z-index: 10;
	background-color: #2E3133;
}
.l-mainheader__nav .l-mainheader__navinner {
	height: 100%;
}
.l-mainheader__closebtn {
	position: relative;
	display: block;
	width: calc(100% - 20px);
	height: 50px;
	margin: 50px auto 0;
	border: 1px solid #fff;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
	text-align: center;
	line-height: 50px;
}
.l-mainheader__closebtn .icon-menu-close {
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
	width: 14px;
	height: 14px;
	background: url(/recruit/assets/images/common/icon_close.svg) no-repeat 0 0;
	background-size: cover;
}
.l-mainheader.is-open .l-mainheader__overlay {
	display: block;
	position: absolute;
	top: 110px;
	left: 0;
	background-color: rgba(0, 87, 128, 0.7);
	width: 100%;
	height: 100vh;
	z-index: -1;
}
.l-mainheader.is-open .l-mainheader__nav {
	display: block;
}
.l-mainheader.is-open .l-mainheader__navtoggle .l-mainheader__bartop {
	opacity: 0;
}
.l-mainheader.is-open .l-mainheader__navtoggle .l-mainheader__barmiddle {
	background-color: #fff;
	transform: translateY(0) rotate(45deg);
}
.l-mainheader.is-open .l-mainheader__navtoggle .l-mainheader__barbottom {
	background-color: #fff;
	transform: translateY(0) rotate(-45deg);
}
.l-mainheader.is-open .l-mainheader__navtoggle .l-mainheader__toggletext {
	color: #fff;
}
@media (max-width: 767px) {
	.l-mainheader.is-open .l-mainheader__nav {
		height: 100%;
		min-height: 100vh;
		overflow: scroll;
	}
}
@media (min-width: 768px), print {
	.l-mainheader {
		min-width: 1240px;
		height: 110px;
	}
	.l-mainheader__logo {
		padding: 40px 0 0 40px;
	}
	.l-mainheader__logo span {
		font-size: 2.4rem;
	}
	.l-mainheader__logo img {
		width: 334px;
		margin-right: 33px;
	}
	.l-mainheader__nav {
		top: 110px;
	}
	.l-mainheader__nav .l-mainheader__navinner {
		height: auto;
	}
	.l-mainheader__navtoggle {
		width: 110px;
		height: 109px;
		transition: background-color 0.2s;
	}
	.l-mainheader__navtoggle .l-mainheader__toggletext {
		bottom: 28px;
		font-size: 1.2rem;
	}
	.l-mainheader__closebtn {
		display: none;
	}
}
.l-mainheader__navtoggle:hover {
	background-color: var(--color-hover);
}
.l-mainheader.is-scrollup {
	position: fixed;
	animation: scrollupSP 0.4s forwards;
	background-color: #fff;
	transition: 0.4s background-color;
}
.l-mainheader.is-scrolldown {
	position: fixed;
	animation: scrolldownSP 0.4s forwards;
	background-color: transparent;
	border-bottom: 0;
	transition: 0.4s background-color;
}
@media (min-width: 1025px) {
	.l-mainheader.is-scrollup {
		min-width: 100%;
		animation: scrollupPC 0.4s forwards;
	}
}
@keyframes scrollupSP {
	from {
		transform: translateY(-70px);
	}
	to {
		transform: translateY(0);
	}
}
@keyframes scrollupPC {
	from {
		transform: translateY(-110px);
	}
	to {
		transform: translateY(0);
	}
}
@media (min-width: 1025px) {
	.l-mainheader.is-scrolldown {
		min-width: 100%;
		animation: scrolldownPC 0.5s forwards;
	}
}
@keyframes scrolldownSP {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(-62px);
	}
}
@keyframes scrolldownPC {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(-110px);
	}
}

.l-gnav {
	width: 100%;
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 5.333%;
	padding-right: 5.333%;
}
@media (min-width: 768px), print {
	.l-gnav {
		padding-left: 20px;
		padding-right: 20px;
	}
}
.l-gnav .icon-menu-blank {
	display: inline-block;
	position: relative;
	top: 3px;
	width: 18px;
	height: 18px;
	background: url(/recruit/assets/images/common/icon_footer_blank.png) no-repeat 0 0;
	background-size: cover;
	margin-left: 10px;
}
.l-gnav__lower {
	padding: 20px 0 0;
	margin-top: 50px;
	border-top: 1px solid #5C6166;
}
.l-gnav__lower .l-gnav__corpolate > a {
	color: #CECECE;
	font-size: 1.3rem;
	font-weight: 500;
}
@media (max-width: 767px) {
	.l-gnav {
		padding-top: 40px;
		padding-bottom: 200px;
	}
	.l-gnav__primary-item + .l-gnav__primary-item {
		margin-top: 30px;
	}
	.l-gnav__cattop {
		position: relative;
		color: #ccc;
		font-size: 1.6rem;
	}
	.l-gnav__cattop > a {
		color: inherit;
		font-weight: 700;
	}
	.l-gnav__cattop > span {
		display: block;
		color: inherit;
		font-weight: 700;
	}
	.l-gnav__cattop + .l-gnav__cattop {
		margin-top: 30px;
	}
	.l-gnav__secondary-items {
		margin-top: 16px;
	}
	.l-gnav__secondary-item {
		font-size: 1.3rem;
		font-weight: 500;
	}
	.l-gnav__secondary-item > a {
		color: #ccc;
	}
	.l-gnav__secondary-item > a > span {
		display: block;
	}
	.l-gnav__secondary-item + .l-gnav__secondary-item {
		margin-top: 10px;
	}
}
@media (min-width: 768px), print {
	.l-gnav {
		padding-top: 70px;
		padding-bottom: 70px;
	}
	.l-gnav__primary-items {
		display: grid;
		grid-template-columns: repeat(6, auto);
		gap: 0 70px;
	}
	.l-gnav__cattop {
		font-size: 1.6rem;
	}
	.l-gnav__cattop > a {
		display: inline-block;
		position: relative;
		color: #ccc;
		font-weight: 700;
		transition: color 0.3s;
	}
	.l-gnav__cattop > a::after {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 1px;
		background-color: var(--color-hover);
		transition: all 0.3s;
		background-color: #fff;
	}
	.l-gnav__cattop > span {
		color: #ccc;
		font-weight: 700;
	}
	.l-gnav__cattop + .l-gnav__cattop {
		margin-top: 30px;
	}
	.l-gnav__secondary-items {
		margin-top: 18px;
	}
	.l-gnav__secondary-item {
		font-size: 1.4rem;
	}
	.l-gnav__secondary-item > a {
		display: inline-block;
		position: relative;
		color: #ccc;
		font-weight: 500;
		transition: color 0.3s;
	}
	.l-gnav__secondary-item > a::after {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 1px;
		background-color: var(--color-hover);
		transition: all 0.3s;
		background-color: #fff;
	}
	.l-gnav__secondary-item + .l-gnav__secondary-item {
		margin-top: 12px;
	}
	.l-gnav__lower .l-gnav__corpolate > a {
		display: inline-block;
		position: relative;
	}
	.l-gnav__lower .l-gnav__corpolate > a::after {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 1px;
		background-color: var(--color-hover);
		transition: all 0.3s;
		background-color: #fff;
	}
	.l-gnav__cattop > a:hover, .l-gnav__secondary-item > a:hover, .l-gnav__corpolate > a:hover {
		color: #fff;
	}
	.l-gnav__cattop > a:hover::after, .l-gnav__secondary-item > a:hover::after, .l-gnav__corpolate > a:hover::after {
		width: 100%;
	}
}

/*----------
	main footer
----------*/
footer {
	width: 100%;
	position: relative;
	z-index: 2;
}
@media print {
	footer {
		display: none;
	}
}

.l-mainfooter {
	position: relative;
	background: #2E3133;
}
.l-mainfooter__inner {
	padding: 80px 0 20px;
}
.l-mainfooter__backhead {
	opacity: 0;
	position: absolute;
	bottom: 9px;
	right: 20px;
	width: 70px;
	height: 70px;
	transition: opacity 0.3s;
	z-index: 10;
}
.l-mainfooter__backhead.is-visible {
	opacity: 1;
	position: fixed;
	top: auto;
	right: 20px;
	bottom: 10px;
}
.l-mainfooter__backhead.is-stop {
	opacity: 1;
	position: absolute;
	bottom: 9px;
	right: 20px;
}
.l-mainfooter__backhead > a {
	display: grid;
	place-content: center;
	width: 100%;
	height: 100%;
	border: 1px solid #808080;
	border-radius: 100%;
}
.l-mainfooter__backhead i {
	display: inline-block;
	width: 0;
	height: 0;
	border-style: solid;
	border-color: transparent transparent #808080 transparent;
	border-width: 0px 6.5px 11px 6.5px;
}
.l-mainfooter__upper {
	width: 100%;
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 5.333%;
	padding-right: 5.333%;
	padding: 0 25px 84px;
}
@media (min-width: 768px), print {
	.l-mainfooter__upper {
		padding-left: 20px;
		padding-right: 20px;
	}
}
.l-mainfooter__lower {
	padding: 20px 25px 0;
}
.l-mainfooter__logo {
	display: block;
	margin-bottom: 15px;
}
.l-mainfooter__logo img {
	max-width: 400px;
}
.l-mainfooter .icon-menu-blank {
	display: inline-block;
	position: relative;
	top: 3px;
	width: 18px;
	height: 18px;
	background: url(/recruit/assets/images/common/icon_footer_blank.png) no-repeat 0 0;
	background-size: cover;
	margin-left: 10px;
}
.l-mainfooter__corpolate a {
	color: #CECECE;
	font-size: 1.3rem;
	font-weight: 500;
}
.l-mainfooter__copyright {
	margin-top: 20px;
	color: #808080;
	font-size: 1rem;
}
@media (max-width: 767px) {
	.l-mainfooter__upper {
		position: relative;
	}
}
@media (min-width: 768px), print {
	.l-mainfooter {
		min-width: 1240px;
	}
	.l-mainfooter__inner {
		padding-top: 120px;
		padding-bottom: 68px;
	}
	.l-mainfooter__cattop {
		color: #ccc;
	}
	.l-mainfooter__backhead {
		width: 70px;
		height: 70px;
	}
	.l-mainfooter__backhead.is-visible {
		right: 30px;
		bottom: 53px;
	}
	.l-mainfooter__backhead.is-stop {
		right: 30px;
		bottom: 53px;
	}
	.l-mainfooter__backhead > a {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 100%;
		transition: background-color 0.3s;
	}
	.l-mainfooter__backhead > a:hover {
		background-color: var(--color-prim);
	}
	.l-mainfooter__upper {
		justify-content: space-between;
	}
	.l-mainfooter__lower {
		position: relative;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding-left: 65px;
	}
	.l-mainfooter__logo {
		transition: opacity 0.3s;
	}
	.l-mainfooter__logo img {
		max-width: 334px;
	}
	.l-mainfooter__corpolate > a {
		display: inline-block;
		position: relative;
	}
	.l-mainfooter__corpolate > a::after {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 1px;
		background-color: var(--color-hover);
		transition: all 0.3s;
		background-color: #fff;
	}
	.l-mainfooter__copyright {
		position: absolute;
		right: 125px;
		bottom: -1em;
		margin-top: 0;
		font-size: 1.2rem;
	}
	.l-mainfooter__corpolate > a:hover {
		color: #fff;
	}
	.l-mainfooter__corpolate > a:hover::after {
		width: 100%;
	}
}

@media (max-width: 767px) {
	.l-fnav__primary-item + .l-fnav__primary-item {
		margin-top: 30px;
	}
	.l-fnav__cattop {
		position: relative;
		color: #ccc;
		font-size: 1.6rem;
	}
	.l-fnav__cattop > a {
		color: inherit;
		font-weight: 700;
	}
	.l-fnav__cattop > span {
		display: block;
		color: inherit;
		font-weight: 700;
	}
	.l-fnav__cattop + .l-fnav__cattop {
		margin-top: 30px;
	}
	.l-fnav__secondary-items {
		margin-top: 16px;
	}
	.l-fnav__secondary-item {
		font-size: 1.3rem;
		font-weight: 500;
	}
	.l-fnav__secondary-item > a {
		color: #ccc;
	}
	.l-fnav__secondary-item > a > span {
		display: block;
	}
	.l-fnav__secondary-item + .l-fnav__secondary-item {
		margin-top: 10px;
	}
}
@media (min-width: 768px), print {
	.l-fnav__primary-items {
		display: grid;
		grid-template-columns: repeat(6, auto);
		gap: 0 70px;
	}
	.l-fnav__cattop {
		font-size: 1.6rem;
	}
	.l-fnav__cattop > a {
		display: inline-block;
		position: relative;
		color: #ccc;
		font-weight: 700;
		transition: color 0.3s;
	}
	.l-fnav__cattop > a::after {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 1px;
		background-color: var(--color-hover);
		transition: all 0.3s;
		background-color: #fff;
	}
	.l-fnav__cattop > span {
		color: #ccc;
		font-weight: 700;
	}
	.l-fnav__cattop + .l-fnav__cattop {
		margin-top: 30px;
	}
	.l-fnav__secondary-items {
		margin-top: 18px;
	}
	.l-fnav__secondary-item {
		font-size: 1.4rem;
	}
	.l-fnav__secondary-item > a {
		display: inline-block;
		position: relative;
		color: #ccc;
		font-weight: 500;
		transition: color 0.3s;
	}
	.l-fnav__secondary-item > a::after {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 1px;
		background-color: var(--color-hover);
		transition: all 0.3s;
		background-color: #fff;
	}
	.l-fnav__secondary-item + .l-fnav__secondary-item {
		margin-top: 12px;
	}
	.l-fnav__cattop > a:hover, .l-fnav__secondary-item > a:hover {
		color: #fff;
	}
	.l-fnav__cattop > a:hover::after, .l-fnav__secondary-item > a:hover::after {
		width: 100%;
	}
}

/*----------
	main content
----------*/
.l-content {
	width: 100%;
	position: relative;
	overflow-x: clip;
	padding-top: 62px;
}
@media (min-width: 768px), print {
	.l-content {
		min-width: 1240px;
		padding-top: 110px;
	}
}

.l-structure {
	position: relative;
	z-index: 2;
	padding-bottom: 100px;
}
@media (min-width: 768px), print {
	.l-structure {
		padding-bottom: 200px;
	}
}

.l-section {
	width: 100%;
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 5.333%;
	padding-right: 5.333%;
}
@media (min-width: 768px), print {
	.l-section {
		padding-left: 20px;
		padding-right: 20px;
	}
}
.l-section--fix {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
}
.l-section__inner {
	width: 100%;
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 5.333%;
	padding-right: 5.333%;
}
@media (min-width: 768px), print {
	.l-section__inner {
		padding-left: 20px;
		padding-right: 20px;
	}
}

.l-breadcrumb {
	position: relative;
	padding: 12px 0;
	margin-bottom: 25px;
	z-index: 1;
}
.l-breadcrumb__list {
	display: flex;
	flex-wrap: nowrap;
	white-space: nowrap;
	justify-content: flex-end;
	line-height: 1.2;
}
.l-breadcrumb__list > li {
	display: block;
}
.l-breadcrumb__list > li > a {
	text-decoration: none;
	color: #999;
	transition: color 0.2s;
}
.l-breadcrumb__list > li > span {
	text-decoration: none;
	color: #999;
}
.l-breadcrumb__list > li + li::before {
	content: ">";
	display: inline-block;
	color: #999;
	margin: 0 4px;
}
.l-breadcrumb__list > li:last-child > span {
	color: #666;
	font-weight: 700;
}
@media (max-width: 767px) {
	.l-breadcrumb__inner {
		width: 100%;
	}
	.l-breadcrumb__list {
		width: 100%;
		max-width: 1240px;
		margin-left: auto;
		margin-right: auto;
		padding-left: 5.333%;
		padding-right: 5.333%;
		width: auto;
		max-width: none;
		font-size: 1rem;
	}
}
@media (max-width: 767px) and (min-width: 768px), print and (max-width: 767px) {
	.l-breadcrumb__list {
		padding-left: 20px;
		padding-right: 20px;
	}
}
@media (min-width: 768px), print {
	.l-breadcrumb {
		padding: 24px 0;
	}
	.l-breadcrumb__inner {
		width: 100%;
		max-width: 1240px;
		margin-left: auto;
		margin-right: auto;
		padding-left: 5.333%;
		padding-right: 5.333%;
		padding-left: 0;
		padding-right: 0;
	}
}
@media (min-width: 768px) and (min-width: 768px), print and (min-width: 768px), print and (min-width: 768px), print {
	.l-breadcrumb__inner {
		padding-left: 20px;
		padding-right: 20px;
	}
}
@media (min-width: 768px), print {
	.l-breadcrumb__list {
		white-space: normal;
		padding-left: 0;
		padding-right: 0;
		font-size: 1.2rem;
	}
	.l-breadcrumb__list > li {
		display: inline;
	}
	.l-breadcrumb__list > li > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
}
.l-breadcrumb--v2 .l-breadcrumb__list > li {
	display: block;
}
.l-breadcrumb--v2 .l-breadcrumb__list > li > a {
	color: #fff;
}
.l-breadcrumb--v2 .l-breadcrumb__list > li + li::before {
	color: #fff;
}
.l-breadcrumb--v2 .l-breadcrumb__list > li:last-child > span {
	color: #fff;
}
@media (min-width: 768px), print {
	.l-breadcrumb--v2 .l-breadcrumb__list > li > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
}

.l-triangle01 {
	position: absolute;
	top: 0;
	left: 0;
	width: 37.33%;
	max-width: 140px;
	aspect-ratio: 1/1;
	clip-path: polygon(0 0, 100% 0, 0 100%);
	background: rgba(0, 159, 232, 0.95);
}
@media (min-width: 768px), print {
	.l-triangle01 {
		width: 15.97%;
		max-width: 230px;
	}
}
.l-triangle01--v2 {
	z-index: 5;
}
@media (min-width: 768px), print {
	.l-triangle01--v2 {
		width: 24.3055%;
		max-width: 350px;
	}
}

.l-triangle02 {
	position: absolute;
	top: 140px;
	right: 0;
	width: 26.67%;
	max-width: 100px;
	aspect-ratio: 1/2;
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
	background: rgba(0, 159, 232, 0.95);
	z-index: 1;
}
@media (min-width: 768px), print {
	.l-triangle02 {
		top: 110px;
		width: 20.83%;
		max-width: 300px;
	}
}

.l-triangle03 {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 26.67%;
	max-width: 100px;
	aspect-ratio: 1/1;
	clip-path: polygon(0 100%, 100% 0, 100% 100%);
	background: rgba(0, 159, 232, 0.95);
	z-index: 1;
}
@media (min-width: 768px), print {
	.l-triangle03 {
		width: 24.3055%;
		max-width: 350px;
	}
}

.js-parallax {
	position: relative;
	height: 100%;
	overflow: hidden;
}

.js-parallax img {
	width: 100%;
	height: calc(100% + 35px);
	object-fit: cover;
	object-position: center top;
	-webkit-transform: translateY(0);
	transform: translateY(0); /* 初期位置 */
	transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
}

.js-fadeinitem,
.js-fadein {
	opacity: 0;
}

.js-fadein.is-anime {
	animation: fadeUpItem 1s forwards;
}

.js-fadein.js-delayin.is-anime {
	animation-delay: 0.2s;
}

.js-fadeinitem.is-anime {
	animation: fadeUpItem 1s forwards;
}

@keyframes fadeUpItem {
	from {
		opacity: 0;
		transform: translateY(120px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}
.js-slideup {
	transform: translateY(300px);
	transition: transform 0.6s;
}

.js-slideup.is-anime {
	transform: translateY(0);
}

/*----------
	icons
----------*/
@font-face {
	font-family: iconfont;
	src: url(/recruit/assets/fonts/iconfont.woff2) format("woff2"), url(/recruit/assets/fonts/iconfont.woff) format("woff"), url(/recruit/assets/fonts/iconfont.svg) format("svg");
	font-weight: normal;
	font-style: normal;
	font-display: block;
}
.icon, .icon-title2, .icon-title1, .icon-blank, .icon-arrow4-r, .icon-arrow3-r, .icon-arrow2-r, .icon-arrow1-r {
	display: inline-block;
	font-family: iconfont !important;
	speak: never;
	font-style: normal !important;
	font-size: inherit;
	font-weight: normal !important;
	font-variant: normal !important;
	text-transform: none;
	line-height: 1;
	color: inherit;
}
.icon-arrow1-r::before {
	content: "\ea01";
}
.icon-arrow2-r::before {
	content: "\ea02";
}
.icon-arrow3-r::before {
	content: "\ea03";
}
.icon-arrow4-r::before {
	content: "\ea04";
}
.icon-blank::before {
	content: "\ea05";
}
.icon-title1::before {
	content: "\ea06";
}
.icon-title2::before {
	content: "\ea07";
}

.icon-freedial {
	display: inline-block;
	vertical-align: baseline;
	line-height: 1;
	width: 70px;
}

.icon-phone {
	display: inline-block;
	vertical-align: baseline;
	line-height: 1;
	width: 60px;
}

.icon-sns {
	display: inline-block;
	vertical-align: baseline;
	line-height: 1;
	width: 40px;
}

/*----------
	billboard
----------*/
.c-billboard {
	position: relative;
	z-index: 2;
}
.c-billboard__heading {
	position: relative;
	margin-bottom: 60px;
	z-index: 1;
}
.c-billboard__title {
	color: var(--color-seco);
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.5;
}
.c-billboard__title span {
	position: relative;
	display: block;
	margin-bottom: 6px;
	color: var(--color-prim);
	text-transform: uppercase;
	font-family: var(--font-barlow);
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1;
	letter-spacing: 0.02em;
}
.c-billboard__title span::before {
	content: "";
	display: inline-block;
	position: relative;
	top: -3px;
	width: 15px;
	height: 3px;
	margin-right: 10px;
	background-color: var(--color-prim);
	transform: skew(-18deg);
}
.c-billboard__lead {
	margin-top: 40px;
	color: var(--color-txt);
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.8;
}
@media (min-width: 768px), print {
	.c-billboard__heading {
		margin-bottom: 150px;
	}
	.c-billboard__heading:has(.c-billboard__lead) {
		margin-bottom: 120px;
	}
	.c-billboard__title {
		font-size: 5.2rem;
	}
	.c-billboard__title span {
		font-size: 3rem;
		margin-bottom: 0;
	}
	.c-billboard__title span::before {
		top: -8px;
		width: 28px;
		height: 5px;
		margin-right: 14px;
	}
	.c-billboard__lead {
		margin-top: 100px;
		font-size: 2rem;
	}
}

/*----------
	billboard-v2
----------*/
.c-billboard-v2 {
	position: relative;
	z-index: 2;
	margin-bottom: 60px;
}
.c-billboard-v2__upper {
	position: relative;
	min-height: 100vh;
	height: 530px;
}
.c-billboard-v2__upper .c-billboard-v2__image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	background-color: #000;
}
.c-billboard-v2__upper .c-billboard-v2__image img {
	height: 100%;
	object-fit: cover;
	opacity: 0.7;
}
.c-billboard-v2__upper .c-billboard-v2__triangle {
	position: absolute;
	top: 100%;
	right: 0;
	width: 26.67%;
	max-width: 100px;
	aspect-ratio: 1/2;
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
	background: rgba(0, 159, 232, 0.95);
	transform: translateY(-50%);
	z-index: 5;
}
@media (min-width: 768px), print {
	.c-billboard-v2__upper .c-billboard-v2__triangle {
		top: 450px;
		width: 31.94%;
		max-width: 460px;
		transform: none;
	}
}
.c-billboard-v2__heading {
	position: absolute;
	left: 0;
	bottom: 50px;
	padding-right: 5.3%;
	padding-left: 5.3%;
	color: #fff;
	z-index: 6;
}
.c-billboard-v2__heading .c-billboard-v2__title {
	margin-bottom: 24px;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.5;
	text-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
}
.c-billboard-v2__heading .c-billboard-v2__title span {
	position: relative;
	display: block;
	margin-bottom: 6px;
	text-transform: uppercase;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1;
	letter-spacing: 0.02em;
}
.c-billboard-v2__heading .c-billboard-v2__title span::before {
	content: "";
	display: inline-block;
	position: relative;
	top: -3px;
	width: 21px;
	height: 4px;
	margin-right: 15px;
	background-color: #fff;
	transform: skew(-18deg);
}
.c-billboard-v2__heading .c-billboard-v2__name {
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.8;
	text-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
}
@media (min-width: 768px), print {
	.c-billboard-v2 {
		margin-bottom: 150px;
	}
	.c-billboard-v2__upper {
		min-height: auto;
		height: 800px;
	}
	.c-billboard-v2__heading {
		left: 100px;
		bottom: 166px;
		padding-right: 20px;
		padding-left: 20px;
	}
	.c-billboard-v2__heading .c-billboard-v2__title {
		margin-bottom: 40px;
		font-size: 5.2rem;
		line-height: 1.34;
		letter-spacing: 0;
	}
	.c-billboard-v2__heading .c-billboard-v2__title span {
		margin-bottom: 10px;
		font-size: 1.6rem;
		letter-spacing: 0;
	}
	.c-billboard-v2__heading .c-billboard-v2__title span::before {
		width: 28px;
		height: 5px;
		margin-right: 20px;
	}
	.c-billboard-v2__heading .c-billboard-v2__name {
		font-size: 1.6rem;
		font-weight: 700;
		line-height: 1.8;
	}
}

/*----------
	heading-primary
----------*/
.c-heading-primary {
	font-weight: bold;
	font-size: 3.4rem;
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.c-heading-primary {
		font-size: 4rem;
	}
}

/*----------
	heading-secondary
----------*/
.c-heading-secondary {
	position: relative;
	margin-bottom: 40px;
	border-top: 1px solid #E6E6E6;
	font-weight: 700;
	font-size: 2.3rem;
	line-height: 1.73;
	letter-spacing: 0.04em;
}
.c-heading-secondary span {
	display: inline-block;
	position: relative;
	padding-top: 16px;
}
.c-heading-secondary span::before {
	content: "";
	display: block;
	position: absolute;
	top: -4px;
	width: 50px;
	height: 6px;
	background: var(--color-prim);
	transform: skew(-18deg);
}
@media (min-width: 768px), print {
	.c-heading-secondary {
		font-size: 3.5rem;
		margin-bottom: 70px;
	}
	.c-heading-secondary span {
		display: inline-block;
		position: relative;
		padding-top: 26px;
	}
	.c-heading-secondary span::before {
		width: 42px;
	}
}
.c-heading-secondary--wh span::before, .c-heading-secondary--wh span::after {
	background: #fff;
}

/*----------
	remarks
----------*/
.c-remarks {
	font-size: 1rem;
	line-height: var(--line-height-s);
}
.c-remarks__item {
	padding-left: 1.5em;
	text-indent: -0.75em;
}
.c-remarks__item::before {
	content: "※";
	display: inline-block;
	margin-right: 0.5em;
}
.c-remarks__item + .c-remarks__item {
	margin-top: 10px;
}
.c-remarks--order {
	counter-reset: orderlist;
}
.c-remarks--order .c-remarks__item {
	padding-left: 3em;
	text-indent: -3em;
}
.c-remarks--order .c-remarks__item::before {
	counter-increment: orderlist;
	content: "※" counter(orderlist);
	min-width: 2em;
	margin-right: 1em;
	text-align: right;
}

/*----------
	button
----------*/
.c-button__inner {
	position: relative;
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 50px;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
	background-color: var(--color-seco);
	border: 1px solid var(--color-seco);
	color: #fff;
	cursor: pointer;
}
.c-button__inner > span {
	padding: 8px 50px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
	color: inherit;
}
.c-button__inner::after {
	content: var(--icon-arrow4-r);
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	font-size: 0.5rem;
}
@media (min-width: 768px), print {
	.c-button__inner {
		transition: all 0.2s;
	}
	.c-button__inner:hover {
		border: 1px solid var(--color-hover);
		background-color: var(--color-hover);
		color: #FFF;
	}
	.c-button__inner > span {
		font-size: 2.1rem;
	}
}

/*----------
	button container
----------*/
.g-button-container {
	margin: 0 auto;
}
@media (max-width: 767px) {
	.g-button-container {
		padding: 0 25px;
	}
	.g-button-container__item {
		width: 100%;
		margin: 0 auto 25px;
	}
	.g-button-container__item:last-child {
		margin-bottom: 0;
	}
}
@media (min-width: 768px), print {
	.g-button-container {
		display: flex;
		flex-wrap: nowrap;
		justify-content: center;
		align-items: stretch;
	}
	.g-button-container__item {
		display: inline-block;
		min-width: 320px;
		margin-left: auto;
		margin-right: auto;
	}
	.g-button-container__item + .g-button-container__item {
		margin-top: 40px;
	}
	.g-button-container--2up {
		justify-content: center;
	}
	.g-button-container--2up .g-button-container__item {
		flex: 1 1 320px;
	}
	.g-button-container--2up .g-button-container__item + .g-button-container__item {
		margin-left: 32px;
	}
	.g-button-container--center {
		justify-content: center;
	}
	.g-button-container--left {
		justify-content: flex-start;
	}
	.g-button-container--right {
		justify-content: flex-end;
	}
	.g-button-container--3up, .g-button-container--4up {
		display: grid;
		gap: 32px;
	}
	.g-button-container--3up .g-button-container__item, .g-button-container--4up .g-button-container__item {
		max-width: none;
	}
	.g-button-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-button-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}

/*----------
	image link
----------*/
.c-imagelink {
	height: 100%;
}
.c-imagelink__image {
	position: relative;
	width: 100%;
	aspect-ratio: 175/117;
}
.c-imagelink__image figure {
	position: relative;
	border-radius: 10px;
	overflow: hidden;
}
.c-imagelink__image figure::before {
	content: "";
	display: block;
	width: 50%;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 100%);
	z-index: 1;
}
.c-imagelink__en {
	display: block;
	position: absolute;
	top: 10px;
	right: -28px;
	right: 0;
	color: #C2C9CC;
	font-family: var(--font-barlow);
	font-size: 4.5rem;
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1;
	writing-mode: vertical-rl;
	z-index: 2;
}
.c-imagelink__content {
	margin-top: 22px;
}
.c-imagelink__title {
	position: relative;
	min-height: 44px;
	padding-bottom: 20px;
	border-bottom: 1px solid #ccc;
	color: var(--color-seco);
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.18;
}
.c-imagelink__title span {
	display: inline-block;
	padding-top: 2px;
}
.c-imagelink__text {
	color: var(--color-txt);
	letter-spacing: 0.03em;
}
.c-imagelink:has(a) .c-imagelink__title {
	padding-left: 34px;
	transition: color 0.2s;
}
.c-imagelink:has(a) .c-imagelink__title::before {
	content: var(--icon-arrow2-r);
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 0;
	left: 0;
	font-size: 2.4rem;
}
.c-imagelink:has(a) .c-imagelink__title::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 0;
	height: 1px;
	background-color: var(--color-hover);
	transition: all 0.3s;
}
@media (max-width: 767px) {
	.c-imagelink + .c-imagelink {
		margin-top: 40px;
	}
}
.c-imagelink--sm .c-imagelink__inner {
	display: block;
	position: relative;
	height: 100%;
	border-bottom: 1px solid #E6E6E6;
}
.c-imagelink--sm .c-imagelink__content {
	margin-top: 20px;
	padding-bottom: 0;
}
.c-imagelink--sm .c-imagelink__title {
	border-bottom: 0;
}
.c-imagelink--sm .c-imagelink__image figure::before {
	display: none;
}
@media (min-width: 768px), print {
	.c-imagelink__image {
		aspect-ratio: 3/2;
	}
	.c-imagelink__en {
		top: 15px;
		font-size: 7rem;
	}
	.c-imagelink__content {
		margin-top: 30px;
	}
	.c-imagelink__title {
		min-height: 60px;
		font-size: 2.1rem;
	}
	.c-imagelink__title span {
		padding-top: 7px;
	}
	.c-imagelink:has(a) .c-imagelink__title {
		padding-left: 56px;
	}
	.c-imagelink:has(a) .c-imagelink__title::before {
		content: var(--icon-arrow1-r);
		font-size: 4rem;
	}
	.c-imagelink a:hover .c-imagelink__title {
		color: var(--color-hover);
	}
	.c-imagelink a:hover .c-imagelink__title::after {
		width: 100%;
	}
	.c-imagelink--sm .c-imagelink__inner {
		display: block;
		position: relative;
		height: 100%;
		border-bottom: 1px solid #E6E6E6;
	}
	.c-imagelink--sm .c-imagelink__inner::after {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		bottom: -1px;
		width: 0;
		height: 1px;
		background-color: var(--color-hover);
		transition: all 0.3s;
	}
	.c-imagelink--sm .c-imagelink__content {
		margin-top: 20px;
		padding-bottom: 20px;
	}
	.c-imagelink--sm .c-imagelink__title {
		font-size: 1.6rem;
		border-bottom: 0;
		min-height: auto;
		padding-bottom: 0;
	}
	.c-imagelink--sm .c-imagelink__title::after {
		display: none;
	}
	.c-imagelink--sm .c-imagelink__title span {
		padding-top: 0;
	}
	.c-imagelink--sm .c-imagelink__image {
		position: relative;
		width: 100%;
		aspect-ratio: 175/117;
	}
	.c-imagelink--sm .c-imagelink__image figure {
		position: relative;
		border-radius: 10px;
		overflow: hidden;
	}
	.c-imagelink--sm .c-imagelink__image figure::before {
		display: none;
	}
	.c-imagelink--sm:has(a) .c-imagelink__title {
		padding-left: 34px;
		min-height: 44px;
		padding-bottom: 20px;
	}
	.c-imagelink--sm:has(a) .c-imagelink__title::before {
		content: var(--icon-arrow2-r);
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		position: absolute;
		top: 4px;
		left: 1px;
		font-size: 2.4rem;
	}
	.c-imagelink--sm a:hover::after {
		width: 100%;
	}
	.c-imagelink--sm a:hover .c-imagelink__text {
		color: var(--color-hover);
	}
}
.c-imagelink--guide .c-imagelink__en {
	right: -10px;
	white-space: nowrap;
}

/*----------
	grid
----------*/
@media (min-width: 768px), print {
	.g-imagelink-grid {
		display: grid;
	}
	.g-imagelink-grid--2up {
		grid-template-columns: repeat(2, 1fr);
		gap: 88px 45px;
	}
}
/*----------
	deflist
----------*/
.c-deflist {
	border-bottom: 1px solid #E6E6E6;
}
.c-deflist__term {
	border-top: 1px solid var(--color-prim);
	padding: 20px 0;
	background-color: #fff;
	font-weight: 700;
	line-height: 1.8;
}
.c-deflist__detail {
	padding: 20px 0;
	background-color: #fff;
	border-top: 1px solid #E6E6E6;
	font-size: 1.4rem;
	line-height: 1.8;
}
.c-deflist__detail strong,
.c-deflist__detail em {
	font-weight: 700;
}
@media (min-width: 768px), print {
	.c-deflist__body {
		display: flex;
		justify-content: space-between;
		align-items: stretch;
	}
	.c-deflist__term {
		flex: 0 0 24.41%;
		padding: 22px 16px 22px 0;
	}
	.c-deflist__detail {
		flex: 1 1 auto;
		margin-left: -1px;
		padding: 22px 30px;
		font-size: 1.6rem;
	}
}

/*----------
	c-qa
----------*/
.c-qa:not(.is-disabled) .c-qa__item--parent {
	cursor: pointer;
}
.c-qa:not(.is-disabled) .c-qa__item--parent::after {
	visibility: visible;
}
.c-qa:not(.is-disabled) .c-qa__item--child {
	height: 0;
	position: relative;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
	transition: all 0.4s linear;
}
.c-qa__item {
	position: relative;
}
.c-qa__item--parent {
	border-bottom: #979797 solid 1px;
}
.c-qa__item--parent::after {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	position: absolute;
	right: 8px;
	top: 0;
	bottom: 0;
	margin: auto;
	visibility: hidden;
	background: url(/recruit/assets/images/common/icon_plus.svg) no-repeat 0 0;
}
.c-qa__item--parent::before {
	content: "";
	display: inline-block;
	width: 32px;
	height: 32px;
	border-radius: 100%;
	background-color: #fff;
	border: 2px solid var(--color-prim);
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
.c-qa__item-inner {
	position: relative;
	line-height: var(--line-height-l);
	letter-spacing: 0.02em;
	display: flex;
}
.c-qa__item-inner--parent {
	align-items: center;
	justify-content: flex-start;
	width: 100%;
	padding: 15px 45px 15px 0;
	color: var(--color-txt);
	text-align: left;
}
.c-qa__item-inner--parent::before {
	content: attr(title);
	display: block;
	position: relative;
	top: -2px;
	color: var(--color-prim);
	font-family: var(--font-barlow);
	font-size: 3rem;
	font-weight: 700;
	line-height: 1;
	margin-right: 23px;
}
.c-qa__item-inner--parent .c-qa__item-txt {
	font-size: 1.8rem;
}
.c-qa__item-inner--child {
	min-height: 104px;
	padding: 18px 35px 30px 0;
}
.c-qa__item-inner--child::before {
	content: "A";
	display: block;
	width: 36px;
	height: 30px;
	padding-left: 7px;
	margin-right: 10px;
	background-color: var(--color-prim);
	clip-path: polygon(0% 0%, 75% 0%, 100% 50%, 75% 100%, 0% 100%);
	color: #fff;
	font-family: var(--font-barlow);
	font-size: 2rem;
	font-weight: 700;
	line-height: 26px;
}
.c-qa__item-inner--child .c-qa__item-txt {
	font-size: 1.6rem;
}
.c-qa__item-txt {
	flex: 1;
}
.c-qa.is-active:not(.is-disabled) .c-qa__item--parent::after {
	background: url(/recruit/assets/images/common/icon_minus.svg) no-repeat 0 0;
}
.c-qa.is-active:not(.is-disabled) .c-qa__item--child {
	height: auto;
	opacity: 1;
	pointer-events: all;
}
@media (min-width: 768px), print {
	.c-qa__item--parent {
		border-bottom: #979797 solid 1px;
	}
	.c-qa__item--parent::after {
		right: 28px;
	}
	.c-qa__item--parent::before {
		right: 20px;
	}
	.c-qa__item-inner {
		font-size: 2rem;
	}
	.c-qa__item-inner--parent {
		padding: 23px 50px 23px 35px;
		cursor: pointer;
	}
	.c-qa__item-inner--parent::before {
		font-size: 4rem;
	}
	.c-qa__item-inner--parent .c-qa__item-txt {
		font-size: 2rem;
	}
	.c-qa__item-inner--child {
		padding: 23px 40px 60px 25px;
	}
	.c-qa__item-inner--child::before {
		width: 53px;
		height: 44px;
		padding-left: 12px;
		margin-right: 16px;
		font-size: 3rem;
		line-height: 40px;
	}
	.c-qa__item-inner--child .c-qa__item-txt {
		padding-top: 6px;
		font-size: 1.6rem;
	}
}

/*----------
	single column
----------*/
.g-center-col__item + .g-center-col__item {
	margin-top: 40px;
}
@media (min-width: 768px), print {
	.g-center-col {
		display: flex;
		justify-content: center;
		align-items: flex-start;
	}
	.g-center-col__item {
		flex: 1 1 66.6666666667%;
		max-width: 66.6666666667%;
	}
	.g-center-col__item + .g-center-col__item {
		margin-top: 0;
	}
	.g-center-col--small .g-center-col__item {
		flex-basis: 33.3333333333%;
		max-width: 33.3333333333%;
	}
	.g-center-col--2up .g-center-col__item {
		flex-basis: 33.3333333333%;
		max-width: 33.3333333333%;
	}
	.g-center-col--2up .g-center-col__item + .g-center-col__item {
		margin-left: 40px;
	}
}

/*----------
	grid
----------*/
.g-grid {
	margin: 0 auto;
}
@media (max-width: 767px) {
	.g-grid__item + .g-grid__item {
		margin-top: 40px;
	}
}
@media (min-width: 768px), print {
	.g-grid {
		display: grid;
		gap: 70px 60px;
	}
	.g-grid--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-grid--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-grid--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}

/*----------
	interviewlist
----------*/
.c-interviewlist {
	display: grid;
	gap: 20px 10px;
	grid-template-columns: repeat(2, 1fr);
}
.c-interviewlist__item .c-interviewlist__inner {
	position: relative;
	display: block;
	border-radius: 10px;
	overflow: hidden;
}
.c-interviewlist__item .c-interviewlist__inner::before {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 50%;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 100%);
	opacity: 1;
	transition: opacity 0.2s;
}
.c-interviewlist__item .c-interviewlist__inner::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 100%);
	opacity: 0;
	transition: opacity 0.2s;
}
.c-interviewlist__item .c-interviewlist__image {
	aspect-ratio: 170/229;
}
.c-interviewlist__item .c-interviewlist__detail {
	position: absolute;
	left: 0;
	bottom: 20px;
	z-index: 1;
}
.c-interviewlist__item .c-interviewlist__job {
	position: relative;
	padding: 3px 7px 3px 15px;
	background-color: var(--color-prim);
	color: #fff;
	font-size: 1.3rem;
	font-weight: 700;
	line-height: 1.7;
	transition: background-color 0.2s;
}
.c-interviewlist__item .c-interviewlist__job::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: -15px;
	width: 30px;
	height: 30px;
	background: var(--color-prim);
	clip-path: polygon(0% 0%, 50% 0, 100% 50%, 50% 100%, 0% 100%);
	z-index: -1;
	transition: background-color 0.2s;
}
.c-interviewlist__item .c-interviewlist__name {
	display: inline-block;
	position: relative;
	margin: 10px 0 0 20px;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.56;
}
.c-interviewlist__item .c-interviewlist__name::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 0;
	height: 1px;
	background-color: var(--color-hover);
	transition: all 0.3s;
	background-color: #fff;
	transition-delay: 0.1s;
}
.c-interviewlist__item .c-interviewlist__name span {
	position: relative;
	display: block;
	font-weight: 400;
}
.c-interviewlist__item .c-interviewlist__name span::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 0;
	height: 1px;
	background-color: var(--color-hover);
	transition: all 0.3s;
	background-color: #fff;
}
@media (min-width: 768px), print {
	.c-interviewlist {
		gap: 60px 42px;
		grid-template-columns: repeat(4, 1fr);
	}
	.c-interviewlist--2up {
		width: 782px;
		margin-inline: auto;
		grid-template-columns: repeat(2, 1fr);
	}
	.c-interviewlist--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.c-interviewlist__item .c-interviewlist__inner {
		width: 100%;
		height: 100%;
		aspect-ratio: 3/4;
	}
	.c-interviewlist__item .c-interviewlist__inner::before {
		height: 58%;
	}
	.c-interviewlist__item .c-interviewlist__image {
		aspect-ratio: 372/500;
	}
	.c-interviewlist__item .c-interviewlist__detail {
		bottom: 40px;
	}
	.c-interviewlist__item .c-interviewlist__job {
		position: relative;
		padding: 6px 8px 7px 16px;
		background-color: var(--color-prim);
		color: #fff;
		font-size: 1.6rem;
		font-weight: 700;
		line-height: 1.7;
	}
	.c-interviewlist__item .c-interviewlist__job::before {
		right: -23px;
		width: 40px;
		height: 40px;
	}
	.c-interviewlist__item .c-interviewlist__name {
		margin: 20px 0 0 30px;
		font-size: 2rem;
	}
	.c-interviewlist__item .c-interviewlist__name span {
		font-size: 1.6rem;
	}
	.c-interviewlist__item .c-interviewlist__inner:hover::before {
		opacity: 0;
	}
	.c-interviewlist__item .c-interviewlist__inner:hover::after {
		opacity: 1;
	}
	.c-interviewlist__item .c-interviewlist__inner:hover .c-interviewlist__job {
		background-color: var(--color-hover);
	}
	.c-interviewlist__item .c-interviewlist__inner:hover .c-interviewlist__job::before {
		background-color: var(--color-hover);
	}
	.c-interviewlist__item .c-interviewlist__inner:hover .c-interviewlist__name::after {
		width: 100%;
	}
	.c-interviewlist__item .c-interviewlist__inner:hover .c-interviewlist__name span::after {
		width: 100%;
	}
}

/*----------
	titleset
----------*/
.c-titleset__title {
	position: relative;
	display: block;
	color: var(--color-prim);
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.5;
}
.c-titleset__title::before {
	content: "";
	display: inline-block;
	position: relative;
	top: -4px;
	width: 16px;
	height: 3px;
	margin-right: 10px;
	background-color: var(--color-prim);
	transform: skew(-18deg);
}
.c-titleset__catch {
	margin-top: 10px;
	color: var(--color-txt);
	font-size: 2.3rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.5;
}
.c-titleset__text {
	color: var(--color-txt);
	margin-top: 20px;
	font-size: 1.4rem;
	letter-spacing: 0.03em;
	line-height: 1.8;
}
@media (min-width: 768px), print {
	.c-titleset__title {
		font-size: 2rem;
	}
	.c-titleset__title::before {
		top: -5px;
		width: 28px;
		height: 5px;
		margin-right: 20px;
	}
	.c-titleset__catch {
		font-size: 3.5rem;
	}
	.c-titleset__text {
		margin-top: 40px;
		font-size: 1.8rem;
		line-height: 1.6;
	}
}

/*----------
	imageblock
----------*/
.c-imageblock + .c-imageblock {
	margin-top: 50px;
}
@media (max-width: 767px) {
	.c-imageblock__detail {
		padding: 20px 5.3333333333% 0;
	}
	.c-imageblock__image {
		aspect-ratio: 39/31;
	}
}
@media (min-width: 768px), print {
	.c-imageblock {
		display: flex;
		align-items: center;
	}
	.c-imageblock + .c-imageblock {
		margin-top: 70px;
	}
	.c-imageblock__image {
		flex: 0 0 calc(50% - 40px);
		height: 540px;
		margin-right: 80px;
	}
	.c-imageblock__detail {
		flex: 0 0 calc(50% - 80px);
	}
	.c-imageblock--reverse {
		flex-direction: row-reverse;
	}
	.c-imageblock--reverse .c-imageblock__image {
		margin-right: 0;
		margin-left: 80px;
	}
}

/*----------
	circleimage
----------*/
.c-circleimage__items {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px 16px;
}
.c-circleimage__image {
	border-radius: 100%;
	overflow: hidden;
}
.c-circleimage__title {
	margin-top: 16px;
	text-align: center;
	font-weight: 700;
	font-size: 1.8rem;
}
.c-circleimage__text {
	margin-top: 10px;
	text-align: center;
}
@media (min-width: 768px), print {
	.c-circleimage__items--3up {
		grid-template-columns: repeat(3, 1fr);
		gap: 60px 42px;
	}
	.c-circleimage__items--4up {
		grid-template-columns: repeat(4, 1fr);
		gap: 80px 42px;
	}
	.c-circleimage__image {
		max-width: 80.65%;
		margin-inline: auto;
	}
	.c-circleimage__title {
		margin-top: 20px;
		font-size: 2rem;
		line-height: 1.6;
	}
	.c-circleimage--small .c-circleimage__image {
		max-width: 240px;
	}
}

/*----------
	timeschedule
----------*/
.c-timeschedule {
	margin-bottom: 60px;
}
.c-timeschedule__item {
	width: 220px !important;
	height: auto;
	margin-right: 2px;
}
.c-timeschedule__item::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 32px;
	aspect-ratio: 1;
	clip-path: polygon(0 0, 100% 0, 0 100%);
	background: var(--color-prim);
	z-index: 2;
}
.c-timeschedule__item::after {
	content: "";
	position: absolute;
	top: -2px;
	left: -2px;
	display: block;
	width: calc(100% + 4px);
	height: calc(100% + 4px);
	background-color: #009FE8;
	clip-path: polygon(80% 0, 100% 50%, 80% 100%, 0 100%, 0 0);
}
.c-timeschedule__inner {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 20px 30px 20px 20px;
	background-color: #fff;
	clip-path: polygon(80% 0, 100% 50%, 80% 100%, 0 100%, 0 0);
	z-index: 1;
}
.c-timeschedule__time {
	color: var(--color-prim);
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.25;
}
.c-timeschedule__detail {
	margin-top: 10px;
	font-size: 1.4rem;
	letter-spacing: 0.0357em;
}
@media (min-width: 768px), print {
	.c-timeschedule {
		margin-bottom: 80px;
	}
	.c-timeschedule__items {
		max-width: 1200px;
	}
	.c-timeschedule__item {
		width: 300px !important;
	}
	.c-timeschedule__inner {
		padding: 30px 70px 30px 40px;
	}
}

.c-timeschedule-slider {
	margin-top: 56px;
}
.c-timeschedule-slider__slide > a {
	position: relative;
	display: block;
	border-radius: 5px;
}
.c-timeschedule-slider__slide:first-child > a {
	overflow: hidden;
	border-radius: 5px 0 0 5px;
}
.c-timeschedule-slider__slide:last-child > a {
	overflow: hidden;
	border-radius: 0 5px 5px 0;
}
.c-timeschedule-slider__slide > p {
	padding: 20px 10px 0;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: var(--line-height-s);
}
.c-timeschedule-slider__ui {
	width: 100%;
	height: 40px;
	position: relative;
}
.c-timeschedule-slider__bar {
	width: calc(100% + 30px);
	height: 4px;
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: #F2F2F2;
}
.c-timeschedule-slider__bar > div {
	display: block;
	height: 4px;
	border-radius: 2px;
	background-color: #C2C9CB;
}
@media (min-width: 768px), print {
	.c-timeschedule-slider {
		padding-left: 40px;
		padding-right: 40px;
	}
	.c-timeschedule-slider__slides {
		max-width: 1200px;
		margin: 0 auto;
	}
	.c-timeschedule-slider__slide:first-child > a {
		border-radius: 10px 0 0 10px;
	}
	.c-timeschedule-slider__slide:last-child > a {
		border-radius: 0 10px 10px 0;
	}
	.c-timeschedule-slider__slide > p {
		font-size: 1.8rem;
	}
	.c-timeschedule-slider__ui {
		margin: 0 auto;
		height: 44px;
		max-width: 1280px;
	}
	.c-timeschedule-slider__bar {
		width: 100%;
		left: 0;
	}
}

/*----------
	募集要項
----------*/
.c-recruitment-description {
	position: relative;
	width: 100%;
	overflow: hidden;
	z-index: 2;
}
.c-recruitment-description__title {
	position: relative;
	z-index: 1;
	font-family: var(--font-barlow);
}
.c-recruitment-description__title::before {
	content: "";
	display: inline-block;
	position: relative;
	top: -5px;
	width: 17px;
	height: 3px;
	margin-right: 10px;
	background-color: #fff;
	transform: skew(-18deg);
}
.c-recruitment-description__title span {
	font-family: var(--font-sans);
}
.c-recruitment-description__link {
	z-index: 1;
}
.c-recruitment-description__link__inner {
	transition: background-color 0.2s;
}
.c-recruitment-description__text {
	color: #fff;
}
.c-recruitment-description__text span {
	position: relative;
	display: inline-block;
}
.c-recruitment-description__text span::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 0;
	height: 1px;
	background-color: #fff;
	transition: all 0.3s;
}
.c-recruitment-description__link01 .c-recruitment-description__link__inner {
	background-color: rgba(0, 159, 232, 0.8);
}
.c-recruitment-description__link02 .c-recruitment-description__link__inner {
	background-color: rgba(0, 87, 128, 0.8);
}
.c-recruitment-description__link03 .c-recruitment-description__link__inner {
	background-color: rgba(29, 29, 29, 0.8);
}
.c-recruitment-description__bg img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (max-width: 767px) {
	.c-recruitment-description__bg {
		aspect-ratio: 390/400;
	}
	.c-recruitment-description__heading {
		position: absolute;
		top: 36px;
		left: 30px;
	}
	.c-recruitment-description__title {
		color: #fff;
		font-size: 1.9rem;
		font-weight: 700;
		line-height: 1.05;
		letter-spacing: 0.04em;
		text-transform: uppercase;
	}
	.c-recruitment-description__title span {
		position: relative;
		display: block;
		margin-top: 13px;
		font-size: 2.7rem;
		font-weight: 700;
		line-height: 1.05;
		letter-spacing: 0;
	}
	.c-recruitment-description__link {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
		height: 113px;
	}
	.c-recruitment-description__link__inner {
		display: grid;
		place-content: center;
		height: 100%;
	}
	.c-recruitment-description__text {
		font-size: 2rem;
		font-weight: 700;
		line-height: 1.45;
	}
	.c-recruitment-description__text > i {
		display: block;
		margin-top: 10px;
		font-size: 2.4rem;
		text-align: center;
	}
	.c-recruitment-description__en {
		display: none;
	}
}
@media (min-width: 768px), print {
	.c-recruitment-description {
		width: 100%;
		min-width: 1240px;
		height: 500px;
	}
	.c-recruitment-description__bg {
		width: 100%;
		height: 100%;
	}
	.c-recruitment-description__heading {
		width: 1200px;
		position: absolute;
		top: 90px;
		left: 50%;
		transform: translateX(-50%);
		z-index: 1;
	}
	.c-recruitment-description__title {
		color: #fff;
		font-size: 2.7rem;
		font-weight: 700;
		text-transform: uppercase;
	}
	.c-recruitment-description__title::before {
		top: -7px;
		width: 28px;
		height: 5px;
		margin-right: 20px;
	}
	.c-recruitment-description__title span {
		position: relative;
		display: block;
		padding-left: 50px;
		font-size: 4.5rem;
		line-height: 1.05;
		letter-spacing: 0;
	}
	.c-recruitment-description__link {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
		height: 200px;
	}
	.c-recruitment-description__link__inner {
		position: relative;
		display: flex;
		justify-content: flex-end;
		align-items: center;
		height: 100%;
		overflow: hidden;
	}
	.c-recruitment-description__text {
		position: relative;
		padding-right: 60px;
		padding-left: 60px;
		font-size: 3rem;
		font-weight: 700;
		line-height: 1.5;
	}
	.c-recruitment-description__text > i {
		position: absolute;
		top: 5px;
		left: 0;
		font-size: 4rem;
	}
	.c-recruitment-description__en {
		position: absolute;
		bottom: -3px;
		right: 0;
		color: rgba(255, 255, 255, 0.5);
		font-family: var(--font-barlow);
		font-weight: 700;
		font-size: 4rem;
		line-height: 1;
	}
	.c-recruitment-description__link__inner:hover {
		background-color: var(--color-hover);
	}
	.c-recruitment-description__link__inner:hover .c-recruitment-description__text span::after {
		width: 100%;
	}
}

/*----------
	c-private-imageset
----------*/
.c-private-imageset {
	display: flex;
	flex-direction: column-reverse;
}
.c-private-imageset__title {
	margin-bottom: 24px;
	font-size: 1.9rem;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.04em;
}
.c-private-imageset__title span {
	display: block;
	color: var(--color-prim);
	font-weight: 700;
	font-size: 1.6rem;
	line-height: 1.875;
	text-transform: uppercase;
}
.c-private-imageset__image {
	margin-bottom: 20px;
	aspect-ratio: 175/116;
}
@media (min-width: 768px), print {
	.c-private-imageset {
		flex-direction: row-reverse;
		justify-content: space-between;
		align-items: center;
		gap: 0 60px;
	}
	.c-private-imageset__title {
		margin-bottom: 15px;
		font-size: 2.7rem;
	}
	.c-private-imageset__detail {
		flex: 0 0 calc(50% - 30px);
	}
	.c-private-imageset__image {
		flex: 0 0 calc(50% - 30px);
		margin-bottom: 0;
		height: 380px;
	}
}

/*----------
	step
----------*/
.c-step__item {
	display: flex;
	align-items: center;
}
.c-step__item + .c-step__item {
	margin-top: 40px;
}
.c-step__item .c-step__header {
	flex: 0 0 60px;
	margin-right: 20px;
}
.c-step__item .c-step__icon {
	width: 100%;
	height: 60px;
	background-color: var(--color-prim);
	clip-path: polygon(0% 0%, 75% 0%, 100% 50%, 75% 100%, 0% 100%);
}
.c-step__item .c-step__icon p {
	display: inline-block;
	padding-top: 13px;
	padding-left: 10px;
	color: #fff;
	font-family: var(--font-barlow);
	font-weight: 700;
	font-size: 1.2rem;
	text-align: center;
	line-height: 1;
}
.c-step__item .c-step__icon p span {
	display: block;
	font-size: 2.2rem;
}
.c-step__item .c-step__body {
	margin-top: -8px;
}
.c-step__item .c-step__title {
	margin-bottom: 8px;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.6;
}
@media (min-width: 768px), print {
	.c-step__item--top {
		align-items: flex-start;
	}
	.c-step__item + .c-step__item {
		margin-top: 50px;
	}
	.c-step__item .c-step__header {
		flex: 0 0 80px;
		margin-right: 30px;
	}
	.c-step__item .c-step__icon {
		height: 80px;
	}
	.c-step__item .c-step__icon p {
		padding-top: 18px;
		padding-left: 18px;
	}
	.c-step__item .c-step__icon p span {
		font-size: 3rem;
	}
	.c-step__item .c-step__body {
		margin-top: -8px;
	}
	.c-step__item .c-step__title {
		margin-bottom: 8px;
		font-size: 2rem;
	}
}

/*----------
	margin
----------*/
/* 汎用マージン */
.u-mt-xs {
	margin-top: 10px !important;
}
@media (min-width: 768px), print {
	.u-mt-xs {
		margin-top: 20px !important;
	}
}

.u-mt-s {
	margin-top: 20px !important;
}
@media (min-width: 768px), print {
	.u-mt-s {
		margin-top: 30px !important;
	}
}

.u-mt-m {
	margin-top: 30px !important;
}
@media (min-width: 768px), print {
	.u-mt-m {
		margin-top: 40px !important;
	}
}

.u-mt-l {
	margin-top: 50px !important;
}
@media (min-width: 768px), print {
	.u-mt-l {
		margin-top: 60px !important;
	}
}

.u-m-xl {
	margin-top: 60px !important;
}
@media (min-width: 768px), print {
	.u-m-xl {
		margin-top: 80px !important;
	}
}

.u-mt-xxl {
	margin-top: 80px !important;
}
@media (min-width: 768px), print {
	.u-mt-xxl {
		margin-top: 120px !important;
	}
}

.u-mt-none {
	margin-top: 0 !important;
}
@media (min-width: 768px), print {
	.u-mt-none {
		margin-top: 0 !important;
	}
}

/*----------
	display
----------*/
@media (max-width: 767px) {
	.u-pc-v {
		display: none;
	}
}

@media (min-width: 768px), print {
	.u-sp-v {
		display: none;
	}
}

/*----------
	text
----------*/
@media (max-width: 767px) {
	.u-pcbr {
		display: none;
	}
}

@media (min-width: 768px), print {
	.u-spbr {
		display: none;
	}
}

.u-txt-center {
	text-align: center !important;
}

@media (min-width: 768px), print {
	.u-txt-pccenter {
		text-align: center !important;
	}
}

.u-txt-right {
	text-align: right !important;
}

.u-txt-left {
	text-align: left !important;
}

.u-txt-normal {
	font-weight: normal !important;
}

.u-txt-medium {
	font-weight: 500 !important;
}

.u-txt-bold {
	font-weight: bold !important;
}

.u-txt-strike {
	text-decoration: line-through !important;
}

.u-txt-indent {
	text-indent: -3em;
	padding-left: 3em;
}

.u-txt-marker {
	font-weight: bold;
	background-image: linear-gradient(transparent 80%, #FFF7A6 80%);
}

.u-txt-prim {
	color: var(--color-prim) !important;
}

.u-txt-seco {
	color: var(--color-seco) !important;
}

.u-txt-default {
	color: var(--color-txt) !important;
}

.u-txt-white {
	color: #fff !important;
}

/* 文字サイズ */
.u-fz-10 {
	font-size: 1rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-10 {
		font-size: 1rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-10 {
		font-size: 1rem !important;
	}
}
.u-fz-11 {
	font-size: 1.1rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-11 {
		font-size: 1.1rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-11 {
		font-size: 1.1rem !important;
	}
}
.u-fz-12 {
	font-size: 1.2rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-12 {
		font-size: 1.2rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-12 {
		font-size: 1.2rem !important;
	}
}
.u-fz-13 {
	font-size: 1.3rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-13 {
		font-size: 1.3rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-13 {
		font-size: 1.3rem !important;
	}
}
.u-fz-14 {
	font-size: 1.4rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-14 {
		font-size: 1.4rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-14 {
		font-size: 1.4rem !important;
	}
}
.u-fz-15 {
	font-size: 1.5rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-15 {
		font-size: 1.5rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-15 {
		font-size: 1.5rem !important;
	}
}
.u-fz-16 {
	font-size: 1.6rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-16 {
		font-size: 1.6rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-16 {
		font-size: 1.6rem !important;
	}
}
.u-fz-17 {
	font-size: 1.7rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-17 {
		font-size: 1.7rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-17 {
		font-size: 1.7rem !important;
	}
}
.u-fz-18 {
	font-size: 1.8rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-18 {
		font-size: 1.8rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-18 {
		font-size: 1.8rem !important;
	}
}
.u-fz-19 {
	font-size: 1.9rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-19 {
		font-size: 1.9rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-19 {
		font-size: 1.9rem !important;
	}
}
.u-fz-20 {
	font-size: 2rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-20 {
		font-size: 2rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-20 {
		font-size: 2rem !important;
	}
}
.u-fz-21 {
	font-size: 2.1rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-21 {
		font-size: 2.1rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-21 {
		font-size: 2.1rem !important;
	}
}
.u-fz-22 {
	font-size: 2.2rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-22 {
		font-size: 2.2rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-22 {
		font-size: 2.2rem !important;
	}
}
.u-fz-23 {
	font-size: 2.3rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-23 {
		font-size: 2.3rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-23 {
		font-size: 2.3rem !important;
	}
}
.u-fz-24 {
	font-size: 2.4rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-24 {
		font-size: 2.4rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-24 {
		font-size: 2.4rem !important;
	}
}
.u-fz-25 {
	font-size: 2.5rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-25 {
		font-size: 2.5rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-25 {
		font-size: 2.5rem !important;
	}
}
.u-fz-26 {
	font-size: 2.6rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-26 {
		font-size: 2.6rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-26 {
		font-size: 2.6rem !important;
	}
}
.u-fz-27 {
	font-size: 2.7rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-27 {
		font-size: 2.7rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-27 {
		font-size: 2.7rem !important;
	}
}
.u-fz-28 {
	font-size: 2.8rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-28 {
		font-size: 2.8rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-28 {
		font-size: 2.8rem !important;
	}
}
.u-fz-29 {
	font-size: 2.9rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-29 {
		font-size: 2.9rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-29 {
		font-size: 2.9rem !important;
	}
}
.u-fz-30 {
	font-size: 3rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-30 {
		font-size: 3rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-30 {
		font-size: 3rem !important;
	}
}
.u-fz-31 {
	font-size: 3.1rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-31 {
		font-size: 3.1rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-31 {
		font-size: 3.1rem !important;
	}
}
.u-fz-32 {
	font-size: 3.2rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-32 {
		font-size: 3.2rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-32 {
		font-size: 3.2rem !important;
	}
}
.u-font-sans {
	font-family: var(--font-sans);
}

.u-font-barlow {
	font-family: var(--font-barlow);
}

.u-pointerevents-none {
	pointer-events: none;
}

/* 5px */
.u-mt-5 {
	margin-top: 5px;
}

/* 10px倍数 */
.u-mt-10 {
	margin-top: 10px !important;
}

.u-mt-20 {
	margin-top: 20px !important;
}

.u-mt-30 {
	margin-top: 30px !important;
}

.u-mt-40 {
	margin-top: 40px !important;
}

.u-mt-50 {
	margin-top: 50px !important;
}

.u-mt-60 {
	margin-top: 60px !important;
}

.u-mt-70 {
	margin-top: 70px !important;
}

.u-mt-80 {
	margin-top: 80px !important;
}

.u-mt-90 {
	margin-top: 90px !important;
}

.u-mt-100 {
	margin-top: 100px !important;
}