@charset "UTF-8";

/* 共通部分
----------------------------------------------- */
body{
	color: #182a44;
	font-family: Arial,"游ゴシック";
	line-height: 1.7;
	font-size: 100%;
	letter-spacing: 0.5em;

	width: 100%;
	height: 100vh;
	background: linear-gradient( 90deg, #928d8d, #eee ,#eeedee);

}
@keyframes  {
	0% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
	100% { background-position: 0% 50%; }
}
#wrapper {
	overflow: hidden;
	max-width: 100%;
	position: relative;
}

img {
	max-width: 100%;
}
a {
	text-decoration: none;
	color: #fff;
}

ul{
	list-style: none;
}


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

/* メインビジュアル */
.main_visual {
	color: #fff;
	height: 100vh;
	width: 100%;
	overflow: hidden;
	position: relative;
	top: 0;
	left: 0;
	background: linear-gradient(90deg,#15348d 30%,transparent);
}
.logo_description_mob {
	display: none;
}
video {
	position: absolute;
	bottom: 0;
	right: -3%;
	z-index: -1;
	min-height: 100%;
	min-width: 100%;
}

.head_inner {
	width: 95%;
	margin: 50px auto;
}

.logo_box {
	display: flex;
	font-size: 0.7rem;
	font-weight: bold;
	letter-spacing: 0;
}
.logo_white {
	width: 100px;
	height: 20px;
	margin-right: 15px;
}
.logonavy_box {
	display: flex;
	font-size: 0.7rem;
	font-weight: bold;
	letter-spacing: 0;
}
.logo_navy {
	width: 100px;
	height: 20px;
	margin-right: 15px;
}


/* グローバルメニュー */
.openbtn {
	display: none;
}
#g-nav {
	position: fixed;
	z-index: -1;
	opacity: 0;
}
.main_nav {
	display: flex;
	text-transform: uppercase;
	font-size: 0.5em;
	letter-spacing: 0.5em;
	font-weight: bold;
}
.main_nav li:nth-child(6) a {
	color: #fff;
}
.main_nav li {
	display: inline-block;
	margin-left: 30px;
}
.main_head {
	display: flex;
	justify-content: space-between;
}

/* nav:hover circles */
.nav_bg1 {
	z-index:10;
	position: relative;
}
.nav_bg1:hover:before {
	content: "";
	z-index: -1;
	position: absolute;
	left: 15%;
	top: -15%;

	background: #a6b1b6;
	width: 50px;
	height: 30px;
	animation: circleanime 5s infinite;
}
@keyframes circleanime {
	0% { transform: rotate(0deg);  border-radius: 80% 20% 60% 30% / 70% 30% 70% 50%; }
	25% { width:20px; height:20px; border-radius: 20% 80% 70% 40% / 50% 40% 20% 40%; }
	50% { border-radius: 80% 30% 20% 40% / 50% 70% 80% 40%; }
	75% { border-radius: 40% 70% 30% 50% / 30% 50% 60% 70%; }
	100% { transform: rotate(360deg);  border-radius: 90% 20% 60% 30% / 70% 30% 70% 50%; }
}

.nav_bg2 {
	z-index:10;
	position: relative;
}
.nav_bg2:hover:before {
	content: "";
	z-index:-1;
	position: absolute;
	left: 15%;
	top: -50%;

	background: #a6b1b6;
	width: 40px;
	height: 40px;
	animation: circleanime2 5s infinite;
}
@keyframes circleanime2 {
	0% { transform: rotate(0deg);  border-radius: 90% 20% 60% 30% / 70% 30% 70% 50%; }
	25% { border-radius: 80% 30% 70% 40% / 50% 40% 80% 40%; }
	50% { border-radius: 80% 30% 70% 40% / 50% 40% 80% 40%; }
	75% { border-radius: 40% 70% 30% 50% / 30% 50% 60% 90%; }
	100% { transform: rotate(360deg);  border-radius: 90% 20% 60% 30% / 70% 30% 70% 50%; }
}

.nav_bg3 {
	z-index:10;
	position: relative;
}
.nav_bg3:hover:before {
	content: "";
	z-index:-1;
	position: absolute;
	left: 0;
	top: -15px;

	background: #a6b1b6;
	width: 10px;
	height: 10px;
	animation: circleanime3 5s infinite;
}
@keyframes circleanime3 {
	0% { transform: rotate(0deg);  border-radius: 30% 20% 60% 30% / 50% 30% 70% 50%; }
	25% { width:45px; height:45px; border-radius: 50% 70% 40% 60% / 40% 50% 70% 80%; }
	50% { border-radius: 60% 30% 70% 40% / 50% 40% 80% 40%; }
	75% { border-radius: 40% 70% 30% 50% / 30% 50% 60% 90%; }
	100% { transform: rotate(360deg);  border-radius: 30% 20% 60% 30% / 50% 30% 70% 50%; }
}

.nav_bg4 {
	z-index:10;
	position: relative;
}
.nav_bg4:hover:before {
	content: "";
	z-index:-1;
	position: absolute;
	left: 15%;
	top: -15%;

	background: #a6b1b6;
	width: 30px;
	height: 25px;
	animation: circleanime4 6s infinite;
}
@keyframes circleanime4 {
	0% { transform: rotate(0deg); border-radius: 90% 20% 60% 30% / 70% 30% 70% 50%; }
	25% { width:50px; height:30px; border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { width:40px; height:50px; border-radius: 80% 30% 70% 40% / 50% 40% 80% 40%; }
	75% { width:50px; height:45px; border-radius: 40% 70% 30% 50% / 30% 50% 60% 90%; }
	100% { transform: rotate(360deg); border-radius: 90% 20% 60% 30% / 70% 30% 70% 50%; }
}

.nav_bg5 {
	z-index:10;
	position: relative;

	padding: 15px 20px;
	background: #15348d;
	border-radius: 50px;
}

.nav_bg5:hover:before {
	content: "";
	z-index:-1;
	position: absolute;
	left: 0;
	top: -15%;

	background: #15348d;
	width:120px;
	height:70px;
	animation: circleanime5 8s infinite;
}
@keyframes circleanime5 {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}
.mainmessage_box {
	margin-left: 10%;
	margin-top: 10%;
}
.main_message {
	font-size: 200%;
}


/* フォント設定 */
.mincho {
	font-family: "游明朝","Sawarabi Mincho";
	letter-spacing: 0.5em;

	opacity: 0;
	transition: opacity 3s;
}
.mincho.view {
	opacity: 1;
}
.italic {
	font-style: italic;
}



/* about */

.about {
	position: relative;
	top:0;
	left:0;
}

.blueline {
	width: 100%;
	background: #15348d;
	color:#fff;
	font-weight:bold;
}
.en {
	padding-top: 10px;
	text-align: center;
	font-size: 1.2vw;
}
.ja {
	text-align: center;
	font-size: 3vw;
	padding-bottom: 10px;
}
.snap_linear {
	position: relative;
	top: -300px;
	left: 0;
	z-index: -1;
	width: 100%;
	margin-bottom: 10%;
}

.philosophy_box {
	width: 100%;
	background: linear-gradient(#000 50%,transparent);
}

.philosophy {
	color: #fff;
	font-size: 1.5vw;
	font-weight:bold;
	line-height: 3em;
	text-align: center;
	padding-top: 50px;
}

.about_linkbox {
	z-index: 100;
	position:absolute;
	bottom: 100px;
	left: 50px;

	background: #fff;
	width: 600px;
	height: 300px;
	box-shadow: 0 5px 4px rgba(0,0,0,0.3);
}

.gaikan_il {
	position: absolute;
	bottom: 50px;
	left: 250px;

	width: 300px;
	height: 200px;
}

.contents {
	position:absolute;
	bottom: 220px;
	left: 50px;

	color: #182a44;
	font-size: 1.3em;
	font-weight:bold;
}
.contents_link {
	position:absolute;
	bottom: 100px;
	left: 50px;

	color: #182a44;
	font-size: 0.7em;
	letter-spacing: 0.5em;
	font-weight:bold;
}
.viewmore {
	position:absolute;
	bottom: 60px;
	left: 50px;

	width:200px;
	height:10px;
}
.about_linkbox:hover {
	background: #fff;
	width: 600px;
	height: 300px;

	animation: aboutcircle 5s infinite;
}
@keyframes aboutcircle {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}


/* works */

#works {
	position: relative;
	top: 0;
	left: 0;

	color: #fff;
}

.hidden {
	position:absolute;
	right: 0px;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.blue_works {
	position:absolute;
	top:0;
	right: 0px;
	z-index: -50;

	width: 90%;
	height: 300px;
	background: #15348d;
}
.works_en {
	position:absolute;
	top:30px;
	left: 5%;
	color: #fff;
	font-size: 1.5vw;
	font-weight: bold;
	width: 90%;
	line-height: 1.5em;
	overflow : hidden;
}
.works_en p{
	display : inline-block;
	white-space : nowrap;
	line-height: 1em;
	animation : bluescroll 25s linear infinite;
}
@keyframes bluescroll {
0% { transform: translateX(100%)}
100% { transform: translateX(-100%)}
}
.works_img {
	position: absolute;
	top: 100px;
	right: 0;
	z-index: -1;

	width: 80%;
	height: 500px:
}
.works_title {
	position: absolute;
	top: 250px;
	left: 70%;
	
	text-align: center;
}
.works_name {
	font-size: 1.5em;
}
.works_detail {
	font-size: 0.8em;
	letter-spacing: 0.5em;
}
.works_linkbox {
	background: #fff;
	width: 600px;
	height: 300px;

	position:absolute;
	top: 580px;
	right: 50px;
	box-shadow: 0 5px 4px rgba(0,0,0,0.3);
}
.works_il {
	position: absolute;
	bottom: 50px;
	right: 30px;

	width: 250px;
	height: 200px;
}

.works_linkbox:hover {
	background: #fff;
	width: 600px;
	height: 300px;

	animation: workscircle 5s infinite;
}
@keyframes workscircle {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}



/* news */

#news {
	position:relative;
	top:0;
	left:0;
	height: 1000px;
	margin-bottom: 300px;
	overflow: hidden;
}
.blue_news {
	position:absolute;
	top:0;
	left: 0;
	z-index: -50;

	width: 90%;
	height: 100%;
	background: #15348d;
}
.news_en {
	position:absolute;
	top:30px;
	left: 5%;
	color: #fff;
	font-size: 1.2em;
	font-weight: bold;
}
.newsimg_hidden {
    margin-top: 100px;
    margin-left: 5%;
	padding: 50px;
    background-image: url(../images/top_newsbg.jpg);
}
.topnews_bg {
	width: 80%;
    margin: 0 auto;
    padding: 50px;
    background: #fff;
    text-align: center;
}
.news_title {
	color: #182a44;
	text-align: center;
}
.news_name {
	font-size: 1.5em;
}
.news_detail {
	font-size: 0.8em;
	letter-spacing: 0.5em;
}

.topnews_img_box {
	width: 100px;
}
.topnew_img {
	margin-left: -90%;
    margin-bottom: -30px;
	animation: flash 2s linear infinite;
}
@keyframes flash {
	0%,100% { opacity: 1; }
	50% { opacity: 0; }
}

.top_news_list {
    color: #182a44;
    padding: 30px;
    display: flex;
}
.topnews_box {
	margin-top: 50px;
}
.top_date {
	margin: 0 50px;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee;
}
.top_news_title {
	
}
.info_link  {
	color: #fff;
	font-size: 1.2em;
	letter-spacing: 0.2em;
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
	margin: 50px auto;
	background: #f1e050;
	border: none;
	border-radius: 50vh;
}
.info_link:hover {
	padding-top: 20px;
	padding-bottom: 20px;
	border: none;
	background: #f1e050;
	animation: circleanime10 8s infinite;
	transition: .3s;
}
@keyframes circleanime10 {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}

/* recruit */

#recruit {
	position:relative;
	top: 0;
	left:0;
	height: 600px;
}
.blue_recruit {
	position:absolute;
	top:0;
	right: 0;
	z-index: -50;

	width: 100%;
	height: 600px;
	background: #15348d;
}
.recruit_en {
	position:absolute;
	top:30px;
	right: 5%;
	color: #fff;
	font-size: 1.2;
	font-weight: bold;
}

