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


/* bootstrap.css基本の打消し（同じclass名での書き換え）
---------------------------------------------------- */
body{ margin:0px; padding:0px;}
h1,h2,h3,h4,h5,h6{ margin:0px; padding:0px; /*font-weight:normal;*/ clear:both}
p{ margin:0px; padding:0px}

.navbar {
  margin-bottom:0px;
  border:none;
}
.table-striped > tbody > tr:nth-of-type(odd) { background-color: #efefef;}
.table{ margin-bottom:30px}
.table th{ width:30%}

@media (min-width: 768px) {.btn-group-vertical a{ padding-top:15px;padding-bottom:15px}}

img.img-fluid {display: block;}


/* 全体構造
---------------------------------------------------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}
.clearfix {
    zoom:1;/*for IE 5.5-7*/
	overflow:hidden;
}
* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}

.clear{clear:both;}

img{border:0;vertical-align:bottom;}

a {
	outline:none;
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

hr {
    display:block;
    height:1px;
    border-top:1px dotted #1e1e1e;
    margin:0;
    padding:0;
	margin-bottom:20px
}

body{
	font-size:85%;/* 基本のフォントサイズ */
	line-height:185%;/* 基本の行間 */
	font-family:FontAwesome, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#1e1e1e;
	letter-spacing: 0.05em;
	background-color: #fff;
}

sup {font-size: 80%;}

header,
main,
footer{
	font-family: "BIZ UDPGothic", sans-serif;
	font-weight: 400;
}

.en{
	font-family: "Roboto", sans-serif;
	font-weight: 700;
}

.ja{
	font-family: "BIZ UDPGothic", sans-serif;
	font-weight: 400;
}


/*アンカーリンクずれ*/
html{
	scroll-padding-top: 0;
}


/* link
---------------------------------------------------- */
a:link,a:visited,a:hover,a:active{text-decoration:none; color:#1e1e1e; }
/*.link_kon a:link,a:visited,a:hover,a:active{text-decoration:none; color:#f58599}*/


/* header
---------------------------------------------------- */
header{
	width: 100%;
	top: 0;
	z-index: 100!important;
	padding-top: 10px;
	padding-bottom: 10px;
	/*position: fixed;*/
	position: relative;
	background: #fff;
	box-shadow: 0px 4px 7px 0px rgba(0, 0, 0, 0.13);
	font-weight: 700;
	border-top:3px solid #ff0000;
}
h1 {
	position: absolute;
	left: 15px;
	top: 7px;
	z-index: 100;
}
h1 a img{
	width: 320px;
	height: auto;
}

@media print, screen and (min-width: 992px) {
	header {height: 130px;}
}
@media print, screen and (min-width: 1200px) {
	header {
		height: 150px;
		padding-top: 15px;
		padding-bottom: 15px;
	}
	h1 a img{ width: 380px;}
}
@media print, screen and (min-width: 1600px) {
	header {height: 150px;}
	h1 { top: 0;}
	h1 a img{ width: 420px;}
}


img.search{
	max-width: 150px;
}
@media print, screen and (min-width: 1200px) {
	img.search{
		max-width: 190px;
	}
}

.head_box{
	display: flex;
	display: -webkit-flex;
	justify-content: flex-end;
	font-size: 85%;
	margin-right: 70px;
}
.head_box > div {margin-left: 10px;}
.head_box > div.saiyou ul{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.head_box > div.saiyou ul {margin-bottom: 10px}
.head_box > div.saiyou ul li{
	margin-right: 5px;
	list-style: none;
}
.head_box > div.entry{
	display: -webkit-flex;
    display: flex;
}
.head_box > div.entry .en{
	margin-top: 3px;
	margin-right: 10px;
}
.head_box > div.entry li {margin-bottom: 5px;}




.career_page .head_box{
	align-items: center;
	margin-top: 16px;
}
.career_page .head_box .btn_head {height: 40px;}
.career_page .head_box > div.entry .en{
	margin-top: 0;
}
.career_page .head_box > div.saiyou ul {
  margin-bottom: 0;
}
@media print, screen and (min-width: 1600px) {
	.head_box{
		font-size: 100%;
		margin-right: 90px;
	}
	.head_box > div {margin-left: 20px;}
}

header .toggle_box{display: none;}

.toggle_box ul{
	    display: -webkit-flex;
    display: flex;
    align-items: center;
	justify-content: center;
	margin-bottom: 20px;
}
.toggle_box ul li{
	margin: 0 10px;
	list-style: none;
}
.toggle_box ul li .bi-instagram {font-size: 30px;}
.toggle_box .search{
	margin: 0 auto;
}
@media print, screen and (min-width: 576px) {
	.toggle_box{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		margin-top: 10px;

	}
	.toggle_box ul{
		margin-bottom: 0;
		margin-right: 20px;
		width: 100%;		
	}
	/*
	.toggle_box >div:last-child{
		margin: 0 0 0 auto;
	}
	*/
}
@media print, screen and (min-width: 992px) {
	.toggle_box{
		margin-top: 30px;
	}
}

.entry_btn{display: none;}
.entry_btn2{display: none;}
@media print, screen and (min-width: 992px) {
	.entry_btn{
		position: fixed;
		right: 0;
		top: 210px;
		color: #fff;
		text-decoration: none;
		background: #ff0000;
	   width:75px;
	   height:120px;
	   /*display:flexで中央配置*/
	   display:flex;
	   align-items:center;
	   justify-content:center;
		text-align: center;
		line-height: 1.4em;
	}
	header.move .entry_btn{top: 80px;}
	.entry_btn a:link,
	.entry_btn a:visited{
		color: #fff;
		border: 1px solid #fff;
		border-radius: 50px;
		padding: 3px 15px;
		margin-top: 5px;
		display: block;
		line-height: 1.4em;
	}
	.entry_btn .title {margin-bottom: 5px; margin-top: 3px;}
	.entry_btn .title span,
	.entry_btn2 .title span{
		display: block;
		font-family: "BIZ UDPGothic", sans-serif;
		font-weight: 700;
		font-size: 90%;
		line-height: 1.4em;
	}
	.entry_btn.h_short .title {margin-bottom: 0;}
	
	
	.entry_btn2{
		position: fixed;
		right: 0;
		top: 210px;
		text-decoration: none;
		background: #ff0000;
		text-align: center;
		line-height: 1.4em;
	   /*display:flexで中央配置*/
	   display:flex;
	   align-items:center;
	   justify-content:center;
	   width:75px;
	   height:75px;
	}
	.entry_btn2 a:link,
	.entry_btn2 a:visited{
		color: #fff;
		display: block;
	   width:75px;
	}
	header.move .entry_btn2{top: 80px;}
	.entry_btn2 .ja {font-weight: 700;}
}
@media print, screen and (min-width: 1200px) {
	.entry_btn {top: 230px;}
	.entry_btn2 {top: 230px;}
}


.saiyou_btn{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	margin-top: 10px;
}
.saiyou_btn p {margin-right: 5px;}
.saiyou_btn .btn1:link,
.saiyou_btn .btn1:visited{
	padding: 10px;
	font-size: 100%;
}

/* navi
---------------------------------------------------- */
@media only screen and (max-width: 991px) {
  .h_logo {
    /*width: 150px;*/
    position: absolute;
    top:2px;
    left: 7px;
    z-index: 100;
  }
	.h_logo a img{
		width: 185px;
	}
	
	header {height: 90px;}
}

/* pc用nav
---------------------------------------------------- */
.menu {
	font-size: 100%;
	position: relative;
	right: 0;
	top: 13px;
	z-index: 1!important;
}
.menu > ul{
	 justify-content: start!important;
}

.menu > ul > li a {color: #1e1e1e; text-align: left!important;}
.menu li.navi-on a{
	color: #ff0000!important;
	opacity: 1;
}
.menu > ul > li { border-bottom: 1px solid #ccc !important;}
.menu > ul > li > ul > li {list-style: none;}
.menu > ul > li > ul > li a {text-align: left!important;}

/*subナビ*/
.menu > ul > li > ul.normal-sub > li {
    width: 100%!important;
	margin: 0!important;
}
.menu > ul > li > ul {
	font-size: 90%;
    width: 100%;
    /*background: #efefef!important;*/
	background: url("../images/filter.png") repeat!important;
    padding: 15px 2px 15px 15px;
	z-index: 200!important;
}
.sub_navi{ display: table;}
.sub_navi .image,
.sub_navi .text{
	display: table-cell;
	vertical-align: middle;
	padding: 0 5px;
}
.sub_navi .image{ width: 80px;}
.sub_navi .title_s{
	font-size: 80%;
	line-height: 1.4em;
}

.menu > ul > li > ul.normal-sub {
  padding: 0!important;
}
.menu > ul > li > ul > li a{
  padding: 15px 5px!important;
}
  .menu > ul > li > ul.normal-sub > li {
      border-bottom: 1px solid #40403d;
      border-right: 1px solid #40403d;
  }
.menu > ul > li.navi-on > ul li a{
	color: #fff!important;
}
.menu > ul > li.navi-on > ul li.navi-on2 a {
  color: #fff!important;
	background-color: #e68fa2!important;
}
@media only screen and (max-width: 991px) {
    .menu-container { margin-top: 0!important;}
	.menu-dropdown-icon > a {margin-left: 30px;}
	/*.menu > ul > li:last-child a {padding: 0!important;}スマホのTEL用*/
}
@media print, screen and (min-width: 576px) {
	/*subナビ*/
	.menu > ul > li > ul.normal-sub > li {
		width: 50%!important;
	}
}
@media print, screen and (min-width: 768px) {
	/*subナビ*/
	.menu > ul > li > ul.normal-sub > li {
		width: 31.3%!important;
	}
}
@media print, screen and (min-width: 992px) {
	.menu {font-size: 95%; top: 70px; }
	.career_page .menu {top: 30px;}
    .menu-container { margin-top: 0!important;}
	.menu .show-on-mobile {padding-top:10px!important;}
	/*
	.menu > ul{
		margin: 0 auto;
	}
	*/
	
	.menu > ul i {padding-left: 5px;}
	/*.menu > ul > li {float: right;}グローバルナビのみ右寄せにするために*/
	.menu > ul > li a{
		padding: 3px 0!important;
		text-align: center!important;
		margin-right: 16px;
		margin-top: 0;/*表示位置調整用*/
	}
	.menu > ul > li:last-child a {margin-right: 0;}
	/*
	.menu > ul > li a:hover,
	.menu li.navi-on a{
		background: url(../images/navi-on.gif) repeat-x bottom;
		color: #1e1e1e!important;
	}
	*/
	.menu > ul > li a:hover li a,
	.menu li.navi-on ul li a{
		background: none!important;

	}
	.menu > ul > li > ul > li a {width: 100%!important;}
	.menu > ul > li > ul > li a:hover,
	.menu li > ul > li.navi-on a{
		background: none;
		color: #e68fa2!important;
	}
	.menu > ul > li { border-bottom: none !important;}
	
	/*subナビ*/
	.menu > ul > li > ul.normal-sub > li {
		width: 50%!important;
	}
	.menu > ul > li > ul.normal-sub > li a{
		padding: 15px!important;
		text-align: center!important;
		margin-right: 0!important;
		margin-left: 0;
		margin-top: 0;/*表示位置調整用*/
		margin-bottom: 0;/*表示位置調整用*/
	}
	.sub_navi .image,
	.sub_navi .text{
		display: table-cell;
		vertical-align: middle;
		padding: 0 5px;
	}
	.sub_navi .image{ width: 90px;}
	.sub_navi .title_s{
		font-size: 90%;
		line-height: 1.4em;
	}
	.sub_navi .title{
		font-size: 120%;
		line-height: 1.4em;
	}
	
	/*subナビ*/
	.menu > ul > li > ul.normal-sub > li {
		/*width: 33.3%!important;*/
		width: 25%!important;
	}
	.sub_navi .image{ width: 100px;}
	.sub_navi .title_s{ font-size: 70%;}
	.sub_navi .title{ font-size: 110%;}
	
	.menu > ul > li > ul.normal-sub.niko > li {
	  width: 50% !important;
	}	
	
	.menu > ul > li.navi-on > ul li.navi-on2 a {
		/*background-color: #323237!important;*/
		background: none!important;
		color: #ff0000!important;
	}
	
	
	
/*ホバー*/
	.menu > ul > li > a{
		position: relative;
		text-decoration: none;
	}
	.menu > ul > li > a::after {
	  background-color: #1e1e1e; /* 下線の色 */
	  bottom: -2px; /* 要素の下端からの距離 */
	  content: ""; /* 要素に内容を追加 */
	  height: 1px; /* 下線の高さ */
	  left: 0; /* 要素の左端からの距離 */
	  position: absolute; /* 絶対位置指定 */
	  transform: scale(0, 1); /* 下線を横方向に0倍、縦方向に1倍に変形（非表示） */
	  transform-origin: left top; /* 変形の原点を左上に指定 */
	  transition: transform .3s; /* 変形をアニメーション化 */
	  width: 100%; /* 要素の幅 */
	}
	/* リンクにホバーした際の下線の表示 */
	.menu > ul > li > a:hover::after {
	  transform: scale(1, 1); /* 下線を横方向に1倍、縦方向に1倍に変形（表示） */
	}
	
	.menu > ul > li.navi-on > a::after{
	  background-color: #ff0000; /* 下線の色 */
	  bottom: -2px; /* 要素の下端からの距離 */
	  content: ""; /* 要素に内容を追加 */
	  height: 1px; /* 下線の高さ */
	  left: 0; /* 要素の左端からの距離 */
	  position: absolute; /* 絶対位置指定 */
	  transform: scale(1, 1); /* 下線を横方向に0倍、縦方向に1倍に変形（非表示） */
	  transform-origin: left top; /* 変形の原点を左上に指定 */
	  transition: transform .3s; /* 変形をアニメーション化 */
	  width: 100%; /* 要素の幅 */
	}
	.menu > ul > li.navi-on > span a .text::after{
	  background-color: #ff0000; /* 下線の色 */
	  bottom: -6px; /* 要素の下端からの距離 */
	  content: ""; /* 要素に内容を追加 */
	  height: 1px; /* 下線の高さ */
	  left: 0; /* 要素の左端からの距離 */
	  position: absolute; /* 絶対位置指定 */
	  transform: scale(1, 1); /* 下線を横方向に0倍、縦方向に1倍に変形（非表示） */
	  transform-origin: left top; /* 変形の原点を左上に指定 */
	  transition: transform .3s; /* 変形をアニメーション化 */
	  width: 100%; /* 要素の幅 */
	}
	
	
	
	.menu > ul > li.sen_none > a::after {
	  display: none;
	}
	
}
@media print, screen and (min-width: 1200px) {
	.menu { font-size: 110%;top: 80px; }
	.menu > ul > li a{
		margin-right: 20px;
	}
}
@media print, screen and (min-width: 1600px) {
	.menu {
		top: 78px;
		font-size: 120%;
	}
	.menu > ul > li a{
		margin-right: 60px;
	}
	.career_page .menu {top: 50px;}
}



/*追記*/
.menu > ul > li > ul > li{width: 100%!important;}
.menu > ul > li > ul.sub-menu {
	/*padding: 15px 15px!important;*/
}
/*スマホ用TELとLINE*/
.sp_box{
	padding: 15px 10px!important;
}


/*展開後の中身*/
.sub_nakami{
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
}


.sub_nakami .box{
	margin: 2% 20px;
}
.sub_nakami .box h3{
	font-size: 140%;
	line-height: 1.4em;
	margin-bottom: 15px;
	font-weight: 700;
	color: #fff;
}


.sub_nakami .box ul{
	margin-left: -1.5%;
	margin-right: -1.5%;
}
.sub_nakami .box ul li{
	list-style: none;
	width: 13.66%;
	float: left;
	margin:0 1.5%;
}
.sub_nakami .box ul li:nth-of-type(6n+1) { clear: both;}


.sub_nakami .box ul li a{
	width: 100%;
	padding: 0 0 20px 0!important;
	margin: 0 0 20px 0!important;
	font-weight: 400;
	border-bottom: none!important;
}
.sub_nakami .box ul li a:link,
.sub_nakami .box ul li a:visited{
	color: #fff;
	text-decoration: none;
	font-size: 100%;
	line-height: 1.4em;
}
.sub_nakami .box ul li a:hover,
.sub_nakami .box ul li.navi-on2 a{
	color: #ff0000!important;
	text-decoration: none;
}
.sub_nakami .box ul li a img{
	width: 100%;
	height: auto;
	margin-bottom: 15px;
}
@media print, screen and (min-width: 1200px) {
	.sub_nakami .box{
		margin: 2% 2.5%;
	}
	.sub_nakami .box h3{
		font-size: 160%;
		margin-bottom: 30px;
	}
	/*
	.sub_nakami .box ul li{
		width: 17%;
	}
	.sub_nakami .box ul li:nth-of-type(4n+1) { clear: none;}
	.sub_nakami .box ul li:nth-of-type(5n+1) { clear: both;}
	*/
	
}
@media print, screen and (min-width: 1600px) {
	.sub_nakami .box h3{
		font-size: 180%;
	}
	/*
	.sub_nakami .box ul li a:link,
	.sub_nakami .box ul li a:visited{
		font-size: 110%;
	}
	*/
}

.menu > ul > li > ul > li a {
  border-bottom: 1px solid #40403d!important;
}


/* トグルナビ
---------------------------------------------------- */
.head_in{
	width: 100%;
	padding-top: 0;
	padding-bottom: 0;
	position: fixed;
	background:none;
	top: 0;
	z-index: 100!important;
}

/* ついてくるナビ
---------------------------------------------------- */
.global-nav {
  position: fixed;
  /* right: -320px; これで隠れる */
	right: -100%;
  top: 0;
   /*width: 300px; スマホに収まるくらい */
	width: 100%;
  height: 100%;
  padding-top: 40px;
  display: flex;
  flex-direction: column;
  background-color: #fff;
  transition: all .6s;
  z-index: 200;
  overflow-y: auto; /* メニューが多くなったらスクロールできるように */
}
.global-nav .container {
  margin-top: auto;
  margin-bottom: auto;
}
/* スクロールバー　デザイン */
.global-nav {
  scrollbar-color: rgba(0,0,0,0.1) rgba(0,0,0,0.05);
  scrollbar-width: thin;
}
.global-nav::-webkit-scrollbar {
  width: 5px;
  height: 5px;
  /* display: none; // 消す場合は有効してください */
}
.global-nav::-webkit-scrollbar-track {
  background: rgba(0,0,0,0.05);
}
.global-nav::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.1)
}


.hamburger {
  position: fixed;
  right: 7px;
  top: 20px;
  width: 55px; /* クリックしやすいようにちゃんと幅を指定する */
  height: 55px; /* クリックしやすいようにちゃんと高さを指定する */
  cursor: pointer;
  z-index: 300;
  background-color: #1e1e1e;
  /*border-radius: 5px;*/
	border-radius: 0;
}
@media print, screen and (min-width: 576px) {
	.hamburger { right: 10px;}
}
@media print, screen and (min-width: 992px) {
	.hamburger { top: 130px; right: 0; }
	header.move .hamburger {top: 0;}
}
@media print, screen and (min-width: 1200px) {
	.hamburger { top: 150px;}
}

.global-nav__list {
  margin: 0;
  padding: 0;
  list-style: none;
}
.global-nav__item {
  text-align: center;
  padding: 0 14px;
}
.global-nav__item a {
  display: block;
  padding: 8px 0;
  /*border-bottom: 1px solid #eee;*/
  border-bottom: 1px solid #d2c5b2;
  text-decoration: none;
  color: #524631;
}
.global-nav__item a:hover,
.global-nav__item.navi-on a{
  /*background-color: #eee;*/
  background-color: #fff;
}
.hamburger__line {
  position: absolute;
  left: 13px;
  width: 28px;
  height: 1px;
  background-color: #fff;
  transition: all .6s;
}
.hamburger__line--1 {
  top: 16px;
}
.hamburger__line--2 {
  top: 22px;
}
.hamburger__line--3 {
  top: 28px;
}
.hamburger__moji {
  position: absolute;
  left: 12px;
  width: 25px;
  transition: all .6s;
	white-space: nowrap;
}
.hamburger__line--moji {
  top: 28px;
  color: #fff;
  font-size: 60%;
	font-family: "BIZ UDPGothic", sans-serif;
	font-weight: 700!important;
}
@media print, screen and (min-width: 992px) {
	.hamburger__line--moji {
	  font-size: 60%;
	}
}

@media only screen and (max-width: 767px) {
	.hamburger {
	  right: 15px;
	  top: 20px;
	  width: 40px; /* クリックしやすいようにちゃんと幅を指定する */
	  height: 42px; /* クリックしやすいようにちゃんと高さを指定する */
		background: none;
	}
	
	.hamburger__line {
	  height: 3px;
	  background-color: #333;
	}
	.hamburger__line--moji {
	  color: #333;
	font-size: 7.5px;
	}
	
	.hamburger__line--1 {
	  top: 12px;
	}
	.hamburger__line--2 {
	  top: 18.7px;
	}
	.hamburger__line--3 {
	  top: 25.7px;
	}
	.hamburger__line--moji {
	  top: 28px;
	}
	
	.hamburger__line {
	  left: 17px;
	  width: 20px;
	}
}



.black-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100;
  background-color: #524631;
  opacity: 0;
  visibility: hidden;
  transition: all .6s;
  cursor: pointer;
}
@media print, screen and (min-width: 992px) {
	.global-nav {
	  padding-top: 80px;
	}
	.global-nav__item a {
	  padding: 16px 0;
	}
	.hamburger {
	  width: 75px; /* クリックしやすいようにちゃんと幅を指定する */
	  height: 80px; /* クリックしやすいようにちゃんと高さを指定する */
	}
	.hamburger__line {
	  left: 23px;
	  width: 30px;
	}
	.hamburger__line--1 {
	  top: 25px;
	}
	.hamburger__line--2 {
	  top: 33px;
	}
	.hamburger__line--3 {
	  top: 41px;
	}
	.hamburger__moji {
	  left: 23px;
	  width: 25px;
	}
	.hamburger__line--moji {
	  top: 45px;
	}
}
/* 表示された時用のCSS */
.nav-open .global-nav {
  right: 0;
	background-color: #fff;
	opacity: 0.8;
}
.nav-open .black-bg {
  opacity: .8;
  visibility: visible;
}
.nav-open .hamburger__line--1 {
  transform: rotate(45deg);
  top: 20px;
}
.nav-open .hamburger__line--2 {
  width: 0;
  left: 50%;
}
.nav-open .hamburger__line--3 {
  transform: rotate(-45deg);
  top: 20px;
}
@media print, screen and (min-width: 992px) {
	.nav-open .hamburger__line--1 {
	  top: 33px;
	}
	.nav-open .hamburger__line--3 {
	  top: 33px;
	}
}


/*スクロール後固定*/
.navi_nakami{
	padding: 30px 0 20px 0;
	width: 100%;
	margin: 0 auto;
	font-family: "BIZ UDPGothic", sans-serif;
	font-weight: 400;
}
@media print, screen and (min-width: 768px) {
	.navi_nakami{
		padding: 0 0 20px 0;
	}
}
@media print, screen and (min-width: 1600px) {
	.navi_nakami{
		padding: 0 20px 20px 20px;
	}
}


.navi_nakami .name{
	max-width: 500px;
	margin: 0 auto 30px auto;
	font-weight: 700;
}
.navi_nakami .name img{
	width: 100%;
	height: auto;
	margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
	.navi_nakami .name{
		margin: 0 auto 30px 0;
	}
}



.nakami_navi .box {
	border-bottom: 1px solid #ccc;
	padding: 30px 20px 20px 20px;
}
.nakami_navi .navi-on a{
	color: #ff0000;
}

.nakami_navi .box li,
.nakami_navi2 li{list-style: none;}

.nakami_navi .box h3{
	font-size: 140%;
	color: #000;
	margin-bottom: 15px;
	font-weight: 700;
}
.nakami_navi .box h3.mb0{
	margin-bottom: 10px;
}
.nakami_navi .box h4{
    font-weight: 700;
    font-size: 120%;
    line-height: 1.4em;
    display: -webkit-flex;
    display: flex;
    align-items: center;
	margin-bottom: 15px;
}
.nakami_navi .box h4:before {
  border-top: 1px solid;
  content: "";
  width: 1em; /* 線の長さ*/
}
.nakami_navi .box h4:before {
  margin-right: 1em; /* 文字の右隣 */
}

.nakami_navi .box ul.sub li{
	font-size: 100%;
	margin: 5px 0;
}
.nakami_navi .box ul.sub li a:before{
	font-family: bootstrap-icons;
	font-weight: 400;
	content: "\F285";
	margin-right: 5px;
	font-size: 8px;
}

.nakami_navi .box ul li a:link,
.nakami_navi .box ul li a:visited{
	color: #1e1e1e;
}
.nakami_navi .box ul li a:hover,
.nakami_navi .box ul li.navi-on a{
	color: #ff0000;
	opacity: 1;
}

/*2*/
.nakami_navi2{
	margin: 30px 20px 20px 20px;
}
.nakami_navi2 li{margin-bottom: 5px; font-size: 110%; font-weight: 700;}
.nakami_navi2 li a:before{
	font-family: bootstrap-icons;
	font-weight: 400;
	content: "\F285";
	margin-right: 5px;
	font-size: 8px;
}

.nakami_navi2 li a:link,
.nakami_navi .box ul li a:visited{
	/*color: #1e1e1e;*/
}
.nakami_navi2 li a:hover,
.nakami_navi2 li.navi-on a{
	color: #ff0000!important;
	opacity: 1;
}



.nakami_navi .box ul.sub.narabi3_768 li{
    width: 48%;
    float: left;
}
.nakami_navi .box ul.sub.narabi3_768 li:nth-of-type(2n+1) { clear: none;}

@media print, screen and (min-width: 768px) {
	.nakami_navi{
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.nakami_navi .box {width: 100%;}
	
	
	.nakami_navi .box ul.sub li{
		width: 50%;
		float: left;
	}
	.nakami_navi .box ul.sub.none li{
		width: 100%;
		float: none;
	}
	.nakami_navi .box ul.sub li:nth-of-type(2n+1) { clear: both;}
	
	.nakami_navi2 li{
		width: 50%;
		float: left;
	}
	.nakami_navi2 li:nth-of-type(2n+1) { clear: both;}

}
@media print, screen and (min-width: 768px) {
	.nakami_navi .box ul.sub.narabi3_768 li{
		width: 33.33%;
	}
	.nakami_navi .box ul.sub.narabi3_768 li:nth-of-type(2n+1) { clear: none;}
	.nakami_navi .box ul.sub.narabi3_768 li:nth-of-type(3n+1) { clear: both;}

	.nakami_navi2 li{
		width: 33.3%;
	}
	.nakami_navi2 li:nth-of-type(2n+1) { clear: none;}
	.nakami_navi2 li:nth-of-type(3n+1) { clear: both;}
	
}
@media print, screen and (min-width: 992px) {
	.nakami_navi .box {
		padding: 35px 20px;
		font-size: 110%;
	}
	.nakami_navi2{
		margin: 35px 20px 20px 20px;
	}
	
	.nakami_navi .box ul.sub li{
		width: 33.3%;
	}
	.nakami_navi .box ul.sub li:nth-of-type(2n+1) { clear: none;}
	.nakami_navi .box ul.sub li:nth-of-type(3n+1) { clear: both;}
	
}
@media print, screen and (min-width: 1200px) {
	.nakami_navi .box {
		font-size: 120%;
	}
	.nakami_navi .box h3{
		font-size: 160%;
		margin-bottom: 20px;
	}
}

@media print, screen and (min-width: 1600px) {
	.nakami_navi .box ul.sub li{
		width: 23%;
	}
	.nakami_navi .box ul.sub li:nth-of-type(3n+1) { clear: none;}
	.nakami_navi .box ul.sub li:nth-of-type(4n+1) { clear: both;}
	
	.nakami_navi .box ul.sub.narabi3_768 li{
		width: 23%;
	}
	.nakami_navi .box ul.sub.narabi3_768 li:nth-of-type(3n+1) { clear: none;}
	.nakami_navi .box ul.sub.narabi3_768 li:nth-of-type(4n+1) { clear: both;}
	
	.nakami_navi2 li{
		width: 23%;
	}
	.nakami_navi2 li:nth-of-type(3n+1) { clear: none;}
	.nakami_navi2 li:nth-of-type(4n+1) { clear: both;}
}



/*-----------------スマホのトグル-----------------*/
.menu-mobile {height: 60px;}
.menu-mobile::after {
  content: ""!important;
  padding: 0;
	background-image: -webkit-linear-gradient( 0deg, rgb(22,45,87) 0%, rgb(0,200,255) 0%, rgb(17,228,151) 100%);
	-moz-background-size:100% auto;
	background-size:100% auto; 
	width: 65px;
	height: 70px;
	 margin-right: -15px!important;
	 margin-top: -23px!important;

}
.menu-mobile {
  padding: 0!important;
}




/* midashi
---------------------------------------------------- */
.fs60 {font-size:60%; line-height: 1.6em;}
.fs70 {font-size:70%;}
.fs75 {font-size:75%;}
.fs80 {font-size:80%; line-height: 1.6em;}
.fs80 {font-size:80%; line-height: 1.6em;}
.fs85 {font-size:85%;}
.fs90 {font-size:90%;}
.fs110 {font-size:110%; line-height:1.6em;}
.fs120 {font-size:120%;}
.fs140 {font-size:130%; line-height:1.6em;}
.fs160 {font-size:160%;}
.fs180 {font-size:180%;}

.fs250 {font-size:180%; line-height:1.0em;}
@media print, screen and (min-width: 768px) {
	.fs250 {font-size:250%;}
}

.fs100_sm90_md90_lg100 {font-size: 100%;}
@media print, screen and (min-width: 768px) {
	.fs100_sm90_md90_lg100 {font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs100_sm90_md90_lg100 {font-size: 100%;}
}

@media print, screen and (min-width: 768px){
	.fs90_smmd{ font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs90_smmd{ font-size: 100%;}
}

.fs60_sm80_md70{font-size: 80%;}
@media print, screen and (min-width: 992px){
	.fs60_sm80_md70{font-size: 70%;}
}
@media print, screen and (min-width: 1200px) {
	.fs60_sm80_md70{font-size: 60%;}
}

.fs160_sp140 {font-size: 140%;}
@media print, screen and (min-width: 768px) {
	.fs160_sp140 {font-size: 160%;}
}

.text_large{font-size: 110%; line-height: 1.6em;}
@media print, screen and (min-width: 768px) {
	.text_large{font-size: 120%;}
}


.normal {font-weight: 400;}

@media print, screen and (min-width: 768px){
	.text_pl {padding-left: 20px;}
	.text_pr {padding-right: 20px;}
}
@media print, screen and (min-width: 1200px){
	.text_pl {padding-left: 40px;}
	.text_pr {padding-right: 40px;}
}


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

/*タイトルエフェクト*/
.title {display: inline-block;}
.block-revealer__element {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #1e1e1e;
    pointer-events: none;
    opacity: 0;
}

/* 画像を使うときはvertical-align bottomをしないと下に余白ができてしまうので注意！！ */
.revealImg {
    width: 300px;
    height: 200px;
    -o-object-fit: cover;
       object-fit: cover;
    vertical-align: bottom;
}

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




.pankuzu{
	font-size: 85%;
	font-family: "BIZ UDPGothic", sans-serif;
	font-weight: 700;
	margin: 15px 0;
	color: #1e1e1e;
	text-align: right;
}
.pankuzu a:link,
.pankuzu a:visited{
	text-decoration: underline;
	color: #666;
	font-weight: 700;
}

.pankuzu i {color: #666; padding: 0 3px;}
@media print, screen and (min-width: 992px){
	.pankuzu{
		margin: 25px 0;
	}
}




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

.midashi_en{
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-size: 250%;
	line-height: 1.2em;
}
.midashi_en2{
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-size: 140%;
	line-height: 1.4em;
}
.midashi_en3{
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-size: 200%;
	line-height: 1.4em;
}
.midashi_en4{
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-size: 200%;
	line-height: 1.4em;
}

.midashi_en5{
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-size: 200%;
	line-height: 1.4em;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.midashi_en5 i{
	color: #ff0000;
	font-size: 10px;
	margin-right: 10px;
}

.midashi_num{
	min-width: 50px;
	max-width: 50px;
	width:50px;
   height:50px;
   border-radius:50%;
   background:#ff0000;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-size: 120%;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
}


.midashi1{
    font-weight: 700;
    font-size: 100%;
    line-height: 1.4em;
}

.midashi2{
    font-weight: 700;
    font-size: 150%;
    line-height: 1.4em;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.midashi2.tac{
    justify-content: center;
}
.midashi2 i{
	color: #ff0000;
	font-size: 8px;
	margin-right: 10px;
}
.midashi2 .fs70{
	margin-left: 10px;
}

.midashi3{
    font-weight: 700;
    font-size: 130%;
    line-height: 1.4em;
}

.midashi4{
    font-weight: 700;
    font-size: 120%;
    line-height: 1.4em;
    display: -webkit-flex;
    display: flex;
    align-items: center;
}
.midashi4:before {
  border-top: 1px solid;
  content: "";
  width: 1em; /* 線の長さ*/
}
.midashi4:before {
  margin-right: 0.5em; /* 文字の右隣 */
}
.midashi4.normal {font-size: 90%;}

.midashi5{
    font-weight: 700;
    font-size: 105%;
    line-height: 1.4em;
}


.midashi6{
    font-weight: 700;
    font-size: 130%;
    line-height: 1.4em;
	border-left: 4px solid #ff0000;
	padding-left: 12px;
}
.midashi6 .midashi8{
    font-size: 10px;
	vertical-align: middle;
	margin-left: 10px;
	padding: 3px 5px;
}

.midashi7{
    font-weight: 700;
    font-size: 130%;
    line-height: 1.4em;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.midashi7.sen{
	border-bottom: 1px solid #1e1e1e;
	padding-bottom: 10px;
}


.sen_color1 .midashi7.sen{ border-bottom: 1px solid #5bb3bc;}
.sen_color2 .midashi7.sen{ border-bottom: 1px solid #d05f52;}
.sen_color3 .midashi7.sen{ border-bottom: 1px solid #2674ab;}


.midashi7 i{
	color: #ff0000;
	font-size: 8px;
	margin-right: 10px;
}

.midashi8{
	border: 1px solid #ff0000;
	color: #ff0000;
	border-radius: 50px;
	padding: 3px 15px;
	display: inline-block;
	line-height: 1.4em;
}

.midashi9{
    font-weight: 700;
    font-size: 120%;
    line-height: 1.4em;
    display: -webkit-flex;
    display: flex;
    align-items: center;
}
.midashi9 .icon{
	min-width: 35px;
	max-width: 35px;
width:35px;
   height:35px;
   border-radius:50%;
   background:#ff0000;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	margin-right: 15px;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
}

.midashi10{
    font-weight: 700;
    font-size: 120%;
    line-height: 1.4em;
	display: inline-block;
	padding-bottom: 5px;
}


.title_sen {
  position: relative;
  text-align: center; /* 文字の中央寄せ */
}
.title_sen::before {
  background-color: #1e1e1e; /* 線の色 */
  bottom: -20px; /* 線の位置 */
  content: "";
  height: 1px; /* 線の高さ */
  left: 50%; /* 線の中央寄せ */
  position: absolute;
  transform: translateX(-50%); /* 線の中央寄せ */
  width: 30px; /* 線の長さ */
}


.marker_line{background:rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #FFDFEF 0%) repeat scroll 0 0;}


@media print, screen and (min-width: 576px) {
	.midashi_en{ font-size: 300%;}
}
@media print, screen and (min-width: 768px) {
	.pl_text {padding-left: 15px;}
	.pr_text {padding-right: 15px;}
	
	.midashi_en3{ font-size: 230%;}
	
	
	.midashi1{
		font-weight: 700;
		font-size: 120%;
		line-height: 1.4em;
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.midashi1:before {
	  border-top: 1px solid;
	  content: "";
	  width: 1em; /* 線の長さ*/
	}
	.midashi1:before {
	  margin-right: 0.5em; /* 文字の右隣 */
	}
	
	.midashi2{ font-size: 200%;}
	.midashi3{ font-size: 150%;}
	.midashi6{ font-size: 150%;}
	.midashi7{ font-size: 150%;}
	
}
@media print, screen and (min-width: 992px) {
	.pl_text {padding-left: 25px;}
	.pr_text {padding-right: 25px;}
	
	.midashi_en3{ font-size: 260%;}
	.midashi_en5{ font-size: 250%;}
	
	.midashi3{ font-size: 170%;}
}
@media print, screen and (min-width: 1200px) {
	.midashi_en{ font-size: 350%;}
	.midashi_en2{ font-size: 160%;}
	.midashi_en3{ font-size: 330%;}
	.midashi2{ font-size: 200%;}
	.midashi6 .midashi8{
		font-size: 12px;
		padding: 3px 10px;
	}
}
@media print, screen and (min-width: 1600px) {
	.midashi_en{ font-size: 380%;}
	.midashi2{ font-size: 250%;}
}


@media print, screen and (min-width: 768px) {
	.title_narabi{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		white-space: nowrap;
	}
	.title_narabi > div:last-child {margin-left: auto;}
	.title_narabi > .last {margin-left: auto;}
}
@media print, screen and (min-width: 1200px) {
	.title_narabi > div.migiyohaku:last-child {margin-left: 20%;}
}

.title_narabi2{
    display: -webkit-flex;
    display: flex;
    align-items: center;
}
.title_narabi2 .first {margin-right: 20px;}




.underline-before {

	background: linear-gradient(#1e1e1e, #1e1e1e) 0 100%/0 2px no-repeat;
	/*左から、カラー（始点と終点それぞれ同じものを指定）、position / サイズ横縦 繰り返しの有無 */

	transition: background 3s;
	/*トランジションの設定。下線を引く動きをアニメーションにするのに必要 */

	text-decoration: none;
	/*テキストの装飾の設定 */
}

.underline-after {
	background-size: 100% 2px;
  /* 変化後のスタイル。横サイズを0から100%に変えることで指定の文字列に下線を引く */
}



/* マーカーのスタイル */
.marker {
  background-image: linear-gradient(90deg, #c1eafa, #c1eafa); /* 線の色 */
  background-position: left bottom; /* 線の起点を左・下に設定 */
  background-repeat: no-repeat;
  background-size: 0 .5em; /* 線の横幅を0、縦幅を0.5emに */
  padding-bottom: 3px; /* 下線を下にズラす */
  transition: background-size 3s; /* 線を伸ばすアニメーション実行時間を指定 */
}
.marker.sen {
  background-image: linear-gradient(90deg, #00aaeb, #00aaeb); /* 線の色 */
  background-position: left bottom; /* 線の起点を左・下に設定 */
  background-repeat: no-repeat;
  background-size: 0 .3em; /* 線の横幅を0、縦幅を0.5emに */
  padding-bottom: 6px; /* 下線を下にズラす */
  transition: background-size 2s; /* 線を伸ばすアニメーション実行時間を指定 */
}
/* マーカーが表示された時のスタイル */
.marker.active {
  background-size: 100% .5em; /* 線の横幅を100%にする */
}
.marker.sen.active {
  background-size: 100% .2em; /* 線の横幅を100%にする */
}


/*リンク・ボタン関係
---------------------------------------------------- */
a:hover{opacity:0.7;filter: alpha(opacity=70);/*transition: 0.5s;*/}

.btn{ padding-top:10px; padding-bottom:10px;}
@media print, screen and (min-width: 768px) {.btn{ padding:10px 25px;}}

.btn.dsb_sp {display: block;}
@media print, screen and (min-width: 768px) {.btn.dsb_sp {display: inline-block;}}

.btn_area{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.btn_area >div:first-child {margin-right: 10px;}


.button1 {
  width:max-content;
  height:auto;
  position:relative
}
.button1 a {
  font-size:100%;
  font-weight:700;
  letter-spacing:0;
  line-height:1.5;
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:color .2s cubic-bezier(0.33, 1, 0.68, 1);
	background-color: #1e1e1e;
	padding: 8px 8px 8px 28px;
	border-radius: 50px;
}
.button1.en a{font-size: 90%;}
.button1 a:link,
.button1 a:visited{
	text-decoration: none;
	color: #fff;
}
.button1 a:hover {
  color:#ff0000;
  opacity:1
}
.button1 a .arrow {
  width:32px;
  height:32px;
  margin-left:30px;
  transition:width .2s cubic-bezier(0.33, 1, 0.68, 1),height .2s cubic-bezier(0.33, 1, 0.68, 1)
}
.button1 a .arrow i {
	color: #fff;
}
.button1 a:hover .arrow {
  width:40px;
  height:40px;
}



.mannaka .button1,
.mannaka .button2,
.mannaka .button3{
	margin: 0 auto;
}


.button2 {
  width:max-content;
  height:auto;
  position:relative
}
.button2 a {
  font-size:100%;
  font-weight:700;
  letter-spacing:0;
  line-height:1.5;
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:color .2s cubic-bezier(0.33, 1, 0.68, 1);
	background-color: #ff0000;
	padding: 8px 8px 8px 28px;
	border-radius: 50px;
}
.button2.en a{font-size: 90%;}
.button2 a:link,
.button2 a:visited{
	text-decoration: none;
	color: #fff;
}
.button2 a:hover {
  color:#1e1e1e;
  opacity:1
}
.button2 a .arrow {
  width:32px;
  height:32px;
  margin-left:30px;
  transition:width .2s cubic-bezier(0.33, 1, 0.68, 1),height .2s cubic-bezier(0.33, 1, 0.68, 1)
}
.button2 a .arrow i {
	color: #fff;
}
.button2 .arrow::before {
  background-color:#1e1e1e
}

.button2 a:hover .arrow {
  width:40px;
  height:40px;
}




.button3 {
  width:max-content;
  height:auto;
  position:relative
}
.button3 a {
  font-size:100%;
  font-weight:700;
  letter-spacing:0;
  line-height:1.5;
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:color .2s cubic-bezier(0.33, 1, 0.68, 1);
	padding: 8px 18px 8px 38px;
	border-radius: 50px;
	border-collapse: collapse;
	border: 1px solid #fff;
}
.button3.en a{font-size: 90%;}
.button3 a:link,
.button3 a:visited{
	text-decoration: none;
	color: #fff;
}
.button3 a:hover {
  color:#1e1e1e;
  opacity:1
}
.button3 a .arrow {
  width:32px;
  height:32px;
  margin-left:30px;
  transition:width .2s cubic-bezier(0.33, 1, 0.68, 1),height .2s cubic-bezier(0.33, 1, 0.68, 1)
}
.button3 a .arrow i {
	color: #fff;
}
.button3 .arrow::before {
  background-color:#1e1e1e
}
.button3 a:hover .arrow {
  width:40px;
  height:40px;
}


.arrow {
  display:flex;
  justify-content:center;
  align-items:center;
  flex-shrink:0;
  width:24px;
  height:24px;
  position:relative;
  border-radius:50%
}
.arrow::before {
  content:"";
  width:100%;
  height:100%;
  position:absolute;
  inset:0 auto auto 0;
  background-color:#ff0000;
  border-radius:50%;
  transition:transform .64s cubic-bezier(0, 0.55, 0.45, 1)
}
.arrow.red::before {
  background-color:#ff0000
}
.arrow.red i {
  fill:#1e1e1e
}
.arrow.gray::before {
  background-color:#f6f6f6
}
.arrow.gray i {
  fill:#ff0000
}
.arrow.white::before {
  background-color:#1e1e1e
}
.arrow.white i {
  fill:#ff0000
}
.arrow i {
  fill:#1e1e1e;
  position:relative
}





.btn1{
	font-size: 120%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
	font-weight: 500;
}
.btn1:link,
.btn1:visited{
	color:#fff;
	padding:10px 50px;
	text-decoration: none;
	z-index: 2;
	background: #ff0000
}
.btn1:hover{
	opacity: 1;
	background-color: #0b0b0b;
}


.btn1 i {
	border-left: 1px solid #1e1e1e;
	padding-left: 10px;
	margin-left: 20px;
	font-size: 120%;
	line-height: 1.0em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	color: #1e1e1e;
}
.btn1.pdf i {
	font-size: 160%;
	color: #ff0000;
}
.btn1:hover i {
	border-left: 1px solid #fff;
	color: #fff;
}
.btn1.hidari i {
	border-left:none;
	border-right: 1px solid #1e1e1e;
	padding-left: 0;
	margin-left: 0;
	padding-right: 10px;
	margin-right: 20px;
}
.btn1.hidari:hover i {
	border-right: 1px solid #ff0000;
}
.btn1.btn {border-radius: 50px; }





.btn2{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
	font-weight: 500;
}
.btn2:link,
.btn2:visited{
	color:#fff;
	padding:15px 10px;
	text-decoration: none;
	z-index: 2;
	display:flex;
	align-items:center;
	justify-content:center;
	width: 190px;
	background: #1e1e1e;
}
.btn2:hover{
	opacity: 1;
	background-color: #fff;
	color: #1e1e1e;
	border: 1px solid #1e1e1e;
	background-image: none;
}

.tac .btn2{
	margin: 0 auto;
}
.tal_sptac .btn2{
	margin: 0 auto;
}
.tar_sptac .btn2{
	margin: 0 auto;
}

@media print, screen and (min-width: 768px) {
	.tal_sptac .btn2{
		margin: 0;
	}
	.tar_sptac .btn2{
		margin-right: 0;
	}
}


.btn2 i {
	border-left: 1px solid #fff;
	padding-left: 10px;
	margin-left: 20px;
	font-size: 120%;
	line-height: 1.0em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	color: #fff;
}
.btn2:hover i {
	border-left: 1px solid #1e1e1e;
	color: #1e1e1e;
}
.btn2.hidari i {
	border-left:none;
	border-right: 1px solid #1e1e1e;
	padding-left: 0;
	margin-left: 0;
	padding-right: 10px;
	margin-right: 20px;
}
.btn2.hidari:hover i {
	border-right: 1px solid #1e1e1e;
}
.btn2.btn {border-radius: 50px; }




.btn3{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
	font-weight: 500;
}
.btn3:link,
.btn3:visited{
	color:#1e1e1e;
	padding:15px 10px;
	text-decoration: none;
	z-index: 2;
	display:flex;
	align-items:center;
	justify-content:center;
	width: 190px;
	background: #fff;
	border: 1px solid #1e1e1e;
}
.btn3:hover{
	opacity: 1;
	background-color: #1e1e1e;
	color: #fff;
	border: 1px solid #1e1e1e;
	background-image: none;
}

.tac .btn3{
	margin: 0 auto;
}
.tal_sptac .btn3{
	margin: 0 auto;
}
.tar_sptac .btn3{
	margin: 0 auto;
}

@media print, screen and (min-width: 768px) {
	.tal_sptac .btn3{
		margin: 0;
	}
	.tar_sptac .btn3{
		margin-right: 0;
	}
}


.btn3 i {
	border-left: 1px solid #1e1e1e;
	padding-left: 10px;
	margin-left: 20px;
	font-size: 120%;
	line-height: 1.0em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	color: #1e1e1e;
}
.btn3:hover i {
	border-left: 1px solid #fff;
	color: #fff;
}
.btn3.hidari i {
	border-left:none;
	border-right: 1px solid #fff;
	padding-left: 0;
	margin-left: 0;
	padding-right: 10px;
	margin-right: 20px;
}
.btn3.hidari:hover i {
	border-right: 1px solid #fff;
}
.btn3.btn {border-radius: 50px; }




.btn4{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
	font-weight: 500;
}
.btn4:link,
.btn4:visited{
	color:#fff;
	padding:15px 10px;
	text-decoration: none;
	z-index: 2;
	display:flex;
	align-items:center;
	justify-content:center;
	width: 190px;
	background: #ff0000;
}
.btn4:hover{
	opacity: 1;
	background-color: #fff;
	color: #ff0000;
	border: 1px solid #ff0000;
	background-image: none;
}

.tac .btn4{
	margin: 0 auto;
}
.tal_sptac .btn4{
	margin: 0 auto;
}
.tar_sptac .btn4{
	margin: 0 auto;
}

@media print, screen and (min-width: 768px) {
	.tal_sptac .btn4{
		margin: 0;
	}
	.tar_sptac .btn4{
		margin-right: 0;
	}
}


.btn4 i {
	border-left: 1px solid #fff;
	padding-left: 10px;
	margin-left: 20px;
	font-size: 120%;
	line-height: 1.0em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	color: #fff;
}
.btn4:hover i {
	border-left: 1px solid #ff0000;
	color: #ff0000;
}
.btn4.hidari i {
	border-left:none;
	border-right: 1px solid #ff0000;
	padding-left: 0;
	margin-left: 0;
	padding-right: 10px;
	margin-right: 20px;
}
.btn4.hidari:hover i {
	border-right: 1px solid #ff0000;
}
.btn4.btn {border-radius: 50px; }



.btn5{
	font-size: 100%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	font-family: "BIZ UDPGothic", sans-serif;
	font-weight: 700;
	line-height: 35px;
}
.btn5:link,
.btn5:visited{
	color:#ff0000;
	border: 1px solid #ff0000;
   border-radius:50px;
	padding: 0 15px;
}
.btn5:hover{
	opacity: 1;
	background: #ff0000;
	border: 1px solid #ff0000;
	color: #fff;
}
.btn5.btn {border-radius: 50px;}
.btn5 i {margin-left: 10px;}




.btn_head{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
	font-weight: 700;
	align-items: center;height: 35px;
}
.btn_head:link,
.btn_head:visited{
	color:#1e1e1e;
	padding:10px 7px!important;
	text-decoration: none;
	border: 1px solid #1e1e1e;
	position: relative;
	z-index: 2;
	text-decoration: none;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
li:first-child .btn_head{
	margin-right: 6px!important;
}
.btn_head:hover,
.btn_head.active{
	opacity: 1;
	background-color: #1e1e1e!important;
	color: #fff!important;
}
/*
.btn_head.active{
	text-decoration: underline;
	text-underline-offset: 5px;
}
*/
.btn_head i {margin-right: 10px; font-size: 90%;}

.btn_head.btn {border-radius: 50px; }
@media print, screen and (min-width: 1200px) {
	.btn_head{ height: 40px;}
	.btn_head:link,
	.btn_head:visited{
		padding:10px 15px!important;
	}
}


.btn_head2{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
	font-weight: 700;
	display: -webkit-flex;
    display: flex;
    align-items: center;
	height: 30px;
}
.btn_head2:before{
	font-family: bootstrap-icons;
	font-weight: 400;
	content: "\F287";
	margin-right: 5px;
	color: #ff0000;
	font-size: 8px;
}
.btn_head2:hover:before{
	color: #fff;
}

.btn_head2:link,
.btn_head2:visited{
	color:#1e1e1e;
	padding:7px 10px ;
	text-decoration: none;
	border: 1px solid #ff0000;
	position: relative;
	z-index: 2;
	text-decoration: none;
}
.btn_head2:hover,
.btn_head2.active{
	opacity: 1;
	background-color: #ff0000;
	color: #fff;
}
.btn_head2:link i,
.btn_head2:visited i{margin-right: 10px; font-size: 90%;}

.btn_head2.btn {border-radius: 50px; }
@media print, screen and (min-width: 1600px) {
	.btn_head2{ height: 40px;}
	.btn_head2:link,
	.btn_head2:visited{
		padding:7px 20px ;
	}
}



.btn_text{
    font-weight: 700;
    font-size: 110%;
    line-height: 1.4em;
    display: -webkit-flex;
    display: flex;
    align-items: center;
}
a.btn_text:link,
a.btn_text:visited{
	text-decoration: none;
}
a.btn_text:hover,
a.btn_text.active{
	opacity: 1;
	color: #ff0000;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
.btn_text:before {
  border-top: 1px solid;
  content: "";
  width: 1em; /* 線の長さ*/
}
.btn_text:before {
  margin-right: 1em; /* 文字の右隣 */
}



.btn_mail{
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/

}
.btn_mail:link,
.btn_mail:visited{
	color:#fff!important;
	background: #ff0000;
	padding:15px 20px!important;
	text-decoration: none;
	font-size: 100%;
	display: block;
}
.btn_mail:hover,
.navi-on .btn_mail{
	opacity: 1;
	background: #e99718!important;
	color:#fff!important;
}
.btn_mail.btn {border-radius: 50px; border: 0;}

.btn_mail i { margin-right: 7px;}
@media only screen and (max-width: 991px) {
	.btn_mail:link,
	.btn_mail:visited{
		font-size: 14px;
		width: 220px!important;
		text-align: center!important;
	}
}




.btn_pdf{
	font-size:25px;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	margin-left: 2px;
}
.btn_pdf:link,
.btn_pdf:visited{
	color:#ff0000!important;
	width: 40px;
	height: 40px;
	line-height: 40px;
	text-align: center;
	vertical-align: middle;
}
.btn_pdf:hover{
	opacity: 1;
	color: #1e1e1e!important;
}
.btn_pdf.btn {border-radius: 50px; padding:0; border: 0;}
.btn_pdf i {line-height: 40px;}



.btn_yaji{
	font-size: 80%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
.btn_yaji:link,
.btn_yaji:visited{
	color:#fff;
	background: #000;
   padding: 3px 25px;
	font-size: 25px;
	line-height: 1.0em;
}
.btn_yaji:hover{
	opacity: 1;
	background: #ff0000;
	color: #fff;
}
.btn_yaji.btn {border-radius: 50px;}





.btn_detail{
	font-size: 80%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	margin-left: 20px;
	font-family: 'Roboto', sans-serif;
	font-weight: 700;
	width: 35px;
	height: 35px;
	line-height: 35px;
}
.btn_detail:link,
.btn_detail:visited{
	color:#ff0000;
	border: 1px solid #ff0000;
   width:35px;
   height:35px;
   border-radius:50%;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
}
.btn_detail:hover{
	opacity: 1;
	background: #ff0000;
	border: 1px solid #ff0000;
	color: #fff;
}
.btn_detail.btn {border-radius: 50px; padding:0;}


.btn_map{
	font-size: 20px;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
  /*display: flex;*/
	display: inline-flex;
	/*
  justify-content: center;
  align-items: center;
	*/
	margin-left: 10px;
	vertical-align: middle;
}
.btn_map:link,
.btn_map:visited{
	color:#ff0000;
	text-decoration: none;
}
.btn_map:hover{
	opacity: 1;
	color:#1e1e1e;
}
.btn_map.btn {border-radius: 50px; padding:0; border: 0;}





.pdf_list li{
	list-style: none;
	margin-bottom: 3px;
}
.pdf_list li a:link,
.pdf_list li a:visited{
	padding: 10px 15px;
	color: #ff0000;
	display: block;
	text-decoration: none;
	font-size: 90%;
	border: 1px solid #ff0000;
	border-radius: 5px;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
    display: -webkit-flex;
    display: flex;
    align-items: center;

}
.pdf_list li a:hover{
	border-radius: 50px;
	opacity: 1;
}
.pdf_list li i {margin-right: 10px; font-size: 140%;}
@media print, screen and (min-width: 768px){
	.pdf_list{
		margin-left: -1%;
		margin-right: -1%;
	}
	.pdf_list li{
		width: 31.3%;
		float: left;
		margin: 1%;
	}
}

.text_link_area a {text-decoration: underline; color: #1e1e1e;}

a.text_link {text-decoration: underline; color: #3333cc!important;}
a.text_link2 {text-decoration: underline; color: #fff;}

.cate_text a:link,
.cate_text a:visited{
	text-decoration: underline;
	color: #00ac9a;
}
@media only screen and (max-width: 767px) {
	.text_link_sp {text-decoration: underline; color: #1e1e1e;}
	.text_link_sp2 {text-decoration: underline!important; color: #fff;}
}

/* リスト
---------------------------------------------------- */
ol.list_ol{
	list-style:decimal;
	margin-left:25px;
}
ol.list_kansuji{
	list-style-type: cjk-ideographic;
	margin-left:35px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
}
ol.list_kansuji li {margin-bottom: 5px;}
ul.list_ul{
	list-style:disc;
	margin-left:20px;
}
ul.list_ul .sub{
	font-size: 80%;
	line-height: 1.6em;
}
ul.list_ul .list_sub {
	color: #8b8b9a;
	font-size: 90%;
}


ol.list_num {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
}
 
ol.list_num> li {
	color: #1e1e1e;
}
ol.list_num > li {
  margin-bottom: 10px;
  padding-left: 35px;
  position: relative;
	font-weight: 500;
}
ol.list_num > li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #1e1e1e;
  color: #fff;
  display: block;
  float: left;
  line-height: 25px;
  margin-left: -35px;
  text-align: center;
  height: 25px;
  width: 25px;
  border-radius: 50%;
font-family: 'Roboto', sans-serif;
font-weight: 700;
	margin-top: 5px;
	font-size: 80%;
}
@media print, screen and (min-width: 576px){
	ol.list_num.cleaning> li {
		width: 48%;
		float: left;
	}
	ol.list_num.cleaning> li:nth-of-type(2n+1) { clear: both;}
}




/*
ul.list_check li{
	list-style:none;
	text-indent: -1.2em;
	padding-left:1.2em;
	line-height: 1.6em;
	font-size: 110%;
	margin-bottom: 5px;
	text-align: left;
}
ul.list_check li:before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f058";
	margin-right: 5px;
	color: #43b7cb;
}
ul.list_check.red li:before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f058";
	margin-right: 5px;
	color: #e24579;
}
*/

ul.list_maru li{
	list-style:none;
	text-indent: -1.2em;
	padding-left:1.2em;
	padding-bottom: 10px;
	line-height: 1.6em;
}
ul.list_maru li:before{
	font-family: bootstrap-icons;
	font-weight: 400;
	content: "\F517";
	margin-right: 5px;
	color: #ff0000;
	font-size: 80%;
}
@media print, screen and (min-width: 768px){
	ul.list_maru li {font-size: 110%;}
	
}


ul.list_check li{
	list-style: none;
	display: -webkit-flex;
    display: flex;
}
ul.list_check li i {margin-right: 7px; color: #ff0000; font-size: 120%;}

ul.list_check.kasen li{
	border-collapse: collapse;
	border-bottom: 1px solid #b9c6b1;
	padding-bottom: 15px;
	margin-bottom: 15px;
}


/* color
---------------------------------------------------- */
.red{color:#ff0000;}
.white{color:#fff;}
.black{color:#1e1e1e;}
.gray {color: #8f8f8f;}



/* hanyo
---------------------------------------------------- */
.large{font-size:110%;line-height:1.7em}
.small{font-size:80%;line-height:1.5em; font-weight:normal}
.lsn{ list-style:none;}
.ln{ line-height:normal}
.dsb{ display:block}
.dsi{ display:inline}

.kome {text-indent:-1em; margin-left:1em;}
.kome_num {text-indent:-2.8em; margin-left:2.8em;}


.tal{ text-align:left}
.tac{ text-align:center}
.tar{ text-align:right}
.bold {font-weight:bold;}

.tar_sptac {text-align:center;}
@media print, screen and (min-width: 768px) {
.tar_sptac {text-align:right;}
.large{font-size:120%;}
}

.tar_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px) {
.tar_spsmtac {text-align:right;}
.large{font-size:130%;}
}

.tar_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tar_sptal {text-align:right;}
}

.tal_lgtar {text-align:left;}
@media print, screen and (min-width: 1200px){
.tal_lgtar {text-align:right;}
}

.tal_smtac {text-align:center;}
@media print, screen and (min-width: 576px){
.tal_smtac {text-align:left;}
}

.tal_sptac {text-align:center;}
@media print, screen and (min-width: 768px){
.tal_sptac {text-align:left;}
}

.tal_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px){
.tal_spsmtac {text-align:left;}
}

.tac_smtal {text-align:left;}
@media print, screen and (min-width: 576px){
.tac_smtal {text-align:center;}
}
.tac_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tac_sptal {text-align:center;}
}

.img_c img{
	margin: 0 auto;
}
.img_r img{
	margin: 0 0 0 auto;
}
.margin_auto{margin: 0 auto;}

/* dl
---------------------------------------------------- */
/*
.dl_list dt{
	background: url(../images/dl_sen.jpg) no-repeat left center;
	padding: 3px 0 3px 25px;
}
.dl_list dd{
	line-height: 1.8em;
	padding-left: 25px;
}
*/

/* テーブル
---------------------------------------------------- */
table{border-spacing:0;border-collapse:separate;}
table ul.list_ul, table ol.list_ol{margin-left:20px;}

.nw {width:1%; white-space:nowrap;}
@media only screen and (max-width: 767px){
	.nw_sp {width:1%; white-space:nowrap;}
}
@media print, screen and (min-width: 768px){
	.nw_spnone {width:1%; white-space:nowrap;}
}

.table1{
	width:100%;
	border-collapse: collapse;
	/*border-top: 1px solid #dadada;*/
}
.table1 th{
	width:100%;
	padding:10px 10px 5px 10px;
	display: block;
	color: #666;
	font-weight: 700;
}
.table1 td{
	width:100%;
	padding:0 10px 10px 10px;
	display: block;
	border-bottom: 1px solid #ccc;
	font-weight: 400;
}
@media print, screen and (min-width: 768px) {
	.table1 th{
		width:35%;
		padding:15px 12px;
		vertical-align:middle;
		text-align:center;
		display:table-cell;
		border-bottom: 1px solid #ccc;
		color: #1e1e1e;
	}
	.table1.guideline th{
		width:18%;
	}
	.table1 td{
		width:100%;
		padding:15px 12px;
		display:table-cell;
		vertical-align: middle;
	}
}
@media print, screen and (min-width: 992px) {
	.table1 th{ width:35%;}
}
@media print, screen and (min-width: 1200px) {
	.table1 th{ width:30%;}
}


.table2{
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
}
.table2 th,.table2 td{
	padding: 15px 5px;
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
	text-align: center;
	vertical-align: middle;
	background: #fff;
	font-size: 80%;
	line-height: 1.4em;
}


.wsnr {white-space: nowrap;}

.table2 .base_1{
	background: rgba(255, 0, 4, 0.1);
}
.table2 .base_2{
	background: rgba(0, 134, 255, 0.1);
}

.vertxt span{
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	/* IE対応 */
	text-orientation: mixed;
	white-space: nowrap;
	vertical-align:middle;
	text-align: center!important;
	width: 20px;
	 display:flex;
   align-items:center;
   justify-content:center;
	margin: 0 auto;
	
}
@media only screen and (max-width: 767px) {
	.head span{
		writing-mode: vertical-rl;
		-ms-writing-mode: tb-rl;
		/* IE対応 */
		text-orientation: mixed;
		white-space: nowrap;
		vertical-align:middle;
		text-align: center!important;
	}
}
	

/* サイズ指定
---------------------------------------------------- */
.mb05{ margin-bottom:5px}
.mb10{ margin-bottom:10px}
.mb15{ margin-bottom:15px}
.mb20{ margin-bottom:20px}
.mb30{ margin-bottom:30px}
.mb40{ margin-bottom:40px}
.mb50{ margin-bottom:50px}
.mb60{ margin-bottom:60px}
.mb70{ margin-bottom:70px}
.mt10{ margin-top:10px}
.mt20{ margin-top:20px}
.mt40{ margin-top:40px}
.ml20{ margin-left:20px}
.ml05{ margin-left:5px}
.ml10{ margin-left:10px}

.pl40 {padding-left: 40px;}
.mt10{ margin-top:10px}

@media print, screen and (min-width: 768px) {.pr30_sp0 {padding-right: 30px;}}

.mb10_sp {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb10_sp {margin-bottom:0;}}

.mb15_sp {margin-bottom:15px;}
@media print, screen and (min-width: 768px) {.mb15_sp {margin-bottom:0;}}

.mb20_sp {margin-bottom:20px;}
@media print, screen and (min-width: 768px) {.mb20_sp {margin-bottom:0;}}

.mb30_sp {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sp {margin-bottom:0;}}

.mb50_sp {margin-bottom:50px;}
@media print, screen and (min-width: 768px) {.mb50_sp {margin-bottom:0;}}

.mb50_lg0 {margin-bottom:50px;}
@media print, screen and (min-width: 992px) {.mb50_lg0 {margin-bottom:0;}}

.mb50_sp_sm0 {margin-bottom:50px;}
@media print, screen and (min-width: 576px) {.mb50_sp_sm0 {margin-bottom:0;}}

@media print, screen and (min-width: 768px) {.mb30_sp0 {margin-bottom:30px;}}

@media print, screen and (min-width: 992px) {.mb30_spsm0 {margin-bottom:0;}}

.mt10_sm20_md30 {margin-top: 10px;}
@media print, screen and (min-width: 768px) {.mt10_sm20_md30 {margin-top: 20px;}}
@media print, screen and (min-width: 992px) {.mt10_sm20_md30 {margin-top: 30px;}}

.mt20_sm40_md50 {margin-top: 20px;}
@media print, screen and (min-width: 768px) {.mt20_sm40_md50 {margin-top: 40px;}}
@media print, screen and (min-width: 992px) {.mt20_sm40_md50 {margin-top: 50px;}}

.mb10_md0 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md0 {margin-bottom: 0;}}

.mb10_lg0 {margin-bottom: 10px;}
@media print, screen and (min-width: 1200px) {.mb10_lg0 {margin-bottom: 0;}}

.mb10_sm30 {margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {.mb10_sm30 {margin-bottom: 30px;}}

.mb10_md20 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md20 {margin-bottom: 20px;}}

@media print, screen and (min-width: 768px) {.mb20_sp0 {margin-bottom: 20px;}}

.mb20_md0 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md0 {margin-bottom: 0;}}

.mb20_sm30 {margin-bottom: 20px;}
@media print, screen and (min-width: 768px) {.mb20_sm30 {margin-bottom: 30px;}}

.mb20_md30 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md30 {margin-bottom: 30px;}}

.mb30_md0 {margin-bottom: 30px;}
@media print, screen and (min-width: 992px) {.mb30_md0 {margin-bottom: 0;}}

.mb30_sm50 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm50 {margin-bottom:50px;}}

.mb30_md50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_md50 {margin-bottom:50px;}}

.mb30_md50_xl80 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_md50_xl80 {margin-bottom:50px;}}
@media print, screen and (min-width: 1600px) {.mb30_md50_xl80 {margin-bottom:80px;}}

.mb30_md50_xl70 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_md50_xl70 {margin-bottom:50px;}}
@media print, screen and (min-width: 1200px) {.mb30_md50_xl70 {margin-bottom:70px;}}

.mb30_lg40_xl50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_lg40_xl50 {margin-bottom:40px;}}
@media print, screen and (min-width: 1200px) {.mb30_lg40_xl50 {margin-bottom:50px;}}

.mb40_md50 {margin-bottom:40px;}
@media print, screen and (min-width: 992px) {.mb40_md50 {margin-bottom:50px;}}

.mb30_sm60 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm60 {margin-bottom:60px;}}

.mb30_sp10 {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb30_sp10 {margin-bottom:30px;}}

.pl50_sm0 {padding-left: 50px;}
@media print, screen and (min-width: 768px) {.pl50_sm0 {padding-left: 0;}}

.mb20_xl30 {margin-bottom:20px;}
@media print, screen and (min-width: 1200px) {.mb20_xl30 {margin-bottom:30px;}}


@media print, screen and (min-width: 768px) {
	.mt20_sp0 {margin-top: 20px;}
}

@media print, screen and (min-width: 992px) {
	.mt40_sm0 {margin-top: 40px;}
	.mt40_md_20_sm0 {margin-top: 20px;}
}
@media print, screen and (min-width: 1200px) {
	.mt40_md_20_sm0 {margin-top: 40px;}
}

.mb_content {margin-bottom: 50px;}
.mt_content {margin-top: 50px;}
@media only screen and (max-width: 767px) {
	.mb_content.sp0 {margin-bottom: 0;}
}
@media print, screen and (min-width: 768px) {
	/*.mb_content {margin-bottom: 60px;}*/
	.mt_content {margin-top: 60px;}
}
@media print, screen and (min-width: 992px) {
	/*.mb_content {margin-bottom: 80px;}*/
	.mt_content {margin-top: 80px;}
}
@media print, screen and (min-width: 1200px){
	/*.mb_content {margin-bottom: 100px;}*/
	.mb_content {margin-bottom: 70px;}
	.mt_content {margin-top: 100px;}
}

.lh160 {line-height: 160%;}
.lh200 {line-height: 200%;}

/* content
---------------------------------------------------- */
main { line-height: 2.0em; font-size: 105%;}

main a:link,
main a:visited{
	text-decoration: underline;
}


.content_pd {padding-top: 50px; padding-bottom: 50px;}
.content_pd2 {padding-top: 30px; padding-bottom: 30px;}
.content_pd3 {padding-top: 30px; padding-bottom: 30px;}
.content_pd.pt30_sp0 {padding-top: 0;}

.pd20 { padding: 20px;}
.pd30 { padding: 30px;}
@media only screen and (max-width: 767px){
	.content_pd.pt0_sp {padding-top: 0;}
	.content_pd.pb0_sp {padding-bottom: 0;}
}
@media print, screen and (min-width: 768px){
	main {font-size: 100%;}
	/*.content_pd {padding-top: 60px; padding-bottom: 60px;}*/
	.content_pd2 {padding-top: 50px; padding-bottom: 50px;}
	.content_pd.pt30_sp0 {padding-top: 30px;}
	.content_pd.pt0_spnone {padding-top: 0;}
	.pt_left {padding-left: 20px;}
	.pt_right {padding-right: 20px;}
}
@media print, screen and (min-width: 992px){
	main {font-size: 115%;}
	/*.content_pd {padding-top: 80px; padding-bottom: 80px;}*/
	.pt_left {padding-left: 30px;}
	.pt_right {padding-right: 30px;}
}
@media print, screen and (min-width: 1200px){
	main {font-size: 125%;}
	.content_pd {padding-top: 70px; padding-bottom: 70px;}
	/*.content_pd {padding-top: 100px; padding-bottom: 100px;}*/
	.content_pd2 {padding-top: 70px; padding-bottom: 70px;}
	.content_pd.xl0 {padding-top: 0; padding-bottom: 0;}
	.pt_left {padding-left: 35px;}
	.pt_right {padding-right: 35px;}
}
.content_pd.pt0{padding-top: 0;}
.content_pd.pt20{padding-top: 20px;}
.content_pd.pb0{padding-bottom: 0;}
.content_pd2.pb0{padding-bottom: 0;}
.content_pd.pb10{padding-bottom: 10px;}
.content_pd.pb30{padding-bottom: 30px;}


/* h2
---------------------------------------------------- */
#h2_area {
	background: url("../images/h2.jpg") no-repeat scroll 50% 50% / cover;
	position: relative;
	padding: 30px 0;
}
#h2_area.career_top {
	background: url("../images/career/h2.jpg") no-repeat scroll 50% 50% / cover;
	position: relative;
	padding: 30px 0;
}


#interview_h2{
	position: relative;
	z-index: 0;
	overflow: hidden;

}
#interview_h2 .h2_filter{
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	width: 100%;
    height: 100%;

}
#interview_h2 .h2_filter img{
	display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;	
}


#other_h2{
	position: relative;
	z-index: 0;
	overflow: hidden;
	height: 147px;
}
#other_h2 .photo{
	width: 100%;
	height: 100%;
}
#other_h2 .photo img{
	filter: brightness(85%);
    display: block;
    aspect-ratio: 300/200;
    width: 100%;
    height: 100%;
    object-fit: cover;	
}
@media print, screen and (min-width: 768px) {
	#other_h2{ height: 177px;}
}
@media print, screen and (min-width: 992px) {
	#other_h2{ height: 236px;}
}
@media print, screen and (min-width: 1200px) {
	#other_h2{ height: 295px;}
}

.midashi_h2{
	z-index: 100;
    position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	width: 100%;
}
.midashi_h2 h2{
	font-size: 120%;
	line-height: 1.4em;
	font-family: "BIZ UDPGothic", sans-serif;
	font-weight: 700;
	color: #fff;
	text-shadow: 1px 2px 3px #222;
}
.midashi_h2 h2.en{
	font-size: 160%;
	line-height: 1.4em;
	/*letter-spacing:0.1em;*/
	text-shadow: 1px 2px 3px #222;
	font-family: "Roboto", sans-serif;
	font-weight: 700;
}


@media print, screen and (min-width: 768px) {
	.midashi_h2 h2{ font-size: 160%;}
	.midashi_h2 h2.en{ font-size: 240%;}
}
@media print, screen and (min-width: 992px) {
	#h2_area { padding: 50px 0;}
	.midashi_h2 h2{ font-size: 200%;}
	.midashi_h2 h2.en{ font-size: 300%;}
}
@media print, screen and (min-width: 1200px) {
	.midashi_h2 h2{ font-size: 250%;}
	.midashi_h2 h2.en{ font-size: 400%;}
}
@media print, screen and (min-width: 1600px) {
	.midashi_h2 h2{ font-size: 250%;}
	.midashi_h2 h2.en{ font-size: 500%;}

}


h2 .text span {
  clip-path: inset(0 0 100% 0);
  transition: all cubic-bezier(0.215, 0.61, 0.355, 1) 1s;
}
h2 .text span:nth-child(1) {
  transition-delay: 0.06s;
}
h2 .text span:nth-child(2) {
  transition-delay: 0.12s;
}
h2 .text span:nth-child(3) {
  transition-delay: 0.18s;
}
h2 .text span:nth-child(4) {
  transition-delay: 0.24s;
}
h2 .text span:nth-child(5) {
  transition-delay: 0.3s;
}
h2 .text span:nth-child(6) {
  transition-delay: 0.36s;
}
h2 .text span:nth-child(7) {
  transition-delay: 0.42s;
}
h2 .text span:nth-child(8) {
  transition-delay: 0.48s;
}
h2 .text span:nth-child(9) {
  transition-delay: 0.54s;
}
h2 .text span:nth-child(10) {
  transition-delay: 0.6s;
}
h2 .text span:nth-child(11) {
  transition-delay: 0.66s;
}
h2 .text span:nth-child(12) {
  transition-delay: 0.72s;
}
h2 .text span:nth-child(13) {
  transition-delay: 0.78s;
}
h2 .text span:nth-child(14) {
  transition-delay: 0.84s;
}
h2 .text span:nth-child(15) {
  transition-delay: 0.9s;
}
h2 .text span:nth-child(16) {
  transition-delay: 0.96s;
}
h2 .text span:nth-child(17) {
  transition-delay: 1.02s;
}
h2 .text span:nth-child(18) {
  transition-delay: 1.08s;
}
h2 .text span:nth-child(19) {
  transition-delay: 1.14s;
}
h2 .text span:nth-child(20) {
  transition-delay: 1.2s;
}
h2 .text span:nth-child(21) {
  transition-delay: 1.26s;
}
h2 .text span:nth-child(22) {
  transition-delay: 1.32s;
}
h2 .text span:nth-child(23) {
  transition-delay: 1.38s;
}
h2 .text span:nth-child(24) {
  transition-delay: 1.44s;
}
h2 .text span:nth-child(25) {
  transition-delay: 1.50s;
}
h2 .text span:nth-child(26) {
  transition-delay: 1.56s;
}
h2 .text span:nth-child(27) {
  transition-delay: 1.62s;
}
h2 .text span:nth-child(28) {
  transition-delay: 1.68s;
}
h2 .text span:nth-child(29) {
  transition-delay: 1.74s;
}
h2 .text span:nth-child(30) {
  transition-delay: 1.80s;
}
h2 .text span:nth-child(31) {
  transition-delay: 1.86s;
}
h2 .text span:nth-child(32) {
  transition-delay: 1.92s;
}
h2 .text span:nth-child(33) {
  transition-delay: 1.98s;
}
.text.-visible span {
  clip-path: inset(0 0 0 0);
}



/* ヘッダー固定で上空ける
---------------------------------------------------- */


/* スクロールアニメーション
-------------------------------------*/
@media print {
   .animate {
     opacity: 1 !important;
     transform: none !important; }
}


.animate {
    opacity: 0;
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.animate.from-bottom {
    transform: translateY(100px);
}

.animate.from-right {
    transform: translateX(100px);
}

.animate.from-left {
    transform: translateX(-100px);
}

.animate.scale-up {
    transform: scale(0.8);
}

.animate.pop {
    opacity: 0;
    transform: scale(0.5);
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}

.animate.fade-in {
    opacity: 0;
    transform: none;
    transition: opacity 2s ease-out;
    /* 2秒でフェードイン */
}

.animate.visible {
    opacity: 1;
    transform: none;
    /* 透明度のみを変化させる */
}

.animate:nth-child(1) {
    transition-delay: 0s;
}

.animate:nth-child(2) {
    transition-delay: 0.4s;
}

.animate:nth-child(3) {
    transition-delay: 0.8s;
}
.animate:nth-child(4) {
    transition-delay: 1.2s;
}

.animate:nth-child(5) {
    transition-delay: 1.6s;
}

.animate:nth-child(6) {
    transition-delay: 2.0s;
}

.animate:nth-child(7) {
    transition-delay: 2.4s;
}

.animate:nth-child(8) {
    transition-delay: 2.8s;
}

.animate:nth-child(9) {
    transition-delay: 3.2s;
}



/* 背景
---------------------------------------------------- */
.bg_gray {background: #f2f2f2;}

#hoge,
#hoge2,
#hoge3,
#hoge4,
#hoge5,
#hoge6{ opacity: 0;}/*文字をスクロールイベント発火*/



.bg1,
.bg2{
  /*height: 100%;*/
  height: 1px;
  line-height: 100%;
  position: relative;
}

span {
  position: relative;
}

/*左から右*/
.bg2::before{
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  background: #666;
  transition: 1s;
  transform-origin: left top;
  transform: scale(0, 1);
}

/*右から左*/
.bg1::before{
  content: '';
  display: block;
  position: absolute;
	right: 0;
  /*width: 80%;*/
  width: 100%;
  height: 100%;
  background: #0e3962;
  transition: 1s;
  transform-origin: right top;
  transform: scale(0, 1);
}

.fade::before {
  transform: scale(1, 1);
}
.fade:not(.show) {
  opacity: 1!important;
}


/*ぼかし*/
img.bokashi {
  opacity: 0;
  -moz-transition: -moz-transform 0.5s linear;
  -webkit-transition: -webkit-transform 0.5s linear;
  -o-transition: -o-transform 0.5s linear;
  -ms-transition: -ms-transform 0.5s linear;
  transition: transform 0.5s linear;
  -webkit-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.img-blur {
  -webkit-animation-name: imageBlur;
  animation-name: imageBlur;
  opacity: 1;
  transition: .8s;
}

@-webkit-keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}
@keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }

  to {
      opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

	
/* サイドナビ追跡
-------------------------------------*/
@media print, screen and (min-width: 768px) {
	.container-sticky {
	  height: auto;
	  width: 100%;
	}
	.heading-sticky {
	  position: sticky;
	  top: 0;
	  width: 100%;
	  z-index: 30;
	}
	.side_contents_box {
	  position: sticky;
	  top: 10rem;
	  padding-bottom: 8.5rem;
	}
	.heading-sticky { top: 55px;}
}
	
/* ホバーアニメーション
-------------------------------------*/
.btn-loading {
  display: inline-flex;
  text-decoration: none;
  font-weight: 700;
  color: #fff;
  width: 140px;
  height: 140px;
  font-size: 11px;
  position: relative;
  opacity: 1 !important;
  transition: all 0.3s;
  background-color: #666;
  border-radius: 100%;
  transition: color 0.4s;
  overflow: hidden;
font-family: "Roboto", sans-serif;
	font-weight: 700;
}
.btn-loading:before,
.btn-loading:after {
  content: "";
  display: block;
  position: absolute;
  width: 50%;
  height: 0;
  background-color: #f00;
  pointer-events: none;
}
.btn-loading:before {
  bottom: 0;
  left: 0;
}
.btn-loading:after {
  top: 0;
  right: 0;
}
.btn-loading:hover {
  color: #f00;
}
.btn-loading:hover:before,
.btn-loading:hover:after {
  height: 100%;
}
.btn-loading:hover:before {
  transition: height 0.2s 0.2s linear;
}
.btn-loading:hover:after {
  transition: height 0.2s linear;
}
.btn-loading span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  background-color: #1e1e1e;
  border-radius: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99;
	color: #fff;
}

.btn-loading i {margin-left: 10px;}

@media print, screen and (min-width: 1200px){
	.btn-loading {
	  width: 190px;
	  height: 190px;
		font-size: 14px;
	}
	.btn-loading i {margin-left: 15px;}
}

/* ボーダーが緩やかにつく
-------------------------------------*/
.stroke {
  /*background: #f0f0f0;*/
  background: #fff;
  max-width: 400px;
  /*height: 250px;*/
	height: 100%;

  position: relative;
}

.stroke .border_waku {
  content: "";
  position: absolute;
  opacity: 0;
}
.stroke .border_waku.top,
.stroke .border_waku.bottom {
  width: calc(100% - 50%);
}
.stroke .border_waku.top {
  border-top: 3px solid #bcbcbc;
  right: 0;
  top: 0;
}
.stroke .border_waku.bottom {
  border-bottom: 3px solid #bcbcbc;
  left: 0;
  bottom: 0;
}

.stroke .border_waku.right,
.stroke .border_waku.left {
  height: calc(100% - 50%);
}
.stroke .border_waku.right {
  border-right: 3px solid #bcbcbc;
  right: 0;
  top: 0;
}
.stroke .border_waku.left {
  border-left: 3px solid #bcbcbc;
  left: 0;
  bottom: 0;
}


/**/

.top_item .box.color2 .stroke .border_waku.top {
  border-top: 3px solid #5bb3bc;
}
.top_item .box.color2 .stroke .border_waku.bottom {
  border-bottom: 3px solid #5bb3bc;
}
.top_item .box.color2 .stroke .border_waku.right {
  border-right: 3px solid #5bb3bc;
}
.top_item .box.color2 .stroke .border_waku.left {
  border-left: 3px solid #5bb3bc;
}


.top_item .box.color3 .stroke .border_waku.top {
  border-top: 3px solid #d05f52;
}
.top_item .box.color3 .stroke .border_waku.bottom {
  border-bottom: 3px solid #d05f52;
}
.top_item .box.color3 .stroke .border_waku.right {
  border-right: 3px solid #d05f52;
}
.top_item .box.color3 .stroke .border_waku.left {
  border-left: 3px solid #d05f52;
}

.top_item .box.color4 .stroke .border_waku.top {
  border-top: 3px solid #2674ab;
}
.top_item .box.color4 .stroke .border_waku.bottom {
  border-bottom: 3px solid #2674ab;
}
.top_item .box.color4 .stroke .border_waku.right {
  border-right: 3px solid #2674ab;
}
.top_item .box.color4 .stroke .border_waku.left {
  border-left: 3px solid #2674ab;
}

.top_item .box.color5 .stroke .border_waku.top {
  border-top: 3px solid #f8dd6d;
}
.top_item .box.color5 .stroke .border_waku.bottom {
  border-bottom: 3px solid #f8dd6d;
}
.top_item .box.color5 .stroke .border_waku.right {
  border-right: 3px solid #f8dd6d;
}
.top_item .box.color5 .stroke .border_waku.left {
  border-left: 3px solid #f8dd6d;
}


.stroke.is-animated .border_waku {
  opacity: 1;
}

.stroke.is-animated .border_waku.top,
.stroke.is-animated .border_waku.bottom {
  animation: stroke-width 1.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.stroke.is-animated .border_waku.right,
.stroke.is-animated .border_waku.left {
  animation: stroke-height 1.8s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes stroke-width {
  0% {
    width: 0;
    opacity: 1;
  }
  100% {
    width: calc(100% - 50%);
    opacity: 1;
  }
}

@keyframes stroke-height {
  0% {
    height: 0;
    opacity: 1;
  }
  100% {
    height: calc(100% - 50%);
    opacity: 1;
  }
}

/* 背景固定
---------------------------------------------------- */
.b_box {
    width: 100%;
    height: 100%;
    margin:0 auto;
    display:flex;
    justify-content:center;
    align-items:center;
    overflow: hidden;
}

.b_fixed_bg {
    position: relative;
    /* min-height: 100%; */
    /*height: 100vh;*/
    height: 100vh;
    background-size: cover; 
    background-attachment: fixed; 
    background-repeat: no-repeat; 
    background-position: center center;
	z-index: 2;
    pointer-events: none;
    transition : all 0.5s ease-in-out;
}
@media screen and (max-width: 767px) {/*iPad横でも不具合でたため、1199px以下にした*/
    .b_fixed_bg {
        height: 450px;
        background-attachment: scroll; /*スマホ・タブ(ios)では不具合がでるため幅992px以下ではこの指定（印刷時のスタイルも）*/
    }
    .b_fixed_bg.takame {
        height: 450px;
    }
	.b_fixed_bg.b_bg3 {
		background-position: center center;
	}
}
@media screen and (min-width: 768px) and (max-width: 1199px)  {/*iPad横でも不具合でたため、1199px以下にした*/
    .b_fixed_bg {
        height: 470px;
        background-attachment: scroll; /*スマホ・タブ(ios)では不具合がでるため幅992px以下ではこの指定（印刷時のスタイルも）*/
    }
    .b_fixed_bg.takame {
        height: 600px;
    }
}


.b_fixed_bg .img_c img{
	max-width: 178px;
	width: 40%;
}
@media print, screen and (min-width: 576px){
	.b_fixed_bg .img_c img{ width: 25%;}
}
@media print, screen and (min-width: 768px){
	.b_fixed_bg .img_c img{ width: 100%;}
}

/* 後ろの画像urlはプレロード */
.b_fixed_bg.b_bg1 {
    background-image: url(../images/kotei1.jpg) , url(../images/kotei1.jpg);
}
.b_fixed_bg.b_bg2 {
    background-image: url(../images/kotei2.jpg) , url(../images/kotei2.jpg);
}
.b_fixed_bg.b_bg3 {
    background-image: url(../images/kotei3.jpg) , url(../images/kotei3.jpg);
}
.b_fixed_bg.b_bg4 {
    background-image: url(../images/kotei4.jpg) , url(../images/kotei4.jpg);
}
.b_fixed_bg.b_bg5 {
    background-image: url(../images/kotei5.jpg) , url(../images/kotei5.jpg);
}
.b_fixed_bg.b_bg6 {
    background-image: url(../images/kotei6.jpg) , url(../images/kotei6.jpg);
}


.career_top .b_fixed_bg.b_bg1 {
    background-image: url("../images/career/kotei1.jpg") , url(../images/career/kotei1.jpg);
	position: relative;
	z-index: 0;
}
.career_top .b_fixed_bg.b_bg2 {
    background-image: url("../images/career/kotei2.jpg") , url(../images/career/kotei2.jpg);
	position: relative;
	z-index: 0;
}
.career_top .b_fixed_bg.b_bg3 {
    background-image: url("../images/career/kotei3.jpg") , url(../images/career/kotei3.jpg);
	position: relative;
	z-index: 0;
}
.career_top .b_fixed_bg.b_bg4 {
    background-image: url("../images/career/kotei4.jpg") , url(../images/career/kotei4.jpg);
	position: relative;
	z-index: 0;
}


.b_cnt {
    /*cursor: pointer;*/
    pointer-events: auto;/*疑似要素をクリック可能に*/
}




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

/* 共通
---------------------------------------------------- */
a:hover img {
	opacity:0.9;
	filter: alpha(opacity=90);
}

.close {
    float: none;
}

/* 縦横比固定 */
.photo-ofi {
	 height: 0;
	 display: block;
	padding-bottom: 75%; /* 高さを指定（ボックスの横幅を基準） */
	/*background-color: #EFEFEF;*/
	overflow: hidden;
	position: relative;
	/*margin-bottom: 10px;*/
}
.photo-ofi img {
	 max-width: inherit;
	 max-height: inherit;
	width: 100%;
	height: 100%;
	 object-fit: scale-down;
	 font-family: 'object-fit: scale-down;';
	 position: absolute;
	 left: 0;
	 top: 0;
}

.object-fit img{
	object-fit: cover;
	font-family: 'object-fit: cover;'; /*IE対策*/
}



div.paging { text-align: center; font-size: 90%; margin-top: 20px; line-height: 1.4em; font-family: "Roboto", sans-serif; font-weight: 400;}
div.paging span.current,
div.paging span.paging-text{
	margin:0px 0.5px;
	color:#1e1e1e;
	display:inline;
	zoom:1;
	display:inline-block;
	overflow:hidden;
	text-decoration:none;
}
div.paging span.paging-text a{
	padding:5px 8.5px;
	display:block;
	color: #1e1e1e;
	border:1px solid #1e1e1e;
}
div.paging span.current{
	background: #1e1e1e;
	border:1px solid #1e1e1e;
	color:#fff;
	zoom:1;
	padding:5px 8.5px;
	text-decoration:none;
	display:inline-block;
	cursor:pointer;
	
}
div.paging span.paging-text a:hover{
	background: #1e1e1e;
	color:#fff;
	text-decoration:none;
	cursor:pointer;
	opacity: 1;
	border:1px solid #1e1e1e;
}



/*左右の余白*/
@media print, screen and (min-width: 768px){
	.yohaku{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
	.yohaku2{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
}
@media print, screen and (min-width: 1500px){
	.yohaku{
		margin-left: 16.666667%;
		margin-right: 16.666667%;
	}
}


/* 画像を徐々に表示
-------------------------------------*/
@media print {
   .img-wrap {
     opacity: 1 !important;
     transform: none !important; }
}


.img-wrap {
  opacity: 0;
}

.img-animation {
  animation: img-opacity 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  overflow: hidden;
  position: relative;
}

.img-animation::before {
  animation: img-animation 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  background: #fff;
  content: '';
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.kon.img-animation::before {
  background: #7d8386;
}

@keyframes img-opacity {
  100% {
    opacity: 1;
  }
}

@keyframes img-animation {
  100% {
    transform: translateX(100%);
  }
}
/*------*/



/* 01 index
---------------------------------------------------- */
.news .box{
	border-bottom: 1px solid #dadada;
	padding: 10px 10px;
	font-size: 85%;
	line-height: 1.4em;
}
.news .box .en{
	color: #979797;
	letter-spacing: 0;
	margin-bottom: 7px;
}
.news_scroll {
  max-height:100px;
  overflow-y: scroll;
  padding-right:10px;
	z-index: 1;
	word-break: break-all;
}
@media print, screen and (min-width: 576px) {
	.news .box{
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.news .box .en{
		min-width: 120px;
		max-width: 120px;
		width:120px;
		margin-bottom: 0;
	}
}
@media print, screen and (min-width: 768px) {
	.news_scroll {max-height:100px;}
}
@media print, screen and (min-width: 992px) {
	.news_scroll {max-height:120px;}
}


.top_catenavi li{
	list-style: none;
	/*border-bottom: 1px solid #1e1e1e;*/
	margin-bottom: 10px;
}
.top_catenavi li i{font-size: 110%;}
.top_catenavi li a:link,
.top_catenavi li a:visited{
	padding: 10px 13px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
	text-decoration: none;
	font-weight: 700;
	
}
.top_catenavi li a:hover,
.top_catenavi li a.active{
	color: #fff;
	background: #bcbcbc;
	opacity: 1;
	border-radius: 5px;
}
.top_catenavi li.color2 a:hover,
.top_catenavi li.color2 a.active{
	background: #5bb3bc;
}
.top_catenavi li.color3 a:hover,
.top_catenavi li.color3 a.active{
	background: #d05f52;
}
.top_catenavi li.color4 a:hover,
.top_catenavi li.color4 a.active{
	background: #2674ab;
}
.top_catenavi li.color5 a:hover,
.top_catenavi li.color5 a.active{
	background: #f8dd6d;
	color: #1e1e1e;
}



.top_catenavi li a:hover i,
.top_catenavi li a.active i{
	color: #fff;
	opacity: 1;
}
.top_catenavi li.color5 a:hover i,
.top_catenavi li.color5 a.active i{
	color: #1e1e1e;
}
.top_catenavi li a i {margin-right: 10px;}
@media print, screen and (min-width: 992px) {
	.top_catenavi li i{font-size: 120%;}
}

@media only screen and (max-width: 767px) {
	.top_catenavi{
		margin-left: -1%;
		margin-right: -1%;
	}
	.top_catenavi li{
		float: left;
		border-bottom: 1px solid #dadada;
		width: 48%;
		margin: 0 1%;
	}
	.top_catenavi li a:link,
	.top_catenavi li a:visited{
		padding: 10px 10px;
	}
	.top_catenavi li a:hover,
	.top_catenavi li a.active{
		border-radius: 0;
	}
}



.top_item .box{
	margin-bottom: 30px;
}
.top_item .box .image {margin-bottom: 15px;}
.top_item .box .image img{
    display: block;
    /*aspect-ratio: 300/200;*/
    aspect-ratio: 300/300;
    width: 100%;
    height: 100%;
    object-fit: cover;
	padding: 10px;
}
.top_item .box h4{
	font-weight: 700;
	margin-bottom: 10px;
	font-size: 110%;
	line-height: 1.4em;
}
.top_item .box a:link,
.top_item .box a:visited{
	text-decoration: none;
}

.tag span{
	border: 1px solid #000;
	border-radius: 50px;
	font-size: 80%;
	line-height: 1.4em;
	padding: 3px 10px;
	display: inline-block;
	margin-right: 3px;
	margin-bottom: 3px;
}
.tag span a:link,
.tag span a:visited{
	text-decoration: none;
	display: block;
}


.tag2 span{
	border: 1px solid #000;
	border-radius: 5px;
	font-size: 90%;
	line-height: 1.4em;
	padding: 10px 10px;
	display: inline-block;
	margin-right: 3px;
	margin-bottom: 3px;
}

.top_item .cate_tag{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	font-weight: 700;
	margin-bottom: 10px;
	font-size: 90%;
}
.top_item .cate_tag i{
	color: #bcbcbc;
	font-size: 8px;
	margin-right: 7px;
}

.top_item .box.color2 .cate_tag i{
	color: #5bb3bc;
}
.top_item .box.color3 .cate_tag i{
	color: #d05f52;
}
.top_item .box.color4 .cate_tag i{
	color: #2674ab;
}
.top_item .box.color5 .cate_tag i{
	color: #f8dd6d;
}

@media print, screen and (min-width: 576px){
	.top_item{
		margin-left: -1%;
		margin-right: -1%;
	}
	.top_item .box{
		width: 48%;
		margin: 0 1% 50px 1%;
		float: left;
	}
	.top_item .box .image {margin-bottom: 20px;}
	.top_item .box:nth-of-type(2n+1) { clear: both;}
}
@media print, screen and (min-width: 992px){
	.top_item .box{
		width: 31.3%;
		margin: 0 1% 50px 1%;
		float: left;
	}
	.top_item .box:nth-of-type(2n+1) { clear: none;}
	.top_item .box:nth-of-type(3n+1) { clear: both;}
}


#top04 .in {
	color: #fff;
}

#top04 .in { text-shadow: 0px 5px 9px rgba(0, 0, 0, 0.93);}

#top04 .btn_area a{
	/*margin: 0 auto;*/
}
#top04 .text{ margin-bottom: 20px;}
@media print, screen and (min-width: 576px){
	#top04 .in {
		padding-left: 5%;
		padding-right: 5%;
		display: -webkit-flex;
		display: flex;
		align-items: center;
		/*justify-content: center;*/
	}

	#top04 .btn_area a {margin-left: auto;}
	#top04 .text{
		margin-bottom: 0;
		margin-right: 10%;
		width: 100%;
	}
}
@media print, screen and (min-width: 1600px){
	#top04 .in{
		width: 80%;
		margin: 0 auto;
	}
}


#top05 .in {
	display: -webkit-flex;
    display: flex;
}
#top05 .in div.last {margin-left: auto;}





/* スライダー
-------------------------------------*/
#top05_area .swiper-wrapper {
	will-change: transform!important;
}
#top05_area .swiper-slide img{
	width: 100%;
	height: auto;
}
@media only screen and (max-width: 767px){
	#top05_area .swiper-slide img{
		max-width: 250px!important;
	}
}
@media print, screen and (min-width: 768px){
	#top05_area .swiper-slide{
		max-width: 300px;
	}
}
@media print, screen and (min-width: 992px){
	#top05_area .swiper-slide{
		max-width: 400px;
	}
}
@media print, screen and (min-width: 1200px){
	#top05_area .swiper-slide{
		max-width: 500px;
	}
}


#interview_h2 .swiper-wrapper {
	will-change: transform!important;
}
#interview_h2 .swiper-slide img{
	width: 100%;
	height: auto;
}
@media only screen and (max-width: 767px){
	#interview_h2 .swiper-slide img{
		max-width: 250px!important;
	}
}
@media print, screen and (min-width: 768px){
	#interview_h2 .swiper-slide{
		max-width: 300px;
	}
}
@media print, screen and (min-width: 992px){
	#interview_h2 .swiper-slide{
		max-width: 400px;
	}
}
@media print, screen and (min-width: 1200px){
	#interview_h2 .swiper-slide{
		max-width: 500px;
	}
}


