@charset "UTF-8";

body {
	font-family: 'Jost', 'Noto Sans JP','游ゴシック Medium','游ゴシック体','Yu Gothic Medium',YuGothic,'ヒラギノ角ゴ ProN','Hiragino Kaku Gothic ProN','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif !important;
	font-weight: 400;
}
html {
	color: #373737;
	font-size: 20px;
	background-image: url(/images/back.jpg);
	background-size: cover;
	background-color: #EFEFEF;
	background-attachment: fixed;
}
ul {
	padding-left: 0;
}
ul li {
	list-style: none;
}
body {
	background: none;
}
#scrolltop {
	position: fixed;
	right: 6px;
	bottom: 8px;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transition: .6s;
	z-index: 100;

}
#scrolltop.active {
	opacity: 1;
	visibility: visible;
}
#scrolltop img {
	width: 66%;
}
section {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

nav {
	min-height: 130px;
	border-bottom: solid 1px #777777;
}

nav .dropdown-toggle::after {
	display: none;
}

.navbar-nav {
	line-height: 1rem;
}

.navbar-nav .dropdown-menu {
    position: absolute;
}

.navbar-toggler-icon {
	background-image: url(/images/menu-open-s.png);
}

#sub-menu-aboutus {
	width: 340px;
}

#sub-menu-business {
	width: 220px;
}

#sub-menu-company {
	width: 180px;
}

.sub-menu-parent {
	position: relative;
}

.sub-menu {
	font-size: 1.15rem;
	padding-top: 0.7rem;
	padding-bottom: 0.7rem;
	position: absolute;
	top: 140%;
	left: -100%;
	right: -100%;
	margin: auto;
	display: none;
	background-color: rgba(255,255,255,0.95);
	z-index: 10;
}

.sub-menu li {
	padding: 0.5rem;
}

.sub-menu li a {
	width: 100%;
	display: block;
}

a {
	text-decoration: none;
	color: #373737;
}

a:visited {
	color: #373737;
}

.first-contents {
	padding-top: 8rem;
}

.navbar-brand {
	width: 15%;
	text-align: center;
}
.navbar-brand img {
	margin-top: -0.50rem;
}
.navbar-sns {
	width: 15%;
}
.nav-item {
	font-size: 1.15rem;
	text-wrap: nowrap;
	padding-right: 1.1rem;
}
.nav-item i {
	font-size: 0.9rem;
	margin-left: 6px;
}
.nav-jpn {
	font-size: 0.6rem;
	font-weight: 500;
}
.navbar-toggler {
	border-color: rgba(0,0,0,0);
}

.footer-nav {
	background-image: url(/images/footer-dot.png);
	background-repeat: repeat-x;
	padding-top: 3rem;
}

footer .footer-company-info {
	display: flex;
	flex-direction: row;
	align-items: flex-end;
/*	justify-content: space-between;*/
	margin-bottom: 1.5rem;
}

footer .footer-company-info .license-number {
	font-size: 0.7rem;
}
footer .footer-company-info .address {
	font-size: 0.8rem;
}
footer .copyright {
	font-size: 0.7rem;
}

footer .footer-menu-list {
	display: flex;
	flex-direction: row;
	align-items: flex-end;
	justify-content: space-between;
	margin-bottom: 2.5rem;
}

footer .footer-menu-list li {
	color: #373737;
	text-align: center;
	flex: 1 1 auto;
}
footer .footer-menu-list li:not(:first-child):not(:last-child) {
	border-left: solid 2px #aaa;
}
footer .footer-menu-list li i {
	font-size: 0.9rem;
	margin-left: 10px;
}
footer .footer-company-info .logo {
	margin-right: 3rem;
}
.btn-more {
	padding: 0.6rem;
	width: 180px;
	color: #efefef;
	text-align: center;
	background-color: #373737;
	border: solid 1px #373737;
	transition: all 0.5s ease-in-out 0s;
}
.btn-more:hover {
	color: #373737;
	background-color: #efefef;
}
.btn-more-white {
	padding: 0.6rem;
	width: 180px;
	color: #373737;
	text-align: center;
	background-color: #efefef;
	transition: all 0.5s ease-in-out 0s;
}
.btn-more-white:hover {
	color: #efefef;
	background-color: #373737;
}