.recruit_imgbox {
	position:absolute;
	top:100px;
	right: 0;

	width: 60%;
	height: 400px;
	overflow: hidden;
}
.recruit_img {
	width: 100%;
}
.recruit_title {
	position: absolute;
	top: 150px;
	left: 40%;
	color: #fff;
	text-align: center;
}
.recruit_name {
	font-size: 1.5em;
}
.recruit_detail {
	font-size: 0.8em;
	letter-spacing: 0.5em;
}

.recruit_linkbox {
	z-index: 100;
	position:absolute;
	top: 150px;
	left: 0;

	background: #fff;
	width: 600px;
	height: 300px;
}
.recruit_linkbox:hover {
	background: #fff;
	width: 600px;
	height: 300px;

	animation: recruitcircle 5s infinite;
}
@keyframes recruitcircle {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}
.snap_il {
	position: absolute;
	bottom: 50px;
	left: 280px;

	width: 300px;
	height: 200px;
}



/* contact */

#contact {
	padding: 100px 0;
	box-sizing: content-box;
    max-width: 100rem;
    margin: 0 auto;
}
.contact_box {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 auto;
	width: 90%;
}
.form_icon {
	margin: 0 auto;
}
.form_linkbox {
	background: #fff;
	width: 50%;
	height: 300px;
	box-shadow: 0 5px 4px rgba(0,0,0,0.3);
}
.form_linkbox:hover {
	background: #fff;
	width: 50%;

	animation: formcircle 5s infinite;
}
@keyframes formcircle {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}

.tel_box {
	width: 50%;
	height: 300px;
	
	text-align: center;
	font-weight: bold;
}
.contact_txt {
	font-size: 180%;
	margin-top: 30px;
}
.tel_txt {
	font-size: 80%;
}
.tel {
	margin-top: 1%; 
	background: #15348d;
	width: 95%;
	border-radius: 50vh;
	box-shadow: 0 5px 4px rgba(0,0,0,0.3);
	transition: .3s;
}

.tel:hover {
	background: #182a44;
	width: 95%;

	box-shadow: 0 0 2px rgba(0,0,0,0.2);
}



/* footer */
#footer {
	margin-top: -10px;
	color: #fff;
	font-size: 70%;
	letter-spacing: 0.5em;
	background: #0D3396;
}
.footer {
	display: flex;
	box-sizing: content-box;
    max-width: 100rem;
    margin: 0 auto;
}
.foot_bg {
	width: 50%;
}

.foot_box {
	width: 50%;
	line-height: 3em;
	padding: 50px;
}
.foot_box a:hover {
	color: #a6b1b6;
}
.foot_contents {
	padding: 30px;
	border-bottom: 1px solid #fff;
}
.contents1 {
	width: 30%;
	float: left;
	padding: 30px;
}
.contents2 {
	padding-top: 30px;
}
.copyright {
	clear: both;
	font-size: 10%;
	letter-spacing: 0.3em;
	text-align: center;
	
	padding-bottom: 30px;
	display: flex;
	box-sizing: content-box;
    max-width: 100rem;
    margin: 0 auto;
}
.copy_left {
	width: 50%;
}
.copy_right {
	width: 50%;
}


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

.current {
	content:"";
	z-index:-5;
	position: absolute;
	left: 10px;
	top: -10px;

	background: #a6b1b6;
	height: 30px;
	width: 30px;
	border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%;
}
.white_leftbox {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	background: #fff;
	width: 55%;
	height: 800px;
}
.subhead_inner {
	width: 90%;
	margin: 50px auto 0;
}
.subhead_inner a {
	color: #182a44;
}
.main_img {
	margin: 70px auto 0;
	width: 90%;
	height: 500px;
	overflow:hidden;
}
.main_title {
	position: absolute;
	top: 350px;
	left: 200px;
	width: 200px;
	z-index:50;
	color: #fff;
	text-align: center;
}
.title_name {
	font-size: 200%;
}
.title_en {
	font-size: 2em;
}
.title_ja {
	font-size: 0.8em;
	letter-spacing: 0.5em;
	font-weight: bold;
}
.comment_bg {
	background: #fff;
	height: 100%;
	padding: 100px 0 100px 100px;

	position: relative;
	top: -200px;
	right: 0;
	z-index: -1;
}
.comment_box {
	margin-left: 1%;
	margin-top: 200px;
}
.comment_en {
	font-size: 5em;
	font-weight: bold;
}
.comment_ja {
	font-size: 2em;
	font-weight: bold;
	color: #15348d;
	margin: 30px 0;
}
.comment {
	font-size: 1em;
	line-height: 3em;
	font-weight: bold;
	letter-spacing: 0.5em;
}

.blue_hidden {
	width: 350px;
	overflow: hidden;
}
.blue_right {
	position: absolute;
	bottom: -200px;
	right: 0;
	z-index: -1;
	width: 350px;
	height: 400px;
	background: #15348d;
	color: #fff;
	text-align: center;
}
.blue_left {
	position: absolute;
	top: -200px;
	left: 0;
	z-index: -1;
	width: 350px;
	height: 400px;
	background: #15348d;
	color: #fff;
	text-align: center;
}
.blue_en {
	padding-top: 170px;
	font-size: 1.5em;
}
.blue_ja {
	font-size: 0.8em;
	letter-spacing: 0.5em;
}
.linkbox {
	margin: 100px auto 0;
}
.linkbox a:hover {
	opacity: 0.5;
}


/* aboutページ
----------------------------------------------- */

/* makotonokokoro */

.makoto {
	position: relative;
	top: -200px;
	left: 0;
	height: 650px;
	width: 100%;
	z-index:-50;
	background-image: url(../images/kokoro_line.png);
	display: flex;
}

.makoto_box {
	position: relative;
	top: 0;
	left: 10%;

	width: 300px;
	height: 500px;
}
.makoto_line {
	position: absolute;
	top: 0;
	left: 28px;

	width: 1px;
	height: 200px;
	background: #808080;
}
.wr_mode {
	position: absolute;
	top: 210px;
	left: 0;

	writing-mode: vertical-rl;
	font-size: 2em;
}


.kokoro {
	position: absolute;
	top: 300px;
	left: 30%;
	font-weight: bold;
}
.kokoro p::first-letter {
	font-size: 1.5em;
}
.kokoroimg_box {
	position: absolute;
	top: 400px;
	left: 75%;

}
.kokoro_img {

	width: 70%
}


/* message */

#message {
	position: relative;
	top:0;
	left: 0;
	height: 1200px;
}
.message {
	position: absolute;
    top: 50px;
    left: 5%;
    width: 90%;
    background: #fff;
    display: flex;
}
.ceo {
	text-align: center;
	font-size: 0.8em;
	font-weight: bold;
	box-shadow: 0 5px 4px rgba(0,0,0,0.3);
}
.message_img {
	width: 50%;
	margin: auto;
}
.message_txt {
	width: 50%;
	font-size: 1em;
    letter-spacing: 0;
    padding: 30px;
	margin: auto;
}


/* company */

