@charset "utf-8";
/* CSS Document */

html{
	width:100%;
	font-size:10px;
	font-family:"游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", Meiryo, sans-serif;
}

body{
	width:100%;
}

p,table{
	font-size:1.6rem;
	line-height: 1.75;
}

a{
	text-decoration: none;
	transition:0.5s;
    }
a:hover{
	opacity: 0.8;
}



/* 共通-フォント */
.txt-en{
	font-family: 'Raleway', sans-serif;
}

.txt-num{
	font-family: 'Oswald', sans-serif;
}

.txt-bg-white{
	background:#fff;
	padding:10px;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}
.txt-bg-gold{
	background:#B8A74D;
	color:#fff;
	padding:10px;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}
.txt-bg-navy{
	background:#001036;
	color:#fff;
	padding:10px;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}

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

.txt-navy{
	color:#001036 !important;
}
.txt-box{
	word-break: break-all;
}

h1{
	font-size:1.6rem;
	line-height: 1.75;
}

h2{
	font-size: 6.0rem;
}

h2.headline{
	position: relative;
	padding-bottom: 50px;
}
h2.headline::before {
	content: attr(data-en);
	display: block;
	font-family: 'Raleway', sans-serif;
	font-size: 12.0rem;
	text-transform: uppercase;
	opacity: 0.1;
	margin-bottom:-20px;
}

h3{
	font-size:3.0rem;
}

h4{
	font-size:2.0rem;
}

@media screen and (max-width: 590px) {
	h2{
	font-size: 3.6rem;
	}
	h2.headline{
	padding-bottom: 40px;
	}

	h2.headline::before {
	display: none;
	}
	h2.headline::after {
	content: attr(data-en);
	display: block;
	font-family: 'Raleway', sans-serif;
	font-size: 1.2rem;
	text-transform: uppercase;
	opacity: 0.5;
	margin-bottom:-20px;
	}
	h3{
	font-size:2.4rem;
}
}

/* 共通-背景 */

.bg-white{
	background:#fff;
}

.bg-beige{
	background:#F6F4EE;
}

.bg-navy{
	background:#001346;
}

.bg-gold{
	background:#B8A74D;
}

.bg-gold-slant,
.bg-beige-slant{
	width: 100%;
    margin: 0;
    padding: 100px 0;
    position: relative;
}

.bg-gold-slant2{
	width: 100%;
    margin: -100px 0 0 0;
    padding: 150px 0 50px;
    position: relative;
	top: 0;
    overflow: hidden;
}
.bg-gold-slant::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background:#B8A74D;
    transform: skewY(-6deg);
    z-index: -1;
}

.bg-gold-slant2::before {
   content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: #B8A74D;
    transform: skewY(-6deg) translateY(100px);
    z-index: -1;
}

.bg-beige-slant::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background:#F6F4EE;
    transform: skewY(-6deg);
    z-index: -1;
}

.shadow{
	box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.2);
}
@media screen and (max-width: 590px) {
	.bg-gold-slant,
	.bg-beige-slant{
		padding: 30px 0;
	}
	.bg-gold-slant2{
		padding: 100px 0 30px;
	}
}

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

.sp-only{
	display: none;
}
.center{
	text-align:center;
}
.block{
	display: block;
}
.content-pad{
	padding:100px 0;
}
.content-pad-min{
	padding:50px 0;
}
.content-inner{
	width:1220px;
	margin:auto;
}
.flex-box{
	display:flex;
	flex-wrap: wrap;
	align-items: flex-start;
}
.reverse{
-webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}
.mt20{
margin-top:20px;
}
.mt50{
margin-top:50px;
}
.mb30{
margin-bottom:30px;
}
.mb50{
margin-bottom:50px;
}

table th,
table td{
	padding:20px;
}
table th{
	width:30%;
}

table tr:first-child{
	border-top: 1px solid #333;
}
table tr{
	border-bottom: 1px solid #333;
}

.w610{
		width:610px;
	}

@media screen and (max-width: 1220px) {
	.content-inner{
	width:90%;
	}
	.w610{
		width:100%;
	}
}

