/*----------------------------------
下層ページ共通
----------------------------------*/

.page-top {
	visibility: hidden;
	z-index: 10;
	position: fixed;
	right: 25px;
	bottom: 25px;
	width: 22px;
	height: 65px;
	opacity: 0;
	transition: opacity 0.3s, transform 0.3s, visibility 0.3s;
}

.page-top.fadeIn {
	visibility: visible;
	opacity: 1;
}

.page-top:hover {
	cursor: pointer;
}

.page-mainvisual {
	position: relative;
	padding-top: 133px;
}

.page-mainvisual::after {
	position: absolute;
	top: -2px;
	left: 0;
	width: 600px;
	width: 44.1176470588vw;
	min-width: 600px;
	height: 1165px;
	height: 85.6617647059vw;
	min-height: 1165px;
	background: url(../img/page_mv_j.png) no-repeat top left/contain;
	content: "";
}

.page-mainvisual.white::after {
	left: -53px;
	width: 550px;
	height: 90.661765vw;
	background-image: url(../img/page_mv_j_white.png);
}

.page-mainvisual.white .inner {
	text-align: left;
}

.page-mainvisual.white .page-mainvisual__title {
	margin: 102px 0 0 0;
}

.page-mainvisual .inner {
	text-align: right;
}

.breadcrumb {
	margin-top: 199px;
	padding-right: 27px;
}

.breadcrumb__items {
	display: flex;
	align-items: center;
}

.breadcrumb__item {
	color: #162142;
	font-weight: 500;
	font-size: 1.5rem;
}

.breadcrumb__item a {
	color: #162142;
	font-weight: 700;
}

.breadcrumb__item:first-child {
	position: relative;
	margin-top: 2px;
	font-family: "Akshar", sans-serif;
}

.breadcrumb__item:nth-child(2) {
	position: relative;
}

.breadcrumb__item:not(:first-child) {
	position: relative;
	margin-left: 26px;
}

.breadcrumb__item:not(:first-child)::before {
	position: absolute;
	top: 51%;
	left: -15px;
	width: 6px;
	height: 10px;
	transform: translateY(-50%);
	background: url(../img/arrow_breadcrumb.svg) no-repeat center left/contain;
	content: "";
}

.breadcrumb__item:not(:last-child) {
	white-space: nowrap;
}

.page-mainvisual__title {
	display: inline-block;
	z-index: 1;
	position: relative;
	margin-top: 166px;
}

.page-mainvisual__title > span {
	display: block;
	text-align: left;
}

.page-mainvisual__title > span.en {
	color: #CE0201;
	font-weight: 700;
	font-family: "Akshar", sans-serif;
}

.page-mainvisual__title > span.ja {
	margin-top: 10px;
	color: #162142;
	font-weight: 800;
	font-size: 4rem;
	line-height: 1.625;
}

.page-mainvisual__img {
	margin: 50px 0 0 115px;
	text-align: right;
}

.page-mainvisual__img img {
	-webkit-clip-path: polygon(7% 0, 100% 0, 100% 100%, 0 100%, 0 50%);
	width: 100%;
	max-width: 98%;
	clip-path: polygon(7% 0, 100% 0, 100% 100%, 0 100%, 0 50%);
	transition: -webkit-clip-path 0.6s ease;
	transition: clip-path 0.6s ease;
	transition: clip-path 0.6s ease, -webkit-clip-path 0.6s ease;
	will-change: clip-path;
}

.page__content {
	position: relative;
}

.page__content .section__title span.ja {
	font-size: 2.5rem;
	line-height: 1.8;
}

.page-sec__title {
	display: flex;
	position: relative;
	align-items: flex-end;
	padding-bottom: 10px;
	border-bottom: 1px solid #818181;
	color: #162142;
	font-weight: 800;
	font-size: 2.5rem;
	line-height: 1.5;
}

.page-sec__title::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 160px;
	height: 3px;
	background-color: #CB0200;
	content: "";
}

.page__wrap {
	display: flex;
}

.page-sidebar {
	flex: 0 0 164px;
	margin-left: -73px;
}

.page-sidebar__title {
	display: none;
}

.page-sidebar__title::after {
	position: absolute;
	top: 50%;
	right: 25px;
	width: 0;
	height: 0;
	transform: translateY(-50%);
	border-top: 0;
	border-right: 4px solid transparent;
	border-bottom: 7px solid #162142;
	border-left: 4px solid transparent;
	border-style: solid;
	content: "";
}

.page-sidebar__title.open::after {
	transform: translateY(-50%) rotateX(180deg);
}

.page-sidebar__title:hover {
	cursor: pointer;
}

.page-sidebar__lists {
	padding-left: 14px;
}

.page-sidebar__list {
	line-height: 1;
}

.page-sidebar__list + .page-sidebar__list {
	margin-top: 30px;
}

.page-sidebar__list.current {
	position: relative;
}

.page-sidebar__list.current::before {
	position: absolute;
	top: 4px;
	left: -15px;
	width: 0;
	height: 0;
	border-top: 5px solid transparent;
	border-right: 0;
	border-bottom: 5px solid transparent;
	border-left: 8px solid #cb0200;
	border-style: solid;
	content: "";
}

.page-sidebar__list.current a {
	color: #162142;
	font-weight: 700;
}

.page-sidebar__list a {
	color: #808080;
	font-size: 1.5rem;
}

.table {
	width: 100%;
	border-collapse: collapse;
	table-layout: fixed;
}

.table tr {
	display: block;
	border-bottom: 1px solid #B9B9D6;
}

.table tr:last-child {
	border-bottom: none;
}

.table th,
.table td {
	padding: 35.5px 0;
	line-height: 1.9125;
}

.table th {
	width: 140px;
	color: #162142;
	font-weight: 700;
	text-align: left;
}

.table td {
	padding-left: 56px;
	color: #2F2F2F;
	vertical-align: middle;
}

.pagination {
	display: flex;
	justify-content: center;
	margin-top: 100px;
}

.pagination * {
	display: inline-block;
	margin-right: 40px;
}

.pagination *:last-child {
	margin-right: 0;
}

.pagination *:last-child .page-numbers {
	border: none;
}

.page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 10px;
	height: 16px;
	color: #000;
	font-weight: 500;
	font-size: 16px;
}

.page-numbers.prev,
.page-numbers.next {
	position: relative;
	color: #162142;
	font-weight: 500;
}

.page-numbers.prev::after,
.page-numbers.next::after {
	position: absolute;
	top: 58%;
	width: 8px;
	height: 13px;
	transform: translateY(-50%);
	background: url(../img/arrow_green.svg) no-repeat center left/contain;
	content: "";
}

.page-numbers.prev {
	justify-content: flex-end;
}

.page-numbers.prev::after {
	left: 0;
	transform: translateY(-50%) rotate(180deg);
}

.page-numbers.next {
	justify-content: flex-start;
}

.page-numbers.next::after {
	right: 0;
}

.page-numbers.current {
	position: relative;
	background-color: #162142;
	color: #fff;
}

.page-numbers.current::before {
	z-index: -1;
	position: absolute;
	top: 56%;
	left: 50%;
	width: 44px;
	height: 44px;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	background-color: #162142;
	content: "";
}

.page-404 {
	margin-top: 200px;
	padding-bottom: 100px;
	text-align: center;
}

.page-404 h1 {
	color: #162142;
	font-weight: 700;
	font-size: 5rem;
	font-family: "Akshar", sans-serif;
}

.page-404 p {
	margin-top: 50px;
}

.page-404 .top-link {
	margin-top: 50px;
}

.page-404 .top-link a {
	color: blue;
}

/*----------------------------------
About usページ
----------------------------------*/

.page-about .page__content {
	padding-top: 238px;
}

.about .content__list + .content__list {
	margin-top: 220px;
}

.about .content__list + .content__list .button-link {
	width: 277px;
}

.about .button-link {
	font-family: "Noto Sans JP", sans-serif;
}

.content__lists {
	padding-left: 114px;
}

.about__title {
	margin-top: 77px;
}

.about__title > span {
	display: block;
}

.about__title > span.en {
	color: #CE0201;
	font-weight: 700;
	font-family: "Akshar", sans-serif;
}

.about__title > span.ja {
	color: #162142;
	font-weight: 800;
	font-size: 3rem;
	line-height: 1.5;
}

.about__text {
	margin-top: 40px;
	font-size: 1.8rem;
	line-height: 2.222;
}

.about-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 73px;
}

.about-link .button {
	margin-left: 30px;
}

.about-link__title {
	color: #162142;
	font-weight: 800;
	font-size: 2rem;
}

/*----------------------------------
Messageページ
----------------------------------*/

.page-message .page__content {
	padding-top: 95px;
}

.message-rinen {
	width: 699px;
	max-width: 100%;
	margin: auto;
}

.message-sec01 {
	margin-top: 105px;
}

.message-sec01 .message__text {
	font-size: 1.8rem;
	line-height: 2.222;
}

.message__img {
	width: 517px;
	max-width: 100%;
	margin: 85px auto 0;
}

/*----------------------------------
Social Contributionsページ
----------------------------------*/

.page-social-contributions .page__content {
	padding-top: 196px;
}

.contributions .inner {
	padding-left: 205px;
}

.contributions .section__title .ja {
	margin-top: 0;
}

.contributions__wrap {
	margin-top: 45px;
}

.contributions__text {
	font-size: 1.8rem;
	line-height: 2.222;
}

.contributions__img {
	width: 271px;
	margin-top: 64px;
}

.contributions-caption {
	margin-top: 11px;
	font-size: 1.8rem;
	line-height: 1;
}

/*----------------------------------
お知らせページ
----------------------------------*/

.archive .page__content {
	padding-top: 135px;
}

.archive__wrap {
	display: flex;
}

.archive__wrap .sidebar {
	position: sticky;
	top: 150px;
	height: 100px;
}

.archive__wrap .no-post {
	margin-left: 100px;
}

.sidebar__list {
	text-align: center;
}

.sidebar__list + .sidebar__list {
	margin-top: 13px;
}

.sidebar__list a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: auto;
	min-width: 121px;
	max-width: 200px;
	height: auto;
	padding: 1.5px 10px;
	border: 1px solid #CE0201;
	border-radius: 50px;
	color: #CE0201;
	font-weight: 700;
	font-size: 1.3rem;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

.archive__content {
	flex: 0 0 calc(100% - 240px);
	margin-left: 119px;
}

.archive__content .info {
	position: relative;
	padding-right: 75px !important;
}

.archive__content .info .arrow {
	display: flex;
	position: absolute;
	top: 50%;
	right: 20px;
	justify-content: space-between;
	width: 40px;
	transform: translateY(-50%);
}

.archive__content .info:hover {
	opacity: 1;
}

.archive__content .info__title {
	transition: all 0.3s ease 0s;
}

.post-cats {
	display: flex;
	flex-wrap: wrap;
	margin-left: 23px;
}

.post-cats .info__category {
	margin-right: 7px;
}

.post-cats .info__category:last-child {
	margin-right: 0;
}

.single .page__content {
	padding-top: 112px;
}

.news-single-head {
	position: relative;
	padding-bottom: 10px;
	border-bottom: 1px solid #818181;
}

.news-single-head::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 102px;
	height: 3px;
	background-color: #CB0200;
	content: "";
}

.news-single-head .info__published {
	margin-right: 16px;
}

.news-single-head .post-cats {
	margin-left: 0;
}

.news-single__title {
	margin-top: 20px;
	color: #162142;
	font-weight: 700;
	font-size: 2.5rem;
	line-height: 1.6;
}

.news-single__content {
	padding: 88px 0;
	border-bottom: 1px solid #818181;
}

.news-single__content p {
	font-size: 1.8rem;
	line-height: 2.222;
}

.news-single__content figure {
	margin: 40px 0;
}

.news-single__content ul,
.news-single__content ol {
	margin: 20px 0;
	list-style: initial;
}

.news-single__content ol li {
	list-style-type: decimal;
}

.news-single__content li {
	list-style-type: initial;
}

.single__footer {
	position: relative;
	height: 15px;
	margin-top: 18px;
	font-weight: 700;
	font-size: 1.3rem;
	font-family: "Akshar", sans-serif;
}

.single__footer .arrow {
	display: flex;
	justify-content: space-between;
	width: 33px;
}

.single__footer .arrow span {
	display: inline-block;
	width: 0;
	height: 0;
	border-top: 4px solid transparent;
	border-right: 0;
	border-bottom: 4px solid transparent;
	border-left: 6px solid #000032;
	border-style: solid;
}

.single__footer-left {
	position: absolute;
	top: 0;
	left: 3px;
}

.single__footer-center {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
}

.single__footer-center a {
	color: #162142;
}

.single__footer-right {
	position: absolute;
	top: 0;
	right: 3px;
}