.inner-link {
	flex-wrap: wrap;
}
.inner-link h2 {
	font-size: 4rem;
	margin-bottom: 0;
}
.inner-link-item {
	width: 50%;
	height: 650px;
	padding: 5rem 0;
}
.inner-link-item-l {
	background-image: linear-gradient(rgba(0,0,0,0.4),rgba(0,0,0,0.4)), url(/images/inner-link-01.jpg);
	background-position: center center;
	background-size: cover;
}
.inner-link-item-r {
	background-image: linear-gradient(rgba(0,0,0,0.4),rgba(0,0,0,0.4)), url(/images/inner-link-02.jpg);
	background-position: center center;
	background-size: cover;
}

.inner-link-item-message {
	line-height: 2.6rem;
	text-align: center;
}

.inner-link .inner-link-btn {
	margin: 0 auto;
}

.inner-link .title-image {
	overflow-x: hidden;
}

.inner-link .title-image img {
	width: 100%;
}

.intro {
	margin-bottom: 12rem;
}
.intro.has-button {
	margin-bottom: 15rem;
}

.intro-title {
	margin-bottom: 4.5rem;
}

.intro-title h2 {
	font-size: 4rem;
}

.intro-title .title-image {
	overflow-x: hidden;
}

.intro-title .title-image img {
	min-width: 800px;
	width: 100%;
}

.intro-title span {
	font-size: 1.25rem;
	font-weight: 500;
}

.intro-message {
	line-height: 2.6rem;
	margin-bottom: 4rem;
}

.mw-1000px {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.border-top-dotted {
	background-image: url(/images/footer-dot.png);
	background-repeat: repeat-x;
	padding-top: 10rem;
	margin-bottom: 15rem;
}

.title-black {
	color: transparent;
	-webkit-text-stroke: 2px #373737;
	text-stroke: 2px #373737;
}

.title-white {
	color: transparent;
	-webkit-text-stroke: 2px #fff;
	text-stroke: 1px #fff;
}
.text-vertical {
	writing-mode: vertical-rl;
	text-orientation: mixed;
	text-wrap: nowrap;
	margin: auto;
	padding-top: 1rem;
}
.text-vertical p {
	margin-left: 0;
	margin-right: 0;
}

.btn-circle {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 60px;
	height: 60px;
	line-height: 1rem;
}

.btn-circle-inner {
	display: flex;
	justify-content: center;
	align-items: center;
	background-image: url(/images/ico_circle_dot.svg);
	background-position: center center;
	background-size: cover;
	width: 90%;
	height: 90%;
}

.btn-circle-inner:hover {
	width: 100%;
	height: 100%;
}

.btn-circle-inner span {
	background-color: #373737;
	color: #efefef;
}


.page-nav {
	display: flex;
	justify-content: space-between;
}

.page-nav-inner {
	display: flex;
	justify-content: center;
	column-gap: 1rem;
}

.page-nav-inner li {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	text-align: center;
	border-radius: 50%;
	border: none;
}

.page-nav-inner li.current {
	border: solid 1px #373737;
}

.page-nav-inner li a {
	width: 100%;
	text-decoration: none;
	color: #373737;
}

.prev-page button, .next-page button {
	border: solid 1px #373737;
	padding: 0.6rem;
	margin-left: auto;
	width: 180px;
	color: #373737;
	text-align: center;
	background-color: transparent;
	border-radius: 50rem;
	transition: all 0.5s ease-in-out 0s;
}

.prev-page button:hover, .next-page button:hover {
	color: #efefef;
	background-color: #373737;
}

.prev-page.disabled, .next-page.disabled {
	visibility: hidden;
}

.offcanvas-backdrop.show {
	opacity: 0.05;
}

.offcanvas-header {
	flex-direction: column;
	align-items: flex-end;
	padding-top: 0.2rem;
	padding-right: 0.75rem;
}
.offcanvas {
	transition: transform 0.5s ease-in-out 0s;
}

.offcanvas .navbar-toggler-icon {
	background-image: url(/images/menu-close-s.png);
}


.navbar-toggler:focus {
	box-shadow: none;
}

.btn-close {
	background-image: url(/images/menu-close-s.png);
	background-size: auto;
	width: 1.5rem;
	height: 1.5rem;
	border: none;
	opacity: inherit !important;
}

.btn-close:focus {
	box-shadow: none;
}

.slider img {
	object-fit: cover;
}

@media screen and (min-width:576px) {
	.slider img {
		margin-right: 32px;
	}
}

@media screen and (min-width:576px) {
	.business-slider img {
		margin-right: 32px;
	}
}

@media screen and (max-width:768px) {
	html {
		font-size: 15px;
	}
	nav {
		min-height: 110px;
	}
	#offcanvas {
		padding-top: 2rem;
		padding-left: 4rem;
		background-image: url(/images/back.jpg);
		border: none;
		overflow-y: auto;
		max-height: 600px;
		height: 100%;
	}
	#offcanvas .navbar-nav {
		row-gap: 1rem;
		padding-bottom: 2rem;
	}
	#offcanvas .navbar-nav .nav-item {
		text-align: left;
	}
	#offcanvas .navbar-nav .nav-item:last-child {
		position: absolute;
		right: 3px;
		top: 85px;
	}
	.sub-menu {
		position: static;
		padding: 0.2rem 0 0 0;
		margin: 0;
		background-color: transparent;
	}
	.sub-menu li {
		padding: 0.3rem 0 0.3rem 0;
	}
	.mw-1000px {
		padding-left: 3.8rem;
		padding-right: 3.8rem;
	}
	.footer-nav {
		font-size: 0.75rem;
	}
	.footer-nav ul li img {
		width: 20px;
	}
	.intro-message {
		line-height: 1.8rem;
	}
	.inner-link-item {
		padding: 3.4rem 0;
		height: 350px;
	}
	.inner-link-item-message {
		font-size: 0.8rem;
		line-height: 1.2rem;
	}
	.inner-link h2 {
		font-size: 3rem;
	}
	.inner-link span {
		font-size: 0.8rem;
	}
	.news-item-date {
		flex-basis: 120px;
	}
	.btn-more {
		width: 140px;
	}
	.btn-more-white {
		width: 140px;
	}
	.intro {
		margin-bottom: 5rem;
	}
	.intro.has-button {
		margin-bottom: 7.5rem;
	}
	h3 {
		font-size: 1.35rem;
	}
	.ceo img {
		min-width: 260px;
		max-width: 50%;
	}
	.prev-page button, .next-page button {
		font-size: 0.75rem;
		width: 100px;
	}
	.page-nav-inner {
		column-gap: 0.5rem;
	}
	.page-nav-inner li {
		width: 34px;
		height: 34px;
	}
	footer .footer-company-info {
		justify-content: space-between;
	}
	footer .footer-company-info .logo {
		width: 20%;
		min-width: 100px;
	}
	footer .footer-company-info .logo {
		margin-right: 1rem;
	}
	footer .footer-company-info .license-info {
		margin-right: 1rem;
	}
}

