@charset "utf-8";
/* CSS Document */
html {
  scroll-behavior: smooth;
}
body {
  font-family: "Noto Sans JP", sans-serif;
}
.wrap {
  overflow: hidden;
}
.txt_center {
  text-align: center;
}
table {
  width: 100%;
}
img {
  max-width: 100%;
  height: auto;
  transition: 1.0s;
}
.center-block {
  display: block;
  margin: 0 auto;
}
.container-f {
  padding-left: 0px;
  padding-right: 0px;
  margin-right: auto;
  margin-left: auto;
}
.container {
  padding-right: 20px;
  padding-left: 20px;
  margin-right: auto;
  margin-left: auto;
  max-width: 1100px;
}
.container-w {
  padding-right: 20px;
  padding-left: 20px;
  margin-right: auto;
  margin-left: auto;
  max-width: 1600px;
}
.flex_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.flex_box_jc {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.flex_box_center, .flex_box_reverse_center {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.flex_box_reverse {
  display: flex;
  justify-content: space-between;
}
.item2 {
  width: calc(50% - 20px);
}
.item3 {
  width: calc(33.3% - 30px);
}
.item4 {
  width: calc(25% - 20px);
}
.item5 {
  width: calc(20% - 20px);
}
.item30 {
  width: calc(30% - 20px);
}
.item40 {
  width: calc(40% - 20px);
}
.item60 {
  width: calc(60% - 20px);
}
.item70 {
  width: calc(70% - 20px);
}
.p30 {
  padding-bottom: 30px;
  padding-top: 30px;
}
.gnav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #eee;
  z-index: 999;
}
.gnav_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 26px 20px;
}
.logo a {
  color: #000;
  text-decoration: none;
  font-weight: bold;
}
/* ===== PC menu ===== */
.nav_list {
  display: flex;
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav_list a {
  color: #000;
  text-decoration: none;
}
/* ===== hamburger ===== */
.hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
}
.hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: #000;

}
/* ===== overlay ===== */
.overlay {
  position: fixed;
  inset: 0;
  background: #fff;
  z-index: 1000;
  /* 初期状態 */
  opacity: 0;
  transform: translateY(-20px);
  pointer-events: none;
  transition: opacity 0.35s ease, transform 0.35s ease;
}
.overlay.active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.overlay_nav {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.overlay_nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
}
.overlay_nav li {
  margin: 20px 0;
  font-weight: 500;
  line-height: 2em;
}
.overlay_nav a {
  color: #000;
  font-size: 20px;
  text-decoration: none;
}
.sec_box {
  padding-bottom: 100px;
  padding-top: 100px;
}
p, td, th {
  line-height: 1.7em;
  font-size: clamp(15px, 1.7vw, 18px);
}
.mv {
  margin-top:94px;
  width: 100%;
  aspect-ratio: 16 / 9;
  position: relative;
  overflow: hidden;
}
.mv video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/*.mvlogo{
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	top: 0;
	bottom:0;
	max-width: 800px;
	max-height: 140px;
}*/

.mvlogo{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 800px;
	width: 80%;   
	max-height: 140px;
}


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