@media screen and (max-width: 590px) {
	.mt20{
	margin-top:15px;
	}
	.mt50{
	margin-top:30px;
	}
	.mb30{
	margin-bottom:20px;
	}
	.mb50{
	margin-bottom:30px;
	}
	.content-pad{
	padding:50px 0;
	}
	#recruit-entry .content-pad,
	#contact .content-pad{
	padding: 5px 0 50px 0;
	}
	.sp-only{
	display: block!important;
}
	.pc-only{
	display: none!important;
}
	table th,
	table td{
	padding:15px;
}
}
/************************************************************************/
/* ヘッダー */
header {
	width: 100%;
	position: absolute;
	top: 0;
	z-index: 100;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1.4em;
}

.logo {
	width: 50%;
	text-align: center;
}

.logo img {
	display: inline;
	width: 260px;
	height: auto;
}

nav {
	display: flex;
	align-items: center;
	width: 50%;
}

.menu__box {
	width: 100%;
	display: flex;
	justify-content: center;
	list-style-type: none;
}

.menu__box > li:first-child {
	display: none;
}

.menu__item {
	display: flex;
	flex-direction: column;
	padding: 0 1em 0 1.9em;
	color: #ffffff;
	font-size: 2rem;
	font-weight: bold;
	text-decoration: none;
	text-transform: uppercase;
}
#contact .menu__item {
	color: #000000;
}



#menu__toggle {
	opacity: 0;
	position: fixed;
}

#menu__toggle:checked ~ .menu__btn::before {
	display: none;
}

#menu__toggle:checked ~ .menu__btn > span {
	transform: rotate(45deg);
	background: #fff;
}

#menu__toggle:checked ~ .menu__btn > span::before {
	top: 0;
	transform: rotate(0);
	background: #fff;
}

#menu__toggle:checked ~ .menu__btn > span::after {
	top: 0;
	transform: rotate(90deg);
	background: #fff;
}

#menu__toggle:checked ~ .menu__box {
	visibility: visible;
	left: 0;
	margin: 0;
	height: 100vh;
}

.menu__btn {
	transition-duration: 0.25s;
	box-sizing: border-box;
	display: none;
	align-items: center;
	position: relative;
	width: 24px;
	height: 24px;
	cursor: pointer;
	z-index: 2;
}

.menu__btn::before {
	content: "";
	display: block;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: 2px solid white;
	position: absolute;
	top: -12px;
	left: -12px;
	box-sizing: border-box;
	background-color: #fff;
  }

.menu__btn span {
	display: inline-block;
	position: absolute;
	width: 100%;
	height: 3px;
	background-color: #000;
}

.menu__btn span::before {
	display: inline-block;
	position: absolute;
	width: 100%;
	height: 3px;
	background-color: #000;
	content: '';
	top: -8px;
	transition-duration: 0.25s;
}

.menu__btn span::after {
	display: inline-block;
	position: absolute;
	width: 100%;
	height: 3px;
	background-color: #000;
	content: '';
	top: 8px;
	transition-duration: 0.25s;
}

@media screen and (max-width: 590px) {
	.logo {
		width: 50%;
	}

	nav {
		display: inline;
  	}

	.menu__box {
		display: block;
		position: fixed;
		visibility: hidden;
		top: 0;
		left: 0;
		width: 100%;
		height: 15em;
		margin: -600px 0 0 0;
		padding: 0.6em 0;
		text-align: left;
		background-color: #000;
		box-shadow: 1px 0 6px rgba(0, 0, 0, .2);
		z-index: 1;
		transition-duration: 0.5s;
	}

	.menu__box > li:first-child {
		display: block;
	}

	.menu__item {
		display: block;
		padding: 12px 24px;
		color: #ffffff;
		font-size: 18px;
		transition-duration: 0.5s;
	}
	#contact .menu__item {
	color: #ffffff;
}


	.menu__item:hover {
		background-color: #4f5464;
	}

	.menu__btn {
		display: flex;
		position: fixed;
		top: 3%;
		right: 5%
	}
}

/* フッター */
footer {
	width: 100%;
	padding: 5rem;
}

