html, body {
	height: 100%;
}
html {
	font-size: 62.5%;
}
body {
	font-size: 1.4em;
	position: relative;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
.m-y-1 {
	margin-top: 2rem !important;
	margin-bottom: 2rem !important;
}
.m-y-2 {
	margin-top: 4rem !important;
	margin-bottom: 4rem !important;
}
.m-y-3 {
	margin-top: 8rem !important;
	margin-bottom: 8rem !important;
}
.lead {
	font-size: 1.6rem;
	line-height: 1.8;
}


.header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	color: #fff;
	z-index: 10;
}
.headertxt {
	background-color: rgba(0,0,0,0.7);
}
.headertxt h1 {
	font-size: 1.3rem;
	margin-bottom: 0;
	padding-top: 0.6rem;
	padding-bottom: 0.6rem;
	line-height: 1;
}
.header .logo .navbar-brand {
	width: 222px;
	padding: 1.5em 0;
	margin: 0;
	transition: all .1s;
}
.header .logo .navbar-brand:hover {
	opacity: 0.5;
}
.header .logo img {
	width: 100%;
}
.headernav a {
	color: #fff;
}
.headernav {
	padding-top: 0;
	padding-bottom: 0;
	background-color: rgba(0,0,0,0.5);
	border-radius: inherit;
}
.headernav.navbar .nav-pills {
	float: right;
}
.headernav.navbar .nav-pills a {
	font-size: 1.6rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	text-indent: 0.1em;
}
.headernav.navbar .nav-pills .nav-link {
	padding: 1.5em 1em;
	border-radius: inherit;
	transition: all .1s;
}
.headernav.navbar .nav-pills .nav-link:hover ,
.headernav.navbar .nav-pills .nav-link.active {
	background-color: #0d6758;
}


.mainvisual {
	position: relative;
	z-index: 1;
	color: #fff;
	padding-top: 12rem;
	padding-bottom: 0;
	margin-bottom: 0;
	background-image: url(/img/top/visual03/bg.jpg);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
.mainvisual .bigtext {
	margin: 0 auto;
}
.mainvisual .bigtext img {
	width: 100%;
}
.visual03 .bigtext {
	width: 80%;
}
.sitetop .mainvisual {
	padding-top: 20rem;
	padding-bottom: 6rem;
}

.pagetitle {
	margin: 6rem auto 10rem;
	text-align: center;
}
.pagetitle .bigtext {
	font-size: 5rem;
	font-weight: bold;
}
.pagetitle p {
	margin-top: 0.5em;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
}


.pagenavi .btn-group {
	display: flex;
}
.pagenavi .btn-group .btn {
	width: 100%;
	padding: 1.2em;
	margin-left: 1px;
	color: #fff;
	font-size: 1.6rem;
	font-weight: bold;
	background-color: #202020;
	border-radius: inherit;
	transition: all .1s;
}
.pagenavi .btn-group .btn:hover ,
.pagenavi .btn-group .btn.active {
	background-color: #0d6758;
}
.pagenavi .btn-group .btn:first-child {
	margin-left: 0;
}


#information {
	background-color: #151515;
	color: #fff;
}
#information .container {
	display: flex;
	padding: 2rem 6rem;
}
#information a {
	display: block;
	color: #fff;
	text-decoration: none;
	transition: all .1s;
}
#information a:hover {
	opacity: 0.5;
}
.informationlist {
	width: 100%;
	padding: 0;
	margin: 0;
	list-style: none;
	font-size: 1.5rem;
}
.informationlist small {
	font-size: 1.5rem;
	display: inline-block;
	padding: 0.3em 0.6em;
	margin-right: 1em;
	background-color: #0d6758;
}
.informationlist span {
	display: inline-block;
	margin-right: 1em;
}
.informationlist time {
	color: #606060;
}
#information .btn {
	font-size: 1.5rem;
	font-weight: bold;
}
#information .btn i {
	margin-right: 0.5em;
}