.prev,
.next {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	color: #162142;
}

.prev .arrow {
	margin-right: 12px;
	transform: rotate(180deg);
}

.next .arrow {
	margin-left: 12px;
}

/*----------------------------------
お問い合わせページ
----------------------------------*/

.page-contact .page__content {
	padding-top: 115px;
}

.contact__lead {
	font-size: 1.8rem;
}

.contact__lead a {
	color: #CE0201;
}

.contact__wrap {
	margin-top: 62px;
	padding: 0 2.5px;
}

.contact__wrap .button {
	margin-top: 80px;
}

.contact__wrap .button-link {
	margin: auto;
	border-color: #162142;
	background-color: inherit;
	color: #162142;
	font-weight: 700;
	font-size: 1.8rem;
	font-family: "Noto Sans JP", sans-serif;
	text-align: left;
}

.contact__wrap .button-link:hover {
	cursor: pointer;
}

.required__text {
	color: #162142;
	font-size: 1.8rem;
}

.required__text .red {
	color: #CB0200;
	font-size: 1.6rem;
}

.contact-content {
	margin-top: 40px;
}

.conditional-field {
	display: none;
}

.conditional-field .contact-title {
	margin-top: 8px;
}

.contact-row {
	display: flex;
	margin-bottom: 40px;
}

.contact-row:first-child .contact-text {
	margin-top: 10px;
}

.contact-row:first-child .contact-text .wpcf7-list-item {
	margin-left: 0;
}

.contact-row:first-child .contact-text .wpcf7-list-item.first {
	margin-right: 1em;
}

.contact-title {
	display: flex;
	flex: 0 0 167px;
	margin-top: 8px;
}

.contact-title.mt-0 {
	margin-top: 0;
}

.contact-title .ttl {
	font-size: 1.8rem;
}

.contact-title .required {
	display: inline-block;
	margin: 2px 0 0 7px;
	color: #CB0200;
}

.contact-text {
	flex: 0 0 calc(100% - 184px);
	max-width: 100%;
	margin-left: 17px;
}

input[type=text],
input[type=email],
select {
	width: 100%;
	height: 50px;
	padding-left: 20px;
	border: none;
	font-size: 16px;
	font-family: "Noto Sans JP", sans-serif;
}

textarea {
	width: 100%;
	height: 407px;
	padding: 17px 20px;
	border: none;
	font-size: 16px;
	font-family: "Noto Sans JP", sans-serif;
}

/* placeholder風の色 */

.js-faux-placeholder.is-placeholder {
	color: rgba(157, 157, 157, 0.9);
}

/* 通常入力時の色（お好みで） */

.js-faux-placeholder {
	color: #111;
	line-height: 2;
}

textarea[name=luggage-content],
textarea[name=car-type],
textarea[name=luggage-temperature] {
	height: 110px;
}

textarea[name=luggage-detail],
textarea[name=other-detail] {
	height: 200px;
}

::-moz-placeholder {
	color: rgba(157, 157, 157, 0.9);
}

::placeholder {
	color: rgba(157, 157, 157, 0.9);
}

.contact-wrapper {
	flex: 0 0 calc(100% - 189px);
	margin-left: 22px;
}

.contact-wrapper .contact-text {
	margin-left: 0;
}

.contact-wrapper .contact-ttl {
	margin-top: 35px;
}

.contact-wrapper .contact-ttl + .contact-text {
	margin-top: 10px;
}

.radio-wrap .wpcf7-list-item {
	display: block;
	margin-left: 0;
}

.radio-wrap .wpcf7-list-item + .wpcf7-list-item {
	margin-top: 5px;
}

.radio-wrap .wpcf7-list-item input {
	margin-left: 0;
}

.wpcf7-radio .wpcf7-list-item > label {
	display: flex;
	align-items: center;
}

.wpcf7-radio .wpcf7-list-item > label .wpcf7-list-item-label {
	margin-left: 3px;
}

input[type=radio] {
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	position: relative;
	top: 0;
	width: 13px;
	height: 13px;
	border: 1px solid #818181;
	border-radius: 50%;
	cursor: pointer;
}

_::-webkit-full-page-media,
_:future,
:root input[type=radio] {
	top: 1px !important;
}

input[type=radio]:checked {
	border-color: #162142;
	background-color: #162142;
}

input[type=radio]:checked::after {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 6px;
	height: 6px;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	background: #fff;
	content: "";
}

.radio-content .contact-title {
	margin-top: 0;
}

.business-contact {
	margin-top: 28px;
	padding: 29px 25px 31px;
	background-color: #fff;
}

.business-contact .wpcf7-list-item.first {
	margin-left: 0;
}

.business-contact textarea {
	margin-top: 5px;
	border: 1px solid rgba(157, 157, 157, 0.9);
}

.business-contact .group-error {
	margin-bottom: 0.6em;
	color: #d00;
}

.business-contact.has-error .wpcf7-not-valid {
	border-color: #d00 !important;
}

.wpcf7-checkbox .wpcf7-list-item.last label {
	margin-right: 0;
}

input[type=checkbox] {
	display: none;
}

span.wpcf7-list-item {
	margin-left: 0;
}

.business-contact span.wpcf7-list-item.last {
	margin-left: 30px;
}

input[type=checkbox] + .wpcf7-list-item-label {
	display: inline-block;
	position: relative;
	padding-left: 25px;
}

input[type=checkbox] + .wpcf7-list-item-label::before {
	background-color: #fff;
}

input[type=checkbox] + .wpcf7-list-item-label::after,
input[type=checkbox] + .wpcf7-list-item-label::before {
	position: absolute;
	top: 54%;
	transform: translateY(-50%);
	content: "";
}

input[type=checkbox] + .wpcf7-list-item-label::before {
	display: block;
	left: 0;
	width: 15px;
	height: 15px;
	border: 1px solid #838491;
	border-radius: 2px;
	background: #fff;
}

input[type=checkbox] + .wpcf7-list-item-label::after {
	top: 13px;
	left: 2px;
	width: 11px;
	height: 6px;
	transform: rotate(-45deg);
	border-bottom: 2px solid #162142;
	border-left: 2px solid #162142;
	opacity: 0;
	transition: opacity 0.3s ease 0s;
}

input[type=checkbox]:checked + .wpcf7-list-item-label::after {
	opacity: 1;
}

.business-contact__item + .business-contact__item {
	margin-top: 20px;
}

.business-contact__item.business-contact-radio {
	padding-bottom: 37px;
}

.contact-caption {
	margin-top: 30px;
}

.contact-img {
	width: 84px;
	margin-top: 10px;
}

.contact-img + .contact-text {
	margin-top: 10px;
}

.button-submit {
	display: block;
	z-index: 1;
	position: relative;
	width: 260px;
	height: 60px;
	margin: auto;
}

.button-submit::before {
	visibility: hidden;
	z-index: -1;
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 100%;
	border-radius: 30px;
	background: #162142;
	content: "";
	opacity: 0;
	transition: all 0.3s;
}

.button-submit .arrow {
	display: flex;
	z-index: 1;
	position: absolute;
	top: 50%;
	right: 25px;
	justify-content: space-between;
	width: 40px;
	height: 7px;
	transform: translateY(-50%);
}

.button-submit .arrow span {
	display: inline-block;
	width: 0;
	height: 0;
	border-top: 4px solid transparent;
	border-right: 0;
	border-bottom: 4px solid transparent;
	border-left: 7px solid #162142;
	border-style: solid;
	transition: all 0.3s ease 0s;
}

.button-submit:hover {
	cursor: pointer;
}

.button-submit:hover::before {
	visibility: visible;
	width: 100%;
	opacity: 1;
	transition: all 0.3s;
}

.button-submit:hover .button-link {
	color: #fff;
}

.page-thanks .page__content {
	padding-top: 107px;
}

.page-thanks .footer {
	margin-top: 193px;
}

.thanks {
	width: 890px;
	max-width: 100%;
	margin: auto;
	text-align: center;
}

.thanks .button {
	margin-top: 60px;
}

.thanks .button-link {
	margin: auto;
	font-weight: 700;
	font-size: 1.8rem;
	font-family: "Noto Sans JP", sans-serif;
}

.thanks__title {
	padding-bottom: 10px;
	border-bottom: 1px solid #B9B9D6;
	color: #162142;
	font-weight: 700;
	font-size: 2.5rem;
}

.thanks__text {
	margin-top: 55px;
	font-size: 1.8rem;
	line-height: 2.222;
}

.wpcf7-form.sent .wpcf7-response-output {
	display: none;
}

/*----------------------------------
Sustainabilityページ
----------------------------------*/

.page-sustainability .page__content {
	padding-top: 79px;
}

.sustainability .inner {
	padding-left: 205px;
}

.sdgs__large-img {
	width: 76.432%;
}

.sustainability__items {
	margin-top: 73px;
}

.sustainability__item + .sustainability__item {
	margin-top: 119px;
}

.sustainability__title {
	color: #162142;
	font-weight: 800;
	font-size: 3rem;
	line-height: 1.666;
}

.sustainability__wrap {
	display: flex;
	margin-top: 30px;
}

.sustainability__content {
	display: flex;
	flex-direction: column;
}

.sustainability__text {
	margin-bottom: 20px;
	font-size: 1.8rem;
	line-height: 2.222;
}

.sdgs__img {
	height: 70px;
	margin-top: auto;
}

.sdgs__img img {
	height: 100%;
}

.sustainability__img {
	flex: 0 0 44.54%;
	margin-left: 50px;
}

.sustainability-box {
	margin-top: 50px;
	padding: 43px 61px 37px 62px;
	background-color: #fff;
}

.sustainability-box__title {
	position: relative;
	flex: 0 0 160px;
	padding-bottom: 15px;
	border-bottom: 1px solid #818181;
	color: #162142;
	font-weight: 800;
	font-size: 2rem;
	line-height: 1;
}

.sustainability-box__title::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 80px;
	height: 3px;
	background-color: #CB0200;
	content: "";
}

.sustainability-box__lists {
	display: flex;
	flex-wrap: wrap;
	margin-top: 25px;
}

.sustainability-box__list {
	width: calc(50% - 15px);
	padding-left: 1.6em;
	text-indent: -1.6em;
}

.sustainability-box__list:nth-child(even) {
	margin-left: 30px;
}

.sustainability-box__list:nth-child(n+3) {
	margin-top: 5px;
}

.sustainability-box__list::before {
	display: inline-block;
	width: 16px;
	height: 10px;
	margin-right: 10px;
	background: url(../img/check.svg) no-repeat center left/contain;
	content: "";
}

/*----------------------------------
Serviceページ
----------------------------------*/

.page-service .page__content {
	padding-top: 114px;
}

.service {
	overflow: hidden;
}

.service .page__wrap {
	margin-top: 277px;
}

.service .page-sidebar {
	margin-top: 15px;
}

.service .content__lists {
	width: calc(100% - 90px);
}

.service .content__list {
	padding-top: 60px;
}

.service .content__list + .content__list {
	margin-top: 212px;
}

.service .content__list:nth-child(2) .service__img,
.service .content__list:nth-child(3) .service__img {
	margin-left: 45px;
}

.service .content__list:nth-child(2) .list__title,
.service .content__list:nth-child(3) .list__title {
	left: 155px;
}

.service .content__list:nth-child(3) .service__item {
	margin-top: 100px;
}

.service__lead {
	padding-left: 205px;
	color: #162142;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 2.222;
}

.service__lists {
	width: calc(100% - 275px);
	margin-left: 111px;
}

.service__list {
	padding-top: 60px;
}

.service__list + .service__list {
	margin-top: 290px;
	padding-top: 60px;
}

.service__wrap {
	display: flex;
	position: relative;
	padding: 105px 0 87px 122px;
}

