@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 #282727;
    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;
	font-weight: bold;
	color:#282727;
	letter-spacing: 0.05em;
	background-color: #fff;
}

sup {font-size: 80%;}

header,
main,
footer{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
}

.bold {font-weight: 700;}

.en{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
}

html{
	scroll-padding-top: 60px;
}

#features1,
#features2,
#features3,
#features4,
#cate_head,
#tokutei1,
#tokutei2,
#tokutei3,
#tokutei4,
#tokutei5,
#ikusei1,
#ikusei2,
#ikusei3,
#ikusei4,
#ikusei5,
#ikusei6{
	margin-top:-60px;
	padding-top:60px;
}
	

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


/* header
---------------------------------------------------- */
header{
	width: 100%;
	top: 0;
	z-index: 100;
	position: fixed;
	padding-top: 10px;
	padding-bottom: 10px;
	background: #fff;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
@media print, screen and (min-width: 992px) {
	header{
		padding: 10px 0;
		height: 120px;
	}
	header.move{
		background: #fff;
		height: 65px;
	}
}
@media print, screen and (min-width: 1600px) {
	header{
		height:125px;
	}
}



/*----------------header固定----------------*/
@media print, screen and (min-width: 992px) {
	header .logo {
		position: absolute;
		top: 35px;
		left: 15px;
		transition: .3s ease-in-out;
		z-index: 100;
	}
	header .logo a h1{
		color: #282727;
		display: -webkit-flex;
		display: flex;
		align-items: center;
		font-weight: 700;
		font-size: 130%;
		line-height: 1.4em;
	}
	header .logo a img{
		min-width: 250px;
		max-width: 250px;
		transition: .3s ease-in-out;
	}
	header.move .logo{
		top: 10px;
	}
	header.move .logo a img{
		min-width:200px;
		max-width: 200px;
	}
	
	.logo a:link,
	.logo a:visited{
		transition: .3s ease-in-out;
		line-height: 1.4em;
		color: #282727;
	}
	
	.logo a:hover {opacity: 1;}
}

@media print, screen and (min-width: 1200px) {
	header .logo {
		top: 30px;
	}
	header .logo a img{
		min-width: 300px;
		max-width: 300px;
	}
	header .logo a h1{ font-size: 150%;}
}
@media print, screen and (min-width: 1600px) {
	header .logo {
		top: 33px;
	}
}

header .tel{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
}
header .tel a:link,
header .tel a:visited{
	padding: 0!important;
	text-decoration: none;
}
header .tel{padding: 10px 15px;}
header .tel span{
	font-size: 150%;
}

header .in{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	padding: 10px 15px;
}
header .in .mail{
	margin-right: 10px;
}
header .in .mail a:link,
header .in .mail a:visited{
	padding: 10px 10px;
	background: #007ab6;
	border-radius: 8px;
	color: #fff;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	height: 45px;
	display:flex;
	align-items:center;
	justify-content:center;
	border: 1px solid #007ab6;
}
header .in .mail a:hover{
	background: #fff;
	color: #007ab6!important;
}
header .in .line img{
	width: 45px;
}
header .in .line a:hover img {
  opacity: 1;
  filter: alpha(opacity=100);
}
header .in .line a:link,
header .in .line a:visited{
	/*
	padding: 10px;
	background: #01bb01;
	border-radius: 5px;
	color: #fff;
	display:flex;
	align-items:center;
	justify-content:center;
	height: 45px;
	*/

	/*border: 1px solid #01bb01;*/
}
header .in .line a:hover{
	/*
	background: #fff;
	color: #01bb01!important;*/
	opacity: 1;
}


header .in i{
	margin-left: 0;
	font-size: 25px;
}


.head_right{display: none;}
@media print, screen and (min-width: 992px) {
	.head_right{
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: flex-end;
		justify-content: flex-end;
		-webkit-align-items: flex-end;
		align-items: center;
	}
	header .in .mail a {font-size: 130%;}
	
	header .in{
		padding: 10px 5px 10px 10px;
	}
	
	.move .head_right {display: none;}
}
@media print, screen and (min-width: 1200px) {
	header .tel {font-size: 120%;}
	
}

header .sp_box2{
	display: none;
}
header.move .sp_box2{
    display: -webkit-flex;
    display: flex;
    align-items: center;
}
header.move .sp_box2 a{
	margin-left: 0!important;
}
header .sp_box2.in{padding: 0 0 0 20px;}


.sp_box{padding-top: 10px; padding-bottom: 10px;}
.sp_box .tel a {display: inline!important;}

/* navi
---------------------------------------------------- */
/*
.gNav a:hover {
  color: #999;
}
*/

.nav { display: none; }/*なぜかこの指定をしていた。何かに影響するかも*/
nav li a {
	font-size: 110%;
	line-height: 1.4em;
}
nav li .en{
	float: right;
	font-size: 80%;
}
nav .sub-menu,.mean-container .mean-nav ul ul {
	background: #fff;
	font-size: 90%;
	line-height: 1.4em;
	font-weight: 400;
}
nav .sub-menu a:link,
nav .sub-menu a:visited{
	color: #4d4d4d!important;
}
nav .sub-menu a:hover,
nav .sub-menu .navi-on2 a{
	color: #007ab6!important;
}

nav li a:link,
nav li a:visited{
	color: #4d4d4d;
}
nav li a:hover{color: #007ab6; opacity: 1;}
nav li.navi-on a{color: #007ab6!important; opacity: 1; background: none;}
nav li.navi-on li a{color: #4d4d4d;}

nav li.navi-on .sub-menu a{color: #4d4d4d!important;}
nav li.navi-on .sub-menu a:hover,
nav li.navi-on .sub-menu .navi-on2 a{color: #007ab6!important;}
/*
.mean-container .mean-nav ul li.navi-on2 a{color: #007ab6!important;}
.gNav .sub-menu li.navi-on2 a{color: #4d4d4d!important;}
*/
  nav li i {
    font-size: 12px;
    margin-left: 5px;
  }

nav li.navi-on a.mean-expand{color: #fff!important;}

@media only screen and (max-width: 767px) {
  .h_logo {
    /*width: 80px;*/
    position: absolute;
    top: 5px;
    left: 10px;
    z-index: 100;
  }
  .gNav .nav {
    overflow-y: auto;
    height: 100vh;
  }
  .mean-nav .container {
    padding: 0;
  }
  nav li .fa {
    display: none;
  }
	
}
@media only screen and (max-width: 991px) {
  .h_logo {
    position: absolute;
    top:8px;
    left: 10px;
    z-index: 210;
  }
	
	.h_logo a{
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.h_logo img{
		width: 185px;
		height: auto;
	}
	
	.mean-nav li{
		border-bottom: 1px solid #dadada;
	}
	.meanmenu-reveal {
	  margin: 15px 17px 27px 17px!important;
	}
	
	.mean-container .mean-bar{
		background: #4d4d4d!important;
		-moz-background-size:100% 2px!important;
		background-size:100% 2px!important; 
	}
	.contact_mail .fa-envelope {display: none;}
	
	nav li .en{
		display: none;
	}
	
	.mean-nav img.img-fluid{
		display: inline-block!important;
		width: 45px;
		vertical-align: middle;
		padding-right: 10px;
	}
}

@media print, screen and (min-width: 992px) {
  /*.h_logo img {  width: 20px;}*/
  .h_top {
    /*display: flex;*/
    justify-content: space-between;
    align-items: center;
  }
  .gNav>ul {
    position: relative;
    /*display: flex;*/
	  display: table;
	  width: auto!important;
	  float: right;
  }
  .gNav li {
    position: relative;
    /*margin-right: 3em;*/
	  display: table-cell;
	  vertical-align: middle;
  }
  .gNav li:last-child {
    margin-right: 0;
  }
  .gNav li a {
    position: relative;
    display: block;
    /*text-align: center;*/
    text-align: left;
    /*line-height: 80px;*/
	  padding: 3px 0 3px 0;
	  /*margin-left: 20px;*/
  }
  .gNav .sub-menu {
    visibility: hidden;/*初期設定を可視化してマウスで反応しないようにします*/
    opacity: 0;
    z-index: 1;
    display: block;
    position: absolute;
    top: 27px!important;
    left: 50%;
    margin-left: -105px;
    width: 225px;
    /*-webkit-transition: all .2s ease;現在では必要ないので消してもいい*/
    /*transition: all .2s ease;*/
	  transition: opacity .2s ease;
	 /* overflow: visible!important;*/
  }
  .gNav .sub-menu.long_pc {
    width: 280px;
  }
  .gNav .sub-menu li a {
    display: block;
    padding: 12px 10px;
    line-height: 1.2em;
	border-bottom: none;
	/*border-bottom: 1px solid #f4d8dd;*/
	font-size: 115%;
  }
  .gNav .sub-menu li:last-child a {
	border-bottom: none!important;
  }
  .gNav .sub-menu a:hover:after {
    content: none;
  }
  .gNav .sub-menu li {
    display: block;
    /*font-size: 16px;*/
    padding: 0;
    margin: 0;
  }
  .gNav .sub-menu li:last-child {
    border-bottom: none;
  }
  .gNav ul > li:hover {
    -webkit-transition: all .5s;
    transition: all .5s;
  }
  .gNav li:hover ul.sub-menu {
    top: 80px;
    visibility: visible;
    opacity: 1;
    z-index: 9999;
  }
  .gNav li ul li:after {
    content: none;
  }
  .gNav .sub-menu li a{margin-left: 0;}
  .gNav .sub-menu li a:hover {
	  color: #007ab6!important;
  }
	
	nav li a {
		font-size: 110%;
	}
	.nav> li>a:hover,
	.nav>li.navi-on> a{
		color: #4d4d4d;
		background: url("../images/navi-on.gif") repeat-x left bottom;
		background-color: none!important;
		opacity: 1;
	}
	nav li.sen_none a:hover{
		background: none;
		
		opacity: 1;
	}
	nav li.navi-on .sub-menu a::after{
		background: none;
	}
	nav li.navi-on .sub-menu a{color: #4d4d4d!important;}
	nav li.navi-on .sub-menu a:hover{color: #007ab6!important;}
	nav li .en{
		float: none;
		display: block;
		font-size: 17px;
		line-height: 1.4em;
	}
	nav li img{
		/*
		width: 60px;
		min-width: 60px;*/
		width: 45px;
		min-width: 45px;
	}
}
@media print, screen and (min-width: 992px) {
	nav { padding-top: 0; padding-right: 5px; margin-top: 0;}
	
	
	.gNav>ul { margin-top: 0;}
	.gNav li a { margin-left: 16px;}
	.recruit_page .gNav li a { margin-left: 12px;}
	.gNav li a:link,
	.gNav li a:visited{
		color: #282727;
	}
	
	.d-lg-inline-block{
		color: #007ab6;
		vertical-align: middle;
	}
	nav .sub-menu,.mean-container .mean-nav ul ul{font-weight: 700;}
	
	/*ホバー*/
	nav > ul > li a::after {
	  position: absolute;
	  bottom: -2px;
	  left: 0;
	  content: '';
	  width: 100%;
	  height: 1px;
	  background: #282727;
	transform: scale(0, 1);
	  transform-origin: center top;
	  transition: transform .3s;
	}
	nav > ul > li a:hover::after {
	  transform: scale(1, 1);
	}
	nav > ul > li.sen_none a::after {
	  background: none!important;
	}
	nav > ul > li.sen_none a:hover::after {
	  transform: 0!important;
	}
	nav > ul > li.navi-on a::after{
	  transform: scale(1, 1);
	}
	nav > ul > li a:hover,
	nav li.navi-on a{
		background: none!important;
		color: #282727!important;
	}
	
	
	nav .sub-menu,.mean-container .mean-nav ul ul {
		background: #4d4d4d;
	}
	.sub-menu {
	  border-top:none!important;
	}
	.gNav .sub-menu li a:hover,
	.gNav .sub-menu li.navi-on2 a{
		/*background: #efefef!important;*/
		background: none!important;
		color: #007ab6 !important;
	}
	.gNav .sub-menu li a i {font-size: 120%; margin-right: 5px;}
	
	
	nav .sub-menu,.mean-container .mean-nav ul ul {
		background: #fff;
		border-radius: 20px;
		padding: 10px 5px;
		box-shadow: 0px 2px 18px 0px rgba(6, 4, 4, 0.21);
	}
}
@media print, screen and (min-width: 1200px) {
	
	nav li a {
		font-size: 120%;
	}
	nav li .en{ font-size: 23px;}
	  .gNav .sub-menu {
		top: 30px!important;
	  }
	.gNav li a { margin-left: 25px;}
}
@media print, screen and (min-width: 1600px) {
}

.sub_navi{
	border-top: 2px solid #4d4d4d;
}
.sub_navi p{
	width: 50%;
	float: left;
	border-bottom: 1px solid #4d4d4d;
}
.sub_navi.long p{
	width: 100%;
	float: none;
	border-bottom: 1px solid #4d4d4d;
}
.sub_navi p a:link,
.sub_navi p a:visited{
	background-color: #e5edf3;
	padding: 12px 15px!important;
}
.sub_navi p:nth-of-type(2n+1) { clear: both;}

nav li.navi-on .sub_navi a{
	color: #4d4d4d!important;
}
nav li.navi-on .sub_navi a:hover{
	color: #212b5c!important;
}
@media print, screen and (min-width: 576px) {
	.sub_navi p{
		width: 25%;
	}
	.sub_navi p:nth-of-type(2n+1) { clear: none;}
	.sub_navi p:nth-of-type(4n+1) { clear: both;}
}
@media print, screen and (min-width: 768px) {
	.sub_navi.long p{
		width: 50%;
		float: left;
	}
}

/*
.mean-container .mean-nav ul li li{
	width: 50%!important;
	float: left;
}
.mean-container .mean-nav ul li li:nth-of-type(2n+1) { clear: both;}
*/
.mean-container .mean-nav ul li.navi-on a:hover{
	/*background: #0f3876!important;*/
	color: #007ab6;
}
@media print, screen and (min-width: 576px) {
	.mean-container .mean-nav ul li li{
		width:50%!important;
		float: left;
		border-bottom: none;
	}
	.mean-container .mean-nav ul li li:nth-of-type(2n+1) { clear: both;}
}
@media print, screen and (min-width: 768px) {
	.mean-container .mean-nav ul li li{
		width:33.33%!important;
	}
	.mean-container .mean-nav ul li li:nth-of-type(2n+1) { clear: none;}
	.mean-container .mean-nav ul li li:nth-of-type(3n+1) { clear: both;}
}


.mean-container .mean-nav ul li .long_pc li{
	width: 100%!important;
	float: left;
}
.sub-menu{
	/*border-top: 1px solid #ccc;*/
}
.mean-container .mean-nav ul li li a {
  padding: 1em 15px!important;
}

.mean-container .mean-bar{background: #fff!important;}/*ナビの背景*/

.osu1 {position: relative; z-index: 1;}
.osu2 {position: relative; z-index: 2;}
.osu3 {position: relative; z-index: 3;}

.f-right {float: right;}


.nav { display: none; }/*一瞬ナビが開くのをやめる*/

#top03 .nav{display: flex;}

#blog .nav{display: flex;}


/* midashi
---------------------------------------------------- */
.fs60 {font-size:60%;}
.fs70 {font-size:70%;}
.fs75 {font-size:75%;}
.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:250%; line-height:1.4em;}

.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.8em;}
@media print, screen and (min-width: 768px){
	.text_large{font-size: 115%; line-height: 2.0em;}
}
@media print, screen and (min-width: 1600px){
	.text_large{font-size: 120%;}
}

.normal {font-weight: 500;}

@media print, screen and (min-width: 1200px){
	.text_pl20 {padding-left: 40px;}
	.text_pr20 {padding-right: 40px;}
}


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

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

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

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


#midashi_h2_area{
	position: relative;
	overflow: hidden;
	z-index: 0;
	color: #fff;
}
#midashi_h2_area .photo{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
#midashi_h2_area .photo img{
	width: 100%;
	height: 100%;
	filter: brightness(85%);

}
/**/


#midashi_h2{
	padding-top: 60px;
	color: #fff;
	margin-top: 55px;
}
#midashi_h2 .area{
	background-color: #09174e;
	padding: 20px 20px 10px 20px;
	width: 80%;
}
#midashi_h2 h2{
	line-height: 1.4em;
	margin-bottom: 30px;
	text-align: left; 
	font-size: 100%;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 700;
		/*text-shadow : 0px 3px 5.6px rgba(0, 0, 0, 0.23) ;*/
}
#midashi_h2 h2 .en{
	font-size: 250%;
	line-height: 1.0em;
	margin-top: 5px;
	display: -webkit-flex;
    display: flex;
    align-items:center;
}
#midashi_h2 h2 .en img{
	min-width: 30px;
	max-width: 30px;
	margin-left: 15px;
}

.pankuzu{
	font-size: 85%;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	margin-bottom: 10px;
}
.pankuzu a:link,
.pankuzu a:visited{
	text-decoration: underline;
	color: #fff;
}
@media print, screen and (min-width: 768px){
	.pankuzu{
		margin-bottom: 20px;
	}
}



@media print, screen and (min-width: 768px){
	#midashi_h2 {margin-bottom: 0;}
	#midashi_h2{  margin-bottom: 0;}
	#midashi_h2 h2{
		font-size:120%;
	}
	#midashi_h2 h2{
		margin-bottom: 40px;
	}
	#midashi_h2 h2 .en{ font-size: 290%;}
}
@media print, screen and (min-width: 992px){
	#midashi_h2{ margin-top: 90px;}
	#midashi_h2 h2{ font-size: 120%;}
	#midashi_h2 h2 .en{ font-size: 330%;}
}
@media print, screen and (min-width: 1200px){
	#midashi_h2{ margin-top: 120px;}
	#midashi_h2 h2{font-size: 140%; margin-bottom: 60px;}
	#midashi_h2 h2 .en{ font-size: 360%;}
}
@media print, screen and (min-width: 1600px){
	#midashi_h2{ margin-top: 150px;}
	#midashi_h2 h2 .en{ font-size: 420%;}
}


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



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