/* キャリアTOP
---------------------------------------------------- */
.job_banner{
	margin-left: -1%;
	margin-right: -1%;
}
.job_banner li{
	list-style: none;
	width: 48%;
	float: left;
	margin: 1% 1%;
}
.job_banner li:nth-of-type(2n+1) { clear: both;}
.job_banner img{
	max-width: 280px;
	width: 70%;
	height: auto;
	margin: 0 auto;
}
@media print, screen and (min-width: 1200px){
	.job_banner{
		width: 100%;
	}
	.job_banner img{
		width: 100%;
	}
}


header .job_banner {margin-top: 10px;}
header .job_banner img{
	width: 100%;
	margin: 5px auto 0 auto;
}
@media print, screen and (min-width: 576px){
	header .job_banner img{ width: 60%;}
}
@media print, screen and (min-width: 768px){
	header .job_banner img{ width: 100%;}
}
@media print, screen and (min-width: 992px){
	header .job_banner img{ width: 80%;}
}
@media print, screen and (min-width: 1200px){
	header .job_banner img{ width: 70%;}
}
@media print, screen and (min-width: 1600px){
	header .job_banner img{ width: 100%;}
	header .job_banner li{
		width: 23%;
		margin: 1% 1%;
	}
	header .job_banner li:nth-of-type(2n+1) { clear: none;}
	header .job_banner li:nth-of-type(4n+1) { clear: both;}
}