.mt50 {
  margin-top: 50px;
}
.eng_tl {
  text-transform: uppercase;
  font-size: clamp(30px, 8vw, 80px);
}
.jp_tl {
  margin-top: 20px;
  margin-bottom: 50px;
  font-size: clamp(18px, 4vw, 40px);
}
.txtbox {
  padding: 0 5%;
}
.move_img {
  position: relative;
  overflow: hidden;
  height: auto;
  opacity: 0;
}
/* 左から右へ表示される */
.move_l_to_r::before {
  position: absolute;
  content: '';
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  background: #fff;
  animation: move_animation_r 0.8s linear 0s 1 forwards normal;
}
/*
.service{
	background: url(../img/servicebg.webp);
}*/
.btn_grad {
  background: linear-gradient(90deg, rgba(33, 84, 145, 1) 0%, rgba(45, 83, 129, 1) 49%, rgba(42, 63, 88, 1) 100%);
  color: #fff;
  border-radius: 50px;
  font-weight: 600;
  text-decoration: none;
  padding: 16px 55px
}
.contact_footer {
  padding-top: 600px;
  background: url(../img/contactbg.webp);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: bottom;
}
/*.service{
	position: relative;
}

.servicetxt{
	text-align: center;
	position: absolute;
	top: 20%;
	margin: auto;
	left: 0;
	right: 0;
	bottom: 0;
	color: #fff;
}*/
.sliderinner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.servicetxt {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #fff;
  text-align: center;
  top: 5%;
}
.service {
  position: relative;
}
.servicebg {
  position: relative;
}
.servicebg, .slider, .slick-list, .slick-track, .sliderinner {
  height: 100%;
}
.company {
  position: relative;
  overflow: hidden;
}
/* 背景ラッパー */
.company_bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
/* アニメーション背景 */
.company .bg {
  animation: slide 6s ease-in-out infinite alternate;
  background-image: linear-gradient(-60deg, #f6fdff 50%, #dde3e5 50%);
  position: absolute;
  top: -20%;
  bottom: -20%;
  left: -100%;
  right: -100%;
  opacity: 0.5;
}
.company .bg2 {
  animation-direction: alternate-reverse;
  animation-duration: 4s;
}
.company .bg3 {
  animation-duration: 5s;
}
/* 中身は背景より上に */
.company .container-f {
  position: relative;
  z-index: 1;
}
.mt30 {
  margin-top: 30px;
}
footer {
  color: #fff;
  background-color: rgb(19, 37, 62);
  padding-top: 60px;
}
footer a {
  color: #fff;
  text-decoration: none;
}
footer p {
  letter-spacing: .08rem;
  line-height: 1.9em;
  font-size: 15px !important;
}
.copy {
  color: #bbb;
  text-align: right;
  font-size: 13px !important;
}
footer ul {
  text-align: right;
}
footer li {
  font-size: 15px !important;
  display: inline-block;
  margin-right: 20px;
}
footer li:last-child {
  margin-right: 0;
}
.contactbtn {
  background: linear-gradient(90deg, rgba(33, 84, 145, 1) 0%, rgba(45, 83, 129, 1) 49%, rgba(42, 63, 88, 1) 100%);
  color: #fff;
  font-size: 14px !important;
  padding: 5px 18px;
  border-radius: 50px;
}
@keyframes slide {
  0% {
    transform: translate3d(-25%, 0, 0);
  }
  100% {
    transform: translate3d(25%, 0, 0);
  }
}
.logo img {
  height: 40px;
  width: 100%;
}
.footer_logo img {
  height: 40px;
  width: auto;
}
.circle-text {
  width: 600px;
  height: 700px;
}
.circle-text svg {
  width: 100%;
  height: 100%;
  animation: rotate 20s linear infinite;
  overflow: visible; /* 念のため */
}
.circle-text text {
  font-size: 150px;
  font-weight: 600;
  letter-spacing: 12px;
  fill: #dde3e5;
}
@keyframes rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.recruit .recimgbox {
  position: relative;
  z-index: 1;
}
.recimgbox .circle-text {
  position: absolute;
  top: -120px; /* 上にずらす */
  right: -350px; /* 右にずらす */
  width: 780px;
  height: 780px;
  z-index: 2;
  pointer-events: none;
  opacity: .8;
}
.recimgbox > *:not(.circle-text) {
  position: relative;
  z-index: 1;
}
.recimgbox .move_img {
  position: relative;
  z-index: 5 !important;
}
.recruit .txtbox {
  position: relative;
  z-index: 5;
}
.recruit .txtbox::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #fff; /* or セクション背景色 */
  z-index: -1;
}
/*.circle-wrap {
  position: relative;
  width: 400px;
  height: 400px;
  margin: 0 auto;
}

.loop {
  position: absolute;
  top: 50%;
  left: 50%;
  transform-origin: 0 0;
  font-size: 120px;
  font-weight: 600;
  color: #dde3e5;
  text-transform: uppercase;

  animation: circle 20s linear infinite;
}

@keyframes circle {
  0% {
    transform: rotate(0deg) translateX(180px);
  }
  100% {
    transform: rotate(360deg) translateX(180px);
  }
}
*/
/*.loop {
  animation: loop 30s linear infinite;
  color: #dde3e5 ;
  font-weight: 600;
  font-size: 200px;
	text-transform: uppercase;
  
}
@keyframes loop {
  0% {
    transform: translateX(100%);
  }
  100% {
    transform: translateX(-100%);
  }
}*/
.footer p {
  font-size: 13px;
}
.footer img {
  max-width: 200px;
  height: auto;
}
.footer h2 {
  font-size: 15px;
  margin-bottom: 10px;
}
.f1 {
  padding-bottom: 20px;
}
.f2 {
  padding-top: 20px;
}
.f1 li {
  font-size: 14px;
  display: inline-block;
  margin-right: 1.5em;
}
.f1 li a {
  text-decoration: none;
  color: #000;
}
.txt_right {
  text-align: right;
}




.gnav {
  position: fixed;
  z-index: 2000;
}

.overlay {
  z-index: 1000;
}

.hamburger {
  position: relative;
  width: 24px;
  height: 20px;
}