.midashi2{
	font-weight: 700;
	font-size: 150%;
	line-height: 1.4em;
}

.midashi3{
	font-weight: 500;
	font-size: 120%;
	line-height: 1.4em;
}
.midashi3.sen{
	border-bottom: 1px solid #282727;
	padding-bottom: 10px;
}
.midashi3.sen2{
	border-left: 5px solid #007ab6;
	padding-left: 12px;
}


.midashi4{
    font-weight: 700;
    font-size: 110%;
    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: 1em; /* 文字の右隣 */
}

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



.midashi_en{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	font-size: 200%;
	line-height: 1.2em;
}

.midashi_num{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	font-size: 200%;
	line-height: 1.2em;
	min-width: 60px;
	max-width: 60px;
   width:60px;
   height:60px;
   border-radius:50%;
   background: #007ab6;
	color: #fff;

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


.midashi_en2{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	font-size: 110%;	
	line-height: 1.2em;
	color: #fff;
	background: #c33;
	border-radius: 50px;
	display: inline-block;
	padding: 5px 15px;
}
.midashi_en2.blue_bg{
	background: #007ab6;
}
.midashi_en2.ja{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
}

.title_soroe{ padding-left: 33px;}


.title_narabi{
	display: -webkit-flex;
    display: flex;
	align-items: center;
}
.title_narabi .migi{
	margin-left: 3%;
}
@media print, screen and (min-width: 576px) {
	.title_narabi{
		align-items:center;
	}
	
}
@media print, screen and (min-width: 768px) {
	.pl_text {padding-left: 35px;}
	.pr_text {padding-right: 35px;}
	.midashi1{ font-size: 170%;}
	.midashi2{ font-size: 180%;}
	.midashi5{ font-size: 130%;}
	.midashi_en{ font-size: 300%;}
	.midashi_num{
		font-size: 300%;
		min-width: 80px;
		max-width: 80px;
	   width:80px;
	   height:80px;
	}
}
@media print, screen and (min-width: 992px) {
	.pl_text_awase{padding-left: 45px;}
	.midashi_num{
		font-size: 300%;
		min-width: 100px;
		max-width: 100px;
	   width:100px;
	   height:100px;
	}
}
@media print, screen and (min-width: 1200px) {
	.midashi1{ font-size: 200%;}
	.midashi2{ font-size: 200%;}
	.title_soroe{ padding-left: 40px;}
	.midashi_en{ font-size: 400%;}
	.midashi5{ font-size: 140%;}
}
@media print, screen and (min-width: 1600px) {
	.midashi2{ font-size: 280%;}
	.midashi_en{ font-size: 450%;}
}



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



.mannaka .button1,
.mannaka .button2{
	margin: 0 auto;
}
.migi .button1{
	margin-left: auto;
}
@media only screen and (max-width: 767px) {
	.mannaka_sp .button1{
		margin: 0 auto;
	}
}


.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: none;
	/*
	padding: 15px 15px 15px 50px;
	border-radius: 50px;
	border: 2px solid #dedede;
	*/
}
.button1 a:link,
.button1 a:visited{
	text-decoration: none;
	color: #282727;
}
.button1 .moji{
	border-bottom: 1px solid #282727;
	padding-bottom: 3px;
}
.button1 a:hover {
  /*color:#0083c5;*/
  opacity:1
}
.button1 a .arrow {
  width:35px;
  height:35px;
  margin-left:20px;
  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:50px;
  height:50px;
}



