@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@200;400;700;900&display=swap&subset=japanese');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;400;600;700;900&display=swap&subset=japanese');

html {
	font-size: 100%;
}

body {
	margin: 0;
	padding: 0;
	height: 100%;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 14px;
	line-height: 1.7;
	color: #000;
	-webkit-text-size-adjust:100%;
}

h1,h2,h3,h4,h5,h6 {
    font-size:100%;
    font-weight:normal;
	margin:0;
    padding:0;
}

p,li,dt,dd,th,td,pre {
	-ms-line-break: strict;
	line-break: strict;
	-ms-word-break: break-strict;
	word-break: break-strict;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: top;
	border: 0;
}

ul,ol {
	padding: 0 0 0 2em;
}

dd {
	margin: 0;
}

object,embed {
  vertical-align: top;
}

a {
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
	color: #005ab4;
	cursor: pointer;
}

a:not(.hover):hover,
a:not(.false):hover {
	opacity: 0.7;
}

a.false,
a.hover {
	opacity: 1!important;
}

a:hover {
	cursor: pointer;
}

a:focus {
	outline: none;
}

p {
	display: block;
	margin: 0 0 1em;
}

.layout {
	padding: 0;
	list-style: none;
}

.cf:before,
.cf:after{
  content:"";
  display: table;
}

.cf:after{
  clear:both;
}

.font {
	font-family: 'Noto Serif JP', serif;
}

/* move */
.move {
	opacity: 0;
	position: relative;
	top: 30px;
	-webkit-transition: all 0.8s ease;
	-moz-transition: all 0.8s ease;
	-o-transition: all 0.8s ease;
	transition: all  0.8s ease;
}

.move.on {
	opacity: 1;
	top: 0;
}

	@media screen and (min-width: 769px) {
		body {
			min-width: 1000px;
		}
	}

/* ----------------------------------------
	Common
---------------------------------------- */
#wrapper {
	padding-top: 60px;
	overflow-x: hidden;
}

.inner {
	margin: 0 auto;
	position: relative;
}

	@media screen and (min-width: 769px) {
		.inner {
			width: 1000px;
		}
	}

	@media screen and (max-width: 768px) {
		#wrapper {
			padding-top: 50px;
		}

		.inner {
			padding: 0 10px;
			box-sizing: border-box;
		}
	}

/* ----------------------------------------
	gNavi
---------------------------------------- */
#gNavi {
	width: 100%;
	background: #fff;
	position: fixed;
	top: 0;
}

#logo {
	margin: 0 0 0 1em;
	float: left;
}

.contact {
	margin: 0 1em 0 0;
	position: absolute;
	top: 0;
	right: 0;
}

#logo,
.contact {
	height: 80px;
	transition: all  0.3s ease;
}

#logo img,
.contact img {
	transition: all  0.3s ease;
	position: relative;
	top: 0;
	height: 100%;
}

#nav {
	margin: 0;
}