.breadcrumb {
	padding-left: 0;
	color: #fff;
	border-radius: inherit;
	background-color: transparent;
}
.breadcrumb a ,
.breadcrumb-item+.breadcrumb-item::before,
.breadcrumb-item.active {
	color: #fff;
}
.breadcrumb-item+.breadcrumb-item::before,
.breadcrumb-item.active {
	opacity: 0.5;
}


.skewbtn {
	text-align: center;
}
.skewbtn .btn {
	display: inline-block;
	margin: 0 auto;
	text-align: center;
	padding: 1em 3em;
	font-size: 1.8rem;
	font-weight: bold;
	-webkit-transform: skew(20deg);
	   -moz-transform: skew(20deg);
	     -o-transform: skew(20deg);
	background: #81C7D4;
	border-radius: 0;
	background-color: transparent;
	border-color: #fff;
	border-width: 2px;
	transition: all .1s;
}
.skewbtn .btn:hover {
	padding: 1em 4em;
	background-color: #0d6758;
	border-color: #0d6758;
}
.skewbtn .btn span {
	display: block;
	-webkit-transform: skew(-20deg);
	   -moz-transform: skew(-20deg);
	     -o-transform: skew(-20deg);
}
.mainvisual .skewbtn .btn {
	font-size: 2.4rem;
}

article section {
	overflow: hidden;
	color: #fff;
}

article section.bgblack {
	background-color: #101010;
}
article section.bggray {
	background-color: #151515;
}

.sectionheading {
	font-size: 3.6rem;
	font-weight: bold;
	text-align: center;
}
.sectionheading small {
	display: block;
	font-size: 1.6rem;
	letter-spacing: 0.08em;
}


.cardlayout .card {
	border-radius: inherit;
	border: none;
}
.cardlayout .card-deck-wrapper {
	margin-right: -4rem;
	margin-left: -4rem;
}
.cardlayout .card-deck {
	border-spacing: 4rem 0;
}


.linklist {
	display: flex;
	width: 75%;
	padding: 0;
	margin: 0 auto;
	list-style: none;
	flex-wrap: wrap;
	justify-content: space-between;
}
.linklist li {
	width: 49%;
	margin: 1rem 0;
}
.linklist li a {
	position: relative;
	display: block;
	width: 100%;
	color: #fff;
	padding: 1.5em;
	font-size: 1.8rem;
	font-weight: bold;
	text-decoration: none;
	background-color: #202020;
	transition: all .1s;
}
.linklist li a::before{
	content: "";
	position: absolute;
	top: 50%;
	right: 2em;
	width: 0.6em;
	height: 0.6em;
	margin-top: -0.3em;
	vertical-align: middle;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.linklist li a:hover {
	color: #999;
}
.linklist li a:hover::before {
	border-color: #999;
}


#about.cardlayout .card {
	background-color: #202020;
}
#about.cardlayout .card a {
	color: #fff;
	transition: all .1s;
}
#about.cardlayout .card a img {
	width: 100%;
	transition: all .1s;
}
#about.cardlayout .card a:hover {
	text-decoration: none;
	color: #999;
}
#about.cardlayout .card a:hover img {
	opacity: 0.7;
}
#about.cardlayout .card .card-img-top {
	border-radius: 0;
}
#about.cardlayout .card .card-block {
	padding: 1.5em;
}
#about.cardlayout .card .card-title {
	font-weight: bold;
	font-size: 1.8rem;
	letter-spacing: 0.08em;
}
#about.cardlayout .card .card-text {
	line-height: 1.8;
}


#business {
	background-image: url(/img/top/business.jpg);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	background-color: #202020;
}
.businessicons {
	width: 100%;
	padding: 0;
	list-style: none;
	display: flex;
	text-align: center;
	justify-content: space-between;
}
.businessicons li img {
	width: 50%;
}
.businessicons li span {
	display: block;
	font-size: 1.6rem;
	font-weight: bold;
	margin-top: 1em;
}
#business .lead {
	font-size: 1.8rem;
	text-align: center;
	line-height: 2;
	letter-spacing: 0.05em;
}