.button2 {
  width:max-content;
  height:auto;
  position:relative
}
.button2 a {
  font-size:100%;
  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: #fff;
padding: 12px 8px 12px 40px;
	border-radius: 50px;
	border: 1px solid #222;
}
.button2 a:link,
.button2 a:visited{
	text-decoration: none;
	color: #282727;
}
.button2 .moji{
	border-bottom: 1px solid #c00000;
	padding-bottom: 3px;
}
.button2 a:hover {
  /*color:#0083c5;*/
  opacity:1
}
.button2 a .arrow {
  width:30px;
  height:30px;
  margin-left:20px;
  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 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);
	background: none;
	/*padding: 8px 8px 8px 28px;*/
	border-radius: 50px;
	/*border: 1px solid #222;*/
}
.button3 a:link,
.button3 a:visited{
	text-decoration: none;
	color: #fff;
}
.button3 .moji{
	border-bottom: 1px solid #282727;
	padding-bottom: 3px;
}
.button3 a:hover {
  /*color:#0083c5;*/
  opacity:1
}
.button3 a .arrow {
  width:50px;
  height:50px;
  margin-left:20px;
  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 a:hover .arrow {
  width:60px;
  height:60px;
}
.button3 .arrow::before {
  background:none;
	border: 1px solid #fff;
}
.button3 a:hover .arrow::before {
  background:none;
}



.button4 {
  width:max-content;
  height:auto;
  position:relative
}
.button4 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: #e4ebfc;
padding: 8px 8px 8px 50px;
	border-radius: 50px;
	/*border: 1px solid #222;*/
}
.button4 a:link,
.button4 a:visited{
	text-decoration: none;
	color: #282727;
}
.button4 .moji{
	border-bottom: 1px solid #c00000;
	padding-bottom: 3px;
}
.button4 a:hover {
  /*color:#0083c5;*/
  opacity:1
}
.button4 a .arrow {
  width:50px;
  height:50px;
  margin-left:20px;
  transition:width .2s cubic-bezier(0.33, 1, 0.68, 1),height .2s cubic-bezier(0.33, 1, 0.68, 1)
}
.button4 a .arrow i {
	color: #fff;
}
.button4 a:hover .arrow {
  width:60px;
  height:60px;
	background-color:#282727;
}
.button4 .arrow::before {
  background-color:#282727;
}
.button4 a:hover .arrow::before {
	background-color:#282727;
}



.arrow {
  display:flex;
  justify-content:center;
  align-items:center;
  flex-shrink:0;
  width:60px;
  height:60px;
  position:relative;
  border-radius:50%;
  transition:transform .64s cubic-bezier(0, 0.55, 0.45, 1)
}
.arrow::before {
  content:"";
  width:100%;
  height:100%;
  position:absolute;
  inset:0 auto auto 0;
  background-color:#282727;
  border-radius:50%;
  transition:transform .64s cubic-bezier(0, 0.55, 0.45, 1);
	/*border: 1px solid #fff;*/
}
a:hover .arrow::before {
  background-color:#282727;
}


.arrow i {
  fill:#7d8386;
  position:relative
}







.btn_mail{
	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;
	/*ここまで*/
	font-weight: 700;
}
.btn_mail:link,
.btn_mail:visited{
	color:#c00000;
	padding:15px 20px;
	text-decoration: none;
	z-index: 2;
	border: 1px solid #307ad0;
}
.btn_mail:hover{
	opacity: 1;
	background-color: #c00000;
	color: #fff;
}


.btn_mail i {margin-right: 15px; font-size: 130%; vertical-align: middle; color: #307ad0;}
.btn_mail:hover i {color: #fff;}
.btn_mail.btn {border-radius: 5px; }
@media print, screen and (min-width: 1200px) {
	.btn_mail {font-size: 140%;}
	.btn_mail:link,
	.btn_mail:visited{
		padding:20px 25px;
	}
}


.btn1{
	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;
	/*ここまで*/
	font-weight: 700;
}
.btn1:link,
.btn1:visited{
	color:#fff;
	padding:10px 20px;
	text-decoration: none;
	z-index: 2;
	background: #282727;
}
.btn1:hover{
	opacity: 1;
	background-color: #007ab6;
	color: #fff;
}


.btn1 i {margin-left: 15px; font-size: 130%; vertical-align: middle;}
.btn1:hover i {color: #fff;}
.btn1.btn {border-radius: 50px; }
@media print, screen and (min-width: 1200px) {
}








.btn3{
	font-size: 100%;
	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;
	/*ここまで*/
	font-weight: 700;
}
.btn3:link,
.btn3:visited{
	color:#282727;
	z-index: 2;
	text-decoration: none;
	border-bottom: 1px solid #282727;
	padding: 5px 0;
}
.btn3:hover{
	opacity: 1;
	padding: 10px 30px;
	background: #282727;
	color: #fff;
}
.btn3.btn {border-radius: 0;}
.btn3 i {margin-right: 7px;}


.btn4{
	font-size: 100%;
	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;
	/*ここまで*/
	font-weight: 700;
}
.btn4:link,
.btn4:visited{
	color:#282727;
	z-index: 2;
	text-decoration: none;
	border: 1px solid #282727;
	padding: 15px 20px;
}
.btn4:hover{
	opacity: 1;
	background: #c00000;
	color: #fff;
	border: 1px solid #c00000;
}
.btn4.btn {border-radius: 5px;}
.btn4 i {margin-left: 20px;}




.btn_recruit{
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	font-weight: 700;
	font-size: 110%;
	text-align: center!important;
	line-height: 1.4em;
}
.btn_recruit:link,
.btn_recruit:visited{
	color:#fff!important;
	background-image: -webkit-linear-gradient( 0deg, rgb(255,125,131) 0%, rgb(248,147,78) 100%);
	text-decoration: none;
	padding: 12px 20px!important;
	width: 145px!important;
}
.btn_recruit:hover{
	opacity: 1;
	background-color: #282727!important;
}
.btn_recruit.btn {border-radius: 5px; padding:0; border: 0;}
@media print, screen and (min-width: 1200px) {
	.btn_recruit:link,
	.btn_recruit:visited{
		width: 175px;
	}
}


.btn_pdf{
	font-size:90%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
}
.btn_pdf:link,
.btn_pdf:visited{
	color:#282727!important;
	text-align: center;
	vertical-align: middle;
	text-decoration: none!important;
}
.btn_pdf:hover{
	opacity: 1;
}
.btn_pdf i {margin-right: 5px; color: #d63923; font-size: 200%;}
.btn_pdf.btn {border-radius: 50px; padding:0;}


.btn_pdf2{
	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-right: 2px;
}
.btn_pdf2:link,
.btn_pdf2:visited{
	text-align: center;
	vertical-align: middle;
}
.btn_pdf2 i{
	color:#c00000!important;
	font-size: 160%;
	margin-right: 5px;
}





.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;
	/*ここまで*/
	position: relative;
	width: 35px;
	height: 35px;
	line-height: 35px;
}
.btn_yaji:link,
.btn_yaji:visited{
	color: #c00000;
	font-size: 160%;
}
.btn_yaji:hover{
	opacity: 1;
	color: #282727;
	font-size: 180%;
}
.btn_yaji.btn {border-radius: 0; padding:0; border: 0;}




.btn_detail{
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
.btn_detail:link,
.btn_detail:visited{
   width:35px;
   height:35px;
   border-radius:50%;
   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
	color: #c00000!important;
	background: #fff;
}
.btn_detail:hover{
	opacity: 1;
	color: #fff!important;
	background-color: #282727;
}
.btn_detail.btn {border-radius: 50px; padding:0;}
.btn_detail i {font-size: 100%;}




.btn_detail2{
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
}
.btn_detail2:link,
.btn_detail2:visited{
   width:35px;
   height:35px;
   border-radius:50%;
   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
	color: #fff!important;
	background: #c00000;
}
.btn_detail2:hover{
	opacity: 1;
	color: #fff!important;
	background-color: #282727;
}
.btn_detail2.btn {border-radius: 50px; padding:0;}
.btn_detail2 i {font-size: 100%;}


.btn_map{
	font-size: 140%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	margin-left: 5px;
	vertical-align: middle;
	line-height: 1.0em;
}
.btn_map:link,
.btn_map:visited{
	color:#007ab6;
	text-decoration: none;
}
.btn_map:hover{
	opacity: 1;
	color: #282727;
}





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




.pdf_list2 li{
	list-style: none;
	margin-bottom: 3px;
}
.pdf_list2 li a:link,
.pdf_list2 li a:visited{
	padding: 10px 15px;
	background: #c00000;
	color: #fff;
	display: block;
	text-decoration: none;
	font-size: 90%;
	border-radius: 0;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	border-radius: 5px;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.pdf_list2 li a:hover{
	padding: 10px 15px;
	opacity: 1;
	border-radius: 50px;
}
.pdf_list2 li i {margin-right: 10px; font-size: 130%;}
@media print, screen and (min-width: 1200px){
	.pdf_list2{
		margin-left: -1%;
		margin-right: -1%;
	}
	.pdf_list2 li{
		width: 31.3%;
		float: left;
		margin: 1%;
	}
}




.text_link_area a {text-decoration: underline; color: #282727;}
.text_link i { color: #c00000; margin-left: 10px; font-size: 110%;}

a.text_link {text-decoration: underline; color: #c00000;}
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: #c00000;}
	.text_link_sp2 {text-decoration: underline!important; color: #fff;}
}



/* ホバーアニメーション　*/

.tar_sptac a.btn_ugoki{
	justify-content: center;
}

a:link.btn_ugoki,
a:visited.btn_ugoki{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	text-decoration: none;
	color: #c00000;
}
a:hover.btn_ugoki{
	opacity: 1;
}



/* リスト
---------------------------------------------------- */
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;
	line-height: 1.6em;
}
ul.list_ul li {margin-bottom: 5px;}
ul.list_ul .sub{
	font-size: 80%;
	line-height: 1.6em;
}


ol.list_num {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
}
 
ol.list_num> li {
	color: #282727;
}
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: #282727;
  color: #fff;
  display: block;
  float: left;
  line-height: 25px;
  margin-left: -35px;
  text-align: center;
  height: 25px;
  width: 25px;
  border-radius: 50%;
font-family: "DM Sans", sans-serif;
font-weight: 500;
	margin-top: 2px;
	font-size: 80%;
}

@media print, screen and (min-width: 1200px){
	.table1  ol.list_num > li:before {
		margin-top: 4px;
	}
}




ul.list_check li{
	list-style:none;
	text-indent: -1.7em;
	padding-left:1.7em;
	line-height: 1.6em;
	font-size: 100%;
	margin-bottom: 5px;
	text-align: left;
}
ul.list_check li:before{
	font-family: bootstrap-icons;
	font-weight: 700;
	content: "\F270";
	margin-right: 10px;
	color: #c00000;
	font-size: 120%;
	vertical-align: top;
}
ul.list_check li .title{
	font-size: 110%;
	color: #c00000;
	margin-bottom: 10px;
} 

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: #c00000;
	font-size: 80%;
}
@media print, screen and (min-width: 576px){
	ul.list_maru li{margin-left: 5px;}
	ul.list_maru{
		margin-left: -1%;
		margin-right: -1%;
	}
}
@media print, screen and (min-width: 1600px){
	ul.list_maru li{margin-left: 10px;}
}



ul.list_maru2 li{
	list-style:none;
	text-indent: -1.2em;
	padding-left:1.2em;
	padding-top: 10px;
	padding-bottom: 10px;
	line-height: 1.6em;
	color: #c00000;
	font-weight: 700;
	font-size: 120%;
	border-bottom: 1px solid #c00000;
}
ul.list_maru2 li:before{
	font-family: bootstrap-icons;
	font-weight: 400;
	content: "\F287";
	margin-right: 12px;
	color: #f7ca5d;
	font-size: 10px;
}
@media print, screen and (min-width: 576px){
	ul.list_maru2 li{margin-left: 5px;}
	ul.list_maru2{
		margin-left: -1%;
		margin-right: -1%;
	}
}
@media print, screen and (min-width: 1600px){
	ul.list_maru2 li{margin-left: 10px;}
}


/* color
---------------------------------------------------- */
.red{color:#c00000;}
.white{color:#fff;}
.black{color:#282727;}
.gray{color:#91908f;}
.blue{color:#007ab6;}

/* 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;
}
.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 0 10px;
	display: block;
	color: #666;
	font-weight: 700;
}
.table1 td{
	width:100%;
	padding:0 10px 10px 10px;
	display: block;
	border-bottom: 1px solid #ccc;
}
@media print, screen and (min-width: 768px) {
	.table1 th{
		width:35%;
		padding:12px 12px;
		vertical-align:middle;
		text-align:center;
		display:table-cell;
		border-bottom: 1px solid #ccc;
		color: #282727;
	}
	.table1 td{
		width:100%;
		padding:12px 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: 1px solid #dadada;
	background: #fff;
}
.table2 th,.table2 td{
	padding: 10px;
	border-bottom: 1px solid #dadada;
	border-right: 1px solid #dadada;
	text-align: center;
	vertical-align: middle;
	line-height: 1.6em;
}
.table2 th{background: #007ab6; color: #fff; padding: 20px 10px;}
.table2 td.center{
	background: #eae6e0;
	white-space: nowrap;
}
@media only screen and (max-width: 767px) {
	.table2 th{
		width: 1%;
		white-space: nowrap;
	}
	.table2 th,.table2 td{
		font-size: 90%;
	}
}


/* サイズ指定
---------------------------------------------------- */
.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_lg0 {margin-bottom: 30px;}
@media print, screen and (min-width: 992px) {.mb30_lg0 {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_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;}}

.mb50_xl70 {margin-bottom:50px;}
@media print, screen and (min-width: 1200px) {.mb50_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;}}


@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;}
	.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_pd.pt30 {padding-top: 30px;}
.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.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: 110%;}
	.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: 120%;}
	.content_pd {padding-top: 100px; padding-bottom: 100px;}
	.content_pd.xl0 {padding-top: 0; padding-bottom: 0;}
	.pt_left {padding-left: 35px;}
	.pt_right {padding-right: 35px;}
}
@media print, screen and (min-width: 1600px){
	main {font-size: 125%;}
}
.content_pd.pt0{padding-top: 0;}
.content_pd.pt20{padding-top: 20px;}
.content_pd.pt50{padding-top: 50px;}
.content_pd.pb0{padding-bottom: 0;}
.content_pd2.pb0{padding-bottom: 0;}
.content_pd.pb10{padding-bottom: 10px;}
.content_pd.pb30{padding-bottom: 30px;}
.content_pd.pb30_xl50{padding-bottom: 30px;}
.content_pd.pb50{padding-bottom: 50px;}
@media print, screen and (min-width: 1200px){
	.content_pd.pb30_xl50{padding-bottom: 50px;}
}

/* mainimage
---------------------------------------------------- */
/* 画面用 */
@media screen {
#main_print { display: none; }
}

/* 印刷用 */
@media print {
#main_print img { margin: 0 auto;}
}


#mainimage {
	position: relative;
	width:100%;
	overflow: hidden;
	margin-top: 60px;
}
@media print, screen and (min-width: 768px){
	#mainimage {
		margin-top: 0;
	}
}



#mainimage .main_moji {
	z-index: 3;
    position: absolute;
    bottom: 8%;
    left: 5%;
}
#mainimage .main_moji img {width: 60%; max-width:670px;}
@media print, screen and (min-width: 1200px){
	#mainimage .main_moji img {width: 80%;}
}
@media print, screen and (min-width: 1700px){
	#mainimage .main_moji img {width: 100%;}
}



/* scroll */
.scroll_area{
	position: relative;
	width: 55%;
}
.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: #fff;
  letter-spacing: 0.1em;
  z-index: 4;
	 font-family: "Google Sans Flex", sans-serif;
	font-weight: 700;
}

.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;
}
.scroll_anime::after {
  content: "";
  position: absolute;
  bottom: -106px;
  left: calc(16px + 10px);
  width: 1px;
  height: 160px;
  background: #fff;
  animation: lineAnime 3s cubic-bezier(1, 0, 0, 1) infinite;
}

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

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

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

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