.service__wrap::before {
	z-index: -2;
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100%;
	margin-right: calc(50% - 50vw);
	background: linear-gradient(to bottom, #162142, #323F69);
	content: "";
}

.service__wrap .number {
	position: absolute;
	top: -70px;
	left: 0;
	color: #CE0201;
	font-weight: 700;
	font-size: 12rem;
	line-height: 1;
	font-family: "Akshar", sans-serif;
}

.service__wrap .list__title {
	position: absolute;
	top: -40px;
	left: 134px;
	color: #CB0200;
	font-weight: 800;
	font-size: 1.8rem;
}

.service__img {
	z-index: -1;
	flex: 0 0 412px;
	margin: -153px calc(50% - 50vw + 163px) 0 68px;
}

.service__wrapper {
	width: 100%;
}

.service__title {
	color: #fff;
	font-weight: 800;
	font-size: 3rem;
	line-height: 1.666;
	white-space: nowrap;
}

.service__text {
	max-width: 780px;
	margin-top: 43px;
	color: #fff;
	font-size: 1.8rem;
	line-height: 2.222;
}

.service__items {
	margin-top: 100px;
}

.service__item + .service__item {
	margin-top: 100px;
}

.page-sec__title.point span {
	display: inline-block;
	margin-right: 70px;
	color: #CE0201;
	font-weight: 700;
	font-size: 1.6rem;
	font-family: "Akshar", sans-serif;
}

.page-sec__title.point::after {
	width: 96px;
}

.service-sec__text {
	margin-top: 38px;
}

.service-point__images {
	display: flex;
	margin-top: 40px;
}

.service-point__img {
	position: relative;
}

.service-point__img + .service-point__img {
	margin-left: 46px;
}

.outsourcing {
	z-index: 1;
	position: relative;
	margin-top: 60px;
	padding: 10px 24px 22px 106px;
	background-color: #E9E9F0;
}

.outsourcing__item {
	display: flex;
	align-items: center;
	padding: 41px 0;
}

.outsourcing__item.green {
	position: relative;
}

.outsourcing__item.green::before {
	z-index: -1;
	position: absolute;
	top: 0;
	left: 45%;
	width: calc(100% + 38px);
	height: 100%;
	transform: translateX(-50%);
	background-color: #fff;
	content: "";
}

.outsourcing__item.green::after {
	position: absolute;
	top: -50px;
	left: 45%;
	transform: translateX(-50%);
	content: "+";
	font-size: 4rem;
}

.outsourcing__item.green .outsourcing__title::after {
	background-color: #00AC97;
}

.outsourcing__item.green .outsourcing-label {
	background-color: #00AC97;
}

.outsourcing__item.green .outsourcing-label:last-child {
	margin-bottom: 0;
}

.outsourcing__item.blue {
	position: relative;
}

.outsourcing__item.blue::after {
	position: absolute;
	top: -50px;
	left: 45%;
	transform: translateX(-50%);
	content: "+";
	font-size: 4rem;
}

.outsourcing__item.blue .outsourcing__title::after {
	background-color: #005DAC;
}

.outsourcing__item.blue .outsourcing-label {
	background-color: #015FAB;
}

.outsourcing__item.blue .outsourcing-label:nth-child(2),
.outsourcing__item.blue .outsourcing-label:nth-child(3) {
	margin-bottom: 0;
}

.outsourcing__item.orange .outsourcing__wrap {
	align-items: center;
}

.outsourcing__item.orange .outsourcing-label {
	background-color: #CB3E00;
}

.outsourcing__item.orange .outsourcing-label:nth-child(2) {
	width: 72px;
}

.outsourcing__item.orange .outsourcing-label:last-child {
	margin-bottom: 0;
}

.outsourcing__container {
	position: relative;
	padding-bottom: 21px;
}

.outsourcing__container::before {
	z-index: -2;
	position: absolute;
	top: 0;
	left: 45%;
	width: calc(100% + 82px);
	height: 100%;
	transform: translateX(-50%);
	background-color: #F2F2F7;
	content: "";
}

.outsourcing__wrapper {
	display: flex;
	align-items: center;
}

.outsourcing__img {
	flex: 0 0 91px;
}

.outsourcing__title {
	flex: 0 0 220px;
	margin-left: 21px;
	color: #162142;
	font-weight: 700;
	font-size: 2rem;
}

.outsourcing__wrap {
	display: flex;
	flex: 0 0 47%;
	flex-wrap: wrap;
	margin-left: 68px;
	gap: 10px;
}

.outsourcing__wrap .arrow {
	margin: 0 18px 0 20px;
}

.outsourcing__wrap .label__wrap {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.outsourcing-label {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 6px 20px 7px;
	border-radius: 16px;
	color: #fff;
	font-weight: 700;
	line-height: 1.1;
	white-space: nowrap;
}

.outsourcing-label:last-child {
	margin-right: 0;
}

.dynamic-management {
	display: flex;
	justify-content: space-between;
	margin-top: 91px;
}

.dynamic-management__item {
	flex: 0 0 35.706%;
	padding-bottom: 40px;
	background-color: #fff;
	text-align: center;
}

.dynamic-management-icon {
	margin-top: -31px;
}

.dynamic-management__title {
	margin-top: 16px;
	color: #162142;
	font-weight: 700;
	font-size: 2rem;
}

.dynamic-management__lists {
	margin-top: 21px;
}

.dynamic-management__lists .plus {
	font-size: 2rem;
}

.dynamic-management__list {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 182px;
	height: 31px;
	margin: 0 auto 18px;
	border-radius: 16px;
	background-color: #005EAC;
	color: #fff;
	font-weight: 700;
}

.dynamic-management__list:nth-child(3),
.dynamic-management__list:last-child {
	margin-bottom: 0;
}

.dynamic-management__img {
	width: 66.767%;
	margin: 10px auto 0;
}

.dynamic-management-caption {
	color: #162142;
}

.dynamic-management__center {
	margin: 76px 10px 0;
}

.dynamic-management__text {
	color: #162142;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.6;
	text-align: center;
}

.dynamic-management-arrow {
	margin-top: -8px;
}

.dynamic-management-arrow.reverse {
	margin: 40px 0 -8px 0;
	transform: rotate(180deg);
}

.tradiss {
	margin-top: 60px;
	padding: 64px 10px 33px;
	background-color: #fff;
}

.tradiss__lead {
	color: #162142;
	font-weight: 700;
	font-size: 2rem;
	text-align: center;
}

.tradiss__img {
	width: 87.378%;
	margin: 36px auto 0;
}

/*----------------------------------
拠点・アクセスページ
----------------------------------*/

.page-access .page__content {
	padding-top: 144px;
}

.access-map {
	z-index: 1;
	position: relative;
	width: 951px;
	max-width: 100%;
	margin: auto;
}

.access-map.pc {
	margin-top: -240px;
}

.access-map.sp {
	display: none;
}

.access-sec + .access-sec {
	margin-top: 182px;
}

.access__img {
	width: 56.485%;
	margin: 47px auto 0;
}

.access__content {
	margin-top: 30px;
}

.google-map iframe {
	max-width: 100%;
}

/*----------------------------------
会社概要ページ
----------------------------------*/

.page-outline .page__content {
	padding-top: 185px;
}

.outline-sec + .outline-sec {
	margin-top: 184px;
}

.outline__content {
	margin-top: 24px;
}

.outline__content .table tr:last-child {
	border-bottom: 1px solid #B9B9D6;
}

/*----------------------------------
About Jline Corporation Inc.ページ
----------------------------------*/

.page-jline-corporation .page__content {
	padding-top: 81px;
}

.jline-corp__lead {
	padding-left: 205px;
	color: #162142;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 2.222;
}

.jline-corp__inner {
	margin-top: 140px;
	padding-left: 205px;
}

.jline-corp__content {
	margin-top: 20px;
}

.jline-corp__content .table tr:last-child {
	border-bottom: 1px solid #B9B9D6;
}

.jline-corp__content .table td > span {
	display: flex;
}

.jline-corp__content .table td > span span:first-of-type {
	white-space: nowrap;
}

.jline-corp__content .table td .d-iblock {
	display: inline-block !important;
}

/*----------------------------------
Serviceページ
----------------------------------*/

.page-safety-management .page__content {
	padding-top: 167px;
}

.page-safety-management .page-sidebar {
	margin-top: 10px;
}

.safety-management .page-sidebar {
	margin-left: 0;
}

.safety-management .page-sidebar__list {
	line-height: 1.466;
}

.safety-management .page-sidebar__list + .page-sidebar__list {
	margin-top: 25px;
}

.safety-management .page-sidebar__list.current::before {
	top: 8px;
}

.safety-management .content__lists {
	padding-left: 53px;
}

.safety-management .content__list + .content__list {
	margin-top: 140px;
}

.safety-management__title {
	display: flex;
	position: relative;
	padding-bottom: 10px;
	border-bottom: 1px solid #818181;
	color: #162142;
	font-weight: 800;
	font-size: 3rem;
}

.safety-management__title::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 112px;
	height: 3px;
	background-color: #CB0200;
	content: "";
}

.safety-management__title .number {
	display: inline-block;
	margin-right: 74px;
	color: #CB0200;
	font-weight: 700;
	font-size: 6rem;
	line-height: 1.1;
	font-family: "Akshar", sans-serif;
	letter-spacing: -0.02em;
}

.safety-management__title + .safety-management__text {
	margin-top: 45px;
}

.safety-management__sub-title {
	margin-top: 60px;
	color: #162142;
	font-weight: 500;
	font-size: 2rem;
	line-height: 1;
}

.safety-management__sub-title + .safety-management__lists {
	margin-top: 39px;
}

.safety-management__lists {
	margin-top: 46px;
}

.safety-management__list {
	display: flex;
	line-height: 1.9125;
}

.safety-management__list + .safety-management__list {
	margin-top: 30px;
}

.safety-management__list .number {
	display: inline-block;
	flex: 0 0 30px;
	margin-right: 32px;
	color: #162142;
	font-weight: 700;
	font-size: 2rem;
	font-family: "Akshar", sans-serif;
}

.safety-management__wrap {
	margin-top: 3px;
}

.safety-management__wrap.flex {
	display: flex;
	flex: 0 0 530px;
	justify-content: space-between;
}

.safety-management__text {
	color: #2F2F2F;
}

.safety-management__text.result {
	margin-left: 50px;
	text-align: right;
	white-space: nowrap;
}

.safety-management__text.download {
	margin-top: 20px;
}

.safety-management__text.download a {
	color: #CB0200;
}

.indent {
	padding-left: 1em;
	color: #2F2F2F;
	text-indent: -1em;
}

.safety-management-figure {
	margin-top: 50px;
}

.safety-management__img {
	width: 88.8281%;
	margin: 69px auto 0;
}

/*----------------------------------
プライバシーポリシーページ
----------------------------------*/

.page-privacy-policy .page__content {
	padding-top: 150px;
}

.page-privacy-policy .page-sidebar {
	margin-top: 20px;
}

.policy .page-sidebar {
	margin-left: 0;
}

.policy .page-sidebar__list {
	line-height: 1.466;
}

.policy .page-sidebar__list.current::before {
	top: 8px;
}

.policy .content__lists {
	padding-left: 53px;
}

.policy .content__list + .content__list {
	margin-top: 110px;
}

.policy__title {
	position: relative;
	border-bottom: 1px solid #818181;
	color: #162142;
	font-weight: 800;
	font-size: 3rem;
}

.policy__title::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 112px;
	height: 3px;
	background-color: #CB0200;
	content: "";
}

.policy__content {
	margin-top: 51px;
}

.policy__text {
	color: #2F2F2F;
	line-height: 1.9125;
}

.policy__sub-title {
	margin: 60px 0 20px;
	color: #162142;
	font-weight: 500;
	font-size: 2rem;
}

.policy-circle__lists {
	margin-top: 20px;
}

.policy-circle__list {
	display: flex;
	color: #2F2F2F;
}

.policy-circle__list::before {
	display: inline-block;
	flex: 0 0 8px;
	height: 8px;
	margin: 14px 10px 0 0;
	border-radius: 50%;
	background-color: #162142;
	content: "";
}

.policy__lists {
	margin-top: 20px;
}

.policy__list {
	display: flex;
	color: #2F2F2F;
	line-height: 1.9125;
}

.policy__list + .policy__list {
	margin-top: 20px;
}

.policy__list .number {
	display: inline-block;
	flex: 0 0 30px;
	margin-right: 32px;
	color: #162142;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.6;
	font-family: "Akshar", sans-serif;
	letter-spacing: 0.05em;
}

.policy-contact {
	margin-top: 20px;
}

.policy-contact__title {
	font-weight: 500;
}

.policy-contact-link {
	margin-top: 10px;
	color: #CE0201;
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 5px;
}

/*----------------------------------
初期化
----------------------------------*/

*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body {
	position: relative;
	margin: 0;
	padding: 0;
}

html {
	font-size: 62.5%;
}

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background: #fff;
	background-color: #F2F2F7;
	color: #000;
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 2;
	font-family: "Noto Sans JP", sans-serif;
	letter-spacing: 0;
	overflow-wrap: break-word;
}

img {
	max-width: 100%;
	height: auto;
	border: none;
}

a {
	text-decoration: none;
	transition: all 0.3s ease 0s;
}

a:hover {
	opacity: 0.7;
}

.d-iblock {
	display: inline-block;
}

/*----------------------------------
補完クラス
----------------------------------*/

.color-active {
	color: #CB0200;
}

.font-size-small {
	font-size: 0.9em;
}

.font-em {
	font-weight: 700;
}

/*----------------------------------
共通パーツ
----------------------------------*/

.top .inner {
	width: min(100% - 100px, 1135px);
	height: inherit;
	margin: auto;
}