.hamburger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: #000;
  transition: 0.3s;
}

.hamburger span:nth-child(1) { top: 0; }
.hamburger span:nth-child(2) { top: 9px; }
.hamburger span:nth-child(3) { bottom: 0; }

.hamburger.active span:nth-child(1) {
  transform: translateY(9px) rotate(45deg);
}
.hamburger.active span:nth-child(2) {
  opacity: 0;
}
.hamburger.active span:nth-child(3) {
  transform: translateY(-9px) rotate(-45deg);
}




/* ===== SP (890px以下) ===== */
@media screen and (max-width: 890px) {
  .nav {
    display: none;
  }
  .hamburger {
    display: block;
  }
  .gnav_inner {
    padding: 15px 20px;
  }
	
	
  .logo img {
    height: 30px;
    width: auto;
  }
  .mv {
    margin-top: 62px;
  }
}
.footer {
  color: #fff;
  background: #2c4059;
  padding: 60px 20px;
}
.footer a {
  color: #fff !important;
}
.f1 img {
  max-width: 270px;
  height: auto;
}
.sectl {
  border-left: 6px solid #28538c;
  padding: 5px 0 5px 20px;
  font-size: clamp(20px, 3vw, 32px);
  letter-spacing: .1rem;
  margin-bottom: 40px;
}
.basictb th {
  border-bottom: solid 1px #ccc;
  white-space: nowrap;
}
.basictb td {
  padding: 20px 0;
  border-bottom: solid 1px #ccc;
}

.rectb th {
  border-bottom: solid 1px #ccc;
  white-space: nowrap;
}
.rectb td {
  padding: 20px 0;
  border-bottom: solid 1px #ccc;
}

