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


html {
	visibility: hidden;
}
html.wf-active {
	visibility: visible;
}
/* -------------------
 defolt 
--------------------*/
html {
	font-size: 62.5%;
}
body {
	color: #191919;
	font-family: "kozuka-gothic-pro", Arial, "Helvetica Neue", "メイリオ", Meiryo, -apple-system, BlinkMacSystemFont, "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, sans-serif;
	font-size: 14px;
	font-size: 1.4rem;
	font-weight: 100;
	line-height: 1.7;
	letter-spacing: 0.02em;
}
.text-center {
	text-align: center;
}
.responsive-img {
	max-width: 100%;
	height: auto;
}
ul, li {
	list-style: none;
}
strong {
	font-weight: bold;
}
.logo {
	color: #1768b2;
	font-size: 3.6rem;
	line-height: 1;
}
.logo a {
	color: #0285dd;
	text-decoration: none;
	font-size: 3.6rem!important;
}
.logo a:visited {
	color: #0285dd;
	font-size: 3.6rem;
}
.twitter {
	width: 34px;
	height: 28px;
	fill: #1963a7;
}
.font-w-normal {
	font-weight: normal;
}
.f10 {
	font-size: 1.0rem!important;
}
.f12 {
	font-size: 1.2rem!important;
}
.f13 {
	font-size: 1.3rem!important;
}
.f14 {
	font-size: 1.4rem!important;
}
.f18 {
	font-size: 1.8rem!important;
}
.f19 {
	font-size: 1.9rem!important;
}
.f20 {
	font-size: 2.0rem!important;
}
.f23 {
	font-size: 2.3rem!important;
}
.f25 {
	font-size: 2.5rem!important;
}
.f28 {
	font-size: 2.8rem!important;
}
.f31 {
	font-size: 3.1rem!important;
}
.f33 {
	font-size: 3.3rem!important;
}
.f42 {
	font-size: 4.2rem!important;
}
.f45 {
	font-size: 4.5rem!important;
}
.f50 {
	font-size: 5.0rem!important;
}
.text-left {
	text-align: left!important;
}
.text-right {
	text-align: right!important;
}
.brnone {
	display: none;
}
.mb-0 {
	margin-bottom: 0rem;
}
.mb- .mb-1 {
	margin-bottom: 1rem;
}
.mb-1-1 {
	margin-bottom: 1.1rem;
}
.mb-2 {
	margin-bottom: 2rem;
}
.mb-3 {
	margin-bottom: 3rem;
}
.mb-4 {
	margin-bottom: 4rem;
}
.mb-5 {
	margin-bottom: 5rem;
}
.mb-6 {
	margin-bottom: 6rem;
}
.mb-7 {
	margin-bottom: 7rem;
}
.mb-8 {
	margin-bottom: 8rem;
}
.mb-9 {
	margin-bottom: 9rem;
}
/*  page top */
.page-top {
    position: fixed;
    bottom: 5px;
    right: 20px;
	    display: none;
}
.page-top a {
    display: block;
    width: 60px;
    padding: 0px 0;
    text-align: center;
    text-decoration: none;
    opacity: 0.7;
}
.page-top a:hover {
	opacity: 0.8;
	text-decoration: none;
}
/* line height */
.lh-1_2 {
	line-height: 1.2;
}
.lh-1_3 {
	line-height: 1.3;
}
.lh-1_4 {
	line-height: 1.4;
}
.lh-2_5{
	line-height: 2.5;
}
/* -------------------
 link 
--------------------*/
a.textlink {
	text-decoration: none;
	font-weight: bold;
	color: #454545;
}
a.textlink:hover {
	color: #1768b2;
}
a.textlink::before {
	content: '>>> ';
}
.linkborder {
	border-bottom: 1px dotted #8d8b8b;
	width: 50%;
}
/* -------------------
 float 
--------------------*/
.float-l {
	float: none;
}
.float-r {
	float: none;
}
/* -------------------
 col 
--------------------*/
.row {
	overflow: hidden;
	margin: auto;
}
.d-flex {
	display: block;
}
.d-inline-block {
	display: inline-block;
}
.w120 {
	width: 100%;
}
.w88p {
	width: 88%;
	margin: auto;
}
/* -------------------
 margin
--------------------*/
.my-5 {
	margin-top: 5rem;
	margin-bottom: 5rem;
}
.mr-1,.mr-2,.mr-3,.mr-4,.mr-5  {
	margin-right: 0;
}