footer > * {
	padding: 0 0 2rem 0;
}

#footer-content {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.footer-left {
	width: 50%;
	display: flex;
	justify-content: start;
	flex-direction: column;
}

.footer-left > * {
	margin: 1rem 0;
}

.footer-left > h3 {
	font-size: 16px;
}

.footer-right {
	width: 50%;
	display: flex;
	justify-content: end;
}

.footer-right > ul > li {
	margin: 1rem 0;
}

.footer-right > ul > li > a {
	text-decoration: none;
	font-size: 2rem;
	font-weight: bold;
	color: #000;
}

footer > hr {
	color: #DDDDDD;
	opacity: 1;
}

footer > p {
	text-align: right;
}

.footer-logo {
	width: 100%;
}

.footer-logo img {
	display: inline;
	width: 260px;
	height: 50px;
}


@media screen and (max-width: 590px) {
	footer {
		padding: 2em 0;
	}

	footer > p {
		text-align: center;
	}

	.footer-left, .footer-right {
		width: 100%;
		justify-content: center;
	}
	.footer-left *, .footer-right * {
		margin: 0.5rem 0;
		text-align: center;
	}
}

/* main メインビジュアル */
#main{
	background:#001036;
	width:100%;
	height: 100vh;
    position: relative;
	-webkit-box-align: center;
    -ms-flex-align: center;
    -moz-align-items: center;
    align-items: center;
}
#main .txt-bg-white{
	background:rgba(255,255,255,0.9);
}

.swiper-main {
    position: relative;
	width: 100%;
}

.swiper-main .swiper-slide {
	width: 100%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    height: 100vh;
    overflow: hidden;
    backface-visibility: hidden;
	opacity: 0.8;
}

.main_txt{
	position: absolute;
	z-index: 99;
    top: 55%;
    left: 25%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    text-align: left;
	letter-spacing: 0.55rem;
}
.main_txt-ja{
	font-size:9.4rem;
	color:#001036;
	font-weight: bold;
}
.main_txt-en{
	font-size: 3.0rem;
	font-weight: normal;
	letter-spacing: 0.28rem;
}
.reveal-text,
.reveal-text::after {
  animation-delay: var(--animation-delay, 2s);
  animation-iteration-count: var(--iterations, 1);
  animation-duration: var(--duration, 800ms);
  animation-fill-mode: both;
  animation-timing-function: cubic-bezier(0.0, 0.0, 0.2, 1);
}

.reveal-text {
  --animation-delay: var(--delay, 0);
  --animation-duration: var(--duration, 800ms);
  --animation-iterations: var(--iterations, 1);
  position: relative;
  animation-name: clip-text;
  white-space: nowrap;
  cursor: default;

  &::after {
    content: "";
    position: absolute;
    z-index: 999;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #fff;
	  opacity: 0;
    transform: scaleX(0);
    transform-origin: 0 50%;
    pointer-events: none;
    animation-name: text-revealer;
  }

}


@keyframes clip-text {
  from {
    clip-path: inset(0 100% 0 0);
  }
  to {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes text-revealer {
  0%, 50% {
    transform-origin: 0 50%;
  }
  60%, 100% {
    transform-origin: 100% 50%;
  }
  60% {
    transform: scaleX(1);
  }
  100% {
    transform: scaleX(0);
  }
}

@media screen and (max-width: 1220px) {
	.main_txt{
		top: 55%;
    	left: 10%;
	}

	.main_txt-ja{
	font-size:8.0rem;
	letter-spacing: 0.2rem;
}
	.main_txt-en{
	font-size: 2.4rem;
	letter-spacing: 0.1rem;
}
}



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

		.main_txt{
		top: 55%;
    	left: 5%;
	}
	.main_txt-ja{
	font-size:4.5rem;
	letter-spacing: 0.2rem;
}
	.main_txt-en{
	font-size: 1.4rem;
	letter-spacing: 0.1rem;
}
}

/* aboutus 私たちの事業について*/
#aboutus .txt-box{
	width:550px;
}
#aboutus .flex-box{
	justify-content: space-between;
}

#aboutus .flex-box:last-child{
	margin-top:50px;
}