#company {
	position: relative;
	top: 0;
	left: 0;
	height: 1000px;
}
.company_all {
	margin: 100px auto;
	height: auto;
	background: #fff;
	font-weight: bold;
	letter-spacing: 0;
	width: 90%
}
.company {
    width: 90%;
    margin: auto;
	display: flex;
	justify-content: space-between;
}
.company_box {
	margin-top: 50px;
	width: 50%;
	line-height: 2.18;
}
.company_box2 {
	margin-top: 50px;
	width: 50%;
	line-height: 2.18;
}
.company_title {
	width: 120px;
	padding: 15px 0 15px 15px;
	border-top: 1px solid #262626;
	float: left;
}
.company_detail {
    padding: 15px 0 15px 30px;
    border-top: 1px solid #ddd;
	margin-left: 120px;
}

.company2 {
	margin: 50px auto;
	width: 90%;
	display: flex;
	justify-content: space-between;
   	border-top: 1px solid #ddd;
}
.company_box3 {
	width: 48%;
	line-height: 2.18;
}
.company_box3 a {
	color: #2c77f6;
}
.company_box3 a:hover {
	color: #928d8d;
}
.company_title2 {
	width: 120px;
	padding: 16px 0 15px 10px;
	border-top: 1px solid #262626;
	float: left;
}
.company_detail2 {
	width: 500px;
    padding: 15px 0 15px 30px;
	margin-left: 120px;
}

.company_box4 {
	padding:50px 50px;
}


/* facility */

#facility {
	position: relative;
	top:200px;
	left: 0;
	height: 800px;
}
.facility_img_hidden {
	position: relative;
    top: 0;
    left: 0;
    overflow: hidden;
	width: 100%;
	height: 600px;
}
.facility_img {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -10;
}
.facility {
	position: absolute;
    top: 15%;
    left: 15%;
    background: rgba(255,255,255,0.9);
    display: flex;
    width: 80%;
	font-weight: bold;
    letter-spacing: 0;
}
.facility_box,.facility_box2 {
	width: 45%;
	padding: 30px;
}
.facility_title {
	padding: 10px;
	border-bottom: 1px solid #aeaeaf;
	float: left;
	width: 80%;
}
.facility_detail {
    padding: 10px;
    border-bottom: 1px solid #aeaeaf;
}

/* access */

#access {
	position: relative;
	top: 300px;
	left: 0;
	z-index: 50;
	height: 800px;
	width: 100%;
}
.access  {
	position: absolute;
	bottom: 0;
	left: 0;

	height: 1000px;
	width: 100%;
	display: flex;
}
.access_img {
	position: absolute;
	top: 300px;
	right: 0;
}
.access_img img {
	width: 70%;
}
.access_map {
	position: relative;
	top: 0;
	left: 0;
	width: 60%;
	padding-top: 75%; /* height ÷ width × 100 */
	z-index: -1;
}
.access_map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;

}



/* sdgsページ
----------------------------------------------- */

#sdgs {
	position: relative;
	top: 0;
	left: 0;
	height: 1000px;
	width: 100%;
	font-size: 80%;
	letter-spacing: 2px;
}
.sdgs {
	background: #15348d;
	width: 100%;
	height: 500px;
}
.sdgs_img {
	float: left;
	width: 40%;
	margin: 50px 20px 0 50px;
}
.sdgs_txt {
	color: #fff;
	padding: 50px 30px 50px 0;
}
.sdgssitelink {
	text-align: center;
	padding-top: 10px;
}
.sdgssitelink a:hover {
	opacity: 0.5;
}
.sdgs_detail {
	color: #182a44;
	font-weight: bold;
	background: #fff;
	text-align: center;
	width: 90%;
	height: 500px;
	margin: -50px auto 0 auto;
}
.sdgs_detail_title {
	font-size: 1.2rem;
	padding: 50px;
	border-bottom: 1px solid #eee;
	width: 80%;
	margin: 0 auto;
}

.sdgs_reiwa {
	display: flex;
	justify-content: space-around;
}
.sdgcat_box {
	width: 30%;
	margin-top: 50px;
}
.sdgs_cat {
	font-size: 1rem;
	font-weight: boler;
	padding: 20px;
}
.sdgicon_img {
	width: 20%;
}


/* worksページ
----------------------------------------------- */

.product {
	position: relative;
	top: 0;
	left: 0;
}
.worksbottom_linkbox {
	margin-top: 100px;
	display: flex;
}
.worksbottom_linkbox a:hover {
	opacity: 0.5;
}


/* newsページ
----------------------------------------------- */
.infolist_box {
    position: relative;
	top: -100px;
	overflow: hidden;
}
.info-list {
	list-style: none;
	width: 60%;
	margin: 100px auto;
	background: #fff;
	padding: 100px;
	box-shadow: 3px 5px 4px rgb(0 0 0 / 30%);
}
.info-list a {
	color:#182a44;
}
.info_scroll {
	position: absolute;
    top: 0;
    left: 0;
	z-index: -1;
	font-size : 5em;
	letter-spacing: 1em;
	text-align : left;
}
.info_scroll p{
	writing-mode: vertical-rl;
	display : inline-block;
	white-space : nowrap;
	line-height : 1.5em;
	animation : infoscroll 20s linear infinite;
}
@keyframes infoscroll {
0% { transform: translateY(0)}
100% { transform: translateY(-30em)}
}
.news_img_box {
	width: 100px;
}
.new_img {
	animation: flash 2s linear infinite;
}
.info_news_list {
    color: #182a44;
    padding: 30px;
}
.info_date {
	font-size: 0.8em;
}
.info_news_title {
    font-size: 1.5em;
}
.info_line {
	width: 120px;
    height: 8px;
	margin: 20px 0;
	background: #eee;
}
.info_news_detail {
	font-size: 0.8em;
	letter-spacing: 0.2em;
}
.news-container li {
	list-style: none;
	padding: 10px;
	font-size: 1vw;
}
.blogPager {
	margin-top: 50px;
}
.blogPager ul{
	display: flex;
	flex-wrap: wrap;
	margin-left: 40%;
}
.blogPager ul li{
	display: flex;
	flex-wrap: wrap;
	text-align: center;
}

/* infodetailページ
----------------------------------------------- */
.infodetail_box {
	position: relative;
	overflow: hidden;
}
.infodetail_scroll {
	position: absolute;
    top: 0;
    left: 0;
	z-index: -1;
    font-size: 5em;
    letter-spacing: 1em;
    text-align: left;
	opacity: 0.1;
}
.infodetail_scroll p{
	writing-mode: vertical-rl;
	display : inline-block;
	white-space : nowrap;
	line-height : 1.5em;
	animation : infoscroll 20s linear infinite;
}
@keyframes infoscroll {
0% { transform: translateY(1.5em)}
100% { transform: translateY(-4.5em)}
}
.infodetail {
	margin: 100px auto;
    background: #fff;
    width: 60%;
    padding: 100px;
	box-shadow: 3px 5px 4px rgb(0 0 0 / 30%);
}
.blogdetail_title {
	font-size: 3vw;
	font-weight: bold;
}
.blogdetail_text {
	text-align: center;
	margin-top: 100px;
}
.blogdetail_line {
	width: 30%;
	height: 30px;
	border-bottom: 8px solid #dad7d0;
}


/* recruitページ
----------------------------------------------- */
#character {
	position: relative;
	top: 0;
	left: 0;
	width: 100%;
	height: 500px;
}
.character_box {
	position: absolute;
	top:-200px;
	left: 0;
	z-index: -5;

	width: 100px;
	height: 500px;
	background: #fff;
}
.character_box2 {
	position: absolute;
	top:0;
	left: 100px;
	z-index: -10;

	width: 100%;
	height: 350px;
	background: #fff;
}
.character {
	position: absolute;
	top:-55%;
	left: 5%;
	width: 50%;
}
#requirement{
	position: relative;
	top:0;
	left: 0;
	width: 100%;
	height: 1300px;
}
.viewmore_box {
	z-index:10;
	position: absolute;
	bottom: 10%;
	right: 10%;
	padding: 30px 80px;

	background: #f1e050;
	border-radius: 50px;
	font-weight: bold;
}
.viewmore_box:hover:after {
	content: "";
	position: absolute;
	z-index:-1;
	bottom: -60%;
	right: 0;

	background: #f1e050;
	width:400px;
	height:200px;
	animation: circleanime6 8s infinite;
}
@keyframes circleanime6 {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}
.requirement {
	background: #fff;
	box-shadow: 0 5px 4px rgba(0,0,0,0.3);
	width: 90%;
	padding: 100px 0 300px;
	position: relative;
    z-index: -10;
    left: 5%;
}
.character1{
    width: 20%;
    position: absolute;
    top: -15%;
    right: 1%;
}
.character2{
    width: 20%;
    position: absolute;
    bottom: 5%;
    left: 1%;
}
.requirement_cat {
	border-bottom: 15px solid #f1e050;
	font-size: 1.8em;
	font-weight: bold;
    margin-bottom: 10%;
}
.font_s {
	font-size: 0.7em;
	margin-right: 50px;
}
.requirement_box {
	margin-top: 10%;
    margin-left: 30%;
    width: 60%;
    letter-spacing: 0;
	line-height: 2.18;
}
.requirement_title {
	width: 120px;
	padding: 15px 0 15px 15px;
	border-bottom: 3px solid #eee;
	vertical-align: middle;
}
.requirement_detail {
    padding: 15px 0 15px 30px;
    border-bottom: 1px solid #eee;
	margin-left: 120px;
}



/* contactページ
----------------------------------------------- */