@media screen and (max-width:576px) {
	nav {
		min-height: 60px;
	}
	.navbar-brand {
		width: 90px;
	}
	#offcanvas {
		padding-top: 0.5rem;
	}
	.mw-1000px {
		padding-left: 2.6rem;
		padding-right: 2.6rem;
	}
	.intro-message {
		margin-bottom: 1.4rem;
	}
	.intro-title {
		margin-bottom: 5rem;
	}
	.intro-title .title-image img {
		min-width: 500px;
	}
	.intro-title span {
		font-size: 0.8rem;
	}
	.inner-link-item {
		width: 100%;
		height: 280px;
		padding: 2rem 0;
	}
	footer .footer-company-info {
		justify-content: space-around;
	}
	footer .footer-company-info .logo {
		width: 100px;
	}
	footer .footer-company-info .address {
		display: none;
	}
	footer .footer-menu-list {
		flex-wrap: wrap;
		row-gap: 0.6rem;
		margin-bottom: 0.5rem;
	}
	footer .footer-menu-list li {
		width: 33%;
		flex: none;
		border-left: solid 1px #aaa !important;
	}
	footer .footer-menu-list li:nth-child(3n+1) {
		border-left: none !important;
	}
	.first-contents {
		padding-top: 3rem;
	}
}

@media screen and (min-width:576px) {
	#scrolltop {
		right: 36px;
		bottom: 20px;
	}
	#scrolltop img {
		width: 100%;
	}
}
@media screen and (min-width:768px) {
	.navbar-brand img {
		margin-top: -1.3rem;
	}
}