#aboutus h3{
	font-size:4.0rem;
	margin-bottom:20px;
}




@media screen and (max-width: 1220px) {
	#aboutus .txt-box{
		width:100%;
		margin-top:20px;
}
	#aboutus h3{
		font-size: 2.4rem;
	}
}

/* our-strength 私たちの強み */


#our-strength .txt-box{
	margin-top:20px;
	color:#fff;
}

#our-strength h3{
	color:#B8A74D;
	margin-bottom: 10px;
}

#our-strength h3::before{
	content: attr(data-en);
	display: inline-block;
	font-family: 'Oswald', sans-serif;
	font-size: 2.0rem;
	padding:5px 11px;
	color:#001346;
	background:#B8A74D;
	border-radius: 2.0rem;
	line-height: 2.0rem;
	margin-right: 10px;
	font-weight:normal;
}

#our-strength .swiper-container{
	width: calc(600px + 50vw);
    margin: 50px 0 0;
}

#our-strength .swiper-slide {
    width: 380px;
}

.swiper-slide img {
    border-radius: 20px;
}

.slide_controls {
    margin: 70px 0 0;
    position: relative;
    text-align: right;
}

.slide_controls .slide-bar {
    background: #fff;
    width: calc(100% - 250px);
    height: 1px;
    position: absolute;
    left: 0;
    top: 50%;
}

.slide_controls button {
  width: 60px;
  height: 60px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  vertical-align: top;
  border: 1px #fff solid;
  border-radius: 50%;
  -webkit-transition: background 0.4s ease;
  transition: background 0.4s ease;
	background: #001346;
}


.slide_controls .button-prev {
  margin-right: 12px;
	transform: scale(-1, 1);
}

.slide_controls i {
  color:#fff;
	font-size: 1.6rem;
}

@media screen and (max-width: 1220px) {
	#our-strength .swiper-container{
	    width: calc(100% + 5%);
}
.slide_controls .slide-bar {
    width: calc(100% - 150px);
}
}

@media screen and (max-width: 590px) {
	#our-strength .swiper-slide{
		width:300px;
}
	#our-strength .swiper-container{
    margin: 20px 0 0;
}
	.slide_controls {
		margin-top:30px;
	}
	#our-strength h3{
		 font-size: 2.2rem;
	}

}


.slide_controls .slide-bar .swiper-pagination-progressbar-fill {
  background: #FFF;
  height: 3px;
}

/* review お客様の声 */

#review .flex-box{
	justify-content: space-around;
}

#review h3::after{
	content: attr(data-en);
	display: block;
	justify-content: space-around;
	font-size:2.4rem;
}


#review .txt-box{
	width:440px;
}

#review img{
	margin:20px 0;
}

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

	#review .txt-box:last-child{
	margin-top:20px;
}
}

/* staff-message スタッフ挨拶 */

#staff-message .flex-box{
	justify-content: space-between
}

#staff-message h3{
	font-size:3.6rem;
	line-height:8.0rem;
	margin-bottom:20px;
}


#staff-message .txt-box{
	color:#fff;
}

#staff-message img{
	width:590px;
	margin: auto;
}

#staff-message .swiper-staff{
	width: 100%;
    margin: 50px 0 0;
	overflow: hidden;

}

#staff-message .swiper-slide {
    width: 430px;
}


#staff-message .swiper-wrapper {
  transition-timing-function: linear;
	max-width: 1290px;
  /*アクティブなスライド以外も見えるように*/
  overflow: visible !important;
}

@media screen and (max-width: 590px) {
	#staff-message h3{
		font-size:2.4rem;
		line-height: 4.8rem;
	}
	#staff-message img{
	width:100%;
}

	#staff-message .swiper-staff{
		margin-top:20px;
	}
	#staff-message .txt-bg-white {
    padding: 5px;
}
	#staff-message .swiper-slide {
    width: 200px
}

	#staff-message .swiper-slide img {
    width: 200px;
}
}

/* company 会社概要 */
#company .flex-box{
	justify-content: space-between;
}
#company table{
	width:590px;
}