.foot {
	margin-top: -100px;
}
.nyuryoku_bg {
	height: 1900px;
	margin-top: 70px;
	background-image: url(../images/contact_bg.jpg);
}
.nyuryoku {
	background: rgba(255,255,255,0.9);
    height: 1700px;
    width: 80%;
    position: absolute;
    top: 35%;
    left: 10%;
}
.contact_title {
	text-align: center;
    font-weight: bold;
    padding: 100px;
}
.contact_en {
    font-size: 150%;
}
.contact_ja {
	font-size: 80%;
	letter-spacing: 0.2em;
}
.kakusyu {
	font-size: 90%;
	letter-spacing: 0.2em;
	font-weight: bold;
    text-align: center;
}
.contact_bluebg {
    width: 75%;
    height: 100px;
    text-align: center;
    background: #15248d;
    border-radius: 10px;
    margin: 30px auto;
    color: #fff;
	padding: 30px 0;
}
.contact_telbox {
	display: flex;
	justify-content: center;
	font-size: 1.5em;
}
.contact_bluebg img {
    width: 18%;
    margin-bottom: -7%;
    margin-right: 10px;
}
.uketuke {
	letter-spacing: 0.2em;
    font-size: 80%;
	margin-top: 30px;
}

.contact_telicon:hover {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: #fff;
	animation: circleanime7 8s infinite;
}
@keyframes circleanime7 {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}

.contact_ul {
	margin-top: 10%;
}
.contact_list {
    position: relative;
    display: flex;
    justify-content: center;
}
.contact_list::before {
    background-color: #a4a4a4;
    width: 324px;
    height: 1px;
    position: absolute;
    top: -32px;
    left: 50%;
    content: '';
    transform: translateX(-50%);
}
.contact_item {
    margin: 0 40px;
    position: relative;
    font-weight: bold;
    color: #a4a4a4;
    font-size: 80%;
}
.contact_item.is-active::before {
    background-color: #182a44;
}
.contact_item::before {
    background-color: #a4a4a4;
    width: 16px;
    height: 16px;
    position: absolute;
    top: -40px;
    left: calc(50% - 8px);
    border-radius: 50%;
    content: '';
}
.contact_item.is-active {
    color: #182a44;
}
.contact_item::after {
    background-color: rgba(164, 164, 164, .25);
    width: 40px;
    height: 40px;
    position: absolute;
    top: -52px;
    left: calc(50% - 20px);
    border-radius: 50%;
}
.contact_item.is-active::after {
    content: '';
}

.contact_form {
    margin-top: 100px;
    margin-left: 50%;
    transform: translateX(-50%);
	font-size: 0.8em;
	letter-spacing: 0.2em;
	font-weight: bold;
	width: 680px;
}
.errmessage {
	color: #f00;
	margin-left: 50%;
	font-weight: normal;
}
.form_items {
	display: flex;
	margin-top: 20px;
}
.form_item {
	display: flex;
}
.form_title {
	width: 200px;
	margin-top: 25px;
}

.form_input {
	border: 1px solid #808080;
	border-radius: 0.3em;
	padding: 1em;
	width: 30em;
	margin-top: 10px;
}
.form_input:focus {
	border-color: #fff;
	background-color: #fff;
	outline: none;
}
.form_area {
	border: 1px solid #808080;
	border-radius: 0.3em;
	padding: 1em;
	width: 30em;
	height: 200px;
	line-height: 1.2;
	margin-top: 10px;
}
.form_area:focus {
	border-color: #fff;
	background-color: #fff;
	outline: none;
}
.required {
	margin-right: 30px;
	height: 50px;
}
.privacy_link {
	margin-top: 80px;
	text-align: center;
}
.privacy_link a {
	color: #15348d;
	border-bottom: double 5px ;
}
.privacy_link a:hover {
	color: #928d8d;
}
.kakunin_btn {
	color: #fff;
	font-weight: bold;
	font-size: 1.2em;
	letter-spacing: 0.2em;

	width: 680px;
	height: 65px;
	margin: 50px auto;
	background: #f1e050;
	border: none;
	border-radius: 50vh;
}
.kakunin_btn:hover {
	width: 680px;
	height: 100px;
	border: none;
	background: #f1e050;
	animation: circleanime8 8s infinite;
	transition: .3s;
}
@keyframes circleanime8 {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}


/* confirmationページ
----------------------------------------------- */
.confirmation_bg {
	height: 1900px;
	margin-top: 70px;
	background-image: url(../images/contact_bg.jpg);
}
.confirmation {
	background: rgba(255,255,255,0.8);
    height: 1600px;
    width: 80%;
    position: absolute;
    top: 35%;
    left: 10%;
}
.confir_ul {
	margin-top: 80px;	
}
.confir_txt {
	text-align: center;
	letter-spacing: 0.2em;
	margin-top: 80px;
	line-height: 3em;
}
.form_kakunin {
	margin: 80px auto;
	font-size: 80%;
    letter-spacing: 0.2em;
    font-weight: bold;
    background: #fff;
    width: 50%;
    padding: 10%;
}
.confir_items {
	display: flex;
}
.confir_item {
	width: 40%;
	padding-bottom: 50px;
}
.confir_items dd {
	width: 60%;
}
.of_scroll {
	overflow: scroll;
    height: 120px;
}
.btn_txt {
	font-weight: bold;
	font-size: 0.8em;
	margin-left: 40%;
    letter-spacing: 0.1em;
}
.btn_box {
	display: flex;
	width: 700px;
    margin: 0 auto;
	padding-bottom: 50px;
}
.back_btn {
	font-weight: bold;

	width: 200px;
	height: 65px;
	margin-left: 10px;
	border: 1px solid #182a44;
	border-radius: 50vh;
	background: rgba(0,0,0,0);
}
.back_btn:hover {
	color: #fff;
	width: 200px;
	height: 65px;
	background: #182a44;
}
.send_btn {
	color: #fff;
	font-weight: bold;
	width: 500px;
	height: 65px;
	margin-left: 10px;
	border: none;
	background: #f1e050;
	border-radius: 50vh;
}
.send_btn:hover {
	width: 500px;
	height: 65px;
	border: none;
	background: #f1e050;
	animation: circleanime9 8s infinite;
	transition: .3s;
}
@keyframes circleanime9 {
	0% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
	25% { border-radius: 50% 90% 40% 60% / 90% 50% 70% 80%; }
	50% { border-radius: 70% 30% 90% 40% / 40% 80% 30% 70%; }
	75% { border-radius: 40% 70% 30% 50% / 80% 50% 60% 90%; }
	100% { border-radius: 80% 20% 50% 90% / 50% 30% 70% 80%; }
}

/* compページ
----------------------------------------------- */
.complete_bg {
    height: 1000px;
    margin-top: 70px;
    background-image: url(../images/contact_bg.jpg);
}
.complete {
    background: rgba(255,255,255,0.9);
    height: 800px;
    width: 80%;
    position: absolute;
    top: 35%;
    left: 10%;
}
.complete_txt {
	text-align: center;
	letter-spacing: 0.2em;	
	font-weight: bold;
	padding-bottom: 80px;
}
.comp {
	font-size: 150%;
	color: #0d3394;
	margin: 100px 0;
}
.comp_txt {
    line-height: 3em;
	width: 80%;
    margin: 0 auto;
}



/* privacyページ
----------------------------------------------- */
.privacy_bg {
	margin-top: 30px;
    background-image: url(../images/contact_bg.jpg);
    padding: 100px 0;	
}
.privacy {
	width: 80%;
    background: rgba(255,255,255,0.9);
    margin: 0 auto;
}
.privacy_txt {
	width: 70%;
	letter-spacing: 0.2em;
    margin: 0 auto;
    padding-bottom: 150px;
}
.privacy dt {
	font-weight: bold;
    padding-bottom: 10px;
    padding-top: 50px;
}







































/* スクロール
----------------------------------------------- */

/* scrolldown */
.scrolldown {
	display: inline-block;
	position: absolute;
	bottom: 0px;
	left: 3%;
	padding-bottom: 60px;

	font-size: 0.2em;
	letter-spacing: 0.8em;
	line-height: 0.5;
	writing-mode: vertical-lr;
}
.scrolldown::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 4%;

	width: 1px;
	height: 50px;
	background: #fff;

	animation: scroll 1.4s ease-in-out infinite;
}
@keyframes scroll {
	0% { transform: scale(1,0); transform-origin:0 0; }
	50% { transform: scale(1,1); transform-origin:0 0; }
	50.1% { transform: scale(1,1); transform-origin:0 100%; }
	100% { transform: scale(1,0); transform-origin:0 100%; }
}

/* fadein */
.fadein {
	opacity: 0;
	transition: opacity 5s;
}
.fadein.view {
	opacity: 1;
}

/* slidein */
.slideleft {
 	transform: translateX(-100px);
	opacity: 0;
}
.slideleft.slideleft_view {
	transition: 1s;
	transform: translateX(0);
	opacity: 1;
}


.slideright {
 	transform: translateX(100px);
	opacity: 0;}
.slideright.slideright_view {
	transition: 1s;
	transform: translateX(0);
	opacity: 1;
}


.slideup {
 	transform: translateY(50px);
	opacity: 0;
}
.slideup.slideup_view {
	transition: 1s;
	transform: translateY(0);
	opacity: 1;
}




/* スライドショー */
.slider {
	position: relative;
	width: 100%;
	height: 800px;
	overflow: hidden;
	margin-bottom: 300px;
}

.slider img {
 	position: absolute;
	top: 300px;
	left: 0;
   	width: 550px;
	opacity: 0;
 	animation: slider 24s infinite ease;
}

@keyframes slider {
	0% { opacity: 0; }
	10% { opacity: 1; }
	28% { opacity: 1; }
	68% { opacity: 0; }
	100% { opacity: 0; }
}

