@import url("reset.css");
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Outfit:wght@100..900&display=swap');

/*--------------------------------
  cssルール
--------------------------------*/
:root{
	/*カラー指定*/
	--color__white:#ffffff;
	--color__black:#181818;
	--color__gray:#f7f7f7;
	--color__blue:#47b8ea;
	--color__yellow:#f4b158;
	--color__green:#87c187;
	--color__red:#dd4558;
	--color__pink:#d388e5;
	
	/*フォント指定*/
	--font__NotoSans:'Noto Sans JP', sans-serif;
	--font__Outfit:'Outfit', sans-serif;
	
	/*マージン指定*/
	--section__margin: 180px auto 0;
	--section__padding: 180px 0 0;
	
	--margin: 90px auto 0;
	--padding: 90px 0 0;
}

/*--------------------------------
  英数字専用フォント設定
--------------------------------*/
@font-face {
  font-family: 'LocalizedFont';
  src: local('Outfit'), local('Arial');
  unicode-range: U+0020-007E; /* 半角英数字・記号 */
}

/*--------------------------------
  日本語専用フォント設定
--------------------------------*/
@font-face {
  font-family: 'LocalizedFont';
  src: local('Noto Sans JP'), local('Hiragino Sans'), local('Meiryo');
  unicode-range: U+3000-9FFF, U+FF00-FFEF; /* 日本語・全角文字 */
}



body{ width: 100%; margin: auto; color: var(--color__black); font-family: 'Noto Sans JP', 'Outfit', sans-serif; font-display: swap; line-height: 2;}

.clearfix { *zoom: 1;}
.clearfix:before,
.clearfix:after { display: table; line-height: 0; content: "";}
.clearfix:after { clear: both;}

.forPC{ display: block;}
.forSP{ display: none;}

h1,h2,h3,h4,h5,li{ letter-spacing: 0.1em; color: var(--color__black);}

p{ font-size: 14px; font-weight: normal; letter-spacing: 0.1em; text-align: left; color: var(--color__black);}
p.indent-1 { padding-left:1em; text-indent:-1em;}
p.indent-15 { padding-left:1.5em; text-indent:-1.5em;}
a{ text-decoration: none; transition: .1s ease-in-out; -moz-transition: .1s ease-in-out; -webkit-transition: .1s ease-in-out; -o-transition: .1s ease-in-out; -ms-transition: .1s ease-in-out; outline: none; font-size: 14px; color: var(--color__black);}
a:hover{ transition: .1s ease-in-out; -moz-transition: .1s ease-in-out; -webkit-transition: .1s ease-in-out; -o-transition: .1s ease-in-out; -ms-transition: .1s ease-in-out;}

.annotation{ color: var(--color__red); font-size: 14px; padding: 0 0 0 18px; box-sizing: border-box; position: relative; display: block;}
.annotation::before{ content: "※"; top: 7px; left: 0; margin: auto; position: absolute; width: 14px; aspect-ratio: 1 / 1; line-height: 1;}
.annotation.none{ padding: 0 0 0 0;}
.annotation.none::before{ display: none;}

.Outfit{ font-family: var(--font__Outfit); line-height: 1.6;}

/* FV Ver.01 */
.fv_area01{ width: 100%; max-width: 1150px; box-sizing: border-box; margin: auto; display: flex; justify-content: space-between; align-items: center; padding: 60px 20px;}
.fv_area01 h1{ width: 100%; max-width: 404px; margin-right: 20px;}
.fv_area01 p{ font-size: 16px; font-weight: 600; display: block;}

/* FV Ver.02 */
.fv_area02{ width: 100%; height: calc(100vh - 148px); background-image: url(../images/fv_bg.jpg); background-size: cover; background-repeat: no-repeat; background-position: center; display: flex; justify-content: center; align-items: center;}
.fv_area02 .wrap{ width: 100%; max-width: 710px;}
.fv_area02 .wrap p{ font-size: 18px; font-weight: 600; text-align: center; color: var(--color__white); margin-top: 40px;}