/* interview
---------------------------------------------------- */
#appeal_text{
	position: relative;
	z-index: 0;
}


#appeal_text .img_en{
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-size: 250%;
	line-height: 1.2em;
	padding-top: 0;
	padding-left: 20%;
}
@media only screen and (max-width: 767px){
	#appeal_text .img_en.ichigyo{ padding-top: 15px;}
}
@media print, screen and (min-width: 768px){
	#appeal_text .img_en{font-size:240%; padding-top: 50px;padding-left: 60px;}
}
@media print, screen and (min-width: 992px){
	#appeal_text .img_en{font-size:260%; padding-top: 70px;padding-left: 100px;}
}
@media print, screen and (min-width: 1200px){
	#appeal_text .img_en{font-size:300%; padding-top: 100px;padding-left: 100px;}
}
@media print, screen and (min-width: 1600px){
	#appeal_text .img_en{font-size:400%; padding-top: 80px;padding-left: 150px;}
}


.ugoki{
	position: relative;
}
.ugoki .in{
	max-width: 100px;
	position: absolute;
	left: 0;
	top: -20px;
	width:100%;
	z-index: -1;
}
.ugoki img{
	width: 100%;
	height: auto;
}
.ugoki .in img:last-child{
	position: absolute;
	left: 0;
	top: 0;
}
@media print, screen and (min-width: 768px){
	.ugoki .in{ max-width: 450px;}
}
@media print, screen and (min-width: 1600px){
	.ugoki .in{top: -100px;}
}