#nav li a {
	color: #000;
	text-decoration: none;
}

	@media screen and (min-width: 769px) {
		#gNavi {
			min-width: 1000px;
			height: 80px;
			transition: all  0.3s ease;
			z-index: 9;
		}

		#gNavi.top {
			height: 60px;
		}

		#gNavi.top #logo img,
		#gNavi.top .contact img {
			/*height: 55px;*/
			top: -10px;
		}

		#btn {
			display: none;
		}
		
		#nav {
			display: block!important;
			width: 100%;
			font-size: 0;
			text-align: center;
			position: absolute;
			top: 50%;
			transform: translate(0,-50%);
			z-index: 10;
		}
		
		#nav li {
			display: inline-block;
			font-size: 14px;
			padding: 0 5px 0 6px;
			box-sizing: border-box;
		}
		
		#nav .sp  {
			display: none;
		}
		
		#nav li a {
			padding: 6px .5em;
			position: relative;
			z-index: 2;
		}

		#nav li a:before {
			display: block;
			content: "";
			width: 100%;
			height: 100%;
			background: #54af24;
			border-radius: 6px;
			position: absolute;
			top: 0;
			left: 0;
			-webkit-transition: all 0.3s ease;
			-moz-transition: all 0.3s ease;
			-o-transition: all 0.3s ease;
			transition: all  0.3s ease;
			z-index: -1;
			transform: scale(1,0);
			transform-origin: center center;
			transition: transform 0s;
		}

		#nav li.on a:before,
		#nav li a:hover:before {
			transform: scale(1, 1);
			transition: transform .3s;
		}

		#nav li.on a,
		#nav li a:hover {
			color: #fff;
		}
	}

	@media screen and (max-width: 1100px) and (min-width: 769px) {
		#logo,
		.contact {
			height: 55px;
		}
		#logo img,
		.contact img {
			margin-top: 10px;
		}

		#gNavi.top #logo img,
		#gNavi.top .contact img {
			margin-top: 5px;
		}
	}

	@media screen and (max-width: 768px) {
		#logo {
			position: absolute;
			top: -50px;
		}

		#logo img {
			height: 55px;
		}

		.contact {
			display: none;
		}

		#gNavi {
			position: relative;
			padding: 0;
			top: 0;
		}

		#menu-line {
			display: none;
		}

		#btn {
			display: block;
			width: 50px;
			height: 50px;
			position: fixed;
			top: 0;
			right: 0;
			z-index: 900;
			text-align: center;
		}

		#btn a {
			display: flex;
			position: relative;
			width: 50px;
			height: 50px;
			align-items: center;
			flex-direction: column;
			padding-top: 8px;
		}

		#btn span {
			background-color: #fff;
			display: block;
			width: 25px;
			height: 2px;
			margin: 3px;
			transition: 0.3s ease;
		}
		
		#btn a span:nth-of-type(1) {
			top: 11px;
		}

		#btn a span:nth-of-type(2) {
			top: 18.5px;
		}

		#btn a span:nth-of-type(3) {
			top: 27px;
		}

		#btn.open a span:nth-of-type(1) {
			transform: translateY(6px) rotate(45deg);
		}

		#btn.open a span:nth-of-type(2) {
			transform: scale(0);
		}

		#btn.open a span:nth-of-type(3) {
			transform: translateY(-10px) rotate(-45deg);
		}

		.btn-menu-txt {
			bottom: 13px;
			color: #fff;
			line-height: 1em;
			position: absolute;
			left: 0;
			right: 0;
			margin: auto;
			font-size: 10px;
			letter-spacing: 0.05em;
		}
		
		#nav {
			display: none;
			width: 100%;
			max-height: 100%;
			overflow: scroll;
			position: fixed;
			padding: 0;
			z-index: 800;
			top: 50%;
			transform: translate(0,-50%);
		}
		
		#nav > li {
			text-align: center;
		}

		#nav li a {
			display: block;
			color: #000!important;
			padding: 14px 0;
		}

		.nav__sns_list li {
			display: inline-block;
			width: 25px;
			margin: 0 .3em;
		}

	}

/* ----------------------------------------
	Header
---------------------------------------- */
#header {
	position: relative;
}

/* ----------------------------------------
	bxslider
---------------------------------------- */
#slider {
	margin: 0;
}

.slide_text,
.slide_title {
	width: 100%;
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	padding: 0 1em;
	box-sizing: border-box;
	pointer-events: none;
}

.slide_text img {
	margin: auto;
}

#header .bx-wrapper {
	margin: 0 auto;
}

#header .bx-wrapper .bx-viewport {
	overflow: visible!important;
}

#slider li:not(.active-slide):before {
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,.5);
	position: absolute;
	top: 0;
	left: 0;
}

#header .bx-wrapper .bx-pager, .bx-wrapper .bx-controls-auto {
	bottom: 2px;
}

#header .bx-wrapper .bx-pager.bx-default-pager a {
	width: 50px;
	height: 4px;
	border-radius: 0;
	background: #fff;
	margin: 0 2px;
}

	@media screen and (max-width: 768px) {
		#header .bx-wrapper .bx-viewport {
			overflow: hidden!important;
		}

		#slider li:not(.active-slide):before {
			display: none;
		}
	}


/* ----------------------------------------
	Footer
---------------------------------------- */
#footer {
	padding: 2em 0;
}

.sns_list {
	margin: 0;
	position: absolute;
	top: -10px;
	left: 0;
}

.sns_list li {
	display: inline-block;
	margin-left: 10px;
}

.footer__copy {
	font-size: 12px;
	color: #fff;
	text-align: center;
	margin: 0;
}

#pagetop {
	display: none;
	position: fixed;
	bottom: 0;
	right: 0;
	margin: 0;
	z-index: 800;
}

#pagetop a {
	display: block;
	width: 100%;
	height: 100%;
}

	@media screen and (max-width: 768px) {
		#footer {
			padding: 1.3em 0;
		}

		.sns_list {
			text-align: center;
			margin: .5em 0 1em;
			position: relative;
			top: 0;
		}
		
		.sns_list li {
			display: inline-block;
			width: 30px;
			margin: 0 3px!important;
		}

		.footer__copy {
			font-size: 10px;
		}

		#pagetop {
			width: 50px;
			height: 50px;
		}
	}