#company h3{
	font-size:3.6rem;
}
#company p{
	line-height:2.18;
}
.company-message{
	margin-top:70px;
	background:#fff;
	padding:60px;
}
.history{
	margin-top:30px;
	background:#001346;
	color:#fff;
	padding:30px 50px;
}

#company iframe{
	margin: auto;
	}

@media screen and (max-width: 1220px) {
	#company h3{
		margin-top:20px;
		font-size: 2.4rem;
	}
	#company iframe{
		width:100%;
		height:370px;
	}

	.company-message img{
		margin:auto;
	}
	.company-message{
		padding:25px;
		margin-top:50px;
	}
	.history {
		margin-top:20px;
		padding:25px;
	}
	#company table{
	width:100%;
	margin-top: 20px;
}
}

/* contact お問い合わせ */
#contact .w610{
	padding:50px;
	text-align: center;
}
#contact .w610:first-child{
	border-right: #ddd 1px solid;
}
#contact h3{
	font-size: 2.0rem;
	margin-bottom:3.0rem;
	color:#001346;
}
#contact h3 > i{
	margin-right: 10px;
}

.contact-mail a{
	display: block;
	border-radius: 10px;
	background:#B8A74D;
	width:370px;
	margin: auto;
	padding:10px;
	color:#fff;
	font-size: 2.0rem;
	position:relative;
}

.contact-mail a::after{
	font-family: "Font Awesome 6 Free";
  	font-weight: 900;
 	 content: '\f061';
	position:absolute;
	top:30%;
	right:20px;
}
.contact-mail a span{
font-size: 1.6rem;
	display: block;
}

.contact-tel a{
	display: block;
	color:#B8A74D;
	font-size: 5.0rem;
	line-height: 100%;
	margin:-10px 0 20px 0;
}

@media screen and (max-width: 590px) {
	#contact .w610:first-child{
	border-right: 0;
	border-bottom: #ddd 1px solid;
}
	#contact .w610{
	padding:20px 10px;
}
	.contact-mail a{
		width:90%;
	}
}

/* recruit 採用トップ */

#recruit-top .flex-box{
	justify-content: space-between;
}
#recruit-top h2,
#recruit-page h2{
	font-size:5.0rem;
}

#recruit-header{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 65px;
	background-color: rgba(255,255,255,1.0);
	padding:5px 0;
	z-index: 99999;
}

#contact #recruit-header .flex-box{
	justify-content: space-between;
}

#entry-button{
	background: linear-gradient(-180deg, #fd9e00, #fb6e00);
	width:400px;
	color:#fff;
	padding:10px;
	border-radius: 5px;
	justify-content: center;
	position: relative;
	}

#entry-button::after {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    content: '\f061';
    position: absolute;
    top: 25%;
    right: 20px;
	 font-size:1.6rem;
	 border:1px solid #fff;
	 padding:0 5px;
	 border-radius: 15px;
}
#entry-button div{
	justify-content: center;
	width:50%;
	margin:auto;
}
#entry-button p{
	font-weight: bold;
	font-size: 3.0rem;
	line-height: 1.0;
}

#entry-button span{
	font-weight: normal;
	font-size: 1.6rem;
	line-height: 1.0;
	display: block;
}

#recruit-header .logo{
	width:260px;
	margin-top:5px;
}

#recruit-main{
	margin-top:85px;
}

#works li a:hover{
	opacity:1.0;
}

#recruit-top a:hover h3{
	background:#001036;
}

#works li,
#recruit-top img {
	margin:auto;
}

#works li::before {
	content: attr(data-en);
	display: block;
	font-family: 'Oswald', sans-serif;
	font-size: 4.8rem;
	text-transform: uppercase;
	opacity: 0.99;
	margin-bottom:-30px;
	color:#001036;
}

#works li h3 {
	width:90%;
	margin:-30px 0 0 10%;
	background:#CFBE67;
	text-align: center;
	padding:10px 0;
	opacity: 0.99;
	color:#fff;
	position: relative;
	font-size:2.4rem;
	transition:0.5s;
}

 #works li h3::after {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    content: '\f061';
    position: absolute;
    top: 15%;
    right: 10px;
	 font-size:1.6rem;
	 border:1px solid #fff;
	 padding:0 8px;
	 border-radius: 26px;
}

