html {
	font-size: 100%;
}

body {
	color: #303038;
	font-family: "Noto Sans JP", sans-serif;
	-webkit-text-size-adjust: 100%;
	   -moz-text-size-adjust: 100%;
	        text-size-adjust: 100%;
	word-wrap: anywhere;
}

:where(:link,
button,
[type=button],
[type=reset],
[type=submit],
label[for],
select,
summary,
[role=tab],
[role=button]),
:where(:visited,
button,
[type=button],
[type=reset],
[type=submit],
label[for],
select,
summary,
[role=tab],
[role=button]),
:where(area[href],
button,
[type=button],
[type=reset],
[type=submit],
label[for],
select,
summary,
[role=tab],
[role=button]) {
	cursor: pointer;
}

:where(:-moz-any-link,
button,
[type=button],
[type=reset],
[type=submit],
label[for],
select,
summary,
[role=tab],
[role=button]) {
	cursor: pointer;
}

:where(:any-link,
button,
[type=button],
[type=reset],
[type=submit],
label[for],
select,
summary,
[role=tab],
[role=button]) {
	cursor: pointer;
}

/*****************************
* A Modern CSS Reset (https://github.com/hankchizljaw/modern-css-reset)
* 上記に、ul要素,ol要素,a要素への記述追加
*****************************/