.interview_ichiran{
	width: 80%;
	margin: 0 auto;
}
.interview_ichiran .box{
	margin-bottom: 40px;
	position: relative;
}
.message_text{
	position: absolute;
	left: 15px;
	top: 15px;
	color: #fff;
	font-size: 90%;
	line-height: 1.4em;
	z-index: 1;
}
.interview_ichiran .box .photo.miyasuku{
	position: relative;
}
.interview_ichiran .box .photo.miyasuku img {
    filter: brightness(85%);
}

.interview_ichiran .box .photo{
	position: relative;
	z-index: 0;
}
.interview_ichiran .box .photo .message{
	position: absolute;
	left: 15px;
	bottom: 15px;
	display: none;
}
.interview_ichiran .box .photo .message h4{
	background: #fff;
	padding: 5px 10px;
	display: inline-block;
	font-weight: 700;
	line-height: 1.4em;
	font-size: 130%;
}
.interview_ichiran .box .text{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	margin-top: 15px;
}
.interview_ichiran .box .text .yaji{
	margin-left: auto;
	background: #000;
	border-radius: 50px;
	color: #fff;
	padding: 3px 25px;
	font-size:20px;
	line-height: 1.4em;
}

.interview_ichiran .box a:link,
.interview_ichiran .box a:visited{
	text-decoration: none;
}
.interview_ichiran .box .text {margin-right: 15px;}
.interview_ichiran .box .text p {font-size: 80%; line-height: 1.4em; margin-bottom: 5px;}
.interview_ichiran .box .text h5,
.interview_ichiran .box .text .name{
	font-weight: 700;
	font-size: 140%;
	line-height: 1.4em;
}
@media print, screen and (min-width: 576px){
	.interview_ichiran{
		/*
		margin-left: -1%;
		margin-right: -1%;
		*/
	}
	.interview_ichiran .box{
		width: 48%;
		float: left;
		margin: 0 1% 50px 1%;
	}
	.interview_ichiran .box:nth-of-type(2n+1) { clear: both;}
}
@media print, screen and (min-width: 992px){
	.interview_ichiran .box{
		width: 31.3%;
	}
	.interview_ichiran .box:nth-child(2){ margin-top: 50px;	}
	.interview_ichiran .box:nth-child(5){ margin-top: 50px;	}
	.interview_ichiran .box:nth-child(8){ margin-top: 50px;	}
	.interview_ichiran .box:nth-child(11){ margin-top: 50px;}
	
	
	.interview_ichiran .box:nth-of-type(2n+1) { clear: none;}
	.interview_ichiran .box:nth-of-type(3n+1) { clear: both;}
}
@media print, screen and (min-width: 1200px){
	.interview_ichiran .box .photo .message h4{ font-size: 140%;}
}