.slider img:nth-child(2){
	animation-delay: 8s;
}
.slider img:last-child{
	animation-delay: 16s;
}


/* ローディング
----------------------------------------------- */

/* 背景画面設定　*/
#splash {
  /*fixedで全面に固定*/
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 1000;
	background: linear-gradient( 90deg, #928d8d, #eee ,#eeedee);
	background-size: 200%,200%;
	animation: bgradient 3s ease infinite;
	text-align:center;
	color:#fff;
}
@keyframes  {
	0% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
	100% { background-position: 0% 50%; }
}
/* Loading画像中央配置　*/
#splash_logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

/* Loading アイコンの大きさ設定　*/
#splash_logo svg{
    width:800px;
}
#mask path {
	fill-opacity: 0;
	transition: none;
	stroke: #15348d;
}
#mask.done path {
	fill: #15348d;
	fill-opacity: 1;
	stroke: #15348d;
}




/* メディアクエリー
----------------------------------------------- */
/* min1800pxここまで　----------------------------------------------- */
@media ( min-width: 1800px){
.main_nav {
	font-size: 80%;
}
.main_message {
	font-size: 300%;
}
.main_message_en{
	font-size: 130%;
	letter-spacing: 0.7em;
}
.logo_box {
	font-size: 110%;
	font-weight: normal;
}
.logonavy_box {
	font-size: 100%;
}
.logo_white {
	width: 150px;
	height: 30px;
	margin-right: 15px;
}
.logo_navy {
	width: 150px;
	height: 30px;
	margin-right: 15px;
}

/* about */
.snap_linear {
	top: -500px;
}
.about_linkbox {
	width: 900px;
	height: 450px;
}
.contents {
    position: absolute;
    bottom: 320px;
    left: 80px;
    color: #182a44;
    font-size: 2em;
    font-weight: bold;
}
.contents_link {
    position: absolute;
    bottom: 150px;
    left: 80px;
    color: #182a44;
    font-size: 0.8em;
    letter-spacing: 0.5em;
    font-weight: bold;
}
.viewmore {
    position: absolute;
    bottom: 80px;
    left: 80px;
    width: 300px;
    height: 15px;
}
.gaikan_il {
    position: absolute;
    bottom: 70px;
    left: 350px;
    width: 500px;
    height: 310px;
}

/* works */
#works {
	top: -100px;
}
.works_linkbox {
	width: 900px;
	height: 450px;
}
.works_il {
    bottom: 70px;
    right: 70px;
    width: 350px;
    height: 300px;
}

/* recruit */
.recruit_linkbox {
	width: 900px;
	height: 450px;
}
.snap_il {
    bottom: 70px;
    left: 430px;
    width: 450px;
    height: 300px;
}
/* message */
.message_img {
	width: 40%;
}
.message_txt {
	width: 60%;
}
/* sdgs */
.sdgs {
	height: 700px;
	font-size: 1.5em;
}
.sdgs_img {
	margin-right: 50px;
}
.sdgs_txt {
	padding-top: 80px;
}
/* recruit */
.character {
    width: 45%;
	top: -300px;
    left: 10%;
}
}
/* min1800pxここまで　----------------------------------------------- */

/* max1800pxここから　----------------------------------------------- */
@media ( max-width: 1800px){
/* sdgs */
.sdgs {
	height: 700px;
	font-size: 1.2em;
}
.sdgs_img {
	margin-right: 50px;
}
.sdgs_txt {
	padding-top: 80px;
}
}
/* max1800pxここまで　----------------------------------------------- */


/* max1600pxここから　----------------------------------------------- */
@media ( max-width: 1600px){
/* sdgs */
.sdgs {
	height: 600px;
}
}
/* max1600pxここまで　----------------------------------------------- */


/* min1500pxここから　----------------------------------------------- */
@media ( min-width: 1500px){
/* message */
.message_txt {
	font-size: 1.2em
}
/* sdgs */
#sdgs {
	height: 1300px;
}

/* recruit */
.character_box2 {
    height: 450px;
}
#requirement {
	top: 100px;
	height: 1500px;
}
.requirement {
	padding: 100px 0 300px;
}
.character_box {
    height: 600px;
}
.requirement_cat {
    font-size: 2.5em;
}
.requirement_title,.requirement_detail {
    font-size: 1.2em;
}
.viewmore_box{
	font-size: 1.2em;
	bottom: 15%;
}
/* confirmation */
.confirmation_bg {
    height: 2000px;
}
.confirmation {
    height: 1700px;
}
.form_kakunin {
    font-size: 100%;
}
/* complete */
.comp {
    font-size: 180%;
}
.comp_txt {
    font-size: 110%;
}
}
/* min1500pxここまで　----------------------------------------------- */


/* max1400pxここから　----------------------------------------------- */
@media screen and ( max-width: 1400px){
/* message */
#message {
	height: 1000px;
}
/* sdgs */
.sdgs {
	font-size: 1em;
	height: 550px;
}
.sdgs_txt {
	padding-top: 60px;
}
}
/* max1400pxここまで　----------------------------------------------- */




/* max1240pxここから　----------------------------------------------- */
@media( max-width: 1240px){
.logo_description {
	display: none;
}
.logo_description_mob {
	display: block;
	width: 100%;
	height: 20px;
	color: #15348d;
	background: #fff;
	text-align: center;
	font-size: 50%;
	letter-spacing: 0.2em;
	font-weight: bold;
	padding: 5px 0;
	}
.main_visual {
	color: #fff;
	height: 100vh;
	width: 100%;
	overflow: hidden;
	position: relative;
	top: 0;
	left: 0;
	background: linear-gradient(90deg,#15348d 10%,transparent);
}
video {
	position: absolute;
	bottom: 0;
	right: -3%;
	z-index: -1;
	min-height: 100%;
	min-width: 100%;
}

/* contact_link */
.form_icon {
	padding-top: 3%;
}

/* footer */
.foot_bg {
	width: 60%;
}
.foot_box {
    padding: 3%; 
}
/* 下層ページ共通
----------------------------------------------- */
.comment_en {
	font-size: 3.5em;
}
.comment_ja {
    font-size: 1.5em;
}

/* message */
#message {
	height: 900px;
}
.sdgs_img {
	margin-right: 20px;
}
.sdgs_reiwa {
    letter-spacing: 0;
}
	
/* infoページ */
.info_list {
	letter-spacing: 0.2em;
}
.blog_title {
    margin-left: 200px;
}
	
/* recruit */
.requirement_cat {
	font-size: 1.5em;
}
.viewmore_box {
	bottom: 15%;
}
/* contactページ */
.contact_telbox {
    letter-spacing: 0.2em;
}
.contact_ul {
    margin-top: 15%;
}
/* confirmation */
.confirmation_bg {
    height: 1800px;
}
.form_kakunin {
    width: 60%;
}
}
/* max1240pxここまで　----------------------------------------------- */


/* max1100pxここから　----------------------------------------------- */
@media screen and ( max-width: 1100px){
/* 下層ページ共通
----------------------------------------------- */
.comment_bg {
	padding: 50px 0 50px 50px;
}
/* message */
.message_txt {
	font-size: 0.8em;
}
/* sdgs */
.sdgs_reiwa {
	font-size: 0.8em;	
}
.sdgs_cat {
	font-size: 0.9rem;
}
.sdgicon_img {
    width: 30%;
}
/* character */
#character {
	top: 100px;
}
.character_box {
	top: -300px;	
}
.character_box2 {
    height: 300px;
}
.character1 {
	width: 30%;
}
#requirement {
	height: 1200px;
}
.requirement_box {
    margin-top: 15%;
}
.requirement_title,.requirement_detail {
	font-size: 0.8em;
}
/* contactページ */
.contact_telbox {
    font-size: 1.2em;
}
/* confirmation */
.confirmation {
    height: 1550px;
}
/* complete */
.complete_txt {
	letter-spacing: 0;
}
.comp {
    font-size: 120%;
}
comp_txt {
    font-size: 80%;
}
}
/* max1100pxここまで　----------------------------------------------- */

/* max1000pxここまで　----------------------------------------------- */
@media screen and ( max-width: 1000px){
/* news */
#news {
	margin-bottom: 200px;
}
.date {
	float: none;
}
.blog_title {
	margin-left: 0;
}
.top_news_list {
	letter-spacing: 0.2em;
}
.newsimg_hidden {
    padding: 50px 29px;
}
/* recruit */
.recruit_imgbox {
		width: 100%;
}

/* contact_link */
.form_linkbox {
	height: 250px;
}
.tel_box {
	height: 250px;
}

/* footer */
.footer {
    display: block;
}
.foot_bg {
    width: 80%;
    margin: 0 auto;
}
.foot_box {
    width: 80%;
    line-height: 3em;
    margin: 0 auto;
    padding: 0 0 50px 0;
}
.contents1 {
    width: 40%;
}
.copyright {
	display: block;
}
.copy_left {
    width: 100%;
}
.copy_right {
    width: 100%;
}
/* 下層ページ共通
----------------------------------------------- */
.comment_box {
    margin-top: 100px;
}
.comment {
    font-size: 1em;
    letter-spacing: 0.2em;
}
.kokoroimg_box {
	top: 500px;
}
/* message */
#message {
	height: 800px;
}
/* company */
#company {
	height: 800px;
}
.company_all {
	font-size: 0.8em
}
.company_title {
    width: 100px;
}
.company_detail {
    margin-left: 100px;
}
/* facility */
.facility {
    font-size: 0.8em;
}
/* access */
.access_img {
    top: 350px;
    right: -200px;
}
/* sdgsページ */
.sdgs_txt {
    letter-spacing: 0;
    padding-top: 50px;
}
.sdgs_detail_title {
    width: 90%;
}
.sdgcat_box {
    width: 35%;
}
/* info */
.info-list {
    width: 70%;
    padding: 50px;
}
/* recruit */
.requirement_cat {
    font-size: 1.4em;
}
.requirement_box {
    width: 65%;
}
/* confirmation */
.confirmation_bg {
    height: 1750px;
}
.confirmation {
    width: 90%;
    left: 5%;
}
/* complete */
.complete_bg {
    height: 900px;
}
.complete {
	height: 750px;
}
}
/* max1000pxここまで　----------------------------------------------- */