/* Box sizing rules */

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

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd,
ul,
ol,
li {
	margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */

ul,
ol {
	list-style: none;
	padding: 0;
}

/* Set core body defaults */

body {
	line-height: 1.5;
	min-height: 100vh;
	text-rendering: optimizeSpeed;
	-webkit-text-size-adjust: 100%;
	word-wrap: anywhere;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
	-webkit-text-decoration-skip: ink;
	        text-decoration-skip-ink: auto;
}

a {
	color: inherit;
	-webkit-text-decoration: none;
	text-decoration: none;
}

/* Make images easier to work with */

img,
picture {
	display: block;
	max-width: 100%;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
	font: inherit;
}

button {
	background-color: transparent;
	background-color: initial;
	border: none;
	padding: 0;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */

.l-inner {
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	width: 100%;
}

.l-wrap {
	position: relative;
}

.l-wrap::before {
	background: url("../../img/dot_bg_02.png") repeat;
	content: "";
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -2;
}

.c-btn {
	border: 0.125rem solid #fff;
	border-radius: calc(infinity * 1px);
	color: #fff;
	display: inline-block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	min-width: 12.25rem;
	padding: 0.5rem 2.625rem 0.5rem 1.625rem;
	position: relative;
}

.c-btn.--lg {
	min-width: 14.75rem;
}

.c-btn__arrow {
	bottom: 0;
	line-height: 1;
	margin: auto 0;
	overflow: hidden;
	position: absolute;
	right: 1.0625rem;
	top: 0;
	width: 0.9375rem;
}

.c-btn__arrow::before,
.c-btn__arrow::after {
	animation-duration: 0.3s;
	animation-fill-mode: forwards;
	background: url(../img/icon_arrow_right_white.svg) no-repeat center center/contain;
	content: "";
	height: 0.9375rem;
	position: absolute;
	right: 0;
	top: 50%;
	translate: 0 -50%;
	width: 0.9375rem;
}

.c-btn__arrow::after {
	transform: translateX(-100%);
}

.c-btn:hover .c-btn__arrow:before {
	animation-delay: 0s;
	animation-name: transformRightLeft;
}

.c-btn:hover .c-btn__arrow:after {
	animation-delay: 0.2s;
	animation-name: transformLeftRight;
}

.c-btn.--white {
	background-color: #fff;
	color: #303038;
}

.c-btn.--white .c-btn__arrow::before,
.c-btn.--white .c-btn__arrow::after {
	background-image: url(../img/icon_arrow_right_black.png);
}

.c-catch {
	color: #eee;
	font-family: "Jost", sans-serif;
	font-size: 6.25rem;
	font-weight: 500;
	line-height: 1;
	position: absolute;
	right: 0;
	text-transform: uppercase;
	top: -0.625rem;
	white-space: nowrap;
	width: min(85.3333333333vw, 20rem);
	z-index: 1;
}

.c-catch.--company {
	color: #c1e5ff;
}

.c-scroll {
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	justify-content: end;
	padding-bottom: 8.125rem;
	position: relative;
}

.c-scroll__text {
	color: #005492;
	font-family: "Jost", sans-serif;
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	position: relative;
	text-transform: uppercase;
	writing-mode: vertical-rl;
}

.c-scroll__bar {
	overflow: hidden;
	position: relative;
}

.c-scroll__barActive {
	animation: 3s ease-in-out backwards infinite scrollDown;
	background-color: #005492;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: 5.875rem;
	justify-content: center;
	transform: translateY(-100%);
	width: 0.0625rem;
}

.c-title {
	position: relative;
	text-align: center;
	z-index: 3;
}

.c-title__en {
	color: #005492;
	display: inline-block;
	font-family: "Jost", sans-serif;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.3;
	position: relative;
	text-align: center;
	text-transform: uppercase;
	width: -moz-fit-content;
	width: -webkit-fit-content;
	width: fit-content;
}

.c-title__en::before {
	background-color: #cc0126;
	border-radius: 50%;
	content: "";
	height: 0.625rem;
	left: -1.0625rem;
	position: absolute;
	top: 50%;
	translate: 0 -50%;
	width: 0.625rem;
}

.c-title__box {
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	justify-content: center;
}

.c-title__main {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.875rem;
	font-weight: 900;
	letter-spacing: 0.02em;
	line-height: 1.2;
}

.c-title__main span {
	padding-left: 0.625rem;
}

.c-title__text {
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.9;
}

.p-card + .p-card {
	margin-top: 3.75rem;
}

.p-card__contents {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column-reverse;
}

.p-card__content {
	background-color: rgba(0, 84, 146, 0.95);
	flex-shrink: 0;
	padding: 3.4375rem 1.25rem 2.625rem;
	position: relative;
	z-index: 1;
}

.p-card:nth-child(3n-1) .p-card__content {
	background-color: rgba(254, 174, 0, 0.95);
}

.p-card:nth-child(3n) .p-card__content {
	background-color: rgba(204, 1, 38, 0.95);
}

.p-card__content::before {
	color: #fff;
	content: counter(num, decimal-leading-zero);
	counter-increment: num;
	font-family: "Jost", sans-serif;
	font-size: 5rem;
	font-weight: 600;
	letter-spacing: -0.05em;
	line-height: 1;
	opacity: 0.5;
	position: absolute;
	right: -0.4375rem;
	top: -0.625rem;
}

.p-card:nth-child(2) .p-card__content::before {
	right: 0;
}

.p-card:nth-child(3) .p-card__content::before {
	right: 0.1875rem;
}

.p-card__title {
	color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.75rem;
	font-weight: 700;
}

.p-card__title span {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
}

.p-card__text {
	color: #fff;
	font-size: 0.875rem;
	line-height: 2.1875;
	margin-top: 1.25rem;
}

.p-card__btn {
	margin-top: 1rem;
	text-align: center;
}

.p-card__linkBox {
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.p-card__imgBox {
	position: relative;
}

.p-card__img img {
	aspect-ratio: 721/430;
	height: 100%;
	-o-object-fit: cover;
	   object-fit: cover;
	width: 100%;
}

.p-card__shape {
	bottom: -0.3125rem;
	display: none;
	left: calc(50% + 10.375rem);
	position: absolute;
	width: min(16.3194444444vw, 14.6875rem);
	z-index: 1;
}

.p-card__shape.--left {
	bottom: 1rem;
	left: -1.5rem;
}

.p-card__shape.--right {
	bottom: 1.25rem;
	left: calc(50% + 14.875rem);
}

.p-card__shape img {
	-o-object-fit: contain;
	   object-fit: contain;
}

.p-card__leadBox {
	position: absolute;
	right: 1.0625rem;
	top: -1.5625rem;
	transform-origin: center center;
	will-change: filter, opacity;
	z-index: 2;
}

.p-card:nth-child(even) .p-card__leadBox {
	left: 1.0625rem;
	right: auto;
	right: initial;
}

.p-card__lead {
	display: block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	line-height: 1.5384615385;
	writing-mode: vertical-rl;
}

.p-card__lead span {
	background-color: #fff;
	padding-top: 0.625rem;
	padding-bottom: 0.625rem;
}

.p-col-cards {
	counter-reset: num;
}

.u-desktop {
	display: none;
}

.u-page-top {
	bottom: 2.75rem;
	cursor: pointer;
	position: fixed;
	right: 1.25rem;
	z-index: 1000;
}

.u-page-top__box {
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.u-page-top__text {
	color: #fff;
	font-size: 0.875rem;
	font-weight: 500;
	text-align: center;
	text-transform: uppercase;
	mix-blend-mode: difference;
}

.smpBR{
	display: none;
}


/* レイアウト
----------------------------------------------------------- */

header {
	align-items: center;
	background-color: #FFF;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 400;
	justify-content: space-between;
	left: 0;
	margin: 0;
	padding: 0;
	padding-left: 1.875rem;
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	width: 100%;
	z-index: 200;
}

header h1 {
	flex-shrink: 0;
	width: min(100%, 12.125rem);
}

header h1 a {
	display: block;
}

header h1 a img {
	aspect-ratio: 194/49;
	height: 3.0625rem;
	-o-object-fit: contain;
	   object-fit: contain;
	width: auto;
}

header h1 a:hover img {
	transform: translate(0, -3px);
	transition: 0.3s;
}

header ul {
	align-items: start;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: end;
	width: 100%;
}

header ul li {
	display: inline-block;
}

header ul li a {
	color: transparent;
	display: block;
	height: 100%;
	padding: 1.75rem 1.5rem 1.8125rem 1.5625rem;
	-webkit-text-decoration: none;
	text-decoration: none;
	width: 100%; /*color: #031a23;*/
}

header ul li a span {
	position: relative;
	z-index: 10;
}

header ul li a:link {
	color: transparent;
}

header ul li a:hover { /*color: #0060b0;*/
}

header ul li.recruit a {
	background-color: #005296;
	color: #FFF;
	font-weight: bold;
	padding-top: 1.9375rem;
	padding-bottom: 1.9375rem;
	position: relative;
}

header ul li.contact a {
	background-color: #00365d;
	color: #FFF;
	font-weight: bold;
	padding-top: 1.9375rem;
	padding-bottom: 1.9375rem;
	position: relative;
}

header ul li:not(.recruit):not(.contact) a span {
	display: inline-block;
	overflow: hidden;
	text-shadow: 0 -1.5rem 0 #0060b0, 0 0 0 #031a23;
	transition: text-shadow 0.3s;
}

header ul li:not(.recruit):not(.contact) a:hover span {
	text-shadow: 0 0 0 #0060b0, 0 1.5rem 0 #031a23;
}

header ul li.recruit a:before,
header ul li.contact a:before {
	background-color: #feb20d;
	content: "";
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transition: 0.3s;
	width: 0;
}

header ul li.contact a:before {
	background-color: #cf0e31;
}

header ul li.recruit a:hover:before,
header ul li.contact a:hover:before {
	width: 100%;
}

#smpMenu {
	display: none;
}

footer {
	background-color: #0060b0;
	color: #FFF;
	padding-bottom: 3rem;
	padding-top: 3rem;
	position: relative;
}

footer a {
	color: #FFF;
}

footer #flogo {
	padding-bottom: 3rem;
	text-align: center;
}

footer #flogo img {
	display: inline-block;
	height: 4rem;
	width: auto;
}

#footerW {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: space-between;
	margin-left: auto;
	margin-right: auto;
	max-width: 1200px;
	width: 100%;
}