/*=============
slick
=============*/
.slider {
  max-width: 2000px;
  width: 100%;
}
.slick-img img {
  height: auto;
  width: 100%;
}
/*
@media only screen and (max-width: 767px){
	.slick-img img{
		display: block;
		aspect-ratio: 300/200;
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: 0 100%;
	}	
}
*/

#mainimage {
    height: 50vh;
}
.slick-img{height: 50vh;}
.slick-img img{
    display: block;
    /*aspect-ratio: 300/200;*/
    width: 100%;
    height: 50vh;
    object-fit: cover;	
}	

@media print, screen and (min-width: 768px){
	#mainimage {
		height: 100vh;
	}
	.slick-img{height: 100vh;}
	.slick-img img{
		display: block;
		/*aspect-ratio: 300/200;*/
		width: 100%;
		height: 100vh;
		object-fit: cover;	
	}	
}



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


/* 背景
---------------------------------------------------- */
.bg_cream{ background: #eae6e0;}
.bg_blue_kusumi{ background: #aab5ba;}


.box26 {
    position: relative;
    margin: 2em 0;
    padding: 0.5em 1em;
    border: solid 1px #000;
}
.box26 .box-title {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    display: inline-block;
    padding: 0 9px;
    line-height: 1;
    background: #eae6e0;
}
.box26 .box-title.bg_white {
    background: #fff;
}
.box26 .box-title.ichi1 {
    top: -16px;
}
.box26 .nakami {
    padding: 50px 20px 20px 20px;
}
.box26 .nakami2 {
    padding: 30px 10px 20px 10px;
}
@media print, screen and (min-width: 576px){
	.box26 .box-title {
		top: -18px;
	}
	.box26 .nakami {
		padding: 30px 20px 20px 20px;
	}
}
@media print, screen and (min-width: 1200px){
	.box26 .nakami {
		padding: 50px 20px 30px 20px;
	}
}




.box28 {
    position: relative;
    margin: 25px 0 0 0;
    padding: 0.5em 5px;
    border-top: solid 1px #aab5ba;
}
.box28 .nakami {
    padding: 30px 0 20px 0;
}

.box28 .title{
   width:50px;
   height:50px;
   border-radius:50%;
   background:#007ab6;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	text-align: center;
	font-size: 11px;
}
.box28 .title .num{
	display: block;
	font-size: 20px;
}
@media print, screen and (min-width: 768px){
	.box28 .midashi3{
		height: 60px;
		display:flex;
	   align-items:center;
	   justify-content:center;
	}
	.box28 .box-title {
		position: absolute;
		top: -25px;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		display: inline-block;
		padding: 0 9px;
		line-height: 1;
		background: #fff;
	}
}

@media print, screen and (min-width: 1200px){
	.box28 .nakami {
		padding: 30px 0 30px 0;
	}
	.box28 .midashi3{
		height: 85px;
	}
}
@media only screen and (max-width: 767px){
	.box28 {
		position: relative;
		margin: 0 0 0 25px;
		padding: 0;
		border-left: solid 1px #aab5ba;
		border-top: none;
		min-height: 80px;
	}
	.box28 .box-title {
		position: absolute;
		left: -25px;
		display: inline-block;
		padding: 9px 0;
		line-height: 1;
		background: #fff;
	}
	.box28 .nakami {
		padding: 20px 0 20px 40px;
	}

	.box28 .title{
	   width:50px;
	   height:50px;
	   border-radius:50%;
	   background:#007ab6;

	   /*display:flexで中央配置*/
	   display:flex;
	   align-items:center;
	   justify-content:center;
		color: #fff;
		font-family: "Roboto", sans-serif;
		font-weight: 700;
		text-align: center;
		font-size: 11px;
	}
	.box28 .title .num{
		display: block;
		font-size: 20px;
	}
	
	.box28 .nakami .tac {text-align: left;}
}
	
	



.bg1,
.bg3{
  height: 100%;
  line-height: 100%;
  position: relative;
}

.bg2{
  height: 1px;
  /*line-height: 100%;*/
  position: relative;
}
@media print {
	.bg1::before,
	.bg2::before,
	.bg3::before{
     opacity: 1 !important;
     transform: none !important; }
}


span {
  position: relative;
}

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

.bg3::before{
  content: '';
  display: block;
  position: absolute;
  /*width: 80%;*/
  width: 100%;
  height: 100%;
  background: #c00000;
  transition: 1s;
  transform-origin: left top;
  transform: scale(0, 1);
	z-index: -1;
}

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




/* 背景固定
---------------------------------------------------- */
.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: 80vh;
    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: 1499px) {/*iPad横でも不具合でたため、1199px以下にした*/
    .b_fixed_bg {
        height: 520px;
        background-attachment: scroll; /*スマホ・タブ(ios)では不具合がでるため幅992px以下ではこの指定（印刷時のスタイルも）*/
    }
	/*
    .b_fixed_bg.takame {
        height: 900px;
    }
	*/
}


.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);
	position: relative;
	z-index: 0;
}
.b_fixed_bg.b_bg2 {
    background-image: url("../images/kotei2.jpg") , url(../images/kotei2.jpg);
	position: relative;
	z-index: 0;
}

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