/*詳細*/

#interview_title{
    position: relative;
    z-index: 0;
}
#interview_title .text{
    position: absolute;
    left: 0;
    bottom: 10%;
    z-index: 1;
	font-weight: 700;
	width: 100%;
}
.white{color: #fff;}
#interview_title .text .name{
	font-size: 150%;
	line-height: 1.4em;
}

.interview_title_sp {
	margin-top: 10px;
	line-height: 1.4em;
	border-left: 4px solid #ff0000;
	padding: 4px 0 4px 15px;
}
.interview_title_sp .name{
	font-size: 150%;
	line-height: 1.4em;
	margin-top: 5px;
	font-weight: 700;
}

#interview_title .photo img{
	filter: brightness(85%);
}
@media only screen and (max-width: 575px) {
	#interview_title .photo img{
		display: block;
		aspect-ratio: 300/150;
		width: 100%;
		height: 100%;
		object-fit: cover;	
	}
	#interview_title .text{
		bottom: 15px;
	}
}
@media print, screen and (min-width: 576px) {
	#interview_title .text .name{ font-size: 200%;}
}
@media print, screen and (min-width: 768px) {
	.interview_title_sp {
		margin-top: 0;
		font-size: 120%;
	}
	.interview_title_sp .name{
		font-size: 170%;
		margin-top: 5px;
	}
}