/* ----------------------------------------
	Contents
---------------------------------------- */
.section {
	line-height: 1.9;
	position: relative;
	padding: 4em 0;
	overflow: hidden;
}

.section__title {
	font-size: 30px;
	text-align: center;
	line-height: 1.5;
}

.section__title:after {
	display: block;
	content: "";
	width: 14px;
	height: 1px;
	background: #000;
	margin: 0 auto .3em;
}

.section__subtit {
	font-size: 14px;
	text-align: center;
	margin: 0 0 2.4em;
}

.bg {
	background-repeat: no-repeat;
	background-size: cover;
	background-position-x: center;
	position: absolute;
	width: 100%;
	height: 150%;
	top: 0;
	left: 0;
	z-index: -1
}

	@media screen and (max-width: 768px) {
		.section__title {
			font-size: 24px;
		}

		.section__subtit {
			font-size: 12px;
		}
	}

/* slider-item */
.slider-wrap {
	width: 100%;
	position: relative;
}

.slider__item {
	background: #fff;
}

.slider__item__img {
	height: 250px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.slider__item__wrap {
	padding: 15px;
}

.slider__item__title {
	text-align: center;
	font-size: 18px;
	color: #0d3780;
	margin: 0 0 .3em;
}

/* news */
.news_list-wrap {
	max-height: 160px;
}
.news_list {
	border-top: 1px solid #e6e6e6;
}

.news_list li {
	border-bottom: 1px solid #e6e6e6;
	padding: 1em;
}

.news_list li a {
	text-decoration: none;
}

.news_list li p {
	display: inline-block;
	margin: 0 1em 0 0;
	vertical-align: top;
}

/*
.news_list__title {
	width: 600px;
}
*/

/*--------------------------
	scroll bar
--------------------------*/
.mCSB_scrollTools {
	opacity: 1;
	width: 8px;
}

.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
	width: 8px;
	border-radius: 0;
}

.mCSB_draggerRail {
	background: #d7d7d7;
}

.mCSB_scrollTools .mCSB_draggerRail {
	width: 8px;
	border-radius: 0;
}

	@media screen and (max-width: 768px) {
		.news_list__title {
			display: block;
		}
	}

/* company */
.company-box {
	display: flex;
}

.company-box__img {
	width: 310px;
}

.company-box__tables {
	width: calc(100% - 310px);
	padding-left: 2em;
	box-sizing: border-box;
}

.company-box__table {
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #c7c7c7;
}

.company-box__table th,
.company-box__table td {
	text-align: left;
	font-weight: normal;
	border-bottom: 1px solid #c7c7c7;
	padding: .95em 1em;
	vertical-align: top;
	box-sizing: border-box;
}

	@media screen and (max-width: 768px) {
		.company-box {
			flex-wrap: wrap;
		}

		.company-box__item {
			width: 100%;
			padding: 0 0 1em;
		}

		.company-box__img {
			text-align: center;
		}

		.company-box__table th {
			white-space: nowrap;
		}

	}

/* map */
#map {
	margin: 1em 0 -4.5em;
}

	@media screen and (max-width: 768px) {
		#map iframe {
			height: 150px;
		}
	}

/* ----------------------------------------
	bxslider
---------------------------------------- */
.slider-wrap .bx-wrapper {
	max-width: 100%;
	margin: 0 auto 50px;
}

.slider-wrap .bx-wrapper .bx-pager.bx-default-pager a {
	width: 8px;
	height: 8px;
	background: #cdcdcd;
	margin: 0 9px;
}

.slider-wrap .bx-wrapper .bx-pager.bx-default-pager a:hover,
.slider-wrap .bx-wrapper .bx-pager.bx-default-pager a.active {
	background: #0d3780;
}

.slider-wrap .bx-wrapper .bx-pager,
.slider-wrap .bx-wrapper .bx-controls-auto {
	bottom: -50px;
}

.slider-wrap .bx-wrapper .bx-controls-direction a {
	width: 17px;
	height: 26px;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	z-index: 1;
}

.slider-wrap .bx-wrapper .bx-prev {
	left: -60px;
	background-image: url(../images/common/btn_prev.png);
}