#recruit-main{
	width:100%;
	background:url(../images/recruit-main.webp) no-repeat top center;
	background-size:auto 100% ;
	height:100vh;
}
#recruit-main .main_txt{
	top: 65%;
    left: 35%;
}

#recruit-entry a {
    display: block;
    border-radius: 10px;
    width: 580px;
    margin: auto;
    padding: 10px;
    color: #fd9f00;
    font-size: 4.8rem;
	background: linear-gradient(#FFFFFF, #F6F4EE);
	text-align: center;
	font-weight:bold;
	position: relative;
}

#recruit-entry a i {
    margin-right:20px;
}


#recruit-entry span {
   color:#333;
	font-size: 1.6rem;
	display:block;
	font-weight: normal;
}

.entry-web::before {
    font-family: "Font Awesome 6 Free";
    font-weight: normal;
    content: '\f0e0';
    position: absolute;
    top: 20%;
    left: 22%;
	font-size: 5.2rem;
}

.entry-tel::before {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    content: '\f095';
    position: absolute;
    top: 20%;
    left: 22%;
	font-size: 5.2rem;
}




@media screen and (max-width: 1220px) {
	#recruit-main{
	background-size:100% auto;
}
	#recruit-entry a:last-child {
    margin-top:20px;
}
	#recruit-vision img{
		margin-top:20px;
	}
	#entry-button {
   width:300px;
}
	#entry-button div {
    width: 65%;
}

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

	#recruit-main{
	height:60vh;
}
	#recruit-main .main_txt{
	top: 45%;
    left: 10%;
}
	#recruit-entry a {
		font-size:2.6rem;
	}

}

@media screen and (max-width: 590px) {
	#recruit-top h2,
	#recruit-page h2{
		font-size:3.3rem;
	}

	#recruit-main{
	height:55vh;
}

	#recruit-header	h1{
   	 width:50%;
}
	#recruit-header	.logo {
   	 width:100%;
	margin-top:10px;
}


	#entry-button::after {
    display: none;
}
	#entry-button div {
    width: 100%;
	text-align: center;
	display: block;
}
	#entry-button p {
    font-size:2.0rem;
	margin-bottom:5px;
}
	#entry-button {
   width:43%;
		padding: 7px;
}
}

/* recruit-page 採用下層ページ */
#recruit-page .flex-box{
	justify-content: space-between;
}

#pankuzu{
	display: block;
	width:100%;
	background:#F6F4EE;
	padding: 10px;
	font-size: 1.6rem;
	border-bottom: solid #ddd 1px;
}

#pankuzu ul{
	width:1220px;
	margin:auto;
}

#pankuzu .flex-box{
	justify-content: flex-start;
}

#pankuzu li{
	margin-right: 5px;
}

#pankuzu a{
	color:#000;
}

#pankuzu li:after{
	content: '>';
	margin-left: 5px;
}

#pankuzu li:last-child:after{
	content : none ;
}


#recruit-ttl{
	margin-top:65px;
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: -2;
	padding: 20px 0;
}
#recruit-ttl::after {
  content: '';
  background-color: rgba(0,0,0,.5);
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
	z-index: -1;
}

#recruit-ttl h2{
	font-size:6.0rem;
	color:#fff;
	width:1220px;
	margin:20px auto 0;
	z-index: 5;
}

#recruit-ttl h2:after{
	content: attr(data-en);
	font-family: 'Raleway', sans-serif;
	font-size:2.0rem;
	font-weight: normal;
	margin-left:10px;
	margin-top: -20px;
}

.interview-main {
    width: 100%;
    height: 644px;
    background-position: center center;
    background-size: cover;
	position: relative;
	margin-bottom: 100px;
}

.interview-profile {
    position: absolute;
    width: 340px;
    background-color: #fff;
    border-radius: 5px;
    margin: 0 0 0 50px;
	left:10px;
	bottom:-54px;
}

.interview-profile__txt{
	width:100%;
	padding:10px 15px;
}