/* レイアウト
---------------------------------------------------- */
.layout1 .photo{
	max-width: 962px;
}
.layout1 .photo img{
	width: 100%;
	height: auto;
}
@media print, screen and (min-width: 768px){
	.layout1 {
		position: relative;
		z-index: 0;
	}
	.layout1 .photo{
		position: absolute;
		right: 5%;
		top: 0;
		width: 40%;
		z-index: 0;
	}
	.layout1 .photo.hidari{
		right: auto;
		left: 5%;
	}
	.layout1 .yohaku{
		position: relative;
		z-index: 2;
	}
}




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

.close {
    float: none;
}

/* 縦横比固定 */
.photo-ofi {
	 height: 0;
	 display: block;
	padding-bottom: 75%; /* 高さを指定（ボックスの横幅を基準） */
	/*background-color: #fff;*/
	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: "DM Sans", sans-serif; font-weight: 500;}
div.paging span.current,
div.paging span.paging-text{
	margin:0px 0.5px;
	color:#282727;
	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: #282727;
	background-color: #fff;
	border-radius: 5px;
}
div.paging span.current{
	background: #282727;
	color:#fff;
	zoom:1;
	padding:5px 8.5px;
	text-decoration:none;
	display:inline-block;
	cursor:pointer;
	border-radius: 5px;
	
}
div.paging span.paging-text a:hover{
	background: #282727;
	color:#fff;
	text-decoration:none;
	cursor:pointer;
	opacity: 1;
}



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






/* アニメーション
---------------------------------------------------- */
/*ぼかし*/
@media print {
   img.bokashi {
     opacity: 1 !important;
     transform: none !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 {
   .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;
}

.blue.img-animation::before {
  background: #c00000;
}

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

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

/* スクロールダウン
-------------------------------------*/
.title_sen{
	position: relative;
}
/* スクロールダウンの位置 */
.scroll_sen {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  /*writing-mode: vertical-rl;*/
}
/* 線のアニメーション部分 */
.scroll_sen::before {
  animation: scroll 2s infinite;
  background-color: #282727;
  bottom: -50px;
  content: "";
  height: 50px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
}
.scroll_sen.white::before {
  background-color: #fff;
}
/* 線のアニメーション */
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}



/* スクロールアニメーション
-------------------------------------*/
@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.1s;
}

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

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

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

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

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


/***************************************************
 * Generated by SVG Artista on 2/20/2026, 2:08:41 PM
 * MIT license (https://opensource.org/licenses/MIT)
 * W. https://svgartista.net
 **************************************************/

.svg-elem-1 {
  stroke-dashoffset: 1399.459716796875px;
  stroke-dasharray: 1399.459716796875px;
  fill: transparent;
  -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
                        fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
          transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
                fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
}

.svg-elem-1.active {
  stroke-dashoffset: 0;
  fill: rgb(40, 39, 39);
}


/* svgアニメーション
---------------------------------------------------- */


/***************************************************
 * Generated by SVG Artista on 4/17/2026, 9:13:28 AM
 * MIT license (https://opensource.org/licenses/MIT)
 * W. https://svgartista.net
 **************************************************/

.svg-elem-2 {
  stroke-dashoffset: 1407.519287109375px;
  stroke-dasharray: 1407.519287109375px;
  fill: transparent;
  -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
                        fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
          transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
                fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
}

.svg-elem-2.active{
  stroke-dashoffset: 0;
  fill: rgb(255, 255, 255);
}








.title .svg-container{
    width: 100%;
}
svg {
    width: 75%; /* 親要素に合わせて拡大縮小 */
    height: auto; /* アスペクト比を保持 */
	max-width: 170px;
}
#top05 svg{ max-width: 140px;}
@media print, screen and (min-width: 576px){
	svg { max-width: 200px;}
	#top05 svg{ max-width: 150px;}
}
@media print, screen and (min-width: 768px){
	svg { max-width: 280px;}
}
@media print, screen and (min-width: 992px){
	svg { max-width: 350px;}
	#top05 svg{ max-width: 230px;}
}
@media print, screen and (min-width: 1600px){
	svg {
		max-width: 450px;
	}
	#top05 svg{
		max-width: 300px;
	}
}

.title{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.title.tac{
	justify-content:center;
}
.title .bi-circle-fill{
	font-size: 13px;
	color: #007ab6;
	margin-right: 20px;
}
@media print, screen and (min-width: 1200px){
	.title .bi-circle-fill{
		font-size: 20px;
	}
}


#top06 .title .bi-circle-fill{
	color: #fff;
}

#top01 .title{
	margin-bottom: 30px;
}
#top02 .title{
	justify-content: center;
}
#top04 .title{
	justify-content: center;
}




/* 01 index
---------------------------------------------------- */
#top01{position: relative; overflow: hidden; z-index: 0; }
#top02{position: relative; overflow: hidden; z-index: 0; background: #eae6e0;}
#top03{position: relative; overflow: hidden; z-index: 0; }
#top04{position: relative; overflow: hidden; z-index: 0; background: #eae6e0;}
#top05{position: relative; z-index: 0; }
#top06{position: relative; overflow: hidden; z-index: 0; background: #aab5ba;}

/*波*/
.canvas-container{
	margin-bottom: -11px;
	overflow: hidden;
	width: 100%;
}
#sineCanvas4,
#sineCanvas5,
#sineCanvas6,
#sineCanvas7{
	width: 100%!important;
}

.top02_box .box{
    background: #fff;
    border-radius: 10px;
    padding: 30px 10px;
	margin-bottom: 10px;
	position: relative;
}

.top02_box .box .num{
   display:flex;
   align-items:center;
   justify-content:center;
	width: 30px;
	border-bottom: 1px solid #282727;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	margin: 0 auto;
}
.top02_box .box img{
	max-width: 70px;
	width: 100%;
	height: auto;
	margin: 20px auto;
}
.top02_box .box .text{
	text-align: center;
	font-size: 110%;
	line-height: 1.6em;
	margin-bottom: 30px;
}

.top02_box a:link,
.top02_box a:visited{
	text-decoration: none;
}

.top02_box .box .more{
	position: absolute;
	right: 10px;
	bottom: 10px;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
}
@media print, screen and (min-width: 576px){
	.top02_box{
		margin-left: -1%;
		margin-right: -1%;
	}
	.top02_box .box{
		width: 48%;
		float: left;
		margin: 0 1% 2% 1%;
	}
	.top02_box .box:nth-of-type(2n+1) { clear: both;}
	
	.top02_box .box .text{
		display:flex;
	   align-items:center;
	   justify-content:center;
		height: 80px;
	}
}
@media print, screen and (min-width: 992px){
	.top02_box .box{
		width: 31.3%;
		float: left;
		margin: 0 1% 2% 1%;
		padding: 30px 15px;
	}
	.top02_box .box:nth-of-type(2n+1) { clear: none;}
	.top02_box .box:nth-of-type(3n+1) { clear: both;}
	.top02_box .box:nth-child(4) {margin-left: 16%;}
	
	.top02_box .box .text{ height: 100px;}
}
@media print, screen and (min-width: 1200px){
	.top02_box .box img{
		max-width: 100px;
	}
}
@media print, screen and (min-width: 1700px){
	.top02_box .box .text{ height: 150px; font-size: 130%;}
}




.gyosyu_list{
	margin-left: -1%;
	margin-right: -1%;
}
.gyosyu_list li{
	width: 48%;
	float: left;
	margin: 0 1%;
	border-bottom: 1px solid #afacab;
	padding: 7px;
	font-size: 90%;
	display:flex;
   align-items:center;
   justify-content:center;
	height:50px;
}
@media print, screen and (min-width: 576px){
	.gyosyu_list li{
		width: 31.3%;
	}
}
@media print, screen and (min-width: 992px){
	.gyosyu_list li{
		width: 23%;
		font-size: 100%;
	}
}
@media print, screen and (min-width: 1200px){
	.gyosyu_list li{
		font-size: 110%;
		height:70px;
	}
}


.top04_box .box {margin-bottom: 30px;}
.top04_box .box .text{
	background: #fff;
	border-radius: 10px;
	padding: 30px 20px;
	width: 90%;
	margin: -30px auto 0 auto;
	position: relative;
	z-index: 1;
}
.top04_box .box .text .num{
   display:flex;
   align-items:center;
   justify-content:center;
	width: 30px;
	border-bottom: 1px solid #282727;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	margin: 0 auto 20px auto;
}
.top04_box .box .midashi2{
	text-align: center;
}
.top04_box .box .moji {margin-bottom: 30px;}
@media print, screen and (min-width: 576px){
	.top04_box .box{
		width: 50%;
		float: left;
	}
}
@media print, screen and (min-width: 768px){
	.top04_box .box {margin-bottom: 50px;}
	.top04_box .box .moji{
		font-size: 110%;
	}
}
@media print, screen and (min-width: 992px){
	.top04_box .box .moji{
		font-size: 120%;
	}
	.top04_box .box .text{
		padding: 30px 30px;
		width: 80%;
	}
}
@media print, screen and (min-width: 1600px){
	.top04_box .box .text{
		padding: 60px 40px;
		margin: -50px auto 0 auto;
	}
	.top04_box .box .moji{
		text-align: center;
		margin-bottom: 30px;
	}
}