.slider-wrap .bx-wrapper .bx-next {
	right: -60px;
	background-image: url(../images/common/btn_next.png);
}

	@media screen and (max-width: 768px) {
		.slider-wrap .bx-wrapper .bx-pager.bx-default-pager a {
			margin: 0 5px;
		}

		.slider-wrap .bx-wrapper .bx-controls-direction a {
			width: 10px;
			height: 19px;
		}

		.slider-wrap .bx-wrapper .bx-prev {
			left: -25px;
		}
		
		.slider-wrap .bx-wrapper .bx-next {
			right: -25px;
		}
	}

/* ----------------------------------------
	remodal
---------------------------------------- */
.remodal-overlay {
	background: rgba(255,255,255,.9);
}

.remodal {
	max-width: 900px;
}

.remodal {
	padding: 0 !important;
	background: transparent;
}

.remodal .remodal-inner {
	position: relative;
	width: 100%;
	max-width: 970px;
	height: 100%;
}

.remodal .remodal-inner .center.min {
	max-width: 640px;
	margin: 0 auto;
	text-align: left;
}

.remodal .remodal-inner .date {
	margin: 30px 0 0;
	font-size: 13px;
	line-height: 1em;
}

.remodal .remodal-inner .title {
	margin: 10px 0;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.6em;
}

.remodal .remodal-inner hr {
	border: none;
	width: 100%;
	height: 1px;
	background: rgba(0,0,0,0.5);
	margin: 30px 0;
}

.remodal .remodal-inner .center .txt {
	margin: 10px 0 0;
}

.remodal .remodal-btn-close {
	position: fixed;
	top: 0px !important;
	right: 0px !important;
	width: 40px;
	height: 40px;
	cursor: pointer;
	background: #000;
	border-radius: 50%;
}

.remodal .remodal-btn-close:before {
	transform: rotate(45deg);
}

.remodal .remodal-btn-close:after {
	transform: rotate(-45deg);
}

.remodal .remodal-btn-close:before,
.remodal .remodal-btn-close:after {
	content: "";
	z-index: 2;
	transition: transform 200ms;
}

.remodal .remodal-btn-close:before,
.remodal .remodal-btn-close:after {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 12px;
	height: 2px;
	margin: auto;
	background: #fff;
}

	@media screen and (max-width: 768px) {
		.remodal .remodal-inner {
			position: relative;
			width: 100%;
			height: 100%;
			padding: 20px;
			box-sizing: border-box;
		}

		.remodal .remodal-btn-close {
			top: 0 !important;
			right: 0 !important;
			width: 20px;
			height: 20px;
		}
	}

/* ----------------------------------------
	mfp
---------------------------------------- */
.news-detail {
	display: table;
	width: 100%;
	height: 100%;
	position: relative;
}

.news-detail-container {
	position: relative;
	display: table-cell;
	vertical-align: middle;
	margin: 0 auto;
	text-align: left;
	z-index: 1045;
	padding: 5%;
}

.news-detail-container__date {
	font-size: 11px;
}

.news-detail-container__title {
	margin: 0 0 20px;
	padding: 0 0 6px;
	border-bottom: 1px solid #fff;
}

.mfp-close-btn-in .mfp-close {
	color: #fff;
}

.mfp-close {
	font-size: 34px;
}

.mfp-close-btn-in .mfp-close {
	background: #999;
}

/*--------------------------
	投稿用
--------------------------*/
.alignleft {
	float: left;
	margin:0px 10px 10px 0;
	font-size: 0.9em;
}

.alignright {
	float: right;
	margin:0px 0 10px 10px;
	font-size: 0.9em;
}

.aligncenter {
	display: block;
	margin: 0 auto 10px;
	font-size: 0.9em;
}

/* ----------------------------------------
	Form
---------------------------------------- */
.page_guide {
	text-align: center;
	margin: 50px;
	padding-top: 60px;
}

.contact_submit {
	text-align: center;
}

.contact_submit input {
	-webkit-appearance: none;
	border: none;
	background-repeat: no-repeat;
	background-position: center;
	text-indent: -9999px;
	overflow: hidden;
}

.contact_submit input:disabled {
	opacity: .5;
}

.agree-box {
	margin: 0 0 40px;
	padding: 15px 0 25px;
	border-bottom: 1px solid #cccccc;
}

.agree-box__title {
	text-align: center;
	margin: 0 0 25px;
}

.privacy-box {
	width: 800px;
	height: 200px;
	margin: auto;
	border: 1px solid #cccccc;
	background: #fff;
	box-sizing: border-box;
}

.privacy-wrap {
	padding: 14px;
}

.agree-input {
	text-align: center;
	padding: 25px 0 0;
}