.inner {
	width: min(100% - 100px, 1130px);
	height: inherit;
	margin: auto;
}

.inner2 {
	width: min(100% - 100px, 933px);
	height: inherit;
	margin: auto;
}

.section__title > span {
	display: block;
	line-height: 1;
}

.section__title > span.en {
	color: #CB0200;
	font-weight: 700;
	font-family: "Akshar", sans-serif;
}

.section__title > span.ja {
	margin-top: 23px;
	color: #162142;
	font-weight: 800;
	font-size: 3rem;
}

.button-link {
	display: flex;
	z-index: 1;
	position: relative;
	align-items: center;
	width: 260px;
	height: 60px;
	padding-left: 33px;
	border: 1px solid;
	border-radius: 30px;
	font-weight: 700;
	font-family: "Akshar", sans-serif;
	transition: all 0.3s ease 0s;
}

.button-link::before {
	visibility: hidden;
	z-index: -1;
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 100%;
	border-radius: 30px;
	content: "";
	opacity: 0;
	transition: all 0.3s;
}

.button-link:hover::before {
	visibility: visible;
	width: 100%;
	opacity: 1;
	transition: all 0.3s;
}

.button-link.normal {
	border-color: #162142;
	color: #162142;
}

.button-link.normal::before {
	background: #162142;
}

.button-link.normal .arrow span {
	border-left-color: #162142;
}

.button-link.normal:hover {
	color: #fff;
}

.button-link.normal:hover .arrow span:first-of-type {
	border-left-color: #58617B;
}

.button-link.normal:hover .arrow span:nth-of-type(2) {
	border-left-color: #A7ABB7;
}

.button-link.normal:hover .arrow span:nth-of-type(3) {
	border-left-color: #fff;
}

.button-link.white {
	border-color: #fff;
	color: #fff;
}

.button-link.white::before {
	background: #fff;
}

.button-link.white .arrow span {
	border-left-color: #fff;
}

.button-link.white:hover {
	color: #CB0200;
}

.button-link.white:hover .arrow span:first-of-type {
	border-left-color: #F8CBCA;
}

.button-link.white:hover .arrow span:nth-of-type(2) {
	border-left-color: #ED6F6D;
}

.button-link.white:hover .arrow span:nth-of-type(3) {
	border-left-color: #CB0200;
}

.button-link.blue {
	border: none;
	background-color: #162142;
	color: #fff;
	font-weight: 800;
}

.button-link.blue::before {
	background: #fff;
}

.button-link.blue .arrow span {
	border-left-color: #fff;
}

.button-link .arrow {
	display: flex;
	position: absolute;
	top: 50%;
	right: 25px;
	justify-content: space-between;
	width: 40px;
	height: 7px;
	transform: translateY(-50%);
}

.button-link .arrow span {
	display: inline-block;
	width: 0;
	height: 0;
	border-top: 4px solid transparent;
	border-right: 0;
	border-bottom: 4px solid transparent;
	border-left: 7px solid;
	border-style: solid;
	transition: all 0.3s ease 0s;
}

.button-link:hover {
	opacity: 1;
}

/*----------------------------------
スクロールでふわっと
----------------------------------*/

.view {
	transform: translate(0, 100px);
	opacity: 0;
	transition: all 2000ms;
}

.view.scrollin {
	transform: translate(0, 0);
	opacity: 1;
}

/* --------------------------------
splash
-------------------------------- */

#splash {
	display: flex;
	z-index: 10000;
	position: fixed;
	top: 0;
	left: 0;
	align-items: center;
	justify-content: center;
	width: 100vw;
	height: 100vh;
	overflow: hidden;
	background: #fff; /* はみ出し防止 */
}

/* スライドする画像 */

.splash-img {
	position: absolute;
	top: -100vh; /* 画面の上からスタート */
	left: 50%;
	width: 100%;
	height: auto; /* 横位置は中央 */
	transform: translateX(-50%);
	transition: top 1s ease;
}

/* on クラスがついたら下にスライド */

#splash.on .splash-img {
	top: 200vh;
	transition-delay: 0.5s;
}

/* ロゴ */

#splash figure {
	opacity: 0;
}

#splash.on figure {
	opacity: 1;
	transition-delay: 1s;
}

/*----------------------------------
ヘッダー
----------------------------------*/

.header {
	z-index: 39;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 115px;
	padding: 28px 127px 10px 42px;
	transition: all 0.4s ease 0s;
}

.header.bg {
	background-color: #F2F2F7;
	transition: all 0.4s ease 0s;
}

.header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.logo {
	width: 139px;
	height: 56px;
}

.logo a {
	display: block;
	width: 100%;
	height: 100%;
}

.logo a img {
	width: 100%;
	height: 100%;
}

.header-contact-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 122px;
	height: 43px;
	border-radius: 22px;
	background-color: #162142;
	color: #fff;
	font-weight: 900;
	font-size: 1.4rem;
}

/*----------------------------------
ドロワー
----------------------------------*/

.drawer__toggle {
	z-index: 42;
	position: fixed;
	top: 45px;
	right: 34px;
	width: 58px;
	height: 21px;
	cursor: pointer;
}

.drawer__wrapper {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 100%;
	transform: translate(-50%, -50%);
}

.drawer__line {
	position: absolute;
	width: 100%;
	height: 1px;
	background: #162142;
	transition: transform 0.3s;
}

.drawer__line--top {
	top: 0;
}

.drawer__line--center {
	top: 10px;
}

.drawer__line--bottom {
	bottom: 0;
}

.drawer__line--top.active {
	top: 12px;
	right: 0;
	width: 62px;
	transform: rotate(20deg);
	background: #162142;
}

.drawer__line--center.active {
	transform: scaleX(0);
}

.drawer__line--bottom.active {
	right: 0;
	bottom: 8px;
	width: 62px;
	transform: rotate(160deg);
	background: #162142;
}

/*gnav*/

.drawer__nav {
	display: none;
	z-index: 40;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 95px 30px 30px;
	overflow: scroll;
	background: #F2F2F7;
	transition: all 1s;
}

.drawer__nav.active {
	display: block;
	transition: all 0.6s;
}

.drawer__nav .wrap {
	justify-content: space-between;
}

.drawer__nav .wrap .button {
	margin-top: 35px;
}

.drawer__nav .wrap .button-link {
	width: 300px;
	height: 70px;
	border-radius: 35px;
}

.drawer__nav .left {
	flex: 0 0 300px;
}

.drawer__nav .company-name {
	width: 300px;
}

.drawer__nav .company-name a {
	width: 100%;
}

.drawer__nav .company-name a img {
	width: 100%;
}

.drawer__nav .company-info,
.drawer__nav .policy-menu-link {
	color: #000;
}

.drawer__nav .company-info {
	margin-top: 30px;
	font-size: 1.4rem;
}

.drawer__nav .policy-menu {
	margin-top: 10px;
}

.drawer__nav .policy-menu-link {
	font-size: 1.3rem;
}

.drawer__nav .nav > ul > li:nth-child(n+4) {
	margin-left: 88px;
}

.drawer__nav .nav ul li a {
	color: #162142;
}

.drawer__inner {
	position: relative;
	width: 976px;
	max-width: 100%;
	height: 100%;
	margin: auto;
}

.drawer__inner .wrap {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	transform: translateY(-50%);
}

/*----------------------------------
トップページ：MV
----------------------------------*/

.mainvisual {
	position: relative;
}

.mainvisual-logo {
	z-index: 2;
	position: absolute;
	top: 0;
	left: 0;
	width: 76%;
	overflow: hidden; /**
   * カーテン：最初は上から100%隠す（= 下方向を切る）
   * inset(top right bottom left)
   */
}

.mainvisual-logo picture,
.mainvisual-logo img {
	display: block;
	width: 100%;
	height: auto;
}

.mainvisual-logo picture {
	-webkit-clip-path: inset(0 0 100% 0);
	clip-path: inset(0 0 100% 0);
	transition: -webkit-clip-path 0.8s cubic-bezier(0.22, 0.61, 0.36, 1);
	transition: clip-path 0.8s cubic-bezier(0.22, 0.61, 0.36, 1);
	transition: clip-path 0.8s cubic-bezier(0.22, 0.61, 0.36, 1), -webkit-clip-path 0.8s cubic-bezier(0.22, 0.61, 0.36, 1);
	will-change: clip-path;
}

.mainvisual.is-anim .mainvisual-logo picture {
	-webkit-clip-path: inset(0 0 0 0);
	clip-path: inset(0 0 0 0);
}

/* もしロゴに薄い縁が欲しい/見え方強調したい場合（任意）
.mainvisual-logo picture {
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.25));
}
*/

.mainvisual__wrap {
	display: flex;
	padding-top: 163px;
	padding-top: 11.9326500732vw;
}

.mainvisual__left,
.mainvisual__right {
	position: relative;
	overflow: hidden;
}

.mainvisual__left img,
.mainvisual__right img {
	-o-object-fit: cover;
	object-fit: cover;
}

.mainvisual__left .mainvisual__img,
.mainvisual__right .mainvisual__img {
	transition: -webkit-clip-path 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
	transition: clip-path 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
	transition: clip-path 0.2s cubic-bezier(0.22, 0.61, 0.36, 1), -webkit-clip-path 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
	will-change: clip-path;
}

.mainvisual__left .mainvisual__img {
	-webkit-clip-path: inset(0 0 0 100%);
	clip-path: inset(0 0 0 100%);
}

.mainvisual__right .mainvisual__img {
	-webkit-clip-path: inset(0 100% 0 0);
	clip-path: inset(0 100% 0 0);
}

.mainvisual.is-anim .mainvisual__left .mainvisual__img {
	-webkit-clip-path: inset(0 0 0 0);
	clip-path: inset(0 0 0 0);
	transition-delay: 0.2s;
}

.mainvisual.is-anim .mainvisual__right .mainvisual__img {
	-webkit-clip-path: inset(0 0 0 0);
	clip-path: inset(0 0 0 0);
	transition-delay: 0.2s;
}

.mainvisual__left {
	margin-top: 136px;
	margin-top: 9.9560761347vw;
}

.mainvisual__right {
	flex: 0 0 53.66%;
}

.mainvisual__right .mainvisual__img img {
	display: block;
	width: 100%;
	height: auto;
}

.mainvisual-copy__wrap {
	position: absolute;
	top: 381px;
	top: 27.8916544656vw;
	left: calc(50% + 4.3vw);
	width: 36.969%;
}

.mainvisual.is-anim .mainvisual-copy {
	transform: translateY(0);
	opacity: 1;
	transition-delay: 0.5s;
}

.mainvisual-copy {
	z-index: 2;
	position: relative;
	transform: translateY(20px);
	opacity: 0;
	transition: opacity 0.8s ease, transform 0.8s ease;
	will-change: opacity, transform;
}

.mainvisual__text {
	margin-top: 181px;
	margin-top: 13.2503660322vw;
	margin-left: 10px;
	margin-left: 0.7320644217vw;
	font-weight: 700;
	font-size: 2.2rem;
}

.mainvisual__wrapper {
	z-index: 1;
	position: absolute;
	top: 115px;
	right: 32px;
	opacity: 0;
}

.mainvisual.is-anim .mainvisual__wrapper {
	opacity: 1;
	transition-delay: 0.7s;
	transition-duration: 1s;
}

.side__nav-items li {
	margin-top: 28px;
	line-height: 1;
}

.side__nav-items li.is-overlap a {
	color: #fff;
}

.side__nav-items li span {
	display: flex;
	justify-content: flex-end;
	color: #162142;
}

.side__nav-items li span.on-image {
	color: #fff;
}

.side__nav-items li a {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	color: #000032;
	transition: color 0.2s;
}

.side__nav-items li a::before {
	display: inline-block;
	width: 0;
	height: 0;
	margin-right: 5px;
	border-top: 4px solid transparent;
	border-right: 0;
	border-bottom: 4px solid transparent;
	border-left: 6px solid #ce0201;
	border-style: solid;
	content: "";
	opacity: 0;
	transition: all 0.5s ease 0s;
}

.side__nav-items li a.on-image {
	color: #fff;
}

.side__nav-items li a:hover {
	opacity: 1;
}

.side__nav-items li a:hover::before {
	opacity: 1;
}

.side__nav-items > li.drop-menu:hover > span {
	font-weight: 700;
}

.side__nav-items > li.drop-menu ul {
	display: none;
}

.side__nav-items > li > a {
	font-size: 1.4rem;
}

.side__nav-items > li > a:hover {
	font-weight: 700;
}

.side__nav-items > li ul li a {
	font-size: 1.2rem;
}

.side__nav-items > li:first-child {
	margin-top: 0;
}

/*----------------------------------
トップページ：ジェーラインエクスプレスについて
----------------------------------*/