/* max900pxここから　----------------------------------------------- */
@media screen and ( max-width: 900px){
.contact_txt {
    font-size: 130%;
}
.tel_txt {
    font-size: 70%;
    letter-spacing: 0.3em;
}
.form_linkbox,.tel_box {
    height: 230px;
}
/* about */
.philosophy {
	padding-top: 0;
}
.snap_linear {
	top: -250px;
}
/* news */
.top_news_list {
	display: block;
}

/* 下層ページ共通
----------------------------------------------- */	
.comment_bg {
    padding-bottom: 100px;
}
.comment_en {
    font-size: 2.8em;
}
.comment_ja {
    font-size: 1.2em;
}
.comment {
    font-size: 0.8em;
    letter-spacing: 0;
}
.blue_hidden {
	width: 300px;
}
.blue_right {
    width: 300px;
    height: 350px;
}
.blue_en {
    padding-top: 150px;
    font-size: 1.2em;
}
.blue_left {
    width: 300px;
    height: 350px;
}
/* message */
.message_txt {
    font-size: 0.7em;
}
/* message */
#message {
	height: 700px;
}
.company_all {
	font-size: 0.7em
}
/* facility */
.facility_title {
    padding: 10px 0 10px 10px;
}
.facility_box, .facility_box2 {
    padding: 20px;
}
/* sdgsページ */
.sdgs {
    height: 450px;
	font-size: 0.8em;
}
.sdgs_detail_title {
    font-size: 1rem;
}
.sdgs_cat {
    padding: 30px 10px;
    font-size: 0.8rem;
}
/* infodetail */
.info_scroll,.infodetail_scroll {
    font-size: 4em;
}
/* recruit */
#requirement {
    height: 1000px;
}
.requirement {
    padding-bottom: 200px;
}
.character {
	width: 60%;	
}
.requirement_box {
    margin-left: 25%;
	width: 70%;
}
.requirement_cat {
    font-size: 1.2em;
}
.requirement_title {
    width: 100px;
	padding: 0;
}
.requirement_title,.requirement_detail {
	font-size: 0.7em;
}
.viewmore_box {
	bottom: 10%;
    font-size: 0.8em;
}
/* contactページ */
.nyuryoku_bg {
    height: 2080px;
}
.nyuryoku {
    width: 90%;
    left: 5%;
	height: 1900px;
}
.contact_bluebg {
	width: 80%;
    height: 80px;
}
.kakusyu {
    font-size: 80%;
}
.contact_item {
    font-size: 70%;
}
.contact_item::before {
    width: 10px;
    height: 10px;
    top: -37px;
}
.contact_item::after {
    width: 30px;
    height: 30px;
    top: -47px;
    left: calc(50% - 18px);
}
.contact_list::before {
    width: 318px;
}

.form_items {
    display: block;
	margin-left: 15%;
}
.form_title {
    width: unset;
}
.required {
    margin-left: 30px;
}
.errmessage {
    margin-left: 30%;
}
.kakunin_btn,.contact_form {
    width: 600px;
}
.kakunin_btn:hover {
	width: 600px;
}

/* confirmation */
.confirmation_bg {
    height: 1700px;
}
.confirmation {
	height: 1500px;
}
.form_kakunin {
    width: 70%;
    padding: 5%;
}
.confir_items {
    display: block;
}
.confir_item {
    padding-bottom: 10px;
    opacity: 0.5;
	width: 100%;
}
.confir_items dd {
    width: 100%;
    margin-bottom: 30px;
}
.btn_box {
    width: 600px;
}
.back_btn,.send_btn {
    height: 60px;
}
.btn_txt {
    margin-left: 35%;
}
}
/* max900pxここまで　----------------------------------------------- */



/* max800pxここから　----------------------------------------------- */
@media screen and ( max-width: 800px){	
/* contactlink */	
.form_linkbox,.tel_box {
    height: 210px;
}
/* 下層ページ共通
----------------------------------------------- */	
.tel_link a,.tel_link a:visited,.tel_link a:active {
	color: #182a44;
	}
.main_title {
	top: 300px;
	left: 50%;
	transform: translate(-50%);
}
.comment_box {
    margin-top: 0;
}
.comment_ja {
    font-size: 1.5em;
    letter-spacing: 0.2em;
}
.comment {
    font-size: 0.8em;
}
.blue_hidden {
	width: 280px;
}
.blue_right {
    width: 280px;
    height: 330px;
}
.blue_left {
    width: 280px;
    height: 330px;
}
/* message */
#message {
	height: 600px;
}
.message_txt {
    font-size: 0.6em;
}
/* company */
.company_all {
	font-size: 0.5em
}
.company_title {
    width: 80px;
}
.company_detail {
    margin-left: 80px;
}
/* sdgsページ */
.sdgs_img {
    margin: 70px 20px 0 50px;
}
.sdgs_reiwa {
    font-size: 0.5em;
}
.sdgs_detail_title {
    font-size: 0.9rem;
    padding: 50px 0;
}
.sdgs_detail {
	width: 95%;
}
/* info */
.info_news_list {
    letter-spacing: 0.2em;
}
.info-list {
    margin: 50px auto;
}
/* recruit */
.character {
    left: 1%;
}
/* contactページ */
.contact_telbox {
    letter-spacing: 0.1em;
}
.uketuke {
	letter-spacing: 0.1em;
    font-size: 70%;
    margin-top: 20px;
}
.kakusyu {
    font-size: 70%;
}
/* confirmation */
.confirmation_bg {
    height: 1650px;
}
.confirmation {
	height: 1450px;
}
.confir_txt {
    margin-top: 80px;
}
.btn_txt {
    margin-left: 30%;
}
/* complete */
.comp {
    font-size: 110%;
	margin: 80px 0;
}
.comp_txt {
    font-size: 70%;
}
/* complete */
.complete_bg {
    height: 800px;
}
.complete {
	height: 650px;
}
}
/* max800pxここまで　----------------------------------------------- */




/* max700pxここから　----------------------------------------------- */
@media screen and ( max-width: 700px){	
/* Loading アイコンの大きさ設定　*/
#splash_logo svg{
    width:500px;
}

#wrapper {
	overflow: hidden;
	max-width: 100%;
	position: relative;
}
.logo_description_mob {
	display: none;
}
.head_inner {
	margin: 20px auto;
}
.main_nav {
	display: none;
}

/* about */
.en {
    letter-spacing: 0.5em;
}
.snap_linear {
	top: -200px;
}
.about_linkbox {
	left: 10%;
	width: 300px;
	height: 150px;
}
.about_linkbox:hover {
	width: 300px;
	height: 150px;
}
.contents {
    position: absolute;
    bottom: 100px;
	left: 30px;
    font-size: 0.7em;
    font-weight: bold;
}
.contents_link {
    position: absolute;
    bottom: 50px;
    left: 30px;
    font-size: 8px;
    letter-spacing: 0.5em;
}
.viewmore {
    position: absolute;
    bottom: 30px;
    left: 30px;
    width: 100px;
    height: 5px;
}
.gaikan_il {
    position: absolute;
    bottom: 25px;
    left: 130px;
    width: 150px;
    height: 100px;
}

/* works */
.works_img {
    top: 80px;
}
.works_title {
    top: 150px;
    left: 60%;
}
.slider {
	top: -100px;
    width: 50%;
    height: 600px;
	margin-bottom: 0;
}
.works_linkbox {
    width: 300px;
    height: 150px;
    position: absolute;
    top: 380px;
    right: 10%;
}
.works_linkbox:hover {
	width: 300px;
	height: 150px;
}
.works_il {
    position: absolute;
    bottom: 20px;
    right: 1%;
    width: 125px;
    height: 100px;
}

/* news */
#news {
    overflow: unset;
	top: 50px;
	height: 800px;
}
.newsimg_hidden {
	width: 100%;
}
.blue_news {
    top: -100px;
}
.topnews {
	font-size: 80%;
	top: 350px;
    right: 15%;
}
.topnews_bg {
	top: 150px;
	width: 80%;
	padding: 30px;
}
.news_title {
		right: 45%;
}
.newsimg_hidden {
    margin-left: 0;
}
.topnew_img {
    margin-left: -80%;
}
	
/* info */
.new {
    display: block;
}
/* recruit */
.recruit_linkbox {
    position: absolute;
    top: 400px;
    left: 0;
    width: 300px;
    height: 150px;
}
.recruit_linkbox:hover {
	width: 300px;
	height: 150px;
}
.snap_il {
    position: absolute;
    bottom: 20px;
    left: 140px;
    width: 150px;
    height: 100px;
}

/* contact_link */
#contact {
	padding: 50px 0;
}
.contact_box {
	display: block;
}
.form_linkbox {
	width: 100%;
	height: clamp(180px,50%,300px);
}
.form_linkbox:hover {
	width: 100%;
}
.form_icon {
	padding: 0;
}
.tel_box {
	width: 100%;
	height: clamp(180px,50%,300px);
}
.contact_txt {
    font-size: 150%;
    margin-top: 5%;
}
.tel_txt {
	font-size: 80%;
	margin-bottom: 5%;
}