#recruit {
	color: #32b16c;
	background-color: #003333;
}
#recruit .linklist li a {
	color: #003333;
	background-color: #32b16c;
}
#recruit .linklist li a::before {
	border-color: #003333;
}
#recruit .linklist li a:hover {
	color: #003333;
	background-color: #2a965b;
}
#recruit .linklist li a:hover::before {
	border-color: #003333;
}
#recruit .lead {
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
	line-height: 2;
}


.tablelist dl {
	display: flex;
	margin: 1px 0 0;
}
.tablelist dt {
	width: 20%;
	padding: 2em 3em;
	background-color: #202020;
}
.tablelist dd {
	width: 80%;
	margin: 0;
	padding: 2em 3em;
	background-color: #282828;
	line-height: 1.8;
}
.tablelist .address div {
	margin: 1.5em 0;
}
.tablelist .address div:first-child {
	margin-top: 0;
}
.tablelist .address div:last-child {
	margin-bottom: 0;
}
.tablelist .address strong {
	display: block;
}


.historylist dd div {
	display: flex;
}
.historylist dd div time {
	width: 8%;
	font-weight: bold;
}
.historylist dd div span {
	width: 92%;
}


.company .mainvisual {
	background-image: url(/img/company/pagevisual.jpg);
}
.business .mainvisual {
	background-image: url(/img/business/pagevisual.jpg);
}

#outline.cardlayout .card-deck {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: -5rem;
}
#outline.cardlayout .card {
	width: 48%;
	margin-top: 5rem;
	background-color: transparent;
}
#outline.cardlayout .card a {
	color: #fff;
}
#outline.cardlayout .card img {
	width: 100%;
	transition: all .1s;
}
#outline.cardlayout .card .card-img-top {
	border-radius: 0;
}
#outline.cardlayout .card .card-block {
	padding: 3rem;
}
#outline.cardlayout .card .card-title {
	font-weight: bold;
	font-size: 2.4rem;
	letter-spacing: 0.05em;
}
#outline.cardlayout .card .card-text {
	line-height: 1.8;
	margin: 2rem 0 0;
}
#outline.cardlayout .card .skewbtn {
	margin: 3rem 0 0;
}

.recruit .mainvisual {
	color: #32b16c;
	background-image: url(/img/recruit/pagevisual.png);
	background-size: 28rem;
	background-position: 70% 58%;
	background-color: #003333;
}
.recruit .mainvisual .pagenavi .btn {
	color: #003333;
	background-color: #32b16c;
}
.recruit .mainvisual .pagenavi .btn:hover {
	background-color: #2a965b;
}
.recruit article section.bggray {
	background-color: #002828;
}
.recruit article section {
	color: #32b16c;
}
.recruit article section .skewbtn .btn {
	color: #32b16c;
	border-color: #32b16c;
}
.recruit article section .skewbtn .btn:hover {
	color: #002828;
	background-color: #32b16c;
}
.recruit article section .display-1 {
	font-size: 8rem;
	font-weight: bold;
}
.recruit .separate {
	width: 4rem;
	background-color: #32b16c;
}
.recruit .eventdate {
	padding: 1em;
	color: #002828;
	font-weight: bold;
	background-color: #32b16c;
}



.footer {
	overflow: hidden;
	color: #fff;
	background-color: #191919;
}
.footer a {
	color: #fff;
}
.footernav a {
	font-weight: bold;
	letter-spacing: 0.05em;
	transition: all .1s;
}
.footernav a:hover {
	color: #666;
	text-decoration: none;
}
.pagetop{
  display: block;
  position: fixed;
  z-index: 9999;
  bottom: -60px;
  right: 10px;
  width: auto;
  padding: 20px 10px;
  margin: 0;
  background: rgba(0,0,0,.3);
  color: #fff;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  transition: .5s;
  cursor: pointer;
}
.pagetop:hover{ 
  background: rgba(0,0,0,.5);
}
.footerlogo {
	width: 222px;
}
.footerlogo img {
	width: 100%;
}
.footeraddress {
	font-size: 1.3rem;
	line-height: 2;
	letter-spacing: 0.05em;
}