/*タブ切り替え*/
.top_catenavi li{
	list-style: none;
	border-bottom: 1px solid #dadada;
	font-weight: 700;
}
.top_catenavi li a:link,
.top_catenavi li a:visited{
	padding: 10px 7px;
    display: -webkit-flex;
    display: flex;
    align-items: center;
	text-decoration: none;
	font-weight: 700;
	font-size: 100%;
}
.top_catenavi li a:hover,
.top_catenavi li a.active{
	color: #007ab6;
	opacity: 1;
}
.top_catenavi li a:hover i,
.top_catenavi li a.active i{
	color: #007ab6;
	opacity: 1;
}
.top_catenavi li a i {margin-right: 10px; font-size: 80%;}
@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;
		height: 55px;
		line-height: 1.4em;
	}
}


.news_box .box{
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #dadada;
}
.news_box .box a:link,
.news_box .box a:visited{
	text-decoration: none;
}

.news_box .box .photo {margin-bottom: 20px;}
.news_box .box .midashi3 {margin-bottom: 10px;}


.date{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	font-size: 90%;
	line-height: 1.4em;
}
.tag{
	color: #007ab6;
	border-left: 1px solid #007ab6;
	padding-left: 7px;
	margin-left: 7px;
	font-size: 90%;
	line-height: 1.4em;
}

@media screen and (min-width: 768px) and (max-width: 991px)  {
	.news_box .date,
	.news_box .tag{
		display: block;
	}
	.news_box .tag {margin-left: 0; margin-top: 5px;}
}

@media print, screen and (min-width: 576px){
	.news_box{
		margin-left: -1%;
		margin-right: -1%;
	}
	.news_box .box{
		width: 48%;
		float: left;
		margin: 0 1%;
	}
	.news_box .box:nth-of-type(2n+1) { clear: both;}
}
@media print, screen and (min-width: 768px){
	.news_box .box{
		margin-bottom: 40px;
		padding-bottom: 0;
		border-bottom: none;
	}

}


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




/*サイドナビ固定*/
@media print, screen and (min-width: 768px) {
	.container-sticky {
	  height: auto;
	  width: 100%;
	}
	.heading-sticky {
	/*
	  background: rgba(255, 255, 255, .9);
	  border: 8px solid #ebebeb;
	  margin: 0 0 40px 0;
	  padding: 1rem;
		*/
	  position: sticky;
	  top: 0;
	  width: 100%;
	  z-index: 30;
	}
	.side_contents_box {
	  position: sticky;
	  top: 10rem;
	  padding-bottom: 8.5rem;
	}
	.heading-sticky { top: 55px;}
}
@media print, screen and (min-width: 992px) {
	.heading-sticky { top: 75px;}
}
@media print, screen and (min-width: 1200px) {
	.heading-sticky { top: 95px;}
}


/* 下部共通　otoiawase
---------------------------------------------------- */
.otoiawase_box .box,
.otoiawase_box .box2{
	background: #fff;
	border-radius: 10px;
	font-size: 110%;
	line-height: 1.4em;
	margin-bottom: 10px;
}
.otoiawase_box .box a,
.otoiawase_box .box2{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	padding: 12px 20px;
}
.otoiawase_box .box img,
.otoiawase_box .box2 img{
	max-width: 35px;
	width: 100%;
	height: auto;
	margin-right: 20px;
}
.otoiawase_box .box a:link,
.otoiawase_box .box a:visited{
	text-decoration: none;
}
/*
.otoiawase_box .box2 a:link,
.otoiawase_box .box2 a:visited{
	text-decoration: none;
}
*/
.otoiawase_box .box2{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
}

.otoiawase_box .box:first-child a:hover,
.otoiawase_box .box:first-child a:hover img {
  opacity: 1;
  filter: alpha(opacity=100);
}

@media print, screen and (min-width: 576px) {
	.otoiawase_box{
		margin-left: -1%;
		margin-right: -1%;
	}
	.otoiawase_box .box,
	.otoiawase_box .box2{
		width: 48%;
		margin: 1% 1%;
		float: left;
	}
	.otoiawase_box .box:nth-of-type(2n+1) { clear: both;}
	.otoiawase_box .box img,
	.otoiawase_box .box2 img{
		margin-right: 10px;
	}
	.otoiawase_box .box2 {font-size: 140%;}
}
@media print, screen and (min-width: 992px) {
	.otoiawase_box{
		margin-left: -0.5%;
		margin-right: -0.5%;
	}
	.otoiawase_box .box,
	.otoiawase_box .box2{
		width: 32.3%;
		margin: 0 0.5%;
	}
	
	.otoiawase_box .box:nth-of-type(2n+1) { clear: none;}
	.otoiawase_box .box:nth-of-type(3n+1) { clear: both;}
	.otoiawase_box .box img,
	.otoiawase_box .box2 img{
		max-width: 35px;
		margin-right: 10px;
	}
	
	.otoiawase_box .box a,
	.otoiawase_box .box2{
		justify-content: center;
		padding: 20px 10px;
	}
}
@media print, screen and (min-width: 1200px) {
	.otoiawase_box .box img,
	.otoiawase_box .box2 img{
		max-width: 45px;
	}
	
	.otoiawase_box .box a,
	.otoiawase_box .box2{
		padding: 30px 10px;
	}
}


/**/
.otoiawase_box_contact .box,
.otoiawase_box_contact .box2{
	background: #fff;
	border-radius: 10px;
	font-size: 110%;
	line-height: 1.4em;
	margin-bottom: 10px;
}
.otoiawase_box_contact .box a,
.otoiawase_box_contact .box2{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	padding: 12px 20px;
}
.otoiawase_box_contact .box img,
.otoiawase_box_contact .box2 img{
	max-width: 35px;
	width: 100%;
	height: auto;
	margin-right: 20px;
}
.otoiawase_box_contact .box a:link,
.otoiawase_box_contact .box a:visited{
	text-decoration: none;
}
.otoiawase_box_contact .box2{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	line-height: 1.0em;
}

.otoiawase_box_contact .time{
	font-size: 13px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	line-height: 1.4em;
	margin-top: 3px;
}
@media print, screen and (min-width: 576px) {
	.otoiawase_box_contact{
		margin-left: -1%;
		margin-right: -1%;
	}
	.otoiawase_box_contact .box,
	.otoiawase_box_contact .box2{
		width: 48%;
		margin: 1% 1%;
		float: left;
	}
	
	.otoiawase_box_contact .box:nth-of-type(2n+1) { clear: both;}
	.otoiawase_box_contact .box img,
	.otoiawase_box_contact .box2 img{
		margin-right: 10px;
	}
	.otoiawase_box_contact .box2 {font-size: 140%;}
	.otoiawase_box_contact .box a,
	.otoiawase_box_contact .box2{
		height: 80px;
		justify-content: center;
	}
}
@media print, screen and (min-width: 992px) {
	.otoiawase_box_contact .box img,
	.otoiawase_box_contact .box2 img{
		max-width: 35px;
		margin-right: 10px;
	}
	
	.otoiawase_box_contact .box a,
	.otoiawase_box_contact .box2{
		padding: 20px 10px;
		height: 100px;
	}
}
@media print, screen and (min-width: 1200px) {
	.otoiawase_box_contact .box{
		font-size: 130%;
	}
	.otoiawase_box_contact .box2{
		font-size: 170%;
	}
	
	.otoiawase_box_contact .box img,
	.otoiawase_box_contact .box2 img{
		max-width: 45px;
	}
	
	.otoiawase_box_contact .box a,
	.otoiawase_box_contact .box2{
		padding: 30px 10px;
		height: 120px;
	}
}

/* 02 news
---------------------------------------------------- */
.news_monthly{
	border: 1px solid #282727;
	padding: 20px 15px;
}
.news_monthly h3{
	border-bottom: 1px solid #282727;
	padding: 10px 5px;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	font-size: 120%;
	margin-bottom: 15px;
}
.news_monthly h3 .ja{
	font-size: 12px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	margin-left: 10px;
}

.news_monthly ul{
	margin-left: -1%;
	margin-right: -1%;
}
.news_monthly li{
	list-style: none;
	width: 48%;
	float: left;
	margin: 1%;
}
.news_monthly li:nth-of-type(2n+1) { clear: both;}

.news_monthly a:link,
.news_monthly a:visited{
	text-decoration: none;
	border: 1px solid #afacab;
	border-radius: 50px;
	padding: 7px 10px;
	line-height: 1.4em;
	font-size: 90%;
	display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: center;
}
.news_monthly a:hover,
.news_monthly .navi-on a{
	background: #007ab6;
	color: #fff;
	border: 1px solid #007ab6;
	opacity: 1;
}
.news_monthly a i{
	color: #007ab6;
	font-size: 10px;
	margin-right: 3px;
}
@media print, screen and (min-width: 576px) {
	.news_monthly a:link,
	.news_monthly a:visited{
		padding: 10px 10px;
	}
}
@media print, screen and (min-width: 768px) {
	.news_monthly a:link,
	.news_monthly a:visited{
		padding: 7px 10px;
	}
}
@media print, screen and (min-width: 1200px) {
}


/*続きを読む*/
.readmore {
    position: relative;
    /*margin: 3em 0;*/
	margin: 15px auto 0 auto;
    display: block;
    color: #007ab6;
    border: none;
    outline: 0;
    cursor: pointer;
    background: none;
    letter-spacing: 0.1em;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	border: none;
	font-size: 90%;
}
.close {
float: none;
  font-size: 110%;
  font-weight: 500;
  line-height: 1;
  color: #007ab6;
  text-shadow:none;
  opacity: 1;
}
.close:hover{
	color: #007ab6;
}

.readmore i {margin-left: 10px;}
/*
.readmore:before {
  content: "";
  width: 50px;
  height: 50px;
  text-align: center;
  border-radius: 50%;
  display: block;
  margin: 0 auto .5em;
  background: url(../img/arrow.png) no-repeat center / 20px #fff;
  transition: .3s;
}
*/
.readmore.on-click:before {
  transform: rotate(180deg);
}
.readmore .open {
  display: block;
}
.readmore.on-click .open {
  display: none;
}
.readmore .close {
  display: none;
}
.readmore.on-click .close {
  display: block;
}

button:link,
button:active,
button:hover,
button:focus {
    outline: none!important;
    -moz-outline-style: none;
}


.news_ichiran .box{
	border: 1px solid #ccc;
	margin-bottom: 10px;
}
.news_ichiran .box .in{
	padding: 20px;
}
.news_ichiran .box a:link,
.news_ichiran .box a:visited{
	text-decoration: none;
	display: block;
}
.news_ichiran .box .midashi3{
	margin-bottom: 10px;
}

.news_ichiran .box .more{
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	text-align: right;
	margin: 0 15px 10px 0;
}
.news_ichiran .box .photo {margin-top: 20px;}