/* footer */
.foot_bg {
    width: 90%;
}

/* ハンバーガーメニュー */
.openbtn {
	display: inline;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 888;
	cursor: pointer;
	width: 50px;
	height: 50px;
}
.openbtn span {
	display: inline-block;
	transition: all.4s;
	position: absolute;
	left: 13px;
	height: 2px;
	border-radius: 5px;
	background: #fff;
	width: 50%;
}
.openbtn span:nth-of-type(1) {
	top: 22px;
}
.openbtn span:nth-of-type(2) {
	top: 29px;
}
.openbtn span:nth-of-type(2)::after {
	content: "MENU";
	position: absolute;
	top: 5px;
	left: -2px;
	color: #fff;
	font-size: 0.6rem;
	letter-spacing: 0;
	text-transform: uppercase;
}
.openbtn.active span:nth-of-type(1) {
	top: 20px;
	left: 16px;
	transform: translateY(6px) rotate(-45deg);
	width: 35%;
}
.openbtn.active span:nth-of-type(2) {
	top: 32px;
	left: 16px;
	transform: translateY(-6px) rotate(45deg);
	width: 35%;
}
.openbtn.active span:nth-of-type(2)::after {
	content: "CLOSE";
	transform: translateY(0) rotate(-45deg);
	top: 5px;
	left: 4px;
}

/* 下層ページハンバーガーメニュー */
.subhead_inner {
	margin: 25px auto 0;
}
.subbtn {
	display: inline;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 888;
	cursor: pointer;
	width: 50px;
	height: 50px;
}
.subbtn span {
	display: inline-block;
	transition: all.4s;
	position: absolute;
	left: 13px;
	height: 2px;
	border-radius: 5px;
	background: #182a44;
	width: 50%;
}
.subbtn span:nth-of-type(1) {
	top: 22px;
}
.subbtn span:nth-of-type(2) {
	top: 29px;
}
.subbtn span:nth-of-type(2)::after {
	content: "MENU";
	position: absolute;
	top: 5px;
	left: -2px;
	color: #182a44;
	font-size: 0.6rem;
	letter-spacing: 0;
	text-transform: uppercase;
}
.subbtn.open span:nth-of-type(1) {
	background: #fff;
	top: 20px;
	left: 16px;
	transform: translateY(6px) rotate(-45deg);
	width: 35%;
}
.subbtn.open span:nth-of-type(2) {
	background: #fff;
	top: 32px;
	left: 16px;
	transform: translateY(-6px) rotate(45deg);
	width: 35%;
}
.subbtn.open span:nth-of-type(2)::after {
	color: #fff;
	content: "CLOSE";
	transform: translateY(0) rotate(-45deg);
	top: 5px;
	left: 4px;
}



html,body.panelactive {
	overflow: auto;
}
.head_inner {
	margin: 0;
}
.logo_box {
	z-index: 999;
	margin: 20px;
}
.logo_box.modal {
	position: fixed;
}
#g-nav {
	position: fixed;
	top: 0;
	z-index: -1;
	opacity: 0;	
	width: 100%;
	height: 100vh;
	background: #15348d;
	transition: all 0.3s;
	color: #fff;
}
#g-nav.panelactive {
	opacity: 1;
	z-index: 888;
}
#g-nav.panelactive #g-nav-list {
	position: fixed;
	z-index: 888;
	width: 100%;
	height: 100vh;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}
#g-nav ul {
	display: none;
	position: absolute;
	z-index: 888;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%)
}
#g-nav a {
	color: #fff;
}
#g-nav.panelactive ul {
	display: block;
}
#g-nav li {
	margin: 20px;
}
.g-nav-li {
	font-size: 10%;
	letter-spacing: 0.5em;
}
.g-nav-foot {
	position: absolute;
	bottom: 10%;
	left: 10%;
	font-size: 10%;
	color: #ccc;
	letter-spacing: 0;
	border-top: 1px solid #ccc;
	width: 80%;
	padding-top: 10px;
}
	
/* 下層ページ共通
----------------------------------------------- */	
.main_title {
	top: 200px;
}
.title_ja {
    font-size: 2vw;
    letter-spacing: 0.5em;
}
.comment_bg {
	padding: 0 0 50px 50px;
}
.comment_en {
	font-size: 3em;
}
.comment_ja {
    font-size: 1.2em;
}
.comment {
    font-size: 0.6em;
}
.blue_hidden {
	width: 250px;
}
.blue_right {
    width: 250px;
    height: 300px;
}
.blue_en {
    padding-top: 120px;
}
.blue_left {
    width: 250px;
    height: 300px;
}
/* aboutページ */
.kokoro {
	font-size: 0.8em;
}
/* message */
#message {
	height: 1000px;
}
.message {
	display: block;
	top: -10px;
}
.message_img {
    width: 70%;
}
.message_txt {
    font-size: 0.4em;
	padding: 10px 10px 30px 10px;
	width: 80%;
}
/* company */
.company {
	display: block;
}
.company_box {
    padding-top: 50px;
    width: 100%;
}
.company_all {
    font-size: 1em;
    font-weight: normal;
}
.company_title {
    width: 120px;
}
.company_detail {
    margin-left: 120px;
}
.company_box2 {
	width: 100%;
}
#company {
	height: 1500px;
}
.company_box2 {
    margin-top: 0;
}
/* facility */
.facility {
    top: 5%;
    left: 5%;
    width: 90%;
    font-size: 0.5em;
}
.facility_box {
    padding: 20px 0 20px 20px;
}
/* sdgsページ */
#sdgs {
    top: -100px;
	height: 1800px;
}
.sdgs_img {
    float: none;
    width: 80%;
    margin: 10% 0 0 10%;
}
.sdgs {
    height: 900px;
    font-size: 1em;
}
.sdgs_txt {
	padding: 30px;
	text-align: center;
}
.sdgs_cat {
    font-size: 0.9rem;
    padding-top: 5%;
}
.sdgs_detail_title {
    padding: 30px 0;
    width: 100%;
	margin: 0;
	font-size: 0.7rem;
}
.sdgs_detail {
    width: 90%;
    height: 1000px;
}

.sdgs_cat3 {
	padding-top: 30%;
}
.sdgs_reiwa {
    display: block;
}
.sdgcat_box {
    width: 100%;
    display: flex;
	margin-left: 5%;
}
.sdgsdetail_txt{
    width: 60%;
    margin-left: 5%;
}
.sdgs_imgbox {
	width: 30%;
}
.sdgs_imgbox img {
	width: 100%;
}
/* info */
.info-list {
    margin: 30px auto 0;
}
.info_line {
    width: 50px;
    margin: 10px 0;
}
/* infodetail */
.infodetail {
    letter-spacing: 0.2em;
}
.info-list {
    padding: 50px;
    letter-spacing: 0;
    font-size: 2vw;
}
/* recruitページ */
#character {
	height: 400px;
}
.character_box2 {
    height: 180px;
}
.character1 {
    top: -10%;
}
.requirement_box {
    margin-left: 10%;
    width: 80%;
}
.character2 {
    width: 15%;
    bottom: 3%;
    left: 5%;
}
.viewmore_box {
    padding: 20px 80px;
}
.viewmore_box:hover:after {
	width:380px;
	height:150px;
}
/* contactページ */
#contact_wrapper {
	overflow: hidden;
	max-width: 100%;
	position: relative;
}
.nyuryoku_bg {
    margin-top: 50px;
}
.nyuryoku {
    top: 5%;
}
.contact_bluebg {
    height: 70px;
}
.contact_telbox {
    font-size: 1em;
}
.kakusyu {
    font-size: 60%;
}
.contact_item {
    letter-spacing: 0.2em;
}
.contact_list::before {
    width: 270px;
}
.contact_ul {
    margin-top: 20%;
}
.contact_form {
	width: 430px;
}
.kakunin_btn {
    width: 430px;
    height: 60px;
}
.kakunin_btn:hover {
	width: 430px;
	height: 90px;
}
.form_items {
    margin-left: 0;
}
.errmessage {
    margin-left: 10%;
}
/* confirmation */
.confirmation_bg {
    height: 1600px;
}
.confirmation {
    height: 1380px;
}
.confir_txt {
    font-size: 0.8em;
    font-weight: bold;
}
.form_kakunin {
    margin: 80px auto;
}
.btn_txt {
	margin-left: 0;
    text-align: center;
    margin-bottom: 10px;
    font-size: 50%;
}
.btn_box {
    width: 400px;
}
.back_btn {
    width: 300px;
    height: 50px;
	color: #182a44;
}
.send_btn {
    width: 500px;
    height: 50px;
	border-radius: 50px;
}
/* complete */
.complete_txt {
	letter-spacing: 0;
}
}
/* max700pxここまで　----------------------------------------------- */



/* max580pxここから　----------------------------------------------- */
@media screen and ( max-width: 580px){
/* Loading アイコンの大きさ設定　*/
#splash_logo svg{
    width:500px;
}
video {
	position: absolute;
	bottom: 0;
	right: -30%;
	z-index: -1;
	min-height: 100%;
	min-width: 100%;
}
.main_message {
	font-size: 120%;
}
.main_message_en {
	font-size: 10%;
	letter-spacing: 0.3rem;
}
/* about */
.snap_linear {
	top: -150px;
}

/* news */
.topnews {
	letter-spacing: 0.3em;
}
	
/* footer */
.contents1,.contents2 {
	font-size: 50%;
    letter-spacing: 0.2em;
}
.comment_en {
	font-size: 1.5em;
}