.contact_form__table input,
.contact_form__table textarea {
	max-width: 100%;
	border: 1px solid #bbb;
	padding: 5px;
	box-sizing: border-box;
}

	@media screen and (min-width: 769px) {	
		.contact_form__table {
		  width: 100%;
		  border-top: 1px solid #ddd;
		  margin: 0 auto 30px;
		}
		
		.contact_form__table th {
		  font-size: 14px;
		  text-align: left;
		  vertical-align: top;
		  padding: 25px 20px 25px 0;
		  overflow: hidden;
		  border-bottom: 1px solid #ddd;
		  width: 25%;
		  white-space: nowrap;
		  position: relative;
		}

		.required {
			font-weight: normal;
		  font-size: 12px;
		  color: #fff;
		  background: #cc0000;
		  line-height: 1;
		  margin: 0 0 0 10px;
		  padding: 5px;
		  letter-spacing: .05em;
		}
		
		.contact_form__table th .required {
		  position: absolute;
		  top: 25px;
		  right: 20px;
		}

		.contact_form__table td {
		  padding: 25px 0;
		  border-bottom: 1px solid #ddd;
		  font-size: 14px;
		}
		
		.contact_form__table td label {
			margin: 0 15px 0 0;
		}
		
		.contact_form__table td textarea {
			height: 185px;
		}
		
		.contact_form__table td input,
		.contact_form__table td textarea {
			width: 95%;
		  font-size: 14px;
		}
		
		.contact_form__table td #company,
		.contact_form__table td #name,
		.contact_form__table td #tel {
			width: 50%;
		}
		
		.contact_form__table td .row1 {
			margin: 0 0 10px;
		}
		
		.contact_form__table td .error {
		  color: #cc0000;
		}
		
		.contact_form__table td span.note {
			font-size: 13px;
		}
		
		.contact_form__table td #zip1, #contact-form td #zip2 {
		  margin: 0 0 8px;
		}
		
		.contact_submit {
		  margin: 0 0 50px;
		}
		
		.contact_submit input {
		  width: 215px;
		  height: 60px;
		  cursor: pointer;
			margin: 0 7px;
		}

		.contact_submit input[name="submitConfirm"] {
			width: 450px;
			background-image: url(../images/contact/btn_confirm.png);
		}

		.contact_submit input[name="submitBack"] {
			background-image: url(../images/contact/btn_back.png);
		}

		.contact_submit input[name="submit"] {
			background-image: url(../images/contact/btn_submit.png);
		}
		
		.contact_agree {
			padding: 20px 0;
		}
		
		.contact_agree .privacybox {
			height: 160px;
			overflow-y: scroll;
			border: 1px solid #dddddd;
			padding: 20px;
			margin: 26px 0 30px;
		}
		
		.contact_agree .checkwrap {
			text-align: center;
			margin: 0 0 10px;
		}
	}
	@media screen and (max-width: 768px) {
		.contact_form__table {
			margin: 0 0 20px;
			padding: 10px 0 0;
			line-height: 1.5em;
		}
		
		.contact_form__table,
		.contact_form__table tbody,
		.contact_form__table tr,
		.contact_form__table th,
		.contact_form__table td {
			display: block;
			text-align: left;
			font-weight: normal;
		}
		
		.contact_form__table td {
			margin: 0 0 15px;
		}
		
		.contact_form__table input,
		.contact_form__table textarea {
			margin: 3px 0;
			font-size: 16px;
		}
		input[type="submit"] {
			margin: 0 10px 0 0;
		}
		
		.required,
		.contact_form__table .error {
			color: red;
		}
		
		.contact_form__table label {
			display: block;
		}

		.mw_wp_form .contact_form__table .horizontal-item + .horizontal-item {
			display: block;
			margin: 0;
		}
		
		.page_guide {
			margin: 20px 0;
		}
		
		.contact_agree {
			padding: 0 0 20px;
		}
		
		.contact_agree .privacybox {
			height: 140px;
			overflow-y: scroll;
			border: 1px solid #dddddd;
			padding: 10px;
			margin: 26px 0 10px;
		}

		.privacy-box {
			width: 100%;
			height: 150px;
		}

		.contact_submit input {
		  width: 110px;
		  height: 42px;
			margin: 0 5px;
			background-size: contain;
		}

		.contact_submit input[name="submitConfirm"] {
			width: 225px;
			background-image: url(../images/contact/btn_confirm_sp.png);
		}

		.contact_submit input[name="submitBack"] {
			background-image: url(../images/contact/btn_back_sp.png);
		}

		.contact_submit input[name="submit"] {
			background-image: url(../images/contact/btn_submit_sp.png);
		}
	}