.pr-9 {
	padding-left: 0;
}
.pl-0 {
	padding-left: 0!important;
}
.justify-content-sb {
	justify-content: space-between;
}
.align-center {
	align-items: center;
}
.flex-wrap {
	flex-wrap: wrap;
}
.d-sm-hidden {
	display: none;
}
.d-md-none {
	display: inline-block;
}
/* -------------------
 table 
--------------------*/
table {
	border-collapse: collapse;
}
table.table th {
	color: #00913a;
	text-align: left;
	font-weight: normal;
	border-bottom: 1px solid #00913a;
	padding: 10px 25px 10px 0;
	vertical-align: top;
}
table.table td {
	border-bottom: 1px solid #00913a;
	vertical-align: top;
	padding: 10px;
}
table tr:nth-child(odd) {
	background: #f4f4f4;
}
table th {
	width: 20%;
	padding: 7px 7px 7px 20px;
	text-align: left;
	vertical-align: top;
	font-weight: normal;
}
table td {
	padding: 7px 7px 7px 15px;
}
.w10p {
	width: 10%!important;
}
.w20p {
	width: 20%;
}
.w30p {
	width: 30%;
}
/* -------------------
 google map 
--------------------*/
.ggmap {
	position: relative;
	width: 100%;    /* 左右に余白が必要なら値を変更してもOK */
	height: 0;
	padding-bottom: 56.25%;    /* padding-topでもOK */
	overflow: hidden;
}
.ggmap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;    /* 必要であれば!importantを付けてください */
	height: 100%;    /* 必要であれば!importantを付けてください */
}
/* -------------------
 keyvisual 
--------------------*/
.keyvisual {
	background: url(common/img/main.jpg) 0 0;
	background-size: cover;
	height: 699px;
	color: #fff;
	position: relative;
	margin-bottom: 70px;
}
.keyvisual h2 {
	font-size: 5rem;
	line-height: 1;
	opacity: 0.8;
	margin-bottom: 1rem;
	text-align: center;
}
.keyvisual h3 {
	font-size: 2rem;
	line-height: 1.4;
	text-align: center;
	margin-bottom: 1rem;
}
.keyvisual.page {
	height: 220px!important;
}
.keyvisual.page {
	background: url(common/img/page_keyvisual.jpg)0 0;
	background-size: cover;
}
.main_desc {
	display: table;
	margin: auto;
	position: relative;
	top: 50%;
	-webkit-transform: translateY(-50%); /* Safari用 */
	transform: translateY(-50%);
}
/* -------------------
 header 
--------------------*/
header {
	margin-top: 0;
}
/* nav */
nav {
	margin: 10px 0px;
}
nav ul {
	display: flex;
}
nav ul li {
	font-size: 1.8rem;
}
nav ul li a {
	display: block;
	text-decoration: none;
	text-align: center;
	padding: 15px 20px;
	color: #191919;
	border-top: 1px solid #e2e2e2;
}
nav ul li a:hover {
	color: #1768b2;
}
nav ul li a:first-child {
	padding-left: 0;
}
#menu {
	display: none;
}
#menu li:first-child {
	margin-right: 0;
}
#menu li:first-child::after {
	content: '≫';
	transform: rotateZ(-270deg);
	position: absolute;
	right: 0;
	top: 15px;
}
.brand {
	font-size: 1.4rem;
	margin-right: 10px;
	margin-top: -10px;
	display: block;
}
.spnav {
	display: flex;
	text-align: right;
	padding: 1rem 1rem 0rem;
	justify-content: space-between;
	align-items: center;
}
.spnav a {
	display: inline-block;
	color: #fff;
	font-size: 1.8rem;
	letter-spacing: 1.5px;
	text-decoration: none;
}
#menu li {
	position: relative;
}
.tgg {
	padding: 5px 0 0;
}
/* hamburguer trigger*/