.top-about {
	margin-top: 519px;
	margin-top: 37.9941434846vw;
	padding: 54px 50px 53px;
	background: linear-gradient(to top, #CE0101, #FF6262);
}

.top-about .button {
	margin-left: 20px;
}

.top-about__inner {
	width: 1257px;
	max-width: 100%;
	margin: auto;
	padding-top: 113px;
	padding-bottom: 113px;
	background: url(../img/top_about.jpg) no-repeat bottom center/cover;
}

.top-about__wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.top-about__text {
	margin-top: 72px;
	font-weight: 700;
}

/*----------------------------------
トップページ：Service
----------------------------------*/

.image {
	position: relative;
	overflow: hidden;
}

.image::after {
	-webkit-clip-path: inset(0 0 100% 0);
	position: absolute;
	top: -32px;
	top: -2.3426061493vw;
	right: -32px;
	width: 100%;
	height: 562px;
	height: 41.1420204978vw;
	background: url(../img/top_service_logo.png) no-repeat center left/contain;
	content: "";
	clip-path: inset(0 0 100% 0);
	transition: -webkit-clip-path 0.3s ease;
	transition: clip-path 0.3s ease;
	transition: clip-path 0.3s ease, -webkit-clip-path 0.3s ease;
}

.image.is-anim::after {
	-webkit-clip-path: inset(0 0 0 0);
	clip-path: inset(0 0 0 0);
}

.top-service {
	position: relative;
	padding: 134px 0;
	background: linear-gradient(to bottom, #0E1C40, #323F69);
}

.top-service__sec-title {
	color: #404C71;
	font-weight: 500;
	font-size: 10.7rem;
	line-height: 1.2;
	font-family: "Akshar", sans-serif;
}

.top-service__items {
	margin-top: 70px;
}

.top-service__item {
	display: flex;
	justify-content: space-between;
}

.top-service__item + .top-service__item {
	margin-top: 71px;
}

.top-service__item:first-of-type .top-service__text {
	padding-right: 19px;
}

.top-service__item:nth-of-type(2) .top-service__text {
	padding-right: 1px;
}

.top-service__left {
	flex: 0 0 31.541%;
}

.top-service__left .number {
	border-bottom: 1px solid;
	color: #CB0200;
	font-weight: 700;
	font-size: 2.5rem;
	font-family: "Akshar", sans-serif;
}

.top-service__title {
	margin-top: 50px;
	line-height: 1;
}

.top-service__title span {
	display: block;
	color: #fff;
}

.top-service__title span.en {
	font-weight: 700;
	font-size: 1.4rem;
	font-family: "Akshar", sans-serif;
}

.top-service__title span.ja {
	margin-top: 25px;
	font-weight: 800;
	font-size: 3rem;
}

.top-service__right {
	flex: 0 0 42.2%;
	padding-top: 74px;
}

.top-service__right .button {
	margin-top: 46px;
}

.top-service__text {
	color: #fff;
	font-weight: 700;
}

/*----------------------------------
トップページ：採用情報
----------------------------------*/

.top-recruit {
	margin-top: 144px;
}

.top-recruit .button-link {
	font-family: "Noto Sans JP", sans-serif;
}

.top-recruit__wrap {
	display: flex;
	position: relative;
	align-items: center;
	padding-left: 94px;
	background-color: #fff;
}

.top-recruit__wrap::after {
	position: absolute;
	top: -4px;
	top: -0.2928257687vw;
	left: 0;
	width: 100%;
	height: 436px;
	height: 31.9180087848vw;
	background: url(../img/top_recruit_logo.png) no-repeat center left/contain;
	content: "";
}

.top-recruit__content {
	z-index: 1;
	position: relative;
}

.top-recruit__text {
	margin-top: 42px;
	font-weight: 700;
}

.top-recruit__images {
	z-index: 1;
	position: relative;
	flex: 0 0 53.603%;
	margin-left: 70px;
}

.top-recruit-link {
	display: block;
	position: relative;
}

.top-recruit-link:hover {
	opacity: 1;
}

.top-recruit-link:hover .button-link {
	color: #162142;
}

.top-recruit-link:hover .button-link::before {
	visibility: visible;
	width: 100%;
	opacity: 1;
	transition: all 0.3s;
}

.top-recruit-link:hover .button-link .arrow span:first-of-type {
	border-left-color: #D8D8E6;
}

.top-recruit-link:hover .button-link .arrow span:nth-of-type(2) {
	border-left-color: #A7ABB7;
}

.top-recruit-link:hover .button-link .arrow span:nth-of-type(3) {
	border-left-color: #162142;
}

.top-recruit-link:hover img {
	transform: scale(1.1);
}

.top-recruit-link .button {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.top-recruit__img {
	overflow: hidden;
}

.top-recruit__img img {
	transition: all 0.5s ease 0s, opacity 0.9s cubic-bezier(0.5, 0, 0, 1) 0s;
}

/*----------------------------------
トップページ：SDGs
----------------------------------*/

.top-sustainability {
	margin-top: 212px;
}

.top-sustainability .inner {
	position: relative;
	padding: 85px 0 94px;
	border-top: 1px solid #162142;
	border-bottom: 1px solid #162142;
}

.top-sustainability .inner::before,
.top-sustainability .inner::after {
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #162142;
	content: "";
}

.top-sustainability .inner::before {
	top: -8px;
}

.top-sustainability .inner::after {
	bottom: -8px;
}

.top-sustainability .button {
	margin-left: 106px;
}

.top-sustainability__wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.top-sustainability__content .section__title > span.ja {
	margin-top: 9px;
}

.top-sustainability__text {
	margin-top: 32px;
	font-weight: 700;
}

/*----------------------------------
トップページ：お知らせ・地域貢献活動
----------------------------------*/

.top-slider {
	margin-top: 199px;
	overflow: hidden;
}

.top-slick {
	position: relative;
	margin-top: 65px;
	overflow: visible;
}

.top-slick .slider__lists {
	display: block !important;
	margin: 0;
	padding: 0;
	list-style: none;
}

.top-slick .slider__lists > li {
	width: auto !important;
}

.top-slick .slick-track {
	display: flex !important;
}

.top-slick .slick-slide {
	margin: 0 27.5px;
	transition: opacity 0.25s ease;
}

.top-slick .slick-list {
	margin: 0 -27.5px;
}

.top-slick .slider-link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.top-slick .slider-link .image__wrap {
	position: relative;
}

.top-slick .slider-link .post-cats {
	position: absolute;
	right: 15px;
	bottom: 13px;
	margin-left: 0;
}

.top-slick .slider-link .info__category {
	width: 113px;
	height: 20px;
	background-color: #fff;
}

.top-slick .slider__img img {
	display: block;
	width: 100%;
	height: auto;
}

.slider__title {
	margin-top: 26px;
	color: #162142;
	font-weight: 800;
	font-size: 1.8rem;
	line-height: 1.555;
}

.slider__text {
	margin-top: 26px;
	font-size: 1.4rem;
	line-height: 1.785;
}

.top-slick .slick-prev,
.top-slick .slick-next {
	z-index: 2;
	position: absolute;
	top: 50%;
	width: 46px;
	height: 46px;
	padding: 0;
	transform: translateY(-50%);
	border: 0;
	background: none;
	cursor: pointer;
}

.top-slick .slick-prev {
	left: 9vw;
}

.top-slick .slick-next {
	right: 9vw;
}

.top-slick .slick-prev img,
.top-slick .slick-next img {
	display: block;
	width: 100%;
	height: 100%;
}

/*---------------------------------- 
トップページ：お知らせ
----------------------------------*/

.top-news {
	margin-top: 133px;
}

.top-news .button {
	margin-top: 48.5px;
}

.top-news .button-link {
	margin-left: auto;
}

.top-news__wrap {
	display: flex;
	justify-content: space-between;
}

.top-news__content {
	flex: 0 0 57.611%;
	margin-left: 40px;
}

.top-news__content .no-post {
	margin-top: 40px;
}

.news__item {
	border-bottom: 1px solid #B9B9D6;
}

.news__item:first-of-type {
	border-top: 1px solid #B9B9D6;
}

.news__item .info {
	display: flex;
	align-items: flex-start;
	padding: 35.5px 0;
}

.news__item .info__title {
	flex: 1;
	margin-left: 46px;
	color: #000;
	font-weight: 700;
	font-size: 2rem;
}

.info__meta {
	display: flex;
	flex: 0 0 var(--meta-col, auto);
	flex-wrap: wrap;
	align-items: center;
	margin-top: 6px;
}

.info__published {
	color: #000;
	font-weight: 700;
	font-family: "Akshar", sans-serif;
}

.info__category {
	display: flex;
	align-items: center;
	justify-content: center;
	width: auto;
	min-width: 121px;
	height: auto;
	padding: 0 6px;
	border: 1px solid #CE0201;
	border-radius: 50px;
	color: #CE0201;
	font-weight: 700;
	font-size: 1.3rem;
	line-height: 1.3;
}

/*----------------------------------
フッター
----------------------------------*/

.home .footer {
	margin-top: 155px;
}

.footer {
	position: relative;
	margin-top: 20px;
	padding: 137px 109px 34px 117px;
	background: linear-gradient(to bottom, #162142, #323F69);
}

.footer::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 184.5px;
	height: 181.5px;
	background: url(../img/footer_bg.png) no-repeat center left/contain;
	content: "";
}

.footer .nav ul li span {
	color: #fff;
}

.footer .wrap .button {
	margin-top: 31px;
}

.footer .wrap .button-link:hover {
	color: #162142;
}

.footer .wrap .button-link:hover .arrow span:first-of-type {
	border-left-color: #A7ABB7;
}

.footer .wrap .button-link:hover .arrow span:nth-of-type(2) {
	border-left-color: #58617B;
}

.footer .wrap .button-link:hover .arrow span:nth-of-type(3) {
	border-left-color: #162142;
}

.wrap {
	display: flex;
	position: relative;
	justify-content: space-between;
}

.wrap .button {
	margin-top: 59px;
}

.wrap .button-link {
	font-weight: 700;
	font-family: "Noto Sans JP", sans-serif;
}

.left {
	flex: 0 0 400px;
}

.company-name a {
	color: #fff;
	font-weight: 800;
	font-size: 2.5rem;
	line-height: 1;
}

.company-info {
	margin-top: 30px;
	color: #fff;
	font-weight: 600;
	line-height: 1.75;
}

.policy-menu {
	display: none;
}

.right {
	flex: 0 0 513px;
	margin-left: 30px;
}

.nav > ul {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	height: 350px;
}

.nav > ul > li + li {
	margin-top: 45px;
}

.nav > ul > li:nth-child(4) {
	margin-top: 0;
}

.nav > ul > li:nth-child(n+4) {
	margin-left: 90px;
}

.nav > ul > li > span,
.nav > ul > li > a {
	font-weight: 800;
	font-size: 2rem;
}

.nav > ul > li > span {
	color: #162142;
}

.nav > ul > li ul {
	margin-top: 30px;
}

.nav > ul > li ul li + li {
	margin-top: 20px;
}

.nav > ul > li ul li a {
	font-size: 1.4rem;
}

.nav ul li {
	line-height: 1;
}

.nav ul li a {
	position: relative;
	color: #fff;
}

.nav ul li a::before {
	display: inline-block;
	position: absolute;
	top: 54%;
	left: -14px;
	width: 0;
	height: 0;
	margin-right: 6px;
	transform: translateY(-50%);
	border-top: 6px solid transparent;
	border-right: 0;
	border-bottom: 6px solid transparent;
	border-left: 9px solid #ce0201;
	border-style: solid;
	content: "";
	opacity: 0;
	transition: all 0.5s ease 0s;
}

.nav ul li a:hover {
	opacity: 1;
}

.nav ul li a:hover::before {
	opacity: 1;
}

.footer__copy {
	margin-top: 125px;
	color: #fff;
	font-weight: 700;
	font-size: 1.2rem;
	line-height: 1;
	font-family: "Akshar", sans-serif;
}

.disable-auto-tel a[href^="tel:"] {
	color: inherit;
	text-decoration: none;
	pointer-events: none;
}

@media (min-width: 768px) {

.about .pin-spacer {
	inset: 5px auto auto !important;
}

.archive__content .info .arrow span {
	display: inline-block;
	width: 0;
	height: 0;
	border-top: 4px solid transparent;
	border-right: 0;
	border-bottom: 4px solid transparent;
	border-left: 7px solid;
	border-style: solid;
	opacity: 0;
}

.archive__content .info .arrow span:first-of-type {
	border-left-color: #A7ABB7;
}

.archive__content .info .arrow span:nth-of-type(2) {
	border-left-color: #58617B;
}

.archive__content .info .arrow span:nth-of-type(3) {
	border-left-color: #162142;
}

.archive__content .info:hover .info__title {
	color: #7C7C7C;
}

.archive__content .info:hover .arrow span {
	animation: fadeIn 0.2s ease forwards;
}

.archive__content .info:hover .arrow span:nth-of-type(2) {
	animation-delay: 0.1s;
}

.archive__content .info:hover .arrow span:nth-of-type(3) {
	animation-delay: 0.2s;
}

.button-submit:hover .arrow span:first-of-type {
	border-left-color: #4F4F69;
}

.button-submit:hover .arrow span:nth-of-type(2) {
	border-left-color: #AFAFC4;
}

.button-submit:hover .arrow span:nth-of-type(3) {
	border-left-color: #fff;
}

.hidden-pc {
	display: none;
}

a[href^="tel:"] {
	pointer-events: none;
}

}

@media (min-width: 768px) and (max-width: 1023px) {

.hidden-tab {
	display: none;
}

.block-tab {
	display: block;
}

a[href^="tel:"] {
	pointer-events: none;
}

}

@media (min-width: 1366px) {

.hidden-xl {
	display: none;
}

.top-recruit__wrap::after {
	top: -4px;
	height: 436px;
}

a[href^="tel:"] {
	pointer-events: none;
}

}

@media (min-width: 1601px) {

.page-mainvisual__img img {
	max-width: 96%;
}

}

@media (min-width: 1951px) {

.service__img {
	position: absolute;
	right: -61px;
	width: 412px;
}

}

@media (max-width: 1299px) {

.page-sidebar {
	margin-left: 0;
}

.service .content__list:nth-child(2) .service__img,
.service .content__list:nth-child(3) .service__img {
	margin-left: -1vw;
}

.service__img {
	flex: 0 0 26.7vw;
	margin: -153px calc(50% - 50vw + 200px) 0 -1vw;
}

.service__wrapper {
	width: 66%;
}

.outsourcing {
	padding-left: 50px;
}

.outsourcing__item.green::before {
	left: 48%;
	width: calc(100% + 10px);
}

.outsourcing__item.green::after {
	left: 48%;
}

.outsourcing__item.blue::after {
	left: 48%;
}

.outsourcing__container::before {
	left: 48%;
	width: calc(100% + 50px);
}

}

@media (max-width: 1220px) {

.hidden-w1220 {
	display: none;
}

}

@media (max-width: 1199px) {

.outsourcing__wrap {
	flex: 0 0 43%;
	margin-left: 50px;
}

.hidden-w1200 {
	display: none;
}

}

@media (max-width: 1149px) {

.hidden-w1150 {
	display: none;
}

}

@media (max-width: 1134px) {

.service .content__lists {
	width: 82%;
}

.outsourcing__wrapper {
	display: block;
	flex: 0 0 36%;
}

.outsourcing__img {
	width: 70px;
	margin: auto;
}

.outsourcing__title {
	margin-left: 0;
	font-size: 1.8rem;
}

}

@media (max-width: 1099px) {

.page-jline-corporation .page-mainvisual__title span.ja {
	font-size: 3.5rem;
}

.display-w1100 {
	display: block;
}

.footer {
	padding-right: 50px;
	padding-left: 50px;
}

}

@media (max-width: 1023px) {

.page-mainvisual::after {
	width: 57vw;
	min-width: initial;
	height: 107vw;
	min-height: initial;
}

.page-mainvisual.white::after {
	left: 0;
	height: 120.661765vw;
}

.page-mainvisual__title > span.ja {
	font-size: 3.2rem;
}

.page-mainvisual__img {
	margin-left: 88px;
}

.content__lists {
	padding-left: 50px;
}

.about-link {
	display: block;
	margin-top: 55px;
}

.about-link .button {
	margin: 20px 0 0 0;
}

.contributions .inner {
	padding-left: 50px;
}

.archive__content {
	flex: 0 0 calc(100% - 170px);
	margin-left: 49px;
}

.post-cats {
	margin-left: 30px;
}

.contact__wrap {
	padding: 0;
}

.sustainability .inner {
	padding-left: 50px;
}

.sustainability__img {
	margin-left: 30px;
}

.sustainability-box {
	padding: 53px 20px 47px 30px;
}

.service .content__lists {
	width: calc(100% - 175px);
}

.service__lead {
	padding-left: 50px;
}

.service__lists {
	width: calc(100% - 215px);
	margin-left: 50px;
}

.service__wrap {
	padding-left: 70px;
}

.service__img {
	position: absolute;
	top: 0;
	right: -92px;
	width: 35%;
	margin-top: -60px;
	margin-right: calc(50% - 50vw + 193px);
}

.service__wrapper {
	width: 100%;
}

.service-point__img + .service-point__img {
	margin-left: 20px;
}

.outsourcing {
	padding: 10px 32px 35px;
}

.outsourcing__item.green::before {
	left: 50%;
	width: calc(100% + 20px);
}

.outsourcing__item.green::after {
	left: 50%;
}

.outsourcing__item.blue::after {
	left: 50%;
}

.outsourcing__container::before {
	left: 50%;
	width: calc(100% + 40px);
}

.outsourcing__wrapper {
	flex: 0 0 176px;
}

.outsourcing__title {
	font-size: 1.6rem;
}

.outsourcing__wrap {
	flex: 0 0 calc(100% - 202px);
	margin-left: 30px;
}

.outsourcing__wrap .arrow {
	margin: 0;
}

.outsourcing-label {
	padding: 7px 18px;
	white-space: initial;
}

.dynamic-management__list {
	width: 144px;
	font-size: 1.4rem;
}

.dynamic-management__text {
	font-size: 1.8rem;
}

.tradiss__lead {
	font-size: 1.8rem;
}

.tradiss__img {
	width: 96%;
}

.access-map.pc {
	margin-top: -100px;
}

.page-jline-corporation .page-mainvisual__title {
	margin-left: 40%;
}

.page-jline-corporation .page-mainvisual__img {
	margin-left: 38px;
}

.jline-corp__lead {
	padding-left: 50px;
}

.jline-corp__inner {
	padding-left: 50px;
}

.safety-management .content__lists {
	padding-left: 0;
}

.safety-management__wrap.flex {
	flex: 0 0 calc(100% - 64px);
}

.safety-management__img {
	width: 100%;
	margin-top: 30px;
}

.policy .content__lists {
	padding-left: 0;
}

.top .inner {
	width: min(100% - 80px, 1135px);
}

.inner {
	width: min(100% - 80px, 1130px);
}

.inner2 {
	width: min(100% - 80px, 933px);
}

.header {
	padding-left: 20px;
}

.drawer__nav .wrap .button-link {
	width: 270px;
}

.drawer__nav .left {
	flex: 0 0 270px;
}

.drawer__nav .company-name {
	width: 270px;
}

.drawer__nav .nav > ul > li:nth-child(n+4) {
	margin-left: 10px;
}

.mainvisual__text {
	margin-top: 7.2vw;
	font-size: 1.9rem;
}

.top-about {
	padding-right: 30px;
	padding-left: 30px;
}

.top-about .section__title > span.ja {
	font-size: 2.7rem;
	line-height: 1.5;
}

.top-service__item:first-of-type .top-service__text {
	padding-right: 0;
}

.top-service__item:nth-of-type(2) .top-service__text {
	padding-right: 0;
}

.top-service__left {
	flex: 0 0 44%;
}

.top-service__right {
	flex: 0 0 49%;
}

.top-recruit__wrap {
	padding-left: 40px;
}

.top-recruit__text {
	margin-top: 30px;
}

.top-recruit__images {
	margin-left: 30px;
}

.top-sustainability {
	margin-top: 150px;
}

.top-sustainability .button {
	margin-left: 30px;
}

.top-slider {
	margin-top: 150px;
}

.top-news__content {
	flex: 0 0 75%;
}

.news__item .info {
	display: block;
}

.news__item .info__title {
	margin: 8px 0 0 0;
}

.footer {
	padding-right: 30px;
	padding-left: 30px;
}

.footer .nav > ul > li > span,
.footer .nav > ul > li > a {
	font-size: 1.7rem;
}

.footer .nav > ul > li ul li a {
	font-size: 1.3rem;
}

.left {
	flex: 0 0 290px;
}

.company-name a {
	font-size: 1.8rem;
}

.company-info {
	font-size: 1.5rem;
}

.right {
	flex: 0 0 398px;
	margin-left: 20px;
}

.nav > ul > li:nth-child(n+4) {
	margin-left: 20px;
}

.nav > ul > li > span,
.nav > ul > li > a {
	font-size: 1.8rem;
}

}

@media (max-width: 899px) {

.page-mainvisual::after {
	width: 62vw;
	height: 118vw;
}

.hidden-w900 {
	display: none;
}

.block-w900 {
	display: block;
}

}

@media (max-width: 768px) {

.splash-img {
	width: 90%;
}

#splash figure {
	width: 250px;
	margin-top: -15vh;
}

}

@media (max-width: 767px) {

.page-top {
	right: 16px;
	width: 18px;
	height: 55px;
}

.page-mainvisual {
	display: flex;
	flex-direction: column-reverse;
	padding-top: 70px;
}

.page-mainvisual::after {
	top: 67px;
	width: 50vw;
	height: 145vw;
	background-image: url(../img/page_mv_j_sp.png);
}

.page-mainvisual.white::after {
	top: 67px;
	width: 180px;
	width: 48vw;
	background-image: url(../img/page_mv_j_white_sp.png);
}

.page-mainvisual.white .page-mainvisual__title {
	margin-top: 53px;
}

.page-mainvisual .inner {
	text-align: left;
}

.breadcrumb {
	z-index: 1;
	position: relative;
	order: 3;
	margin-top: 103px;
	padding-right: 16px;
}

.breadcrumb__item {
	font-size: 1.2rem;
}

.breadcrumb__item:nth-child(2) {
	white-space: nowrap;
}

.page-mainvisual__title {
	order: 1;
	margin-top: 57px;
	margin-top: 15.2vw;
	padding-right: 0;
}

.page-mainvisual__title > span.ja {
	margin-top: 5px;
	font-size: 2.8rem;
}

.page-mainvisual__img {
	z-index: -1;
	position: relative;
	order: 2;
	height: 286px;
	height: 76.2666666667vw;
	margin-top: 102px;
	margin-top: 27.2vw;
	margin-left: 0;
}

.page-mainvisual__img img {
	-o-object-fit: cover;
	-webkit-clip-path: polygon(30% 0, 100% 0, 100% 100%, 0 100%, 0 50%);
	width: 100%;
	max-width: 100%;
	height: 100%;
	object-fit: cover;
	clip-path: polygon(30% 0, 100% 0, 100% 100%, 0 100%, 0 50%);
}

.page-sec__title {
	padding-bottom: 7px;
	font-size: 2rem;
}

.page-sec__title::after {
	bottom: -1.5px;
	width: 68px;
	height: 2px;
}

.page__wrap {
	display: block;
}

.page-sidebar {
	z-index: 2;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
}

.page-sidebar__title {
	display: block;
	display: flex;
	position: relative;
	align-items: center;
	justify-content: center;
	height: 56px;
	background-color: #fff;
	font-weight: 700;
	font-family: "Akshar", sans-serif;
}

.page-sidebar__wrap {
	display: none;
}

.page-sidebar__lists {
	padding: 44px 10px 50px 45px;
	background-color: #F2F2F7;
}

.page-sidebar__list {
	line-height: 1.45;
}

.page-sidebar__list.current::before {
	content: none;
}

.table th,
.table td {
	display: block;
	padding: 14px 0;
}

.table th {
	width: 100%;
	padding-bottom: 0;
	font-size: 1.6rem;
}

.table td {
	padding-top: 0;
	padding-left: 0;
	line-height: 1.666;
}

.pagination {
	margin-top: 50px;
}

.pagination * {
	margin-right: 30px;
}

.page-numbers.current::before {
	width: 35px;
	height: 35px;
}

.page-404 {
	margin-top: 100px;
	padding-bottom: 50px;
}

.page-404 h1 {
	font-size: 3rem;
}

.page-about .page__content {
	padding-top: 10px;
}

.page-about .footer {
	padding-bottom: 86px;
}

.about {
	overflow: hidden;
}

.about .content__list:first-child {
	margin-top: 100px;
}

.about .content__list + .content__list {
	margin-top: 163px;
}

.content__lists {
	padding-left: 0;
}

.about__img {
	width: 100vw;
	height: 191px;
	height: 50.9333333333vw;
	margin: 0 calc(50% - 50vw);
}

.about__img img {
	-o-object-fit: cover;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.about__title > span.en {
	font-size: 1.2rem;
}

.about__title > span.ja {
	margin-top: 7px;
	font-size: 2.4rem;
}

.about__title {
	margin-top: 34px;
}

.about__text {
	margin-top: 26px;
	color: #162142;
	font-size: 1.6rem;
	line-height: 2;
}

.about-link .button {
	margin-top: 32px;
}

.about-link .button-link {
	margin: auto;
	background-color: inherit !important;
	color: #162142 !important;
}

.about-link .button-link .arrow span {
	border-left-color: #162142 !important;
}

.about-link__text {
	margin-top: 10px;
}

.page-message .page__content {
	padding-top: 80px;
}

.message-sec01 {
	margin-top: 50px;
}

.message-sec01 .message__text {
	margin-top: 40px;
	font-size: 1.6rem;
	line-height: 2;
}

.message__img {
	margin-top: 70px;
}

.page-social-contributions .page__content {
	padding-top: 80px;
}

.contributions .inner {
	padding-left: 0;
}

.contributions .section__title .ja {
	font-size: 2rem !important;
}

.contributions__wrap {
	margin-top: 30px;
}

.contributions__text {
	font-size: 1.6rem;
}

.contributions__img {
	margin-top: 30px;
}

.contributions-caption {
	font-size: 1.6rem;
}

.archive .page__content {
	padding-top: 80px;
}

.archive__wrap {
	display: block;
}

.archive__wrap .sidebar {
	position: static;
	height: auto;
}

.archive__wrap .no-post {
	margin: 50px 0 0 0;
	text-align: center;
}

.sidebar__lists {
	display: flex;
	flex-wrap: wrap;
}

.sidebar__list {
	min-width: 100px;
	margin-bottom: 10px;
}

.sidebar__list + .sidebar__list {
	margin: 0 0 0 11px;
}

.sidebar__list a {
	padding: 1.5px 6px;
}

.archive__content {
	margin: 30px 0 0 0;
}

.archive__content .news__item:first-of-type {
	border-top: none;
}

.archive__content .info {
	padding-top: 24px !important;
	padding-right: 0 !important;
	padding-bottom: 17px !important;
}

.archive__content .info .arrow {
	right: 0;
}

.archive__content .info__category {
	width: 107px;
	height: 20px;
	margin-left: 0;
	border-radius: 12px;
}

.archive__content .info__published {
	margin-right: 15px;
	font-size: 1.3rem;
}

.post-cats {
	margin-left: 0;
}

.post-cats .info__category {
	margin-right: 6px;
	margin-bottom: 3px;
}

.single .page__content {
	padding-top: 88px;
}

.news-single-head::after {
	bottom: -1.5px;
	height: 2px;
}

.news-single-head .info__published {
	margin-right: 14px;
}

.news-single__title {
	margin-top: 5px;
	margin-top: 10px;
	color: #000;
	font-size: 2rem;
}

.news-single__content {
	padding: 53px 0;
}

.news-single__content p {
	font-size: 1.6rem;
}

.news-single__content figure {
	margin: 30px 0;
}

.single__footer {
	font-size: 1.2rem;
}

.single__footer .arrow {
	width: 20px;
}

.single__footer .arrow span {
	border-top: 3px solid transparent;
	border-bottom: 3px solid transparent;
	border-left: 5px solid #000032;
}

.page-contact .page__content {
	padding-top: 93px;
}

.contact__lead {
	font-size: 1.6rem;
}

.contact__wrap {
	margin-top: 30px;
}

.contact__wrap .button-link {
	background-color: #162142;
	color: #fff;
}

.required__text {
	font-size: 1.6rem;
}

.contact-row {
	display: block;
	margin-bottom: 20px;
}

.contact-title .ttl {
	font-size: 1.5rem;
}

.contact-text {
	margin: 10px 0 0 0;
}

input[type=text],
input[type=email],
select {
	height: 44px;
}

textarea {
	height: 250px;
}

.contact-wrapper {
	margin: 10px 0 0 0;
}

.business-contact {
	margin-top: 15px;
	padding: 10px;
}

input[type=checkbox] + .wpcf7-list-item-label::after {
	top: 10px;
}

.business-contact__item.business-contact-radio {
	padding-bottom: 0;
}

.button-submit .arrow span:first-of-type {
	border-left-color: #58617B;
}

.button-submit .arrow span:nth-of-type(2) {
	border-left-color: #A7ABB7;
}

.button-submit .arrow span:nth-of-type(3) {
	border-left-color: #fff;
}

.button-submit:hover::before {
	content: none;
}

.page-thanks .page__content {
	padding-top: 80px;
}

.page-thanks .footer {
	margin-top: 125px;
}

.thanks__title {
	font-size: 2rem;
}

.thanks__text {
	margin-top: 40px;
	font-size: 1.6rem;
	text-align: left;
}

.sustainability .inner {
	padding-left: 0;
}

.sdgs__large-img {
	width: 100%;
}

.sustainability__items {
	margin-top: 50px;
}

.sustainability__item + .sustainability__item {
	margin-top: 80px;
}

.sustainability__title {
	font-size: 2rem;
}

.sustainability__wrap {
	display: block;
}

.sustainability__text {
	font-size: 1.6rem;
}

.sustainability__img {
	margin: 30px 0 0 0;
}

.sustainability-box {
	display: block;
	margin-top: 30px;
	padding: 30px 20px;
}

.sustainability-box__title {
	font-size: 1.8rem;
}

.sustainability-box__title::after {
	bottom: -1.5px;
	height: 2px;
}

.sustainability-box__lists {
	margin-top: 15px;
}

.sustainability-box__list {
	width: 100%;
	padding-left: 1.4em;
	text-indent: -1.4em;
}

.sustainability-box__list:nth-child(even) {
	margin-left: 0;
}

.sustainability-box__list:nth-child(2) {
	margin-top: 5px;
}

.sustainability-box__list::before {
	margin-right: 5px;
}

.page-service .page__content {
	padding-top: 50px;
}

.service .page__wrap {
	margin-top: 125px;
}

.service .content__lists {
	width: 100%;
}

.service .content__list + .content__list {
	margin-top: 60px;
}

.service .content__list:nth-child(2) .service__img,
.service .content__list:nth-child(3) .service__img {
	margin: calc(50% - 50vw);
}

.service .content__list:nth-child(2) .list__title,
.service .content__list:nth-child(3) .list__title {
	left: 135px;
}

.service .content__list:nth-child(3) .service__item {
	margin-top: 70px;
}

.service__lead {
	padding-left: 0;
	color: #000;
	font-size: 1.6rem;
}

.service__lists {
	width: 100%;
	margin-left: 0;
}

.service__list {
	padding-top: 30px;
}

.service__list + .service__list {
	margin-top: 90px;
}

.service__wrap {
	flex-direction: column-reverse;
	padding: 0;
}

.service__wrap::before {
	top: 16px;
	margin: calc(50% - 50vw);
}

.service__wrap .number {
	top: -83px;
	left: -13px;
}

.service__wrap .list__title {
	top: -50px;
	left: 114px;
	font-size: 1.6rem;
}

.service__img {
	position: static;
	width: 100vw;
	height: 360px;
	height: 96vw;
	margin: calc(50% - 50vw);
}

.service__img img {
	-o-object-fit: cover;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.service__wrapper {
	margin-top: 60px;
	padding-bottom: 70px;
}

.service__title {
	font-size: 2.4rem;
	line-height: 1.5;
}

.service__text {
	margin-top: 26px;
	font-size: 1.6rem;
}

.service__items {
	margin-top: 50px;
}

.service__item + .service__item {
	margin-top: 50px;
}

.page-sec__title.point span {
	display: block;
	margin-right: 35px;
	font-size: 1.2rem;
}

.page-sec__title.point::after {
	width: 54px;
}

.service-point__images {
	display: block;
}

.service-point__img {
	height: 205px;
	height: 54.6666666667vw;
}

.service-point__img + .service-point__img {
	margin: 25px 0 0 0;
}

.service-point__img img {
	-o-object-fit: cover;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.outsourcing {
	width: 100vw;
	margin: 47px calc(50% - 50vw) 0;
	padding: 16px 23px 24px;
}

.outsourcing__item {
	display: block;
	padding: 28px 15px;
}

.outsourcing__item.green {
	margin-top: 15px;
}

.outsourcing__item.green::before {
	width: calc(100% - 11px);
}

.outsourcing__item.orange .outsourcing__wrap {
	width: 187px;
	margin: 10px auto 0;
}

.outsourcing__item.orange .outsourcing-label:nth-child(2) {
	width: 68px;
}

.outsourcing__container {
	padding-bottom: 11px;
}

.outsourcing__container::before {
	width: calc(100% + 10px);
}

.outsourcing__img {
	width: 75px;
}

.outsourcing__title {
	margin-top: 10px;
	font-size: 2rem;
	text-align: center;
}

.outsourcing__wrap {
	width: 400px;
	max-width: 100%;
	margin: 10px auto 0;
	gap: 6px;
}

.outsourcing__wrap .label__wrap {
	gap: 6px;
}

.outsourcing-label {
	padding: 7px 20px;
	font-size: 1.4rem;
}

.dynamic-management {
	display: block;
	margin-top: 60px;
}

.dynamic-management__item {
	position: relative;
	width: calc(100% - 60px);
	margin: auto;
}

.dynamic-management__item.first {
	padding: 27px 0 37px;
}

.dynamic-management__item.second {
	padding: 36px 0;
}

.dynamic-management-icon {
	position: absolute;
	top: 50%;
	left: -30px;
	width: 60px;
	margin-top: 0;
	transform: translateY(-50%);
}

.dynamic-management__title {
	margin-top: 0;
}

.dynamic-management__lists {
	margin-top: 15px;
}

.dynamic-management__lists .plus {
	line-height: 1.5;
}

.dynamic-management__list {
	width: 160px;
}

.dynamic-management__center {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 7px 0 6px;
}

.dynamic-management__text {
	font-size: 1.6rem;
}

.dynamic-management-arrow {
	margin: 0 0 0 14px;
}

.dynamic-management-arrow.reverse {
	margin: 0 14px;
}

.tradiss {
	padding: 37px 13px 37px 12px;
}

.page-access .page__content {
	padding-top: 50px;
}

.access-map.pc {
	display: none;
}

.access-map.sp {
	display: block;
	width: calc(100% - 32px);
	margin: 26px auto 0;
}

.access-sec + .access-sec {
	margin-top: 110px;
}

.access__img {
	width: 72.594%;
	margin-top: 30px;
}

.access__content {
	margin-top: 25px;
}

.google-map {
	margin-top: 22px;
}

.google-map iframe {
	height: 171px;
	height: 45.6vw;
}

.page-outline .page__content {
	padding-top: 80px;
}

.outline-sec + .outline-sec {
	margin-top: 100px;
}

.outline__content {
	margin-top: 10px;
}

.page-jline-corporation .page-mainvisual__title {
	margin-left: 0;
}

.page-jline-corporation .page-mainvisual__title span.ja {
	font-size: 2.8rem;
}

.page-jline-corporation .page-mainvisual__img {
	margin-left: 0;
}

.page-jline-corporation .page__content {
	padding-top: 60px;
}

.jline-corp__lead {
	padding-left: 0;
	color: #000;
	font-size: 1.6rem;
}

.jline-corp__inner {
	margin-top: 80px;
	padding-left: 0;
}

.jline-corp__content {
	margin-top: 10px;
}

.page-safety-management .page__content {
	padding-top: 78px;
}

.safety-management .content__list + .content__list {
	margin-top: 56px;
}

.safety-management .content__list:nth-child(3) .safety-management__list {
	display: block;
}

.safety-management .page-sidebar__lists {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	height: 286px;
}

.safety-management .page-sidebar__list {
	width: calc(50% - 42px);
}

.safety-management .page-sidebar__list + .page-sidebar__list {
	margin-top: 0;
}

.safety-management .page-sidebar__list:nth-child(n+6) {
	margin-left: 20px;
}

.safety-management .page-sidebar__list:not(:nth-child(5n+1)) {
	margin-top: 20px;
}

.safety-management__title {
	font-size: 2rem;
	line-height: 1.6;
}

.safety-management__title::after {
	bottom: -1.5px;
	width: 78px;
	height: 2px;
}

.safety-management__title .number {
	margin: -7px 44px 0 0;
	font-size: 4.1rem;
}

.safety-management__sub-title {
	margin-top: 40px;
	font-size: 1.6rem;
}

.safety-management__sub-title + .safety-management__lists {
	margin-top: 20px;
}

.safety-management__lists {
	margin-top: 30px;
}

.safety-management__list + .safety-management__list {
	margin-top: 20px;
}

.safety-management__list .number {
	margin-right: 40px;
}

.safety-management__text.goal {
	flex: 0 0 46.938%;
}

.safety-management__text.download {
	font-size: 1.6rem;
}

.safety-management-figure {
	margin-top: 30px;
}

.page-privacy-policy .page__content {
	padding-top: 80px;
}

.policy .content__list + .content__list {
	margin-top: 56px;
}

.policy__title {
	font-size: 2rem;
}

.policy__title::after {
	bottom: -1.5px;
	width: 78px;
	height: 2px;
}

.policy__content {
	margin-top: 30px;
}

.policy__sub-title {
	margin: 30px 0 10px;
	font-size: 1.6rem;
}

.policy-circle__lists {
	margin-top: 10px;
}

.policy-circle__list::before {
	margin-top: 11px;
}

.policy__lists {
	margin-top: 10px;
}

.policy__list + .policy__list {
	margin-top: 10px;
}

.policy__list .number {
	margin-right: 40px;
}

body {
	background-color: #F0F0F5;
	font-size: 1.5rem;
	line-height: 1.866;
}

.hidden-sp {
	display: none;
}

.top .inner {
	width: min(100% - 32px, 1135px);
}

.inner {
	width: min(100% - 32px, 1130px);
}

.inner2 {
	width: min(100% - 32px, 933px);
}

.section__title > span.en {
	font-size: 1.4rem;
}

.section__title > span.ja {
	margin-top: 12px;
	font-size: 2.4rem;
}

.button-link {
	font-size: 1.6rem;
}

.button-link::before {
	content: none;
}

.button-link.normal {
	background-color: #162142;
	color: #fff;
}

.button-link.normal .arrow span:first-of-type {
	border-left-color: #58617B;
}

.button-link.normal .arrow span:nth-of-type(2) {
	border-left-color: #A7ABB7;
}

.button-link.normal .arrow span:nth-of-type(3) {
	border-left-color: #fff;
}

.button-link.white {
	background-color: #fff;
	color: #CB0200;
}

.button-link.white .arrow span:first-of-type {
	border-left-color: #F8CBCA;
}

.button-link.white .arrow span:nth-of-type(2) {
	border-left-color: #ED6F6D;
}

.button-link.white .arrow span:nth-of-type(3) {
	border-left-color: #CB0200;
}

.view {
	transform: translate(0, 50px);
	transition: all 1000ms;
}

.header {
	height: 67px;
	padding: 13px 10px 11px 16px;
	background-color: #F0F0F5;
}

.header__inner {
	justify-content: initial;
}

.logo {
	width: 107px;
	height: 43px;
}

.header-contact {
	display: none;
}

.drawer__toggle {
	top: 26px;
	right: 16px;
	width: 45px;
	height: 16px;
}

.drawer__line--center {
	top: 8px;
}

.drawer__line--bottom {
	bottom: -1px;
}

.drawer__line--top.active {
	top: 9px;
	width: 47px;
}

.drawer__line--bottom.active {
	bottom: 6px;
	width: 47px;
}

.drawer__nav {
	top: 67px;
	padding: 35px 16px 56px;
}

.drawer__nav .wrap .button-link {
	width: 245px;
	height: 62px;
	color: #fff;
}

.drawer__nav .wrap .button-link .arrow span:first-of-type {
	border-left-color: #58617B;
}

.drawer__nav .wrap .button-link .arrow span:nth-of-type(2) {
	border-left-color: #A7ABB7;
}

.drawer__nav .wrap .button-link .arrow span:nth-of-type(3) {
	border-left-color: #fff;
}

.drawer__nav .left {
	width: 267px;
	margin-top: 70px;
}

.drawer__nav .company-name {
	width: 262px;
}

.drawer__nav .company-info {
	margin-top: 31px;
}

.drawer__nav .nav > ul > li:nth-child(n+4) {
	margin-left: 0;
}

.drawer__nav .right {
	width: 100%;
}

.drawer__nav .nav > ul {
	display: block;
	height: auto;
}

.drawer__nav .nav > ul > li {
	position: relative;
	padding: 22px 0;
	padding-left: 36px;
	border-bottom: 1px solid #B9B9D6;
}

.drawer__nav .nav > ul > li::before {
	position: absolute;
	top: 27px;
	left: 20px;
	width: 0;
	height: 0;
	border-top: 6px solid transparent;
	border-right: 0;
	border-bottom: 6px solid transparent;
	border-left: 9px solid #ce0201;
	border-style: solid;
	content: "";
}

.drawer__nav .nav > ul > li + li {
	margin-top: 0;
}

.drawer__nav .nav > ul > li:last-child {
	border-bottom: none;
}

.drawer__nav .nav > ul > li > span,
.drawer__nav .nav > ul > li > a {
	font-size: 2rem;
	white-space: nowrap;
}

.drawer__nav .nav > ul > li ul {
	margin-top: 20px;
}

.drawer__nav .nav ul li a::before {
	content: none;
}

.drawer__inner {
	width: 100%;
	height: auto;
	padding-bottom: 56px;
}

.drawer__inner .wrap {
	position: static;
	transform: none;
}

.mainvisual-logo {
	top: 67px;
	right: 0;
	left: initial;
	width: 100%;
}

.mainvisual__wrap {
	display: block;
	padding-top: 187px;
	padding-top: 49.8666666667vw;
}

.mainvisual__left *,
.mainvisual__right * {
	width: 100%;
	height: 100%;
}

.mainvisual__left {
	width: 182px;
	width: 48.5333333333vw;
	height: 173px;
	height: 46.1333333333vw;
	margin-top: 0;
}

.mainvisual__right {
	width: 284px;
	width: 75.7333333333vw;
	height: 218px;
	height: 58.1333333333vw;
	margin-top: 135px;
	margin-top: 36vw;
	margin-left: auto;
}

.mainvisual__right .mainvisual__img img {
	height: 100%;
}

.mainvisual-copy__wrap {
	position: static;
	width: 272px;
	margin: 0 16px 0 auto;
}

.mainvisual-copy {
	position: absolute;
	top: 84vw;
	left: 16px;
	width: calc(100% - 32px);
}

.mainvisual__text {
	margin-top: 78px;
	margin-top: 20.8vw;
	margin-left: 0;
	font-size: 1.6rem;
}

.mainvisual__wrapper {
	display: none;
}

.top-about {
	z-index: 1;
	position: relative;
	margin-top: 74px;
	padding: 18px 20px;
}

.top-about .section__title > span.ja {
	font-size: 2.4rem;
}

.top-about .button {
	margin: 30px 0 0 0;
}

.top-about .button-link {
	margin: auto;
}

.top-about__inner {
	padding: 67px 0 78px;
	background-image: url(../img/top_about_sp.jpg);
}

.top-about__inner .inner2 {
	width: 100%;
	padding: 0 26px 0 27px;
}

.top-about__wrap {
	display: block;
}

.top-about__text {
	margin-top: 20px;
	color: #162142;
}

.image {
	height: 245px;
	height: 65.3333333333vw;
	margin-top: -40px;
	margin-top: -10.6666666667vw;
}

.image::after {
	top: 25px;
	top: 6.6666666667vw;
	right: -14px;
	height: 258px;
	height: 68.8vw;
	background-image: url(../img/top_service_logo_sp.png);
}

.top-service {
	padding: 30px 0 70px;
	background: linear-gradient(to bottom, #162142, #323F69);
}

.top-service__sec-title {
	font-size: 6rem;
}

.top-service__items {
	margin-top: 25px;
}

.top-service__item {
	display: block;
}

.top-service__item + .top-service__item {
	margin-top: 73px;
}

.top-service__title {
	margin-top: 47px;
}

.top-service__title span.ja {
	margin-top: 18px;
	font-size: 2.4rem;
}

.top-service__right {
	padding-top: 30px;
}

.top-service__right .button {
	margin-top: 50px;
}

.top-service__right .button-link {
	margin: auto;
}

.top-service__text {
	font-size: 1.6rem;
	line-height: 2;
}

.top-recruit {
	margin-top: 77px;
}

.top-recruit__wrap {
	display: block;
	padding-left: 0;
}

.top-recruit__wrap::after {
	top: -22vw;
	height: 535px;
	height: 142.6666666667vw;
	background-image: url(../img/top_recruit_logo_sp.png);
}

.top-recruit__content {
	padding: 70px 26px 0 27px;
}

.top-recruit__images {
	margin: 41px 0 0 0;
}

.top-recruit-link {
	height: 189px;
	height: 50.4vw;
}

.top-recruit__image {
	height: 100%;
}

.top-recruit__img {
	height: 100%;
}

.top-recruit__img img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
}

.top-sustainability {
	margin-top: 86px;
}

.top-sustainability .inner {
	padding: 52px 0 48px;
}

.top-sustainability .inner .inner2 {
	width: 100%;
}

.top-sustainability .button {
	margin: 30px 0 0 0;
}

.top-sustainability__wrap {
	display: block;
	padding-right: 26px;
	padding-left: 27px;
}

.top-sustainability__wrap .button-link {
	margin: auto;
}

.top-sustainability__text {
	margin-top: 20px;
}

.top-slider {
	margin-top: 68px;
}

.top-slick {
	margin-top: 51px;
}

.top-slick .slick-slide {
	margin: 0 10px;
}

.top-slick .slick-list {
	margin: 0 -10px;
}

.slider__title {
	font-size: 1.6rem;
}

.top-slick .slick-prev,
.top-slick .slick-next {
	top: 27%;
	width: 28px;
	height: 28px;
}

.top-slick .slick-prev {
	left: 4vw;
}

.top-slick .slick-next {
	right: 4vw;
}

.top-news {
	margin-top: 73px;
}

.top-news .button {
	margin-top: 46px;
}

.top-news .button-link {
	margin: auto;
}

.top-news__wrap {
	display: block;
}

.top-news__content {
	margin: 31px 0 0 0;
}

.top-news__content .no-post {
	text-align: center;
}

.news__item .info {
	padding: 23.5px 0 27.5px;
}

.news__item .info__title {
	font-size: 1.6rem;
}

.info__meta {
	margin-top: 0;
}

.info__published {
	margin-right: 10px;
	font-size: 1.4rem;
}

.info__category {
	padding: 1px 20px;
}

.home .footer {
	margin-top: 100px;
}

.footer {
	margin-top: 10px;
	padding: 95px 0 30px;
}

.footer::before {
	width: 105px;
	height: 105px;
}

.footer .nav {
	display: none;
}

.wrap {
	flex-direction: column-reverse;
}

.wrap .button {
	margin-top: 56px;
}

.wrap .button-link {
	color: #162142;
}

.wrap .button-link .arrow span:first-of-type {
	border-left-color: #A7ABB7;
}

.wrap .button-link .arrow span:nth-of-type(2) {
	border-left-color: #58617B;
}

.wrap .button-link .arrow span:nth-of-type(3) {
	border-left-color: #162142;
}

.left {
	width: 290px;
	max-width: 100%;
	margin: auto;
}

.company-info {
	margin-top: 20px;
	font-size: 1.4rem;
	line-height: 2;
}

.policy-menu {
	display: block;
	margin-top: 20px;
}

.policy-menu-link {
	color: #fff;
	font-weight: 700;
	font-size: 1.2rem;
	text-decoration: underline;
	text-underline-offset: 5px;
}

.right {
	flex: initial;
	width: 288px;
	max-width: 100%;
	margin: auto;
}

.footer__copy {
	margin-top: 54px;
	margin-left: 16px;
	font-size: 12px;
}

}

@media (max-width: 449px) {

.block-w450 {
	display: block;
}

}

@media (max-width: 433px) {

.hidden-w433 {
	display: none;
}

}

@media (max-width: 400px) {

.block-w400 {
	display: block;
}

}

@media (max-width: 389px) {

.hidden-w390 {
	display: none;
}

}

@media (max-width: 380px) {

.hidden-w380 {
	display: none;
}

}

@media (max-width: 375px) {

.block-w376 {
	display: block;
}

}

@media (max-width: 374px) {

.sidebar__list + .sidebar__list {
	margin-left: 5px;
}

.hidden-w375 {
	display: none;
}

.top-about .section__title > span.ja {
	font-size: 22px;
	font-size: 5.8823529412vw;
}

}

@media (max-width: 359px) {

.thanks__title {
	font-size: 1.9rem;
}

.service .content__list:nth-child(2) .list__title,
.service .content__list:nth-child(3) .list__title {
	left: 128px;
}

.service__wrap .number {
	width: 130px;
}

.safety-management__title .number {
	margin-right: 32px;
}

.hidden-sm {
	display: none;
}

.drawer__nav .nav > ul > li {
	padding-left: 20px;
}

.drawer__nav .nav > ul > li::before {
	left: 5px;
}

.mainvisual__text {
	margin-top: 33.8vw;
}

.top-about__inner .inner2 {
	padding-left: 20px;
}

.top-sustainability__wrap {
	padding-left: 20px;
}

.company-address,
.company-number {
	font-size: 1.3rem;
}

}

@keyframes fadeIn {

0% {
	opacity: 0;
}

100% {
	opacity: 1;
}

}