#footerW access h2 {
	font-size: 1rem;
	font-weight: 400;
}

#footerW access p.googlemap {
	color: #FFF;
}

#footerW access p.googlemap a {
	border-bottom: 1px #FFF solid;
	color: #FFF;
}

#footerW access p.googlemap a:hover {
	color: #cdeaff;
}

#footerW access p.googlemap a:after {
	background: url("../img/f_mappin.svg");
	background-repeat: no-repeat;
	background-size: contain;
	content: "　";
	font-size: 0.75rem;
	margin-left: 1rem;
}

#footerW access p.googlemap a:after:hover {
	color: #cdeaff;
}

#footerW ul {
	grid-column-gap: 1rem;
	-moz-column-gap: 1rem;
	     column-gap: 1rem;
	display: grid;
	grid-template-columns: auto auto 6rem;
	width: 39%;
}

#footerW ul li a {
	display: block;
}

#footerW ul a {
	color: transparent; /*color: #FFF;*/
	display: block;
	height: 100%;
	width: 100%;
}

#footerW ul a span {
	position: relative;
	z-index: 10;
}

#footerW ul a:link {
	color: transparent;
}

#footerW ul a span {
	color: transparent;
	display: inline-block;
	overflow: hidden;
	text-shadow: 0 -1.5rem 0 #cdeaff, 0 0 0 #FFF;
	transition: text-shadow 0.3s;
}