#interview_title h2{
	font-weight: 700;
	line-height: 1.4em;
	display: block;
	font-size: 130%;
	display: none;
}
#interview_title h2 span{
	background: #fff;
	padding: 5px 10px;
	display: inline-block;
}
@media print, screen and (min-width: 768px) {
	#interview_title h2{ font-size: 200%;}
}
@media print, screen and (min-width: 992px) {
	#interview_title h2{ font-size: 250%;}
}
@media print, screen and (min-width: 1600px) {
	#interview_title h2{ font-size: 300%;}
}



#interview_schedule_area{
	position: relative;
	z-index: 0;
}
#interview_schedule_area .gara{
	max-width: 10px;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
#interview_schedule_area .gara img{
	display: block;
    /*aspect-ratio: 300/200;*/
    width: 100%;
    height: 100%;
    object-fit: cover;	
}


#interview_schedule{
	position: relative;
	z-index: 0;
}
#interview_schedule .photo .filter {display: none;}
@media print, screen and (min-width: 768px){
	#interview_schedule h3 {color: #fff;}
	#interview_schedule .photo{
		max-width: 900px;
		position: absolute;
		left: 0;
		top: 0;
		width: 45%;
		height: 100%;
		z-index: -1;
	}
	#interview_schedule .photo img{
		display: block;
		/*aspect-ratio: 300/200;*/
		width: 100%;
		height: 100%;
		object-fit: cover;	
	}
	#interview_schedule .photo .filter {
		display: block;
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;height: 100%;
	}
	
	#interview_schedule_area .gara{
		max-width: 30px;
	}
	
	#interview_schedule .title { padding-left: 10%;}
}
@media print, screen and (min-width: 1700px){
	#interview_schedule_area .gara{
		max-width: 100px;
	}
}