.news_ichiran .box .photo img{
    display: block;
    aspect-ratio: 300/200;
    width: 100%;
    height: 100%;
    object-fit: cover;	
}

@media print, screen and (min-width: 992px) {
	.news_ichiran .box .in{
		display: -webkit-flex;
		display: flex;
		align-items: center;
	}
	.news_ichiran .box .in .photo{
		width: 200px;
		min-width: 200px;
		max-width: 200px;
		margin-left: auto;
	}
	.news_ichiran .box .in .text{
		width: 100%;
		margin-right: 30px;
	}
}


.news_detail .box {margin-bottom: 50px;}

.mannnaka .box {margin-bottom: 30px;}
@media print, screen and (min-width: 576px) {
	.mannnaka{
		display: -webkit-flex;
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		margin-left: -1%;
		margin-right: -1%;
	}
	.mannnaka .box{
		width: 48%;
		float: left;
		margin: 0 1%;
	}
	.mannnaka .box:nth-of-type(2n+1) { clear: both;}
}


/* 03 features
---------------------------------------------------- */
@media print, screen and (min-width: 768px) {
	.features01 .photo{
		max-width: 960px;
		width: 40%;
		height: 100%;
		position: absolute;
		right: 0;
		top: 0;
		z-index: -1;
	}
	.features01 .photo img{
		width: 100%;
		height: 100%;
		object-position: 100% 100%;
		
	}
}
@media print, screen and (min-width: 1800px) {
	.features01 .photo img{
		object-position: 50% 50%;
		
	}
}



.features_point .box{
    background: #fff;
    border-radius: 10px;
    padding: 30px 30px;
	margin-bottom: 10px;
	position: relative;
}

.features_point .box .num{
   display:flex;
   align-items:center;
   justify-content:center;
	width: 30px;
	border-bottom: 1px solid #282727;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	margin: 0 auto;
}
.features_point .box img{
	max-width: 70px;
	width: 100%;
	height: auto;
	margin: 20px auto;
}
.features_point .box .text{
	text-align: left;
	font-size: 110%;
	line-height: 1.6em;
	margin-bottom: 10px;
}
@media print, screen and (min-width: 576px){
	.features_point{
		margin-left: -1%;
		margin-right: -1%;
	}
	.features_point .box{
		width: 31.3%;
		float: left;
		margin: 0 1% 2% 1%;
		padding: 30px 20px;
	}
	.features_point .box:nth-of-type(3n+1) { clear: both;}
	.features_point .box .text{
		font-size: 105%;
	}
}
@media print, screen and (min-width: 992px){
	.features_point .box{
		padding: 30px 30px;
	}
}
@media print, screen and (min-width: 1200px){
	.features_point .box img{
		max-width: 100px;
	}
}