#footerW ul a:hover span {
	text-shadow: 0 0 0 #cdeaff, 0 1.5rem 0 #FFF;
}

#footer {
	background-color: #00365d;
	padding-bottom: 1.5rem;
	padding-top: 1.5rem;
}

#footer div {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: space-between;
	margin-left: auto;
	margin-right: auto;
	max-width: 1200px;
	width: 100%;
}

#footer p {
	color: #FFF;
}

#footer p a {
	color: #FFF;
}

#footer p a:hover {
	color: #cdeaff;
}

/*
------------------------------------------------------------*/

@media (prefers-reduced-motion: reduce) {

*,
*::before,
*::after {
	animation-duration: 0.01ms !important;
	animation-iteration-count: 1 !important;
	scroll-behavior: auto !important;
	transition-duration: 0.01ms !important;
}

}

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

html {
	font-size: 1.28vw;
}

a,
button {
	transition: 0.3s;
}

a:hover,
button:hover {
	cursor: pointer;
	opacity: 0.7;
}

a[href*="tel:"] {
	cursor: default;
	pointer-events: none;
	-webkit-text-decoration: none;
	text-decoration: none;
}

.l-inner {
	max-width: 1250px;
	padding-left: 1.5625rem;
	padding-right: 1.5625rem;
}

.l-inner.--sm {
	max-width: 75.625rem;
}

.c-btn {
	border-width: 0.25rem;
	padding: 0.8125rem 2.625rem 0.8125rem 1.625rem;
}

.c-catch {
	font-size: 10.625rem;
	top: -1.125rem;
	width: min(46.6666666667vw, 42rem);
}

.c-scroll__text {
	font-size: 0.875rem;
}

.c-title {
	text-align: left;
}

.c-title.--center {
	text-align: center;
}

.c-title__en {
	font-size: 1.25rem;
}

.c-title__box {
	flex-direction: row;
	justify-content: space-between;
}

.c-title.--center .c-title__box {
	justify-content: center;
}

.c-title__main {
	font-size: 3.75rem;
	line-height: 1.7;
}

.c-title__text {
	font-size: 1.25rem;
}

.p-card + .p-card {
	margin-top: 7.5rem;
}

.p-card__contents {
	flex-direction: row;
}

.p-card:nth-child(even) .p-card__contents {
	flex-direction: row-reverse;
}

.p-card__content {
	margin-top: 3.75rem;
	padding: 4.0625rem 2.875rem 2.625rem 3.6875rem;
	width: 50%;
}

.p-card__content::before {
	font-size: 7.5rem;
	top: -0.875rem;
}

.p-card__title {
	font-size: 2.5rem;
}

.p-card__title span {
	font-size: 1.875rem;
}

.p-card__text {
	font-size: 1rem;
}

.p-card__btn {
	margin-top: 1.5625rem;
	text-align: left;
}

.p-card__linkBox {
	flex-direction: row;
	gap: 1.5625rem;
}

.p-card__imgBox {
	margin-left: -7.5rem;
	width: 60.0833333333%;
}

.p-card:nth-child(even) .p-card__imgBox {
	margin-left: 0;
	margin-right: -7.5rem;
}

.p-card__shape {
	display: block;
}

.p-card__leadBox {
	right: 3.375rem;
	top: -1.125rem;
}

.p-card:nth-child(even) .p-card__leadBox {
	left: 3.25rem;
	top: -2.3125rem;
}

.p-card:nth-child(3) .p-card__leadBox {
	top: -2.1875rem;
}

.p-card__lead {
	font-size: 1.625rem;
}

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

}

@media (min-width: 1250px) {

html {
	font-size: 100%;
}

}