/* 下層ページ共通 */
.white_leftbox {
    height: 700px;
}
.blue_hidden {
	width: 200px;
}
.blue_right {
    width: 200px;
    height: 250px;
}
.blue_en {
    padding-top: 100px;
    font-size: 0.8em;
}
.blue_ja {
    font-size: 0.5em;
}
.blue_left {
    width: 200px;
    height: 250px;
}

/* about */
.kokoro {
	font-size: 0.5em;
}
.kokoroimg_box {
	top: 450px;
}
/* message */
#message {
	height: 900px;
}

/* company */
#company {
	height: 1300px;
}
.company_all {
	font-size: 0.8em;
    margin: 150px auto;
}
/* sdgsページ */
#sdgs {
    top: -80px;
	height: 1500px;
}
.sdgs {
    height: 800px;
    font-size: 0.8em;
}
.sdgs_detail {
    height: 900px;
}

/* infoページ */
.info_scroll {
	font-size: 3em;
}
/* infodetail */
.infodetail {
    margin: 50px auto;
    background: #fff;
    width: 65%;
    padding: 80px 30px;
    font-size: 2vw;
}
.infodetail_scroll {
    top: 30px;
    font-size: 3em;
}

/* recruitページ */
#requirement {
    height: 900px;
}
.requirement_cat {
    font-size: 1em;
}
.requirement {
    padding-top: 50px;
}
.requirement_box {
    margin-left: 5%;
    width: 90%;
}
.viewmore_box {
    padding: 20px 50px;
}
.viewmore_box:hover:after {
	width:300px;
	height:150px;
}
/* contactページ */
.contact_bluebg {
    width: 85%;
    height: 60px;
}
.contact_telbox {
    font-size: 80%;
}
.uketuke {
	font-size: 50%;
}
/* complete */
.comp {
    font-size: 90%;
}
.comp_txt {
    font-size: 50%;
}
/* privacy */
.privacy {
    width: 90%;
}
}
/* max580pxここまで　----------------------------------------------- */


/* max500pxここから　----------------------------------------------- */
@media screen and ( max-width: 500px){
.works_en {
    font-size: 3vw;
}
/* news */
.topnew_img {
    width: 15%;
    margin-left: -70%;
}
.top_date {
    font-size: 2vw;
}
.top_news_title {
    font-size: 3vw;
}
.newsimg_hidden {
    margin-top: 180px;
}
.info_link {
    font-size: 3vw;
}
/* 下層ページ共通 */
.comment_bg {
    padding: 0 0 30px 30px;
}
.comment_en {
    letter-spacing: 0.2em;
}
.comment_ja {
    font-size: 1em;
}
.blue_hidden {
	width: 150px;
}
.blue_right {
    width: 150px;
    height: 200px;
}
.blue_en {
	padding-top: 80px;
	font-size: 0.5em;
    letter-spacing: 0.5em;
}

.blue_ja {
	font-size: 0.1em;
}
.blue_left {
    width: 150px;
    height: 200px;
}
/* message */
#message {
	height: 760px;
}
.message {
	top: -50px;
}
/* company */
.company_all {
    font-size: 0.3em;
}
.company_title {
    width: 80px;
}
.company_detail {
    margin-left: 80px;
}
.company_title2 {
    width: 80px;
}
.company_detail2 {
	margin-left: 80px;
}
#company {
	height: 1100px;
}
/* facility */
.facility_img_hidden {
    top: -10%;
    width: 200%;
    height: 700px;
}
.facility {
    top: -5%;
    left: 20%;
    width: 60%;
    font-size:2vw;
    display: block;
    padding: 20px 0 20px 50px;
}
.facility_box, .facility_box2 {
    width: 80%;
	padding: 0;
}
/* sdgs */
#sdgs {
	height: 1500px;
}
.sdgs {
    height: 700px;
}
.sdgs_detail_title {
    font-size: 0.5rem;
}
.sdgs_detail {
    height: 950px;
    width: 80%;
}
.sdgcat_box {
    width: 100%;
    display: block;
    margin: 30px auto;
}
.sdgs_imgbox {
    margin: 0 auto;
}
.sdgsdetail_txt {
    width: 80%;
    margin: 0 auto;
}
.sdgs_cat {
    padding: 5%;
}
.sdgs_imgbox3 {
	display: flex;
	margin-left: 20%;
}
/* info */
.info-list {
    padding: 10px;
}
.new_img {
    width: 15%;
    margin-bottom: -30px;
}
/* recruitページ */
#requirement {
    height: 780px;
}
.requirement_cat {
    font-size: 90%;
}
.font_s {
    margin-right: 20px;
}
.requirement_title {
	width: 50px;
}
.requirement {
	top: -10%;
	padding-bottom: 150px;
}
.kakusyu {
    font-size: 50%;
    letter-spacing: 0.1em;
}
/* contactページ */
.contact_bluebg {
    width: 90%;
	padding: 20px 0;
    margin: 20px auto;
}
.kakusyu {
    font-size: 1.8vw;
}
.contact_ul {
    margin-top: 35%;
}
.contact_form {
    width: 300px;
    margin-top: 50px;
}
.contact_item {
	margin: 0 20px;
    letter-spacing: 0;
    font-size: 50%;
}
.contact_list::before {
    width: 150px;
}
.form_input,.form_area {
    width: 90%;
}
.errmessage {
    margin-left: 5%;
    font-size: 0.8em;
}
.privacy_link {
    font-size: 0.8em;
}
.kakunin_btn {
    width: 300px;
    height: 50px;
    font-size: 1em;
}
.kakunin_btn:hover {
	width: 300px;
	height: 80px;
}
/* confirmation */
.confirmation_bg {
    height: 1350px;
}
.confirmation {
    width: 96%;
    left: 2%;
	top: 19%;
    height: 1280px;
}
.confir_ul {
	margin-top: 10px;	
}
.confir_txt {
    font-size: 2vw;
}
.form_kakunin {
    margin: 50px auto;
	width: 80%;
}
.btn_box {
    width: 90%;
    font-size: 2vw;
}
.back_btn {
    width: 40%;
}
.send_btn {
    width: 60%;
}
/* complete */
.complete_bg {
    height: 1000px;
    margin-top: 50px;
}
.comp {
    font-size: 2.5vw;
}
.comp_txt {
    font-size: 1.8vw;
}
.complete {
    width: 96%;
    left: 2%;
	top: 20%;
}
/* privacy */
.privacy_bg {
    padding: 10px 0 20px;
}
.privacy {
    width: 95%;
}
.privacy_txt {
    width: 80%;
	font-size: 2.5vw;
    letter-spacing: 0;
    padding-bottom: 100px;
}
}
/* max500pxここまで　----------------------------------------------- */


/* max400pxここから　----------------------------------------------- */
@media screen and ( max-width: 400px){
/* about */
.philosophy_box {
	background: linear-gradient(#000 30%,transparent);
}
.philosophy {
	padding-top: 10px
}
.snap_linear {
	top: -100px;
}
.about_linkbox {
	bottom: 0;
}

/* works */
#works {
	top: 70px;
}
.works_img {
	width: 100%;
}
.works_linkbox {
    top: 300px;
	right: 0;
}
/* news */
#news {
	height: 700px;
}
.topnews {
	font-size: 50%
}
.news_title {
    right: 35%;
}
.info_link {
	margin: 40px auto;
}
.ii_detail {
	padding: 20px;
}

/* recruit */
.recruit_title{
	top: 100px;
	left: 30%;
}
.recruit_linkbox {
	top: 380px;
	left: 10%;
}
.contents1,.contents2 {
	letter-spacing: 0.2em;
}
.copyright {
	font-size: 2vw;
}
.copy_right {
	font-size: 1vw;
}
/* 下層ページ共通
----------------------------------------------- */
.white_leftbox {
    height: 500px;
}
.main_title {
    top: 170px;
}
.comment_bg {
    padding: 0 0 20px 20px;
}
.comment_en {
    font-size: 120%;
	letter-spacing: 0.2em;
}
.comment_ja {
    font-size: 70%;
}

/* about */
.main_img {
    height: 380px;
}
.makoto_line {
    left: 18px;
}
.wr_mode {
    font-size: 1.2em;
}
.kokoro {
    font-size: 0.2em;
	top: 330px;
	left: 25%;
}
.kokoroimg_box {
	top: 450px;
}
/* message */
#message {
	height: 740px;
}
/* company */
#company {
	height: 1150px;
    top: 50px;
}
.company_box {
    padding-top: 30px;
}
.company_title {
    width: 60px;
}
.company_detail {
    margin-left: 60px;
}
.company_title2 {
    width: 80px;
}
.company_detail2 {
	margin-left: 80px;
}
/* facility */
#facility {
	height: 750px;
}
.facility_img_hidden {
    width: 300%;
}
.facility {
    top: 0;
}

/* access */
.access_map {
    top: 250px;
    width: 80%;
    height: 50px;
    overflow: hidden;
}
.access_img {
    top: 550px;
    right: -20%;
    width: 100%;
}
/* sdgs */
#sdgs {
    height: 1350px;
}
.sdgs {
    height: 600px;
    font-size: 2vw;
    letter-spacing: 0;
}
.sdgs_detail {
    height: 900px;
}
.sdgs_detail_title {
    font-size: 3vw;
}
.sdgs_reiwa {
    font-size: 2.5vw;
}
.sdgs_cat {
    font-size: 0.8rem;
}
/* recruitページ */
#requirement {
    height: 700px;
}
.requirement_title, .requirement_detail {
    font-size: 50%;
}
.viewmore_box {
	font-size: 50%;
    padding: 15px 25px;
}
.viewmore_box:hover:after {
	width:250px;
	height:100px;
}
}
/* max400pxここまで　----------------------------------------------- */