.interview-profile li{
	font-size: 1.6rem;
    line-height: 1.5;
	color:#fff;
}

.interview-profile p{
    font-size: 1.6rem;
    line-height: 1.5;
}
.interview-profile__name{
	font-size: 3.0rem !important;
    font-weight: bold;
    line-height: .76;
    margin: 5px 0;
}
.interview-profile__history{
	background: #001036;
	width:340px;
	padding:15px;
	border-radius: 0 0 5px 5px;
}


.stepbar {
  margin: 0 auto;
  width: 100%;
}

.stepbar .stepbarwrap {
  margin: 2em 0;
  position: relative;
}

.stepbar .stepbarwrap .steptitle {
  display: inline-flex;
  align-items: center;
}

.stepbar .stepbarwrap .steptitle .stepcircle {
  display: inline-block;
  width: 30px;
  height: 30px;
  content: "";
  border-radius: 50%;
  background-color: #CFBE67;
	z-index: 3;
}

.stepbar .stepbarwrap .steptitle .stepnum {
  padding-left: 1em;
  font-size: 1.6rem;
  color: #333;
}

.stepbar .stepbarwrap .steptxt {
  padding-left: 45px;
}

.stepbar .stepbarwrap .steptxt .title {
  margin: 0.5em 0;
  font-weight: bold;
}



.stepbar .stepbarwrap .stepline {
  width: 1px;
  height: calc(100% + 1em);
  background-color: #000;
  position: absolute;
  top: 1em;
  left: 15px;
}

.stepbarwrap:last-of-type .stepline:last-of-type {
  display: none;
}

.recruit-list{
	position: relative;
}
.recruit-list h3{
position: absolute;
  top: 50%;
  transform: translate(0, -50%);
	width:50%;
}

.recruit-list ul{
	padding-left:50%;
}

.recruit-list li{
	display: flex;
}
.recruit-list li::before{
	content: '●';
	display: block;
	font-size: 1.6rem;
	text-transform: uppercase;
	margin-right: 10px;
	line-height: 1.75;
}

.good li::before{
	color:#CFBE67;
}

.recruit-list2 h3{
	font-weight: normal;
	line-height: 1.8;
	width:80%;
}

.recruit-list2 li{
	display: flex;
	margin-bottom: 15px;
	border-bottom:1px solid #ddd;
	align-items: center;
    justify-content: center;
}

.recruit-list2 li::before{
	content: attr(data-en);
	display: block;
	font-family: 'Oswald', sans-serif;
	font-size: 3.6rem;
	text-transform: uppercase;
	width:60px !important;
	height: 60px;
	text-align: center;
	background:#CFBE67;
	color:#fff;
	margin-right: 10px;
}

.recruit-box{
	display: block;
	width:48%;
	border:1px solid #000;
	border-radius: 20px;
	padding:30px;
}

.recruit-box h3{
	width:50%;
	text-align: center;
	background: #fff;
	margin:auto;
	margin-top:-45px;
	margin-bottom: 30px;
}


@media screen and (max-width: 1220px) {
#pankuzu ul,
#recruit-ttl h2{
	width:90%;
	margin:0 auto;
}
	#description img{
	margin-top:20px;
}
	.interview-main {
    width: 100%;
    background-position: right center !important;

}

}

@media screen and (max-width: 590px) {
	#recruit-ttl h2{
	text-align: center;
		width:100%;
	margin:0;
		font-size:4.0rem ;
}
	.interview-main {
    width: 100%;
    height: 300px;
    background-position: right center !important;
    background-size: auto 300px !important;
		margin-bottom: 150px;
}



	.interview-profile {
		width: 90%;
		margin: auto;
		left:5%;
		bottom:-100px;
	}
	.interview-profile__history{
			width: 100%;
		}

	#staff-interview img{
		margin-top:20px;
	}


#recruit-ttl h2:after{
	display: block;
	margin:0;
}
  .stepbar,