.menu-trigger, .menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 50px;
	height: 33px;
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: #2e3838;
	border-radius: 1px;
}
.menu-trigger span:nth-of-type(1) {
	top: 0;
}
.menu-trigger span:nth-of-type(2) {
	top: 15px;
}
.menu-trigger span:nth-of-type(3) {
	bottom: 0;
}
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(13px) rotate(-45deg);
	transform: translateY(13px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-18px) rotate(45deg);
	transform: translateY(-18px) rotate(45deg);
}
/* -------------------
 footer 
--------------------*/
footer {
	background: #c5d8e4;
	padding: 50px 0 20px;
	margin-top: 130px;
}
footer a {
	color: #191919;
	text-decoration: none;
}
footer a:hover {
	text-decoration: underline;
}
footer address {
	font-style: normal;
}
footer div:nth-of-type(4) {
	margin-left: auto;
}
.footercontact {
	background: #fff;
	width: 100%;
	padding: 11px 20px;
	margin-bottom: 1rem;
	margin-top: 2rem;
}
.footercontact p {
	border-bottom: 1px dotted #999;
	padding-bottom: .5rem;
	margin-bottom: .5rem;
}
.footercontact ul li {
	color: #40a6e6;
	font-size: 1.8rem;
	font-weight: bold;
}
.footercontact ul li.icon_tel::before {
	content: url(common/img/icon_tel.png);
	top: 1px;
	position: relative;
	padding-right: 1rem;
}
.footercontact ul li.icon_mail::before {
	content: url(common/img/icon_mail.png);
	top: 3px;
	position: relative;
	padding-right: 1rem;
}
.footercontact a {
	color: #40a6e6;
	text-decoration: none;
}
.footercontact a:hover {
	text-decoration: none;
	opacity: 0.8;
}
/* -------------------
 container 
--------------------*/
.container {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}
section {
	margin: auto 10px;
	position: relative;
}
/* -------------------
 main 
--------------------*/
main {
	width: 100%;
}
.border-text {
	border-top: 1px solid #0285dd;
	border-bottom: 1px solid #0285dd;
	padding: 10px 19px;
	margin-bottom: 40px;
	text-align: center;
}
/* -------------------
 sidebar  
--------------------*/
aside {
	width: 100%;
	margin-bottom: 2rem;
}
aside dt {
	background: #0285dd;
	color: #fff;
	padding: 10px 8px;
	font-weight: bold;
}
aside ul {
	border: 1px solid #0285dd;
}
aside li {
	border-bottom: dotted 1px #888;
	margin: 8px;
	padding-top: 2px;
}
aside li:last-child {
	border-bottom: none;
}
aside li a {
	text-decoration: none;
	color: #191919;
}
aside li a:hover {
	color: #0285dd;
}
/*page */
/* feature */
.featurelist {
	line-height: 2;
}
.featurelist li ul {
	margin-left: 22px;
}
.featurelist li ul li::before {
	content: '・';
	padding: 5px;
	margin-left: -25px;
}
/* business */
.mmtb {
	margin: 130px auto;
	font-size: 1.8rem;
	font-weight: bold;
}
.busbox {
	border: 1px solid #1768b2;
	padding: 10px 20px;
}

/* --------------------------------------
 Media query 
---------------------------------------*/
@media (min-width: 768px) {
body {
	min-width: 1210px;
}
.responsive-img {
	max-width: none;
	height: auto;
}
.mr-1 {
	margin-right: 1rem;
}
.mr-2 {
	margin-right: 2rem;
}
.mr-3 {
	margin-right: 3rem;
}
.mr-4 {
	margin-right: 4rem;
}
.mr-5 {
	margin-right: 5rem;
}
.brnone {
	display: inline;
}
.d-sm-hidden {
	display: inline-block;
}
.d-flex {
	display: -webkit-box;
	display: -moz-box;
	display: -webkit-flexbox;
	display: -moz-flexbox;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: -moz-flex;
	display: flex;
}
.justify-content-sb {
	justify-content: space-between;
}
.float-l {
	float: left;
}
.float-r {
	float: right;
}
/* -------------------
 header 
--------------------*/
header {
	margin-top: 50px;
}
/* -------------------
 keyvisual 
--------------------*/
.keyvisual h2 {
	font-size: 9rem;
}
.keyvisual h3 {
	text-align: right;
	font-size: 3.6rem;
	margin-bottom: auto;
}
/* -------------------
 nav 
--------------------*/
nav {
	margin: 50px 0px 20px;
}
nav ul li a {
	display: block;
	text-decoration: none;
	text-align: center;
	padding: 0 20px;
	color: #191919;
	border-top: none;
}
.spnav {
	display: none;
}
#menu li:first-child::after {
	content: '≫';
	transform: rotateZ(-270deg);
	position: absolute;
	right: 0;
	top: 0;
}
#menu {
	display: -webkit-box;
	display: -moz-box;
	display: -webkit-flexbox;
	display: -moz-flexbox;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: -moz-flex;
	display: flex!important;
}
#menu li:first-child {
	margin-right: 3rem;
}
#menu li:last-child {
	margin-left: auto;
}
/* -------------------
 container 
--------------------*/
.container {
	width: 1210px;
	margin-left: auto;
	margin-right: auto;
}
section {
	margin: auto;
	position: relative;
}
/* -------------------
 main 
--------------------*/
main {
	width: 950px;
}
/* -------------------
 sidebar  
--------------------*/
aside {
	width: 220px;
}
.footercontact {
	background: #fff;
	width: auto;
	padding: 11px 20px;
	margin-bottom: 1rem;
	margin-top: auto;
}
}