.features_point2 .box{
    background: #fff;
    border-radius: 10px;
    padding: 30px 30px;
	margin-bottom: 10px;
}

	
.kyoka {
	width: 70%;
	margin: 0 auto;
}
.kyoka p{
	margin: 0 auto 10px auto;
}
@media print, screen and (min-width: 576px){
	.kyoka {
		width: 100%;
		display: -webkit-flex;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.kyoka p{
		margin: 0 10px;
	}
}

/* 04 staff
---------------------------------------------------- */
.staff_point .box{
    background: #fff;
    border-radius: 10px;
    padding: 30px 30px;
	margin-bottom: 10px;
	position: relative;
}

.staff_point .box h4{
   display:flex;
   align-items:center;
   justify-content:center;
	border: 1px solid #007ab6;
	border-radius: 50px;
	margin: 0 auto;
	padding: 8px 5px;
	color: #007ab6
}
.staff_point .box img{
	max-width: 70px;
	width: 100%;
	height: auto;
	margin: 20px auto;
}
.staff_point .box .text{
	text-align: left;
	font-size: 110%;
	line-height: 1.6em;
	margin-bottom: 10px;
}
@media print, screen and (min-width: 576px){
	.staff_point{
		margin-left: -1%;
		margin-right: -1%;
	}
	.staff_point .box{
		width: 31.3%;
		float: left;
		margin: 0 1% 2% 1%;
		padding: 30px 20px;
	}
	.staff_point .box:nth-of-type(3n+1) { clear: both;}
	.staff_point .box .text{
		font-size: 105%;
	}
	.staff_point .box h4{
		align-items: center;
		height: 50px;
		text-align: center;
	}
}
@media print, screen and (min-width: 992px){
	.staff_point .box{
		padding: 30px 30px;
	}
}
@media print, screen and (min-width: 1200px){
	.staff_point .box img{
		max-width: 100px;
	}
}



.interview_box{
	border: 2px solid #000;
	padding: 5px;
	margin-bottom: 30px;
}
.interview_box .in{
	border: 1px solid #000;
	padding: 5px;
	padding: 20px;
}

.interview_box .title{
	background: #218fc5;
	margin-bottom: 5px;
}
.interview_box .title.bg_color2{
	background: #fde1cc;
}
.interview_box .title img{
	max-width: 300px;
	margin: 0 auto;
	width: 70%;
	height: auto;
}



.interview_box .midashi {margin-bottom: 30px;}
.interview_box .midashi .photo{
	width: 70%;
	margin: 0 auto 20px auto;
}
.interview_box .midashi .photo img{
	/*border-radius: 50%;*/
	border-radius: 10px;
	width: 100%;
	height: auto;
}

.interview_box .midashi .midashi3{
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: 1px solid #000;
}
.interview_box .midashi .midashi2 span {margin-right: 10px;}
@media print, screen and (min-width: 576px){
	.interview_box .in{
		padding: 30px;
	}
	.interview_box .midashi{
		display: -webkit-flex;
		display: flex;
		/*align-items: center;*/
		align-items: start;
		
	}
	.interview_box .midashi .photo{
		min-width: 40%;
		max-width: 40%;
		width: 40%;
		margin: 0 5% 0 0;
	}
	.interview_box .midashi .naiyou {width: 100%;}
}
@media print, screen and (min-width: 992px){
	.interview_box .midashi {margin-bottom: 50px;}
	.interview_box .midashi .photo{
		min-width: 30%;
		max-width: 30%;
		width: 30%;
	}
	.interview_box .midashi .midashi3 {margin-bottom: 30px;}
}



.interview_faq_title{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.interview_faq_title .icon{
	min-width: 40px;
	max-width: 40px;
	width:40px;
   height:40px;
   border-radius:50%;
   background:#ffa093;

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

.interview_faq_text{
	border-left: 1px solid #666;
	padding: 10px 0 10px 35px;
	margin-left: 20px;
	display: -webkit-flex;
    display: flex;
	font-size: 90%;
}
.interview_faq_text .bi-person-fill{
	font-size: 30px;
	margin-right: 15px;
	color: #218fc5;
}
.interview_faq_text .text h4{
	color: #218fc5;
	font-weight: 700;
	margin-top: 7px;
	margin-bottom: 5px;
}

.sen_img{
	max-width: 250px;
	width: 100%;
	height: auto;
	margin:10px auto 0 auto;
}
.tal_sptac .sen_img{
	margin:10px auto 0 auto;
}
@media print, screen and (min-width: 768px){
	.tal_sptac .sen_img{
		margin:10px 0 0 0;
	}
}


/* 05 tokutei
---------------------------------------------------- */
.tokutei_navi{
	margin-left: -1%;
	margin-right: -1%;
}
.tokutei_navi li{
	list-style: none;
	width: 48%;
	float: left;
	margin: 1%;
	font-size: 90%;
}
.tokutei_navi li:nth-of-type(2n+1) { clear: both;}


.tokutei_navi li a{
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.tokutei_navi li a:link,
.tokutei_navi li a:visited{
	text-decoration: none;
	padding: 10px 7px;
	border-radius: 3px;
	background: #007ab6;
	color: #fff;
}
.tokutei_navi li a:hover{
	background: #282727;
	color: #fff;
	opacity: 1;
}
.tokutei_navi li a i{
	color: #fff;
	font-size: 12px;
	margin-right: 7px;
}
@media print, screen and (min-width: 576px){
	.tokutei_navi li{
		width: 31.3%;
		margin: 1%;
	}
	.tokutei_navi li:nth-of-type(2n+1) { clear: none;}
	.tokutei_navi li:nth-of-type(3n+1) { clear: both;}
}
@media print, screen and (min-width: 768px){
	.tokutei_navi li a:link,
	.tokutei_navi li a:visited{
		text-decoration: none;
		padding: 15px 10px;
	}
	.tokutei_navi li{
		font-size: 100%;
	}
}
@media print, screen and (min-width: 1600px){
	.tokutei_navi.max5{
		margin-left: -0.5%;
		margin-right: -0.5%;
	}
	.tokutei_navi.max5 li{
		width: 19%;
		margin: 0 0.5%;
	}
	.tokutei_navi.max5 li a{
		justify-content: center;
	}
	.tokutei_navi.max5 li:nth-of-type(3n+1) { clear: none;}
	.tokutei_navi.max5 li:nth-of-type(5n+1) { clear: both;}
}

.tokutei_box{
	position: relative;
}
.tokutei_box .message{
	position: absolute;
	right: 10px;
	top: -80px;
	width:90px;
   height:90px;
   border-radius:50%;
   background:#fff;
	border: 2px solid #007ab6;
	font-size: 80%;
	line-height: 1.6em;
	color: #007ab6;
	text-align: center;
	font-weight: 700;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
}
@media print, screen and (min-width: 768px){
	.tokutei_box .message{
		right: 10px;
		top: -70px;
	}
	
}
@media print, screen and (min-width: 1200px){
	.tokutei_box .message{
		right: 10px;
		top: -50px;
		width:110px;
	   height:110px;
	}
	
}


.tokutei_point .box{
    background: #fff;
    border-radius: 10px;
    padding: 30px 30px;
	margin-bottom: 10px;
}

.tokutei_point.cream_bg .box{
	border: 1px solid #007ab6;
}




.recruit_box .box .icon{
	max-width: 90px;
}
.recruit_box .box .icon img{
	width: 100%;
	height: auto;
}
.recruit_box .box h4{
	font-weight: 700;
	font-size: 110%;
	line-height: 1.4em;
}

@media only screen and (max-width: 767px){
	.recruit_box .box .midashi{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		margin-bottom: 10px;
	}
	.recruit_box .box .icon {
		margin-right: 10px;
		min-width: 50px;
		width: 50px;
	}
}
@media print, screen and (min-width: 768px){
	.recruit_box .box{
		float: left;
		margin: 0 0 20px 0;
	}
	.recruit_box .box{
		width: 48%;
	}
	.recruit_box .box:nth-of-type(2n+1) { clear: both;}
	
	.recruit_box .box .icon{
		margin: 0 auto 10px auto;
	}
	.recruit_box .box h4{
		text-align: center;
		margin-bottom: 10px;
	}
	.recruit_box .box .fs90{
		padding-left: 10px;
		padding-right: 10px;
		text-align: center;
	}
	
}
@media print, screen and (min-width: 992px){
	.recruit_box .box{
		width: 23%;
		margin-bottom: 0;
	}
	.recruit_box .box:nth-of-type(2n+1) { clear: none;}
	.recruit_box .box:nth-of-type(4n+1) { clear: both;}
	
	.recruit_box .box .icon{
		margin: 10px auto 15px auto;
	}
	
}




/* 06 ikusei
---------------------------------------------------- */
.ikusei_box{
	background: #efefef;
	padding: 30px;
	border-radius: 10px;
}
.ikusei_box .box28 .box-title{
	background: #efefef;
}

.ikusei_box.shin{
	border: 5px solid #007ab6;
	background: #fff;
}
.ikusei_box.shin .box28 .box-title{
	background: #fff;
}

.ikusei_box .box h4{
	font-weight: 700;
	font-size: 110%;
	line-height: 1.4em;
}

.ikusei_box .bi-person{
	font-size: 30px;
	text-align: center;
	color: #007ab6;
	margin: 0 auto;
}
@media only screen and (max-width: 767px){
	.ikusei_box .box .midashi{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		margin-bottom: 10px;
	}
	.ikusei_box .box .icon {
		margin-right: 10px;
	}
}
@media print, screen and (min-width: 768px){
	.ikusei_box{
		padding: 40px 30px 0 30px;
	}
	.ikusei_box .box{
		float: left;
		margin: 0 0 20px 0;
	}
	.ikusei_box .box{
		width: 33.3%;
	}
	.ikusei_box .box:nth-of-type(3n+1) { clear: both;}
	
	.ikusei_box .box .icon{
		margin: 0 auto 10px auto;
	}
	.ikusei_box .box h4{
		text-align: center;
		margin-bottom: 10px;
		font-size: 130%;
	}
	.ikusei_box .box .fs90{
		padding-left: 10px;
		padding-right: 10px;
		text-align: center;
	}
	.ikusei_box .midashi{text-align: center;}
	
}
@media print, screen and (min-width: 992px){
	.ikusei_box .box .icon{
		margin: 10px auto 15px auto;
	}
	
}

.ikusei_box2 i {margin-left: 23px; color: #007ab6;}
.ikusei_box2 .midashi_en2 {margin-bottom: 5px;}
@media print, screen and (min-width: 576px){
	.ikusei_box2{
		display: -webkit-flex;
		display: flex;
		/*align-items: center;*/
	}
	.ikusei_box2 i{ margin: 0 20px;}
	
}




.ikusei_point .box{
    background: #fff;
    border-radius: 10px;
    padding: 30px 30px;
	margin-bottom: 10px;
	position: relative;
}

.ikusei_point .box .num{
   display:flex;
   align-items:center;
   justify-content:center;
	width: 30px;
	border-bottom: 1px solid #282727;
	font-family: "DM Sans", sans-serif;
	font-weight: 500;
	margin: 0 auto;
}
.ikusei_point .box img{
	max-width: 70px;
	width: 100%;
	height: auto;
	margin: 20px auto;
}
.ikusei_point .box .text{
	text-align: center;
	font-size: 110%;
	line-height: 1.6em;
	margin-bottom: 10px;
	font-weight: 700;
}
@media print, screen and (min-width: 576px){
	.ikusei_point{
		margin-left: -1%;
		margin-right: -1%;
	}
	.ikusei_point .box{
		width: 31.3%;
		float: left;
		margin: 0 1% 2% 1%;
		padding: 30px 20px;
	}
	.ikusei_point .box:nth-of-type(3n+1) { clear: both;}
	.ikusei_point .box .text{
		font-size: 105%;
	}
}
@media print, screen and (min-width: 992px){
	.ikusei_point .box{
		padding: 30px 30px;
	}
}
@media print, screen and (min-width: 1200px){
	.ikusei_point .box img{
		max-width: 100px;
	}
}

/* 07 company
---------------------------------------------------- */
.company_pdf li{
	list-style: none;
	margin-bottom: 3px;
	position: relative;
	z-index: 100;
}
.company_pdf li a:link,
.company_pdf li a:visited{
	padding: 10px 15px;
	color: #c00000;
	display: block;
	text-decoration: none;
	font-size: 100%;
	border-radius: 0;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	border-radius: 5px;
	display: -webkit-flex;
    display: flex;
    align-items: center;
	border: 1px solid #c00000;
}
.company_pdf li a:hover{
	padding: 10px 15px;
	opacity: 1;
	border-radius: 50px;
}
.company_pdf li i {margin-right: 10px; font-size: 200%;}
@media print, screen and (min-width: 768px){
	.company_pdf{
		margin-left: -1%;
		margin-right: -1%;
	}
	.company_pdf li{
		width: 31.3%;
		float: left;
		margin: 1%;
	}
}


.ue_tsumeru{margin-top: -140px;}

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


.contact_box .box{
	background: #efefef;
	border-radius: 10px;
	padding: 30px 20px;
	text-align: center;
	margin-top: 20px;
}
.contact_box .box h4{
	font-size: 120%;
	font-weight: bold;
	margin-bottom: 20px;
}
.contact_box .box .en{
	font-size: 200%;
	margin-bottom: 10px;
}
.contact_box .box .en a:link,
.contact_box .box .en a:visited{
	text-decoration: none;
}

.contact_box .box .time{
	font-size: 90%;
	line-height: 1.4em;
}
@media print, screen and (min-width: 768px){
	.contact_box{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.contact_box .midashi1{
		white-space: nowrap;
		margin-right: 40px;
	}
	.contact_box .box {
		margin: 0 5px;
		width: 100%;
	}
}
@media print, screen and (min-width: 1200px){
	.contact_box .box{
		padding: 50px 20px;
	}
}


/*フォームのテーブル*/
.table_form{
	width:100%;
	border-collapse:collapse;
	border-top:1px solid #dadada;
	line-height: 2.0em;
}

.table_form th{
	width:100%;
	padding:10px 15px 3px 15px;
	display: block;
	color: #666;
	font-weight: 700;
}
.table_form td{
	width:100%;
	border-bottom:1px solid #dadada;
	padding:3px 15px 10px 15px;
	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: #d63923;
	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: #282727;
	}
	.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%;}
}


.table_form.waku{
	border:1px solid #282727;
}
@media print, screen and (min-width: 768px) {
	.table_form.waku tr:last-child th,
	.table_form.waku tr:last-child td{
		border-bottom:1px solid #282727;
	}

}



/* フォーム関係 */
.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:14px;vertical-align:middle; padding:9px}
input[type="file"]{width: 99%;}
input[type="text"], select{border:1px solid #ccc; border-radius:3px; color: #282727;}
input[type="email"]{color: #282727;}

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: #282727; font-size: 14px;}

.form-control {color: #282727;font-weight: 700;}
.form-control.w50 {width:100px; display: inline-block; margin-right: 10px;}
.form-control.w200 {width:150px; display: inline-block; margin-right: 10px; margin-bottom: 10px;}
.form-control.w300 {width:200px;}
@media (min-width: 576px) {
.form-control.w200 { margin-bottom: 0;}
}
@media (min-width: 768px) {
.form-control.w300 {width:250px;}
}


.privacy_waku{
	padding:20px 20px;
	font-size: 90%;
	background-color: #fff;
	/*font-weight: 500;*/
	border: 1px solid #e1e1e1;
	line-height: 1.8em;
}
@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_box3{
	border-collapse: collapse;
	border-left: 4px solid #d4def4;
	padding: 5px 0 5px 25px;
}


.midashi_box2{
	background: #007ab6;
	color: #fff;
	border-radius: 10px;
	padding: 30px 20px;
}

.btn-primary{
	border-radius:5px;
	font-size: 100%;
}
.btn-primary:hover{
	background-color: #218fc5;
	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 #e1e1e1;
	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;
	text-align: center;
	position: relative;
}
footer .in {padding: 50px 0;}

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

.foot_line img{
	max-width: 45px;
	width: 100%;
	height: auto;
	margin: 20px auto 0 auto;
}
.foot_line a:hover,
.foot_line a:hover img {
  opacity: 1;
  filter: alpha(opacity=100);
}

@media print, screen and (min-width: 992px) {
	.foot_logo img{
		max-width: 200px;
		margin: 0 0 20px 0;
	}
	.foot_line img{
		margin: 20px 0 0 0;
	}
}
@media print, screen and (min-width: 1200px) {
	footer {font-size: 110%;}
	footer .in {padding: 60px 0;}
	.foot_logo img{
		max-width: 300px;
	}
}



@media print, screen and (min-width: 992px) {
	footer{text-align: left;}
}
@media print, screen and (min-width: 1600px) {
	footer .in {padding: 80px 0;}
}



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

.foot_link{
	display: none;
}
@media print, screen and (min-width: 768px) {
	.foot_link{
		margin-top: 30px;
		display: block;
	}
	.foot_link ul{
		text-align: center;
	}
	.foot_link li{
		list-style: none;
		display: inline-block;
		font-weight: 700;
		margin: 5px 10px;
		font-size: 105%;
	}
	.foot_link li a:link,
	.foot_link li a:visited{
		text-decoration: none;
	}
}
@media print, screen and (min-width: 992px) {
	.foot_link{
		margin-top: 0;
		margin-bottom: 30px;
		display: flex;
		display: -webkit-flex;
		justify-content: flex-end;
	}
	.foot_link ul{
		text-align: left;
		margin-left: 40px;
	}
	.foot_link li{
		display: block;
		margin: 5px 0;
		font-size: 105%;
	}
}
@media print, screen and (min-width: 1200px) {
}



.copy {
	text-align: center;
	font-size: 80%;
	margin-top: 20px;
}
@media print, screen and (min-width: 992px) {
	.copy{
		margin-left: auto;
		margin-top: 0;
		text-align: right;
	}
}


/* pagetop
---------------------------------------------------- */

footer .scroll_anime {
  color: #7c888c;
  cursor: pointer;
}

footer .scroll_anime::after {
  content: "";
  position: absolute;
  bottom: -106px;
  left: calc(16px + 10px);
  width: 1px;
  height: 160px;
  background: #7c888c;
  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%;
  }
}

	