.schedule_box{
	margin-bottom: 10px;
}
.schedule_box .time{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.schedule_box .time > p{
	width: 100px;
	min-width: 100px;
	max-width: 100px;
}

.time_short .schedule_box .time > p{
	width: 60px;
	min-width: 60px;
	max-width: 60px;
}
.time_short2 .schedule_box .time > p{
	width: 40px;
	min-width: 40px;
	max-width: 40px;
}

.schedule_box .time h4{
	font-weight: 700;
	margin-left: 20px;
	font-size: 110%;
	line-height: 1.4em;
}
.schedule_box .text{
	border-left: 1px solid #1e1e1e;
	padding: 10px 10px 10px 20px;
	font-size: 90%;
	line-height: 1.8em;
	margin-left: 20px;
}
@media print, screen and (min-width: 992px){
	.schedule_box .time > p{
		width: 120px;
		min-width: 120px;
		max-width: 120px;
	}
	.time_short .schedule_box .time > p{
		width: 70px;
		min-width: 70px;
		max-width: 70px;
	}
	.time_short2 .schedule_box .time > p{
		width: 50px;
		min-width: 50px;
		max-width: 50px;
	}
}


/* careerpath
---------------------------------------------------- */
@media print, screen and (min-width: 567px){
	.careerpath_box{
		display: -webkit-flex;
		display: flex;
		align-items: start;
	}
	.careerpath_box .midashi4 {margin-right: 20px;}
}

.careerpath_photo{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	margin-left: -5px;
	margin-right: -5px;
}
.careerpath_photo > p{
	margin: 0 5px;
}


.careerpath_flow{
	position: relative;
}
.careerpath_flow .career{
	position: absolute;
	left: 0;
	top: 0;
}
.careerpath_flow .career ul{
	position: relative;
}
.careerpath_flow ul li:nth-child(2),
.careerpath_flow ul li:nth-child(3),
.careerpath_flow ul li:nth-child(4),
.careerpath_flow ul li:nth-child(5),
.careerpath_flow ul li:nth-child(6),
.careerpath_flow ul li:nth-child(7),
.careerpath_flow ul li:nth-child(8){
	position: absolute;
	left: 0;
	top: 0;
}
.careerpath_flow .life{
	position: absolute;
	left: 0;
	bottom: 0;
}


/* 職種（技術系）紹介 job
---------------------------------------------------- */
.job_box .text{ margin-bottom: 20px;}
.job_box{
	border-top: 1px solid #dadada;
	padding: 30px 0;
}
@media print, screen and (min-width: 567px){
	.job_box{
		display: -webkit-flex;
		display: flex;
		border-top:none;
		padding: 30px 0;
	}
	.job_box .text{
		margin-right: 30px;
		width: 100%;
	}
	.job_box .photo{
		min-width: 45%;
		max-width: 45%;
		width: 45%;
		margin-left: auto;
	}
}
@media print, screen and (min-width: 992px){
	.job_box .text{
		margin-right: 40px;
	}
	.job_box .photo{
		min-width: 35%;
		max-width: 35%;
		width: 35%;
	}
}
@media print, screen and (min-width: 1600px){
	.job_box .photo{
		min-width: 25%;
		max-width: 25%;
		width: 25%;
	}
}

/* 保護者・先生の皆様へ teachers
---------------------------------------------------- */
.teachers_box {
    background: #fff;
    border-radius: 20px;
    padding: 30px;
	margin-bottom: 20px;
}
.teachers_box .text {margin-bottom: 20px;}
.teachers_box .image >p {margin-top: 5px;}
.teachers_box .image img {border-radius: 10px;}

.teachers_box .list_maru li{
	border-bottom: 1px solid #dadada;
	padding-bottom: 15px;
	margin-bottom: 15px;
	font-size: 100%;
}
.teachers_box .list_maru li:last-child{
	border-bottom: none;
}

.teachers_box .midashi4 {margin-left: 72px;}
@media screen and (min-width: 576px) and (max-width: 767px)  {
}
@media print, screen and (min-width: 768px){
	.teachers_box{
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.teachers_box .text {
		margin-bottom: 0;
		margin-right: 40px;
		width: 100%;
	}
	.teachers_box .image{
		width: 40%;
		min-width: 40%;
		max-width: 40%;
	}
}
@media print, screen and (min-width: 1200px){
	.teachers_box{
		padding: 30px 30px 30px 50px;
	}
	.teachers_box .image{
		width: 30%;
		min-width: 30%;
		max-width: 30%;
	}
	.teachers_box .text {
		margin-right: 60px;
	}
}


@media print, screen and (min-width: 768px){
	.teachers_box2{
		margin-left: 20%;
	}
}


#teachers_bg{
	/*background: url("../images/teachers/teachers_bg.jpg") no-repeat center center;
	-moz-background-size: auto 100%;
	background-size: auto 100%; 
	*/
	/*background: url("../images/teachers/teachers_bg.jpg") no-repeat scroll 50% 50% / cover;*/
	position: relative;
	padding: 50px 0;
}
.sakura_l{
	position: absolute;
	max-width: 680px;
	left: 0;
	bottom: 0;
	z-index: -1;
	width: 25%;
}
.sakura_r{
	position: absolute;
	max-width: 680px;
	right: 0;
	top: 0;
	z-index: -1;
	width: 25%;
}
.sakura_l img,
.sakura_r img{
	width: 100%;
	height: auto;
}
@media print, screen and (min-width: 768px){
	#teachers_bg {
		padding: 50px 0;
	}
	#teachers_bg .tac{
		font-size: 110%;
		line-height: 2.0em;
		font-weight: 700;
	}
}
@media print, screen and (min-width: 992px){
	#teachers_bg {
		padding: 80px 0 80px 0;
	}
	#teachers_bg .tac{
		font-size: 120%;
		line-height: 2.4em;
	}
}
@media print, screen and (min-width: 1200px){
	
	/*
	#teachers_bg{
		background: url("../images/teachers/teachers_bg.jpg") no-repeat center center;
		-moz-background-size: 80% auto;
		background-size: 80% auto; 
		padding: 80px 0 150px 0;
	}
	*/
}


/* 事業フィールド business
---------------------------------------------------- */