@media screen and (max-width: 1024px) {

header {
	padding-left: 0.625rem;
}

header ul {
	box-shadow: 0 2.5rem 2rem -2rem hsla(200, 50%, 20%, 0.4);
	display: grid;
	grid-template-columns: 1fr;
	margin-left: -0.625rem;
	margin-top: 5.75rem;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	visibility: hidden;
	width: 100%;
	z-index: 100;
}

header ul li a {
	-webkit-backdrop-filter: blur(5px);
	        backdrop-filter: blur(5px);
	background-color: rgba(255, 255, 255, 0.9411764706);
	text-align: center;
	transition: 0.5s;
}

header ul li.recruit a {
	background-color: rgba(0, 82, 150, 0.9411764706);
}

header ul li.contact a {
	background-color: rgba(0, 54, 93, 0.9411764706);
}

#smpMenu {
	background-color: #00365d;
	display: block;
	height: 4.3125rem;
	position: relative;
	transition: 0.5s;
	width: 6rem;
	z-index: 100;
}

#smpMenu span {
	background-color: #FFF;
	display: block;
	height: 1px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, 0);
	width: 2rem;
}

#smpMenu span:before,
#smpMenu span:after {
	background-color: #FFF;
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -0.75rem);
	transition: 0.5s;
	width: 2rem;
}

#smpMenu span:after {
	transform: translate(-50%, 0.75rem);
}

/*---メニュー出現時 start----*/

#smpMenu.open {
	background-color: #feb20d;
	display: block;
	position: relative;
	width: 6rem;
	z-index: 100;
}

#smpMenu.open span {
	background-color: #feb20d;
	display: block;
	height: 1px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, 0);
	width: 2rem;
}

#smpMenu.open span:before,
#smpMenu.open span:after {
	background-color: #FFF;
	content: "";
	left: 50%;
	top: 50%;
	transform: translate(-50%, 0) rotate(45deg);
	transform-origin: center center;
	transition: 0.5s;
}

#smpMenu.open span:after {
	transform: translate(-50%, 0) rotate(-45deg);
}

header ul.open {
	margin-top: 41.875rem;
	opacity: 1;
	pointer-events: auto;
	transition: 0.5s;
	visibility: visible;
}

/*---メニュー出現時 end----*/

footer {
	font-size: 0.75rem;
	padding-top: 5.375rem;
	padding-bottom: 2.25rem;
}

footer #flogo img {
	height: 3rem;
}

#footerW {
	display: grid;
	grid-template-columns: 1fr;
	padding-left: 2rem;
	padding-right: 2rem;
	grid-row-gap: 2rem;
	row-gap: 2rem;
	text-align: center;
}

#footerW ul {
	display: none;
}

#footer div {
	display: grid;
	grid-template-columns: 1fr;
	grid-row-gap: 1.125rem;
	row-gap: 1.125rem;
	text-align: center;
}

#footer {
	font-size: 0.75rem;
}

}






@media screen and (max-width:767px){
	
.smpBR{
	display: inline;
}
	.no-br-mobile {
    font-feature-settings: "palt";
  }
  .no-br-mobile br {
    display: none;
  }
	
	
}
/* スマートフォン 横(ランドスケープ) */
@media only screen and (max-width:640px){
	
	

}

/* スマートフォン 縦(ポートレート) */
@media only screen and (max-width:480px){

}

@media (orientation: landscape) and (max-height: 450px) {
	
}




@media (max-width: 375px) {

html {
	font-size: 4.2666666667vw;
}

}



/*-----------------------------------*/




@keyframes transformLeftRight {

0% {
	transform: translateX(-100%);
}

100% {
	transform: translateX(0);
}

}

@keyframes transformRightLeft {

0% {
	transform: translateX(0);
}

100% {
	transform: translateX(100%);
}

}

@keyframes scrollDown {

0% {
	transform: translateY(-100%);
}

100% {
	transform: translateY(100%);
}

}
@keyframes rotate360 {

0% {
	transform: rotate(0deg);
}

100% {
	transform: rotate(359deg);
}
}
	
@keyframes popIn {

0% {
	transform: scale(0);
	opacity: 0;
}
20% {
	transform: scale(1.3);
	opacity: 0.5;
}

100% {
	transform: scale(1);
	opacity: 1;
}

}