.recruit-list ul  {
    width: 90%;
	margin:auto;
  }
	.recruit-list h3{
	position: relative;
	width: 100%;
}
	.recruit-list2 li::before{
		font-size:2.4rem;
		width: 40px !important;
    	height: 40px;
	}
	.recruit-list2 h3 {
		font-size:2.0rem;
		line-height: 1.5;
	}

.recruit-list ul  {
	padding-left:0;
  }
.recruit-list p  {
   text-align:justify;
  }
.recruit-box{
	width:100%;
	}
.recruit-box:first-child{
	margin-bottom: 30px;
	}
	#recruit-page table th,
	#recruit-page table td{
	padding:15px;
	display: block;
	width: 100%;
}
}

/*  contact（フォーム関連）
--------------------------------------------- */
.Form {
 width: 100%;
}

.Form-Item {
  padding-top: 24px;
  padding-bottom: 24px;
  width: 100%;
  display: flex;
  align-items: center;
}
.Form-Item-Label {
  width: 30%;
  letter-spacing: 0.05em;
  font-weight: bold;
  font-size: 18px;
}
.Form-Item-Label.isMsg {
  margin-top: 8px;
}
.Form-Item-Label-Required {
  border-radius: 6px;
  margin-left: 8px;
  padding: 2px 0;
  width: 48px;
  display: inline-block !important;
  text-align: center;
  background: #CFBE67;
  color: #fff !important;
  font-size: 14px !important;
}

.Form-Item-Input {
  border: 1px solid #ddd;
  border-radius: 6px;
  margin-left: 40px;
  padding-left: 1em;
  padding-right: 1em;
  height: 48px;
  flex: 1;
  width: 100%;
  background: #fff;
  font-size: 18px;
}
.Form-Item-Textarea {
  border: 1px solid #ddd;
  border-radius: 6px;
  margin-left: 40px;
  padding: 0 1em;
  height: 216px;
  flex: 1;
  width: 100%;
  background: #fff;
  font-size: 18px;
}
.Form-Btn {
  border-radius: 6px;
  margin: 32px auto 0 auto;
  padding: 20px 0;
  width: 50%;
  display: block;
  letter-spacing: 0.05em;
  background: #001036;
  color: #fff;
  font-weight: bold;
  font-size: 2.0rem;
}
.Form_Err{
	color:#ff0000;font-weight: bold;font-size: 18px;display: block;
	margin-left: 50px;
}
.wrap_input{
  width: 70%;
}

.box_check{
	font-size:1.6rem;
}

.box_check input{
	margin-right: 10px;
}

@media screen and (max-width: 590px) {
 	 .Form {
    margin-top: 20px;
  }
	  .Form-Item {
    padding-left: 14px;
    padding-right: 14px;
    padding-top: 16px;
    padding-bottom: 16px;
    flex-wrap: wrap;
  }
	  .Form-Item-Label {
	 width: 100%;
    max-width: inherit;
    display: flex;
    align-items: center;
    font-size: 15px;
  }
	  .Form-Item-Label.isMsg {
    margin-top: 0;
  }
	.Form-Item-Label-Required {
    border-radius: 4px;
    padding-top: 4px;
    padding-bottom: 4px;
    width: 32px;
    font-size: 10px;
  }
	  .Form-Item-Input {
    margin-left: 0;
    margin-top: 18px;
    height: 40px;
    flex: inherit;
    font-size: 15px;
  }
	  .Form-Item-Textarea {
    margin-top: 18px;
    margin-left: 0;
    height: 200px;
    flex: inherit;
    font-size: 15px;
  }
	  .Form-Btn {
    margin-top: 24px;
    padding-top: 8px;
    padding-bottom: 8px;
    width: 160px;
    font-size: 1.6rem;
  }
  .Form_Err{
  	color:#ff0000;font-weight: bold;font-size: 15px;display: block;
  	margin-bottom: -15px;
      margin-top: 10px;
  	margin-left: 5px;
  }
  .wrap_input{
	width: 100%;
}
}

@media screen and (max-width: 590px) {
    table th, table td {
        padding: 5px 5px;
    }
}
.br_sp { display: none}
.br_pc { display: block}

@media (max-width: 768px) {
.br_sp { display: block}
.br_pc { display: none}
}