.mb100 {
  margin-bottom: 100px;
}
.tbtl {
  border-bottom: 2px solid #28538c !important;

  letter-spacing: .1rem;
  font-size: clamp(16px, 2vw, 22px);
  padding-bottom: 10px;
  padding-left: 10px;
}
.kasou_top {
  position: relative;
  padding: 60px 20px 10px 20px;
  margin-top: 100px;
	margin-bottom: 100px;
}
/* 背景ラッパー */
.kasou_topbg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
/* アニメーション背景 */
.kasou_top .bg {
  animation: slide 6s ease-in-out infinite alternate;
  background-image: linear-gradient(-60deg, #28548d 50%, #2c415b 50%);
  position: absolute;
  top: -20%;
  bottom: -20%;
  left: -100%;
  right: -100%;
  opacity: 0.5;
}
.kasou_top .bg2 {
  animation-direction: alternate-reverse;
  animation-duration: 4s;
}
.kasou_top .bg3 {
  animation-duration: 5s;
}
/* 中身は背景より上に */
.kasou_top .container-w {
  position: relative;
  z-index: 1;
}
.whtxt {
  color: #fff;
}

.req{
	color: #fff;
	margin-left: 20px;
	font-size: 50%;
	  background: #27538d;
	padding:4px 10px;
	border-radius: 5px;
	letter-spacing: .1rem;
}

.entrytb th{
	padding: 15px 10px 15px 10px;
	border: 1px solid #ccc;
	white-space: nowrap;
	width: 30%;
	font-weight: 500;
	    background-color: #F9F9F9;
}
.entrytb td{
	padding: 15px 10px;
	text-align: center;
	border: 1px solid #ccc;
}

.mb30{
	margin-bottom: 30px;
}

.mb40{
	margin-bottom: 40px;
}


.entrytb textarea{
	width: 90%;
	min-height: 100px;
}

.entrytb input{width: 90%;
	height: 32px;
	
}

.subbtn{
	    color: rgb(255, 255, 255);
    font-weight: 600;
    background: linear-gradient(90deg, rgb(33, 84, 145) 0%, rgb(45, 83, 129) 49%, rgb(42, 63, 88) 100%);
    border-radius: 50px;
    text-decoration: none;
	letter-spacing: .2rem;
    padding: 16px 55px;
	border:none; 
	cursor: pointer;
}

.kasou_imgtop{
	margin-top: 60px;
	position: relative;

}


.kasou_imgtop_txt{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 10%;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.kasou_imgtop .jp_tl {
	margin-bottom: 0;
}
.kasou_imgtop img {
    object-fit: cover;
    width: 100%;
    object-position:  center;
	max-height: 400px;
}

.gmap {
height: 0;
overflow: hidden;
padding-bottom: 56.25%;
position: relative;
}

.gmap iframe {
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 100%;
}

.btn_anc{
	display: block;
	width: 100%;
	text-align: center;
	color: #28538c;
	border: #28538c solid 1px;
	font-weight: 500;
	padding: 20px 10px;
	text-decoration: none;
	letter-spacing: 1px;
	position: relative;
	  transition: .6s;
		box-sizing: border-box;
}

.btn_anc:hover{
	background:#28538c;
	color: #fff;
}

.btn_anc::after{
	  content:"\f13a";
  font-family: "Font Awesome 6 Free";
	 font-weight: 900;
	position: absolute;
	right:5%;
	}

.rec_page h2{
	text-align: center;
	line-height:2em;
	    font-size: clamp(15px, 2.2vw, 35px);
}

.rec_page{
	padding-bottom: 150px;
	padding-top: 150px;
}
.recslider .slick-slide{
	margin: 0 25px; 
}

.para_box{
	margin-bottom: 50px;
}

.para_box h3{
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 1px solid #28538c
}


@media (min-width: 771px) {
  .visible-xs {
    display: none;
  }
}
@media (max-width: 770px) {

	.recslider .slick-slide{
		margin: 0 10px; }
	
	.rec_page{
	padding-bottom: 50px;
	padding-top: 50px;
}
	.anc_list .item3{
		margin-bottom: 20px;
	}
	.kasou_imgtop{
		margin-top: 62px;
	}

	
	.kasou_imgtop .jp_tl{
		margin-top: 5px;
	}
	.entrytb{
		max-width: 94%;
	}
	.entrytb th{
		width: 100%;
		display: block;
	
	}
	
	.entrytb td{
		width: 100%;
		display: block;
		border-bottom: none;
		border-top:none; 
	}
	
	.rectb{
		max-width: 94%;
	}
	.rectb th{
		width: 100%;
		display: block;
	background-color: #F9F9F9;
		border: 1px solid #ccc;
		padding: 10px;
	}
	
	.rectb td{border: 1px solid #ccc;
		width: 100%;
		display: block;
		border-bottom: none;
		border-top:none; 
		padding: 10px;
	}
	
	.lasttr td{
		border-bottom: 1px solid #ccc;
	}
	
	.mt20sp{
		margin-top: 20px;
	}
	
	.mb20sp{
		margin-bottom: 20px;
	}
	
	.f1 img {
		margin-bottom: 20px;
	}
  .basictb th {
    padding-right: 20px;
  }
  .hidden-xs {
    display: none;
  }
  .item4, .item3, .item2, .item30, .item40, .item60, .item70 {
    width: 100%;
  }
  footer ul {
    text-align: left !important;
    margin-top: 20px;
  }
  footer li {
    padding-bottom: 5px;
  }
  .sec_box {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .company .item2 {
    padding-bottom: 40px;
  }
  .service {
    height: 60vh;
  }
  .slider {
    height: 100%;
  }
  .sliderinner {
    height: 100%;
  }
  .servicetxt {
    top: 50%;
    transform: translateY(-50%);
    padding: 0 10px;
  }
}
@keyframes move_animation_r {
  100% {
    transform: translateX(100%);
  }
}
/*
.wavebg {
    margin: auto;
    font-family: -apple-system, BlinkMacSystemFont, sans-serif;
    overflow: auto;
    background: linear-gradient(315deg, rgba(101,0,94,1) 3%, rgba(60,132,206,1) 38%, rgba(48,238,226,1) 68%, rgba(255,25,25,1) 98%);
    animation: gradient 15s ease infinite;
    background-size: 400% 400%;
    background-attachment: fixed;
	height: 100vh;
}

@keyframes gradient {
    0% {
        background-position: 0% 0%;
    }
    50% {
        background-position: 100% 100%;
    }
    100% {
        background-position: 0% 0%;
    }
}

.wave {
    background: rgb(255 255 255 / 25%);
    border-radius: 1000% 1000% 0 0;
    position: fixed;
    width: 200%;
    height: 12em;
    animation: wave 10s -3s linear infinite;
    transform: translate3d(0, 0, 0);
    opacity: 0.8;
    bottom: 0;
    left: 0;
    z-index: -1;
}

.wave:nth-of-type(2) {
    bottom: -1.25em;
    animation: wave 18s linear reverse infinite;
    opacity: 0.8;
}

.wave:nth-of-type(3) {
    bottom: -2.5em;
    animation: wave 20s -1s reverse infinite;
    opacity: 0.9;
}

@keyframes wave {
    2% {
        transform: translateX(1);
    }

    25% {
        transform: translateX(-25%);
    }

    50% {
        transform: translateX(-50%);
    }

    75% {
        transform: translateX(-25%);
    }

    100% {
        transform: translateX(1);
    }
}*/