.business_box .text {margin-bottom: 30px;}
@media print, screen and (min-width: 768px){
	.business_box{
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.business_box .text {margin-right: 5%; width: 55%; margin-bottom: 0;}
	.business_box .photo{
		min-width: 40%;
		max-width: 40%;
		width: 40%;
		height: 100%;
	}
	.business_box .photo img{
		display: block;
		/*aspect-ratio: 300/200;*/
		width: 100%;
		height: 100%;
		object-fit: cover;	
	}
}


/* 福利厚生 welfare
---------------------------------------------------- */
.welfare_box {
    background: #fff;
    border-radius: 20px;
    padding: 30px;
}
.welfare_box.sen {
	border: 1px solid #dadada;
}
.welfare_box.sen.sen_color1 {
	border: 2px solid #5bb3bc;
	box-shadow: 5px 5px 0px 0px #c6efee;
}
.welfare_box.sen.sen_color2 {
	border: 2px solid #d05f52;
	box-shadow: 5px 5px 0px 0px #ecb4ae;
}
.welfare_box.sen.sen_color3 {
	border: 2px solid #2674ab;
	box-shadow: 5px 5px 0px 0px #afd5f0;
}


.welfare_box .text {margin-top: 20px;}
@media print, screen and (min-width: 576px){
	.welfare_box .image{
		width: 200px;
		float: right;
		margin-left: 20px;
		margin-bottom: 20px;
	}
	.welfare_box .image img{
		width: 100%;
		height: auto;
	}
	.welfare_box .text {margin-top: 0;}
}
@media print, screen and (min-width: 992px){
	.welfare_box .image{ width: 250px;}
}
@media print, screen and (min-width: 1200px){
	.welfare_box{ padding: 50px;}
	.welfare_box .image{ width: 300px;}
}

.welfare_photo {margin-bottom: 20px;}
.welfare_photo > p {margin-bottom: 6px;}
@media print, screen and (min-width: 768px){
	.welfare_photo{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		margin-left: -3px;
		margin-right: -3px;
	}
	.welfare_photo > p {margin: 0 3px;}
}


.welfare_photo2 .photo {margin-bottom: 20px;}
.welfare_photo2 .photo2 {margin-bottom: 20px;}
.welfare_photo2 .photo2 > p {margin-bottom: 5px;}
.welfare_photo2 .photo3 {margin-bottom: 20px;}
.welfare_photo2 .photo3 > p {margin-bottom: 5px;}
@media print, screen and (min-width: 768px){
	.welfare_photo2 .photo {
		width: 31.3%;
		float: left;
		margin-right: 30px;
	}
	.welfare_photo2 .text{
		overflow: hidden;
		zoom:0;
	}
	.welfare_photo2.mb0 .photo {margin-bottom: 0;}
	
	.welfare_photo2 .photo2 {
		width: 31.3%;
		float: left;
		margin-right: 30px;
	}
	.welfare_photo2 .photo3 {
		width: 62%;
		float: left;
		margin-right: 30px;
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.welfare_photo2 .photo3 > p {
		margin-bottom: 0;
		margin-right: 5px;
	}

}
@media print, screen and (min-width: 1600px){
	.welfare_photo2 .photo2 {
		width: 62%;
		float: left;
		margin-right: 30px;
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.welfare_photo2 .photo2 > p {
		margin-bottom: 0;
		margin-right: 5px;
	}
}


.welfare_link{
	margin-left: -1%;
	margin-right: -1%;
}
.welfare_link .box{
	border: 1px solid #ccc;
	width: 48%;
	float: left;
	margin: 1%;
	position: relative;
	z-index: 0;
}
.welfare_link .box:nth-of-type(2n+1) { clear: both;}

.welfare_link .box a:link,
.welfare_link .box a:visited{
	padding: 20px 5px 20px 5px ;
	display: block;
	text-decoration: none;
}
.welfare_link .box .in{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.welfare_link .box .in h3{
	font-weight: 700;
}
.welfare_link .box .in h3 .en{
	display: block;
	font-size: 80%;
	margin-bottom: 5px;
	color: #ff0000;
}
.welfare_link .box img{
	max-width: 40px;
	width: 100%;
	height: auto;
	margin-right: 5px;
}
.welfare_link .box .yaji{
	position: absolute;
	right: 0;
	bottom: 0;
	background: #ff0000;
	color: #fff;
   display:flex;
   align-items:center;
   justify-content:center;
	width: 25px;
	height: 25px;
	font-size: 12px;
}
@media print, screen and (min-width: 576px){
	.welfare_link .box img{
		max-width: 60px;
		margin-right: 15px;
	}
}
@media print, screen and (min-width: 768px){
	.welfare_link .box{
		width: 31.3%;
	}
	.welfare_link .box:nth-of-type(2n+1) { clear: none;}
	.welfare_link .box:nth-of-type(3n+1) { clear: both;}
	.welfare_link .box img{
		max-width: 80px;
	}
}
@media print, screen and (min-width: 1600px){
	.welfare_link .box{
		width: 14.6%;
	}
	.welfare_link .box:nth-of-type(3n+1) { clear: none;}
	.welfare_link .box:nth-of-type(6n+1) { clear: both;}
}


.welfare_title{
	/*
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin-bottom: 20px;
	*/
    display: -webkit-flex;
    display: flex;
    align-items: center;
}
.welfare_title img{
	max-width: 50px;
	width: 100%;
	height: auto;
	margin-right: 10px;
}
@media print, screen and (min-width: 768px){
	.welfare_title img{ max-width: 70px;}
}
@media print, screen and (min-width: 1200px){
	.welfare_title img{ margin-right: 20px;}
}


/* 募集要項 guideline
---------------------------------------------------- */
.guideline_list{
	display: table;
}
.guideline_list li{
	display: table-cell;
}
.guideline_list .title{
	width: 80px;
}

/* よくある質問 qa
---------------------------------------------------- */
.faq_box{
	background: #fff;
	padding: 20px;
	border-radius: 10px;
	margin-bottom: 10px;
}
.faq_box .title{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.faq_box .title .en{
	min-width: 40px;
	max-width: 40px;
   width:40px;
   height:40px;
   border-radius:50%;
   background:#ff0000;
	color: #fff;
	margin-right: 15px;
	font-size: 20px;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
}

.faq_box .answer{
	border-top: 1px solid #1e1e1e;
	padding-top: 15px;
	margin-top: 15px;
	padding-left: 55px;
}
@media print, screen and (min-width: 768px){
	.faq_box{ padding: 30px;}
}
@media print, screen and (min-width: 1200px){
	.faq_box{ padding: 50px 40px;}
}

.qa_list{
	display: table;
}
.qa_list li{
	display: table-cell;
}
.qa_list .title{
	margin-right: 10px;
	font-weight: 700;
	white-space: nowrap;
}

/* 国内拠点 group
---------------------------------------------------- */
.group_popup {
	font-family: "BIZ UDPGothic", sans-serif;
	padding: 0 20px 20px 20px;
}
.group_popup .title{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	/*border-bottom: 1px solid #1e1e1e;*/
	padding-bottom: 10px;
	margin-bottom: 10px;
}
.group_popup .title .num{
	font-size: 16px;
	min-width: 35px;
	max-width: 35px;
   width:35px;
   height:35px;
   border-radius:50%;
   background:#1e1e1e;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	margin-right: 15px;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;	
}
.group_popup .list_ul{margin-left: 0;}
.group_popup .list_ul li{
	display: inline-block;
	margin-right: 10px;
	font-size: 110%;
}
.group_popup .list_ul li:before{
	font-family: bootstrap-icons;
	font-weight: 400;
	content: "\F287";
	margin-right: 5px;
	font-size: 8px;
}

.group_popup .address{
	font-weight: 700;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}

.group_popup .in{
	padding: 20px;
	border-radius: 10px;
	margin-bottom: 20px;
	border: 2px solid #87d896;
}
.group_popup .in.color2{ border: 2px solid #c8ea8b;}
.group_popup .in.color3{ border: 2px solid #a6dbed;}
.group_popup .in.color4{ border: 2px solid #a4cbf6;}
.group_popup .in.color5{ border: 2px solid #f7f37d;}
.group_popup .in.color6{ border: 2px solid #f6c969;}
.group_popup .in.color7{ border: 2px solid #f88a73;}
.group_popup .in.color8{ border: 2px solid #f5b5c9;}

#group_map area{cursor: pointer;}
@media only screen and (max-width: 767px){
	.group_popup .address .fs120 {font-size: 100%;}
}
@media print, screen and (min-width: 768px){
	.group_popup .in{
		padding: 30px;
	}
}
@media print, screen and (min-width: 992px){
	.group_popup .title{
		font-size: 110%;
	}
}


#group_map .container .comment {margin-bottom: 10px; font-size: 90%;
		border: 1px solid #ccc;
		padding: 20px;
		border-radius: 10px;

}
@media print, screen and (min-width: 576px){
	#group_map .container{
		position: relative;
	}
	#group_map .container .comment{
		position: absolute;
		left: 0;
		top: 0;
		z-index: 1;
		font-size: 90%;
		width: 40%;
	}
}
@media print, screen and (min-width: 992px){
	#group_map .container .comment{
		position: absolute;
		left:3%;
		top: 10%;
		font-size: 100%;
	}
}



/* 研修・教育関連施設　facility
---------------------------------------------------- */
#facility_map area{cursor: pointer;}

.facility_photo {margin-bottom: 20px; text-align: center;}
.facility_photo img{ margin-bottom: 5px;}
@media print, screen and (min-width: 576px){
	.facility_photo{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		margin-left: -5px;
		margin-right: -5px;
	}
	.facility_photo >p{
		margin: 0 5px;
	}
}


.facility_flow{
	position: relative;
	margin: 0 auto;
	max-width: 1450px;
}
.facility_flow img{
	margin: 0 auto;
}
.facility_flow li{
	position: absolute;
	left: 0;
	top: 0;
}


/* 数字で見る　numbers
---------------------------------------------------- */
.numbers_box{
	margin-left: 1%;
	margin-right: 1%;
}
.numbers_box .box{
	width: 48%;
	float: left;
	margin: 0 1% 30px 1%;
}
.numbers_box .box:nth-of-type(2n+1) { clear: both;}
.numbers_box .box h3{
	text-align: center;
	font-size: 85%;
	line-height: 1.4em;
	margin-bottom: 10px;
	font-weight: 700;
}
.numbers_box .box img{
	margin: 0 auto;
	border-radius: 20px;
}

.numbers_box .box .waku{
	border: 2px solid #6dd4d1;
	border-radius: 20px;
	border-style: solid;
	padding: 10px 0;
	box-shadow: 5px 5px 0px 0px #c6efee;
}
.numbers_box .date{
	text-align: center;
	font-size: 80%;
}
@media print, screen and (min-width: 576px){
	.numbers_box .box{
		width: 31.3%;
		margin: 0 1% 30px 1%;
	}
	.numbers_box .box:nth-of-type(2n+1) { clear: none;}
	.numbers_box .box:nth-of-type(3n+1) { clear: both;}
}
@media print, screen and (min-width: 768px){
	.numbers_box .box h3{
		font-size: 110%;
	}
}
@media print, screen and (min-width: 992px){
	.numbers_box .box h3{
		font-size: 120%;
		margin-bottom: 15px;
	}
	.numbers_box .box{
		margin: 0 1% 50px 1%;
	}
}
@media print, screen and (min-width: 1600px){
	.numbers_box .box{
		width: 23%;
	}
	.numbers_box .box:nth-of-type(3n+1) { clear: none;}
	.numbers_box .box:nth-of-type(4n+1) { clear: both;}
}


/* contact
---------------------------------------------------- */
.contact_btn{
	display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
}
.contact_btn p{
	width: 55%;
	margin: 10px 1%;
}


.otoiawase_box .box {margin-bottom: 20px;}
.otoiawase_box .box .en{
	font-size: 160%;
	line-height: 1.4em;
	margin-top: 5px;
}
@media print, screen and (min-width: 576px) {
	.otoiawase_box {
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.otoiawase_box .box {width: 50%;}
}
@media print, screen and (min-width: 992px) {
	.otoiawase_box .box .en{
		font-size: 200%;
	}
}
@media print, screen and (min-width: 1600px) {
	.otoiawase_box .box .en{
		font-size: 250%;
	}
}
	
	


.contact_list li{
	list-style: none;
}
@media print, screen and (min-width: 576px){
	.contact_list{
		margin-left: -1%;
		margin-right: -1%;
	}
	.contact_list li{
		width: 48%;
		float: left;
		margin: 0 1%;
	} 
	.contact_list li:nth-of-type(2n+1) { clear: both;}
}
@media print, screen and (min-width: 1200px){
	.contact_list li{
		width: 31.3%;
	} 
	.contact_list li:nth-of-type(2n+1) { clear: none;}
	.contact_list li:nth-of-type(3n+1) { clear: both;}
	
}




/*フォームのテーブル*/
.table_form{
	width:100%;
	border-collapse:collapse;
	border-top:1px solid #dadada;
}
.table_form th{
	width:100%;
	padding:10px 5px 3px 5px;
	display: block;
	color: #5c5c5c;
}
.table_form td{
	width:100%;
	border-bottom:1px solid #dadada;
	padding:3px 5px 10px 5px;
	display: block;
}
.table_form th > div{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.table_form th .hissu{margin-left: auto;}

.table_form th .hissu{/*必須*/
	font-size:70%;
	color:#fff;
	padding:5px 6px;
	/*float:right;*/
	border-radius:3px; 
	font-weight: normal;
	background-color: #ff0000;
	line-height: 1.4em;
	width: 40px;
	min-width: 40px;
	max-width: 40px;
	text-align: center;
}
.table_form td.last {border-bottom:none;}



.table_form th.sen_none,
.table_form td.sen_none{
	border:0;
}

@media print, screen and (min-width: 768px) {
	.table_form th{
		width:35%;
		border-bottom:1px solid #dadada;
		padding:15px 20px;
		vertical-align:middle;
		text-align:left;
		display:table-cell;
		color: #1e1e1e;
	}
	.table_form td{
		width:100%;
		padding:15px 20px;
		display:table-cell;
	}
	
	.table_form.sen_none .last td{padding-bottom: 10px;}
	.table_form.sen_none th{
		padding:10px 20px 0 20px;
	}
	.table_form.sen_none td{
		padding:10px 25px 0 25px;
	}

}
@media print, screen and (min-width: 992px) {
	.table_form th{width:30%;}
}


/* フォーム関係 */
.required input[type="text"], .required input[type="password"], .required select, .required textarea{border:1px solid #c36;}
input[type="checkbox"], input[type="radio"] {vertical-align:middle; margin:5px 5px 5px 0;}
input{font-size:100%;vertical-align:middle; padding:9px}
input[type="file"]{width: 99%;}
input[type="text"], select{border:1px solid #ccc; border-radius:3px; color: #1e1e1e;}
input[type="email"]{color: #1e1e1e;}

input:focus[type="text"]{border:1px solid #06c;}
textarea{font-size:100%;border:1px solid #ccc;width:99%; border-radius:3px; }
input,textarea{ 
  /*display: inline-block; 
  font-family: FontAwesome; */
  font-style: normal; 
  font-weight: normal; 
  line-height: 1; 
  -Webkit-font-smoothing: antialiased; 
  -moz-osx-font-smoothing: grayscale;
} 
select {padding: 9px; color: #1e1e1e; }

.form-control {color: #1e1e1e;}
.form-control.w50 {width:120px; display: inline-block; margin-right: 10px;}
.form-control.w300 {width:200px;}
@media (min-width: 768px) {
.form-control.w300 {width:250px;}
}


.privacy_waku{
	padding:30px 20px;
	font-size: 90%;
	background-color: #fff;
	font-weight: 400;
	border: 1px solid #dadada;
}
@media print, screen and (min-width: 992px){
	.privacy_waku{	padding:40px 20px;}
}


.privacy_scroll {
  max-height:200px;
  overflow-y: scroll;
  padding-right:10px;
	z-index: 1;
	word-break: break-all;
}
@media print, screen and (min-width: 768px) {
.privacy_scroll {max-height:400px;}
}


.midashi_box{
	border-collapse: collapse;
	border-left: 4px solid #dadada;
	padding: 5px 0 5px 25px;
}
.midashi_box2{
	border-collapse: collapse;
	border-left: 1px solid #1e1e1e;
	padding: 5px 0 5px 25px;
	margin-left: 5px;
}
.midashi_box2.red{
	border-left: 1px solid #ff0000;
	color: #1e1e1e;
}
.midashi_box3{
	background: #ff0000;
	color: #fff;
	padding: 20px;
	border-radius: 10px;
}
.midashi_box4{
	border-collapse: collapse;
	border-left: 1px solid #ff0000;
	padding: 5px 0 5px 35px;
	margin-left: 15px;
	
}

@media print, screen and (min-width: 768px) {
	.midashi_box3{
		padding: 20px 30px;
	}
}



.btn-primary{
	border-radius:50px;
	font-size: 100%;
}
.btn-primary:hover{
	background-color: #014091;
	opacity: 1;
}


.form-control {
    height: 50px;
    padding: 12px 10px;
    font-size: 14px;
    line-height: 1.42857143;
    background-image: none;
    border: 1px solid #cccccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}



/*▼メールフォームの「例」のカラー変更*/
::placeholder {
  color: #959595!important;
}
/* 旧Edge対応 */
::-ms-input-placeholder {
  color: #959595!important;
}
/* IE対応 */
:-ms-input-placeholder {
  color: #959595!important;
}


.privacy_text{
	border-collapse: collapse;
	border-left: 6px solid #dadada;
	padding: 10px 0 10px 15px;
}
.privacy_text .name{
	font-weight: 700;
	line-height: 1.4em;
	margin-bottom: 10px;
}



/* footer
---------------------------------------------------- */
footer {
	font-size: 100%;
	line-height: 1.6em;
	color: #fff;
	z-index: 0;
	position: relative;
	background: #1e1e1e;
}


footer .in {padding: 50px 0;}

.foot_text{
	text-align: center;
	font-weight: 700;
	margin-bottom: 5px;
	font-size: 11px;
}

.foot_logo{
	margin: 0 auto 20px auto;
}
.foot_logo img{
	width: 100%;
	height: auto;
	margin: 0 auto 15px auto;
	max-width: 500px;
}

footer a:link,
footer a:visited{
	color: #fff;
	text-decoration: none;
}

footer .sub a:link,
footer .sub a:visited{
	color: #818181!important;
}
footer .nakami_navi2 a:link,
footer .nakami_navi2 a:visited{
	color: #fff;
}
footer .nakami_navi .box{
	/*border-bottom: 1px solid #666;*/
	border-bottom: none;
}
@media print, screen and (min-width: 576px) {
	.foot_logo{
		margin: 0 auto 20px 0;
	}
	.foot_logo img{
		margin: 0 auto 15px 0;
	}
	.foot_logo img{ width: 70%;}
}
@media print, screen and (min-width: 768px) {
	footer .in {padding: 50px 0 0 0;}
	
	.foot_logo img{ width: 80%;}
	
}
@media print, screen and (min-width: 1200px) {
	footer{
		text-align: left;
	}
	/*footer .in {padding: 70px 0;}*/
	
	.foot_logo{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		font-size: 115%;
	}
	.foot_logo img{
		width: 70%;
		margin: 0 15px 0 0;
	}
	
	.foot_box{
		justify-content: right;
	}
}
@media print, screen and (min-width: 1600px) {
	.foot_logo{
		font-size: 140%;
	}
	.foot_logo img{
		width: 100%;
		margin: 0 20px 0 0;
	}
	
}

@media print, screen and (min-width: 992px) {
  footer .nakami_navi2 {
    margin: 30px 20px 20px 20px;
  }
}



.foot_box2 {margin-top: 30px; display: none;}
.foot_box2 ul{
	display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
}
.foot_box2 ul li{
	list-style: none;
	margin: 0 10px;
}
.foot_box2 ul li .bi-instagram {font-size: 30px;}
@media print, screen and (min-width: 768px) {
	.foot_box2 ul{
		 justify-content: end;
	}
}



.foot_link .box h3 {
  font-size: 140%;
  margin-bottom: 15px;
  font-weight: 700;
}

footer .kasen{
	border-top: 1px solid #666;
}


.copy_box{
	background: #0b0b0b;
	padding: 30px 0;
}

img.gaibu{
	max-width: 12px;
	width: 100%;
	height: auto;
	margin-left: 5px;
	display: inline-block;
	vertical-align: middle;
}
.copy_box ul{
	margin-bottom: 10px;
	text-align: center;
}
.copy_box li{
    list-style: none;
    display: inline-block;
    border-right: 1px solid #ccc;
    padding-right: 10px;
    margin-right: 10px;
	line-height: 1.2em;
	font-size: 90%;
}
.copy_box li:last-child{
    border-right: none;
    padding-right: 0;
    margin-right: 0;
}
.copy_box li a:link,
.copy_box li a:visited{
    text-decoration: none;
}
@media print, screen and (min-width: 768px) {
	.copy_box {margin-top: 40px;}
}
@media print, screen and (min-width: 1200px) {
	.copy_box .container{
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.copy_box .copy {margin-left: auto;}
	
	.copy_box ul{
		margin-bottom: 0;
		text-align: left;
	}
	
}
@media only screen and (max-width: 767px) {
	.copy_box ul{
		text-align: left;
	}
	.copy_box li{
		display: block;
		border-right: none;
		padding-right: 0;
		margin-right: 0;
		margin-bottom: 7px;
	}
}

/*copy*/

.copy {
	text-align: center;
	font-size: 80%;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-weight: 400;
}

@media print, screen and (min-width: 1200px) {
	.copy {text-align: right;}
}

@media only screen and (max-width: 767px) {
	footer .in{
		display: none;
	}
	.copy {text-align: left;}
}



/* scroll */
#pagetop .scroll_anime {
  position: absolute;
  bottom: 106px;
  right: min(3.91vw, calc(30px + 16px + 10px));
  writing-mode: vertical-rl;
  white-space: nowrap;
	/*
  font-family: "Oswald", sans-serif;
  font-weight: 500;
	*/
  font-size: 12px;
  color: #B3B3B3;
  letter-spacing: 0.1em;
  z-index: 4;
font-family: "Roboto", sans-serif;
font-weight: 400;
	cursor: pointer;
}

#pagetop .scroll_anime::before {
  content: "";
  position: absolute;
  bottom: -106px;
  left: calc(16px + 10px);
  width: 1px;
  height: 160px;
  /*background: rgba(29, 32, 135, 0.5);*/
	background: none;
}
#pagetop .scroll_anime::after {
  content: "";
  position: absolute;
  bottom: -106px;
  left: calc(16px + 10px);
  width: 1px;
  height: 160px;
  background: #B3B3B3;
  animation: lineAnime2 3s cubic-bezier(1, 0, 0, 1) infinite;
}

@keyframes lineAnime2 {
  100% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }

  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }

  50% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }

  0% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