/* nav */
nav{ width: 100%; height: 148px; background-color: var(--color__black); z-index: 100; transition: .3s ease-in-out;}
nav ul{ width: 100%; max-width: 1150px; padding: 0 20px; box-sizing: border-box; height: 100%; margin: auto; list-style: none; display: flex; justify-content: center; align-items: center; gap: 0 80px;}
nav ul li{ height: 100%; position: relative; overflow: hidden;}
nav ul li > a{ display: block; width: 100%; height: 100%; display: flex; justify-content: center; align-items: center; color: var(--color__white); font-size: 18px; font-weight: 400;}
nav ul li > a:hover{ color: var(--color__red);}
nav ul li.lang{ width: 60px; height: 100%; position: relative; display: flex; justify-content: center; align-items: center;}
nav ul li.lang .bg{ width: 35px; height: 35px; background-color: var(--color__red); transform: rotate(45deg); margin: auto;}
nav ul li.lang a{ position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; display: flex; justify-content: center; align-items: center; font-size: 16px; font-weight: 600;}
nav ul li.lang a:hover{ color: var(--color__black);}
body.home nav ul li.home::after,
body.company_profile nav ul li.company_profile::after,
body.track_record nav ul li.track_record::after,
body.office_view nav ul li.office_view::after,
body.recruit nav ul li.recruit::after{ position: absolute; content: ""; width: 20px; height: 5px; bottom: -2px; left: 0; right: 0; margin: auto; background-color: transparent; transition: .1s ease-in-out; background-color: var(--color__white);}
body.home nav ul li:hover.home::after,
body.company_profile nav ul li.company_profile:hover::after,
body.track_record nav ul li.track_record:hover::after,
body.office_view nav ul li.office_view:hover::after,
body.recruit nav ul li.recruit:hover::after{ background-color: var(--color__red) !important;}

nav.fixed{ position: fixed; width: 100%; height: 75px; top: 0; left: 0;}

/* title01 */
.title01{ width: 100%;}
.title01 h2{ font-size: 14px; font-family: var(--font__Outfit); font-weight: 600; padding-left: 30px; box-sizing: border-box; position: relative;}
.title01 h2::before{ content: ""; position: absolute; top: 0; left: 0; bottom: 0; margin: auto; width: 20px; height: 20px; background-image: url(../images/icon01.svg); background-repeat: no-repeat; background-position: center; background-size: 100%;}
.title01 h3{ font-size: 28px; font-weight: bold;}

/* link btn */
.link_btn01{ width: auto; display: block; float: right;}
.link_btn01 span{ font-size: 20px; font-family: var(--font__Outfit); font-weight: 600; color: var(--color__white); position: relative; padding-right: 40px;}
.link_btn01 span::after{ content: ""; position: absolute; top: 0; right: 0; bottom: 0; width: 29px; height: 29px; background-image: url(../images/icon03.svg); background-size: 100%; background-repeat: no-repeat; background-position: center;}
.link_btn01:hover span{ color: var(--color__red);}

.link_btn02{ width: auto; display: block; float: right; border: 1px solid var(--color__black); box-sizing: border-box; padding: 10px 20px;}
.link_btn02 span{ font-size: 20px; font-family: var(--font__Outfit); font-weight: 600; color: var(--color__black); position: relative; padding-right: 40px;}
.link_btn02 span::after{ content: ""; position: absolute; top: 0; right: 0; bottom: 0; width: 29px; height: 29px; background-image: url(../images/icon03.svg); background-size: 100%; background-repeat: no-repeat; background-position: center;}
.link_btn02:hover{ background-color: var(--color__black);}
.link_btn02:hover span{ color: var(--color__red);}

/* footer */
footer{ padding: 30px 10px; box-sizing: border-box; border-top: 1px solid var(--color__black);}
footer p{ font-size: 14px; font-family: var(--font__Outfit); font-weight: 600; text-align: center;}
button.js-backToTop{ position: fixed; display: flex; align-items: center; justify-content: center; right: 20px; bottom: 20px; width: 40px; height: 40px; font-size: 12px; font-weight: bold; color: var(--color__white); background: var(--color__black); border: 1px solid var(--color__white); cursor: pointer; opacity: 0; visibility: hidden; transition: .3s;
}
button.js-backToTop.is-active{ opacity: 1; visibility: visible;}

/* company_map */
.company_map{ width: 100%; margin: var(--section__margin);}
.company_map .txt_box{ width: 100%; background-color: var(--color__black); padding: 30px 0; box-sizing: border-box;}
.company_map .txt_box .wrap{ width: 100%; max-width: 1150px; padding: 0 20px; box-sizing: border-box; margin: auto; display: flex; justify-content: space-between; align-items: flex-start;}
.company_map .txt_box .wrap .left{ width: 100%; max-width: 180px;}
.company_map .txt_box .wrap .left h2,
.company_map .txt_box .wrap .left h3{ color: var(--color__white);}
.company_map .txt_box .wrap .right{ width: 100%; max-width: calc(100% - 180px); display: flex; justify-content: flex-end;}
.company_map .txt_box .wrap .right > div{}
.company_map .txt_box .wrap .right > div p{ font-size: 18px; color: var(--color__white);}
.company_map .map{ -webkit-filter: grayscale(100%); -moz-filter: grayscale(100%); -ms-filter: grayscale(100%); -o-filter: grayscale(100%); filter: grayscale(100%); line-height: 0;}