@charset "utf-8";

/* firefoxでページ移動の際、コンテンツが少なくても中心がずれないようにする */
html {
	overflow-y: scroll;
}
body,
div,
p,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
blockquote,
pre,
form,
input,
textarea,
header,
footer,
nav {
	margin: 0;
	padding: 0;
	zoom: 1;
	color : #000000;
	-webkit-text-size-adjust: 100%;
	font-family: 'Noto Sans JP', sans-serif;
}

ul,
ol {
	list-style-type: none;
}

img {
	border: none;
}

hr {
	display: none;
	margin: 0;
	padding: 0;
	width: 1px;
	height: 1px;
}

a {
	outline: none;
	text-decoration: none;
}
a.televe {
    pointer-events: none;
}
@media only screen and (max-width: 480px) {
	a.televe {
		pointer-events: auto;
	}
}
a.group1 {
	transition: 0.4s;
}
a.group1:hover {
	opacity : 0.7;
}

body {
	line-height: 1.6;
	color: #000000;
	font-style: normal;
	font-weight: normal;
	background-color: #ffffff;
}

#container {
	width: 100%;
	background-color: #ffffff;
	overflow: hidden;
}

@media only screen and (max-width: 400px) {
	#container {
		overflow: hidden;
	}
}

#nonimages,
#opnimages {
	position: absolute;
	top: -1000px;
	left: -1000px;
}

#nonimages div {
	display: none;
}

#nonimages div img {
	display: none;
}

#opnimages div {
	display: none;
}

#opnimages div img {
	display: none;
}

/* -------------------------------------------------------------------
 clearfix
------------------------------------------------------------------- */

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

.clearfix:after {
	clear: both;
}

/* For IE 6/7 */
.clearfix {
	zoom: 1;
}

#wrapper {
	height: 883px;
	overflow: hidden;
	position: relative;
	z-index: 10;
	margin-top: 100px;
}

#wrapHeaderTop {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 90;
	height: 70px;
	transition: all .3s;
	background-color : #ffffff;
}
.headMenuInner {
	width : 100%;
}
#wrapHeaderTop .headLogo {
	display: inline-block;
	position: relative;
	text-align: left;
	margin: 0;
	padding: 15px 0 0 40px;
	line-height : 1;
	z-index: 12;
	transition: 0.3s;
}
.headLogo img {
	width: 184px;
}
.headLogo strong {
	display: inline-block;
	vertical-align: middle;
	font-size: 20px;
	color: #1d208a;
	position: relative;
	top: -10px;
	left: 20px;
}
.admin_headMenuInner {
	width: 100%;
	max-width: 990px;
	margin: 0 auto;
	position: relative;
}
#wrapHeaderTop #header {
	display: block;
	position: relative;
	width: 100%;
	top: 0px;
	max-width: 1980px;
	margin: 0 auto;
	height: 100px;
	z-index: 10;
	transition: all .3s;
}
#wrapHeaderTop .wrk_topbg {
	background-color : rgba(0, 0, 0, 1);
}
#smp_header {
	display: none;
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 78px;
	text-align: right;
	padding-top: 6px;
	background-color: #ffffff;
	z-index: 10;
}

.headMenu {
	display: inline-block;
	position: absolute;
	height : 70px;
	top: 0px;
	right: 0px;
	z-index: 9;
}

.headMenu li {
	display: inline-block;
	vertical-align: top;
	color: #000000;
	font-size: 16px;
}
.headMenu .main li a {
	color: #000000;
	font-size: 16px;
	font-weight: 700;
	text-decoration: none;
	display: inline-block;
	vertical-align: top;
	line-height: 70px;
	padding: 0 20px;
	position: relative;
	transition: .3s;
}
.headMenu .main li.last {
	color: #ffffff;
	background-color : #000000;
	margin-left : 20px;
}
.headMenu .main li.last a {
	color: #ffffff;
	padding: 0 40px;
}

.headMenu .main li span {
	display: inline-block;
	vertical-align: top;
	color: #b8b8b8;
	font-size: 24px;
	line-height: 1.0;
	padding: 0 12px;
	position: relative;
	top: -6px;
}

.headMenu .main li a::after {
	position: absolute;
	bottom: 10px;
	left: 50%;
	content: '';
	width: 0;
	height: 2px;
	background-color: #44ac67;
	transition: .3s;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}
.headMenu li a:hover {
	color : #e1e1e1;
}
.headMenu li a:hover::after {
	width: 60%;
}

.headInqu {
	display: inline-block;
	position: absolute;
	top: 0px;
	right: 0px;
	z-index: 9;
	width: 200px;
	height: 100px;
}

.headInqu a {
	display: block;
	text-align: center;
	width: 100%;
	height: 64px;
	padding: 36px 0 0 18px;
	font-size: 16px;
	color: #ffffff;
	text-decoration: none;
	background: #000000 url(../img/mail_mark.png) no-repeat center left 30px;
	transition: .5s;
}

.headInqu a:hover {
	background-color: #757575;
}

.headTel {
	display: block;
	position: absolute;
	top: 32px;
	right: 200px;
	z-index: 9;
	width: 174px;
	text-align: center;
}

.headTel a {
	display: inline-block;
	margin: 0 14px;
}

.headTel span {
	display: inline-block;
	text-align: left;
	width: calc(100% - 40px);
	height: 32px;
	line-height: 1.0;
	padding-top: 5px;
	padding-left: 40px;
	font-weight: 500;
	font-size: 24px;
	color: #010101;
	text-decoration: none;
	background: url(../img/tel_mark.png) no-repeat left top 3px;
	transition: .5s;
	vertical-align: top;
}

.smp_headBtn {
	display: block;
	position: absolute;
	top: 0px;
	right: 0px;
	z-index: 10;
	background-color: #ffffff;
	width: 100%;
	height: 51px;
	padding-top: 4px
}

.smp_headMenu {
	display: block;
	width: 100%;
	position: absolute;
	top: -600px;
	right: 0px;
	text-align: left;
	z-index: 9;
	background-color: #ffffff;
	transition: .5s;
}

.smp_headMenu li {
	display: block;
	border-bottom: 1px solid #c1c1c1;
}

.smp_headMenu li a.main {
	color: #464646;
	font-size: 14px;
	font-weight: bold;
	text-decoration: none;
	display: block;
	line-height: 1.0;
	padding: 14px 0 12px 8px;
	position: relative;
	transition: .3s;
}

.smp_headMenu li a.main strong {
	display: inline-block;
	width: 130px;
	vertical-align: middle;
}

.smp_headMenu li a.main span {
	display: inline-block;
	color: #979797;
	font-size: 13px;
	font-weight: normal;
	text-align: left;
	margin-left: 30px;
	vertical-align: middle;
}

.subMenu {
	position: absolute;
	top: -200px;
	right: 80px;
	padding: 10px 16px;
	background-color: #ffffff;
	font-weight: bold;
	border: 2px solid #c1c1c1;
	z-index: 9;
	transition: all 0.3s;
}

.subMenu dl {
	display: inline-block;
	vertical-align: top;
	margin: 0 20px;
	line-height: 1.6;
}

.subMenu dt {
	padding-top: 6px;
}

.subMenu dt a {
	font-size: 14px;
	color: #646464;
	text-decoration: none;
	transition: all 0.2s;
}

.subMenu dd a {
	font-size: 13px;
	color: #868686;
	text-decoration: none;
	transition: all 0.2s;
}

.subMenu dt a:hover {
	color: #000000;
}

.subMenu dd a:hover {
	color: #3f3f3f;
}

.smp_subMenu {
	display: none;
	padding-bottom: 10px;
	transition: all .3s;
}

.openMenuArea {
	transition: all .3s;
}

.ttlimgWrap {
	text-align: center;
}

.ttlimgWrap img {
	width: 100%;
	max-width: 1678px;
}

.smp_subMenu a {
	color: #646464;
	font-size: 13px;
	font-weight: bold;
	text-decoration: none;
	display: block;
	line-height: 1.0;
	padding: 7px 0 7px 20px;
}

/*
.smp_headline .menu-trigger {
	display: block;
	position: absolute;
	top: 12px;
	left: 20px;
	width: 22px;
	height: 20px;
	transition: all .4s;
}
*/
.smp_headline .menu-trigger {
	display: block;
	position: absolute;
	top: 16px;
	left: 15px;
	width: 30px;
	height: 26px;
	transition: all .4s;
}


.smp_headline .menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #ffffff;
	transition: all .4s;
}

.smp_headline .menu-trigger span:nth-of-type(1) {
	top: 0;
}
/*
.smp_headline .menu-trigger span:nth-of-type(2) {
	top: 8px;
}
*/
.smp_headline .menu-trigger span:nth-of-type(2) {
	top: 11px;
}

.smp_headline .menu-trigger span:nth-of-type(3) {
	bottom: 0;
}
/*
.menu-trigger.is-open span:nth-of-type(1) {
	width: 48%;
	-webkit-transform: translate3d(1px, 4px, 0) rotate(45deg);
	transform: translate3d(1px, 4px, 0) rotate(45deg);
}
*/
.menu-trigger.is-open span:nth-of-type(1) {
	width: 48%;
	-webkit-transform: translate3d(1px, 5.5px, 0) rotate(45deg);
	transform: translate3d(1px, 5.5px, 0) rotate(45deg);
}
.menu-trigger.is-open span:nth-of-type(2) {
	-webkit-transform: translate3d(-1px, 0, 0) rotate(-45deg);
	transform: translate3d(-1px, 0, 0) rotate(-45deg);
}
/*
.menu-trigger.is-open span:nth-of-type(3) {
	width: 47%;
	-webkit-transform: translate3d(9px, -4px, 0) rotate(45deg);
	transform: translate3d(9px, -4px, 0) rotate(45deg);
}
*/
.menu-trigger.is-open span:nth-of-type(3) {
	width: 47%;
	-webkit-transform: translate3d(12px, -5px, 0) rotate(45deg);
	transform: translate3d(12px, -px, 0) rotate(45deg);
}
.headScroll {
	position : absolute;
	bottom : 30px;
	left : 12%;;
	width : 40px;
	text-align : center;
}
.headScroll .scrollDown {
	display: flex;
	align-items: center;
	width : 100%;
	font-size : 1rem;
	letter-spacing: 2px;
	color : #ffffff;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-weight : 700;
	text-align : center;
	opacity : 1;
	cursor : pointer;
	font-family: 'Oswald', sans-serif;
}
.headScroll .scrollArrow {
	display ; block;
	margin : 10px auto;
	width : 2px;
	height : 180px;
	overflow : hidden;
}
.headScroll .scrollArrowInner {
	display ; inline-block;
	width : 2px;
	height : 150px;
	background-color : #ffffff;
	animation: arrowMove 2s infinite linear;
	transform: translate(0, -100px);
}
.headScroll .scrollArrowInner.active {
	animation: arrowMoveUp 2s infinite linear;
	transform: translate(0, 100px);
}
@keyframes arrowMove {
	to {
		  transform: translate(0, 100px);
	}
}
@keyframes arrowMoveUp {
	to {
		  transform: translate(0, -100px);
	}
}
@media only screen and (max-width: 720px) {
	.headScroll {
		bottom : 0;
		left : 5%;
	}
	.headScroll .scrollArrow {
		height : 100px;
	}
}
.cp_overLeft {
	position: fixed;
	top: 50%;
	left: 0;
	z-index: 20;
}
.smplink {
	display :  none;
}
@media only screen and (max-width: 1200px) {
	#wrapHeaderTop .headLogo {
		padding: 15px 0 0 2vw;
	}
	.headMenu .main li a {
		padding: 0 1vw;
		font-size : 14px;
	}
	.headMenu .main li.last {
		margin-left : 1vw;
	}
	.headMenu .main li.last a {
		padding: 0 2vw;
	}
}
@media only screen and (max-width: 960px) {
	#wrapHeaderTop .headLogo {
		padding: 12px 0 0 20px;
	}
	#smp_header {
		display: block;
	}
	.headMenu {
		display: none;
	}
	.headTel {
		display: none;
	}
	.headInqu {
		display: none;
	}
	.smplink {
		display : block;
	}
}

.snsButtons {
	display: block;
}

.topimages {
	width: 100%;
	max-width: 1980px;
}

.slide_all {
	margin: 0 auto;
	position: relative;
	width: 100%;
}

.slide_wrap {
	left: 50%;
	margin-left: -1800px;
	position: absolute;
	width: 3600px;
}

.noslide {
	width: 100%;
	max-width: 1200px;
	position: relative;
	margin: 0 auto;
}

.noslide img {
	width: 100%;
	max-width: 1200px;
}

#prev,
#next {
	display: block;
	height: 753px;
	position: absolute;
	top: 0px;
	width: 50%;
	z-index: 9999;
}

#prev {
	left: -600px;
}

#next {
	right: -600px;
}

#access {
	margin-top: -130px;
	padding-top: 130px;
}

#template {
	margin-top: -130px;
	padding-top: 130px;
}

#submit {
	margin-top: -130px;
	padding-top: 130px;
}

.submenu {
	background-color: #fff949;
	text-align: right;
	padding: 7px 0 16px 0;
}

.submenu h2 {
	text-align: center;
	color: #000000;
	margin: 20px 0;
	letter-spacing: 3px;
}

.submenu a {
	display: inline-block;
	padding: 0 8px 0 16px;
	background: url(../img/arrow.png) no-repeat left center;
	color: #303030;
	font-size: 12px;
	text-decoration: none;
}

.submenu a:hover {
	color: #000000;
	text-decoration: underline;
}

.pankuzu {
	font-size: 13px;
	color: #494949;
	padding: 6px 0 12px 4px;
	width: 100%;
	max-width: 1343px;
	margin: 0 auto;
	position: relative;
}

#wrapGlobalMenu {
	width: 100%;
	margin-bottom: 16px;
	margin-top: -17px;
	overflow: hidden;
	background-color: #4c4109;
	position: relative;
	z-index: 999;
}

#wrapTopMenu {
	width: 1183px;
	position: relative;
	margin: 0 auto;
}

.headMenu td a.bdnone {
	padding-left: 3px;
}

.smp_headbtn {
	display: none;
	text-align: center;
	width: 100%;
	position: absolute;
	left: 0;
	bottom: 6.5vw;
}

.smp_headbtn a img {
	width: 50%;
	min-width: 160px;
}

.pc_headbtn {
	display: block;
	position: absolute;
	left: 50%;
	margin-left: -70px;
	bottom: 20px;
}

.wrapContents {
	width: 100%;
	position: relative;
	padding-top: 140px;
}

#p_points {
	display: block;
}

#s_points {
	display: none;
}

.pc_headline {
	display: inline;
}

.smp_headline {
	display: none;
}

.smp_centerbtn {
	display: none;
}

.pc_topimg {
	display: inline;
}

.smp_topimg {
	display: none;
}

.smp_headTel {
	display: inline-block;
	width: 49%;
	padding: 14px 0;
	text-align: center;
}

.smp_headTel a {
	font-size: 16px;
	color: #010101;
	text-decoration: none;
	font-weight: 500;
}

.smp_headTel a img {
	position: relative;
	height: 20px;
	margin-right: 8px;
	top: 4px;
}

.smp_headInqu {
	display: inline-block;
	width: 49%;
	padding: 14px 0;
	text-align: center;
}

.smp_headInqu a {
	font-size: 14px;
	color: #010101;
	text-decoration: none;
}

.smp_headInqu a img {
	position: relative;
	height: 16px;
	margin-right: 8px;
	top: 2px;
}

@media only screen and (max-width: 1200px) {
	.slide_wrap {
		left: 0;
		margin-left: 0;
		position: absolute;
		width: 100%;
	}
}
.smp_headSns  {
	text-align : center;
	padding : 6px 0;
}
.smp_headSns a {
	display : inline-block;
	margin : 0 16px;
}
@media only screen and (max-width: 960px) {
	.slide img {
		width: 100%;
		height: 60vw;
		object-fit: cover;
	}
	.pc_headline {
		display: none;
	}
	.pc_topimg {
		display: none;
	}
	.smp_topimg {
		display: inline;
	}
	.smp_headline {
		display: block;
		position: fixed;
		width: 100%;
		max-width: 100vw;
		height: 60px;
		top: 0;
		left: 0;
		box-sizing: border-box;
		transition: .5s;
	}
	.smp_menu {
		position: absolute;
		top: 0;
		right: 0;
		width: 60px;
		height: 60px;
		text-align: center;
		background-color : #000000;
	}
	.smp_menu p {
		display: block;
		position: absolute;
		top: 34px;
		left: 0;
		width: 60px;
		text-align: center;
		color: #ffffff;
		font-weight: 300;
		font-size: 12px;
	}
	.smp_headline .innerSmpTels h3 {
		margin-bottom: 8px;
	}
	.innerSmpTels {
		position: absolute;
		width: 100%;
		top: -480px;
		left: 0;
		z-index: 99;
		margin-bottom: 6px;
		background-color: rgba(255, 255, 255, 0.9);
		transition: .5s;
	}
	.innerSmpTels li a {
		text-decoration: none;
		font-size: 14px;
		color: #010101;
		display: block;
		width: calc(100% - 12px);
		padding: 12px 0 12px 12px;
		text-align: left;
		border-bottom: 1px solid #c6c6c6;
	}
	.smp_headbtn {
		display: block;
	}
	.pc_headbtn {
		display: none;
	}
	.smp_centerbtn {
		display: block;
		text-align: center;
		margin-top: 36px;
	}
	.smp_centerbtn img {
		width: 60%;
		max-width: 386px;
	}
	#wrapHeaderTop {
		height: 60px;
	}
	#wrapHeaderTop #header {
		height: 60px;
	}
	.headLogo img {
		width : 180px;
	}
	.headMenuInner {
		z-index: 100;
		height: 60px;
	}
	.wrapContents {
		padding-top: 60px;
	}
}

@media only screen and (max-width: 600px) {
	#p_points {
		display: none;
	}

	#s_points {
		display: block;
	}
}

@media only screen and (max-width: 500px) {
	.bx-controls {
		display: none;
	}

	.headLogo strong {
		margin-bottom: 1px;
	}
}

@media only screen and (max-width: 400px) {
	.headLogo {
		top: 6px;
	}

	.slide img {
		width: 100%;
		height: 63vw;
	}
}

@media only screen and (max-width: 340px) {
	.sml320 {
		height: 22px;
	}
	.headLogo {
		left: -4px;
	}
}


/* トップページコンテンツ */

.topImg  {
	width : 100%;
	height : calc(70vw + 100px);
	max-height : 881px;
	margin : 70px auto 0 auto;
	overflow : hidden;
	position : relative;
}
.topImgShadow {
	position : absolute;
	top : 0;
	right : 0;
	width : 50%;
	height : 100%;
	background : linear-gradient(90deg, rgb(0, 0, 0, 0), rgb(0, 0, 0, 0.8));
}
.pos-rel {
	position : relative;
	background-color : #c4b266;
}
.slide_all {
	width : 100%;
	height : calc(70vw + 100px);
	max-height : 881px;
	margin : 0 auto;
}
.no_slide {
	width : 100%;
	height : calc(70vw + 100px);
	max-height : 881px;
	margin : 0 auto;
}
.pict {
	width : 100%;
	height : calc(70vw + 100px);
	max-height : 881px;
	margin : 0 auto;
	position : absolute;
	top : 0;
	left : 0;
}
.slide_all img {
	width : 100%;
	height : 100%;
	object-fit : cover;
	object-position: left bottom;
}
.overWrap  {
	position : absolute;
	top : 14%;
	left : 54%;
	width : 46%;
	height : 100%;
	max-height : 700px;
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : center;
	justify-content : center;
	background : url(../img/over_img.png) no-repeat left bottom;
}
.overWrap .overText {
	font-size : 24px;
	color : #ffffff;
	font-weight : 500;
	padding-right : 80px;
	line-height : 2.0;
	text-align : left;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}
.overWrap .overText strong {
	font-size : 40px;
	font-weight : 500;
}
@media only screen and (max-width: 1800px) {
	.overWrap .overText {
		padding-right : 4vw;
	}
}
@media only screen and (max-width: 1600px) {
	.overWrap  {
		background-size : 100%;
		height : 65vw;
	}
	.overWrap .overText {
		padding-right : 0vw;
		padding-left : 8vw;
	}
}
@media only screen and (max-width: 1200px) {
	.overWrap  {
		background-size : 100%;
		height : calc(65vw + 30px);
		top : 10%;
	}
	.overWrap .overText {
		padding-right : 4vw;
	}
	.overWrap .overText {
		font-size : calc(1.25vw + 9.0px);
	}
	.overWrap .overText strong {
		font-size : calc(2.27vw + 12.8px);
	}
}
@media only screen and (max-width: 960px) {
	.topImg  {
		margin-top : 60px;
	}
}
@media only screen and (max-width: 640px) {
	.topImg  {
		height : calc(80vw + 100px);
	}
	.slide_all {
		height : calc(80vw + 100px);
	}
	.no_slide {
		height : calc(80vw + 100px);
	}
	.pict {
		height : calc(80vw + 100px);
	}
	.overWrap  {
		height : calc(65vw + 100px);
	}
}
.bottomScroll {
	position : absolute;
	bottom : 0;
	left: calc(50% - 25px);
	transition: 0.7s;
}
.bottomScroll.hide {
	bottom : -80px;
	transition: 0.7s;
}
.bottomScroll img {
	width : 50px;
}
.boxTitle {
	display : inline-block;
	text-align: center;
	position: relative;
	border: solid 3px black;
	background-color: #fff;
	padding : 10px 36px;
}
.boxTitle::before,
.boxTitle::after {
	position: absolute;
	content: "";
	display: block;
	background-color: #fff;
}
.boxTitle::before {
	top: -3px;
	bottom: -3px;
	left: 20px;
	right: 20px;
}
.boxTitle::after {
	top: 20px;
	bottom: 20px;
	left: -3px;
	right: -3px;
}
.boxTitle span {
	position: relative;
	z-index: 1;
	font-weight : 400;
}
.boxTitle strong {
	display : block;
	color : #b9b9b9;
	font-size : 14px;
	letter-spacing: 1px;
	position: relative;
	z-index: 1;
	font-weight : 500;
	top : 6px;
	font-family: 'Oswald', sans-serif;
}
.normalTitle {
	display : inline-block;
	text-align: center;
	position: relative;
}
.normalTitle span {
	position: relative;
	z-index: 1;
	font-weight : 400;
}
.normalTitle strong {
	display : block;
	color : #b9b9b9;
	font-size : 14px;
	letter-spacing: 1px;
	position: relative;
	z-index: 1;
	font-weight : 500;
	top : 6px;
	font-family: 'Oswald', sans-serif;
}
.mainTitle {
	display : block;
	text-align: center;
	position: relative;
	background-color : #000000;
	width : 78%;
	max-width : 488px;
	padding : 16px 0 28px 0;
}
.mainTitle span {
	position: relative;
	z-index: 1;
	font-weight : 300;
	color : #ffffff;
}
.mainTitle strong {
	display : block;
	color : #b9b9b9;
	font-size : 14px;
	letter-spacing: 1px;
	position: relative;
	z-index: 1;
	font-weight : 500;
	top : 6px;
	font-family: 'Oswald', sans-serif;
}
@media only screen and (max-width: 1400px) {
	.overWrap .overLeft {
		left : -40px;
	}
}
@media only screen and (max-width: 1200px) {

}
@media only screen and (max-width: 800px) {
	.overWrap .overLeft {
		left : -80px;
	}
	.mainTitle {
		display : block;
		text-align: center;
		position: relative;
		background-color : #000000;
		width : 78%;
		max-width : 488px;
		padding : calc(1vw + 6px) 0 calc(2vw + 8px) 0;
	}
}
@media only screen and (max-width: 480px) {
	.boxTitle::before {
		left: 15px;
		right: 15px;
	}
	.boxTitle::after {
		top: 15px;
		bottom: 15px;
	}
}
.top_container {
	position: absolute;
	font-size: 10px;
	color: #000000;
	padding: 0;
	top: 0px;
	right: 0px;
}


/*　ナビ包括-----------------------------*/
/* グローバルナビゲーション */
.panWrap  {
	width : 100%;
	max-width : 1200px;
	margin : 0 auto;
	overflow : hidden;
	box-sizing: border-box;
	position : relative;
	padding : 10px 10px 0 10px;
}
.panWrap li {
	display: inline-block;
	margin-right : 7px;
	font-size : 14px;
	color : #4b4b4b;
	font-weight : 500;
}
.panWrap li a {
	display: inline-block;
	color : #4b4b4b;
	transition: 0.3s;
}
.panWrap li:first-child a {
	padding-left : 30px;
	background : url(../img/home.png) no-repeat center left;
}
.panWrap li a:hover {
	opacity : 0.6;
}
@media only screen and (max-width: 1340px) {
	.panWrap  {
		padding : 10px 0 0 10px;
	}
}

/* コンテンツ包括
---------------------------------------------------------------------- */
.pcNavi {
	display: block;
}

.smpNavi {
	display: none;
}

.smp_mgb80 {
	margin-bottom: 0;
}

.top_images {
	position: relative;
}

.top_images p {
	position: absolute;
	top: 126px;
	left: 422px;
}

#news,
#commit,
#info {
	padding-top: 64px;
	margin-top: -64px;
}

/* メインコンテンツ包括---------------------------*/

.grayback {
	background-color : #f2f2f2;
}
.top_images {
	width: 100%;
	position: relative;
	z-index: 2;
	text-align: center;
	background: url(../img/top_image.jpg) repeat-x top center;
	max-height: 576px;
	font-size: 0;
	line-height: 0;
}

.aboutWrap p {
	color : #000000;
	line-height : 2.4;
	font-weight : 400;
}

@media only screen and (max-width: 1080px) {
	.aboutWrap p {
		font-size : calc(0.53vw + 12.3px);
		line-height : 2.0;
	}
}
@media only screen and (max-width: 640px) {
	.aboutWrap p {
		text-align : left !important;
	}
}

@media only screen and (max-width: 400px) {
	.aboutWrap p {
		line-height : 1.8;
		letter-spacing: 0px;
	}
}


.newsWrapOuter {
	background : url(../img/haikei3.jpg) no-repeat 0 0;
	height : 481px;
}
.reverceTitle {
	text-align : center;
	font-family : 'Yu Mincho', 'YuMincho', 'メイリオ', 'Meiryo', serif;
	font-size : 36px;
	font-weight : 500;
	letter-spacing: 2px;
	color : #ffffff;
	line-height : 1.4;
	height : 102px;
	padding-top : 38px;
}
.reverceTitle.t_news {
	background : url(../img/news_ttl.png) no-repeat center top;
}
.reverceTitle.e_profile {
	background : url(../img/profile_ttl.png) no-repeat center top;
	position : relative;
	left : 24px;
}
.reverceTitle.e_recruit {
	background : url(../img/recruit_ttl.png) no-repeat center top;
}
.contactTitle {
	text-align : center;
	font-family : 'Yu Mincho', 'YuMincho', 'メイリオ', 'Meiryo', serif;
	font-size : 36px;
	font-weight : 500;
	letter-spacing: 2px;
	color : #707070;
	line-height : 1.4;
	height : 82px;
	padding-top : 38px;
	background : url(../img/contact_ttl.png) no-repeat center top;
}
.contactTitle.e_essential {
	background : url(../img/essential_ttl.png) no-repeat center top;
}

.newsWrap {
	width : 100%;
	max-width : 920px;
}
.newsFlex {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
	width : 100%;
	margin : 0 auto;
}
.newsRight {
	width : 20%;
	max-width : 300px;
}
.newsRight h3 {
	font-weight : 400;
	color : #ffffff;
	position : relative;
	background-color : #000000;
	line-height : 42px;
	padding-bottom : 2px;
	width : 100%;
	text-align : center;
}
.newsRight a {
	font-weight : 700;
	color : #000000;
	line-height : 2.4;
	transition: 0.3s;
}
.newsRight a:hover {
	color : #009ac0;
}
.newsRight a span {
	font-weight : 300;
}
.selecter {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : center;
	justify-content : center;
}
.selecter a {
	display : block;
	line-height : 2.0;
	font-size : 16px;
	color : #0b152b;
	background-color : #ffffff;
	border : 2px solid #0b152b;
	padding : 0 24px;
	margin : 0 10px;
}
.selecter a.active {
	color : #ffffff;
	background-color : #0b152b;
}
.newsType em {
	font-style : normal;
}
.newsItem {
	border-bottom : 1px dotted #d2d2d2;
	position : relative;
	padding-right : 40px;
	box-sizing: border-box;
}
.newsItem::after {
	content : ">";
	position : absolute;
	top : 30%;
	right : 0;
	font-size : 32px;
	color : #878787;
	font-family: Oswald;
}
.newsItem .image {
	width : 30%;
}
.newsItem .image img {
	width : 100%;
	height : 14vw;
	max-height : 168px;
}
.newsItem .text {
	width : 65%;
	padding-left : 5%;
}
.newsItem p {
	color : #000000;
	font-weight : 400;
	line-height : 1.6;
	text-align : left;
	margin-right : 20px;
	height : 40px;
	overflow : hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.date span {
	display : inline-block;
	color : #ffffff;
	line-height : 40px;
	width : 184px;
	text-align : center;
}
.date span.col01 {
	background-color : #cbb356;
}
.date span.col02 {
	background-color : #567ecb;
}
.newsTab {
	text-align : left;
	padding-left : 44px;
}
.newsTab a {
	display : inline-block;
	background-color : #000000;
	color : #ffffff;
	font-size : 1.1rem;
	text-align : center;
	padding : 20px 0;
	border-radius : 10px 10px 0 0;
	width : 236px;
	margin-right : 10px;
	position : relative;
}
.newsTab a#tab00 {
	width : 146px;
}
.newsTab a.active::after {
	content : "";
	position : absolute;
	bottom : 14px;
	left : calc(50% - 25px);
	width : 50px;
	height : 3px;
	background-color : #ffffff;
	font-size : 0;
}
.topNewsInner {
	border : 1px solid #000000;
	padding : 30px 30px 30px 43px;
}
.topNewsItem {
	width : 49%;
	position : relative;
	box-sizing: border-box;
}
.topNewsItem .image {
	width : 35%;
}
.topNewsItem .image img {
	width : 100%;
	height : 12vw;
	max-height : 136px;
}
.topNewsItem .text {
	width : 62%;
	padding-left : 3%;
}
.topNewsItem p {
	color : #000000;
	font-weight : 400;
	line-height : 1.6;
	text-align : left;
	margin-right : 20px;
}
.topNewsItem p.title {
	height : 40px;
	overflow : hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.topNewsItem .date span {
	width : 154px;
	line-height : 30px;
}
.newsParts {
	display : -webkit-flex;
	display : flex;
}
.newsParts .date {
	color : #000000;
	font-weight : 400;
	line-height : 1.6;
	text-align : left;
}
.newsParts .cate {
	font-size : 14px;
	color : #ffffff;
	background-color : #00a0c8;
	padding : 0 10px;
	line-height : 1.8;
}
.newsListWrap h2 {
	border-bottom : 1px solid #dcdcdc;
	padding : 10px 0 10px 0;
	line-height : 1.8;
}
.newsListWrap .photo img {
	width : 100%;
}
.newsListWrap .detailComm {
	color : #000000;
	font-weight : 400;
	line-height : 1.8;
	text-align : left;
}
#newsmenuTab {
	display : none;
}
.addArrow_w {
	color : #000000;
	font-weight : 700;
	display : inline-block;
	padding-left : 60px;
	line-height : 130px;
	background-color : #ffffff;
	border : 1px solid #000000;
	width : 60%;
	max-width : 450px;
	text-align : left;
	position : relative;
	transition: 0.4s;
}
.addArrow_w.small {
	padding-left : 40px;
	line-height : 100px;
	width : 60%;
	max-width : 400px;
}
.addArrow_w::after {
	content : "→";
	position : absolute;
	top : 0%;
	right : 5%;
	color : #000000;
	font-weight : 500;
	font-size : 24px;
	transition: 0.4s;
}
.addArrow_w:hover {
	background-color : #dcdcdc;
}
.addArrow_w:hover::after {
	right : 4%;
}
.photoWrap {
	width : 100%;
}
.photoMain {
	position : relative;
}
.photoMain img {
	width : 100%;
	max-width : 920px;
	height : 64vw;
	max-height : 640px;
	object-fit: contain;
}
.photoThumb {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : center;
	justify-content : center;
    list-style: none;
}
.photoThumb li {
	width : 16%;
	margin-bottom : 10px;
}
.photoThumb li.thumbTrans {
	width : 16%;
	height : 1px;
	font-size : 0;
}
.photoThumb img {
	width : 100%;
	max-width : 96px;
	height : 6vw;
	max-height : 68px;
	object-fit: cover;
}
.photoThumb > li {
    width: 12%;
}
.photoThumb > li > a {
    display: block;
    position: relative;
    padding-top: 75%;
	opacity : 0.7;
	transition: 0.3s;
}
.photoThumb > li > a.active {
    opacity : 1.0;
}
.photoThumb > li > a > img {
    position: absolute;
    top: 0px;
    left: 0;
    width: 100%;
	height : 8vw;
	max-height : 75px;
	object-fit: cover;
}
.photoThumb > li > a > span {
    position: absolute;
    top: 0px;
    left: 0;
    width: 100%;
	height : 15vw;
	max-height : 120px;
	display : block;
	background-repeat : no-repeat;
	background-position : center center;
	background-size : cover;
}
.bx-wrapper {
    background-color: transparent;
    margin: 0px auto 20px auto !important;
    border: none;
    box-shadow: none;
}
.bx-wrapper img {
    display: block;
    width: 100%;
}
@media only screen and (max-width: 1400px) {
	.newsWrap {
		width : 68%;
		max-width : 920px;
	}
	.newsRight {
		width : 25%;
		max-width : 300px;
	}
}
@media only screen and (max-width: 960px) {
	.newsWrapOuter .normalWrap {
		padding : 0 10vw;
	}
	.newsWrap .imageTitle img {
		width : 50%;
		max-width : 269px;
	}
	.normalTitle {
		font-size : 28px;
		height : 92px;
		padding-top : 30px;
	}
	.reverceTitle {
		font-size : 28px;
		height : 92px;
		padding-top : 30px;
	}
	.contactTitle {
		font-size : 28px;
		height : 70px;
		padding-top : 38px;
	}
	.newsRight h3 {
		font-size : calc(0.62vw + 14.0px);
		letter-spacing: 1px;
	}
	.topNewsInner {
		border : 1px solid #000000;
		padding : 3vw 3vw 3vw 4vw;
	}
}
@media only screen and (max-width: 800px) {
	.topNewsItem p.title {
		height : calc(3vw + 10px);
	}
	.newsTab {
		text-align : left;
		padding-left : 0;
	}
	.newsTab a {
		font-size : 1rem;
		padding : 2vw 0;
		width : 38vw;
		margin-right : 1vw;
	}
	.newsTab a#tab00 {
		width : 19vw;
	}
	.newsTab a#tab02 {
		width : 28vw;
	}
	.newsTab a.active::after {
		bottom: 1.4vw;
		left: calc(50% - 20px);
		width: 40px;
	}
	.newsItem {
		padding-right : 0;
	}
	.date span {
		font-size : 12px;
		line-height : 30px;
		width : 120px;
	}
}
@media only screen and (max-width: 640px) {
	.selecter a {
		font-size : calc(1.25vw + 8.0px);
		border : 1px solid #0b152b;
		padding : 0 2.4vw;
		margin : 0 1vw;
	}
	.newsWrapOuter .rtlPageTitle {
  		top: 0;
	}
	.newsWrapOuter .normalWrap {
		padding : 0 4vw;
	}
	.photoWrap {
		width : 100%;
		padding : 0 2vw 0 2vw;
		box-sizing: border-box;
	}
	.photoMain img {
		height : 64vw;
	}
	.photoThumb img {
		height : 12vw;
	}
	.topNewsItem {
		width : 100%;
	}
	.topNewsItem .image img {
		height : 20vw;
	}
	.newsFlex .newsWrap {
		width : 100%;
		padding-right : 0;
	}
	.newsFlex .newsRight {
		width : 160px;
		position : absolute;
		right : -228px;
		transition: 0.5s;
		padding : 10px 32px;
		background-color : #ffffff;
		border : 2px solid #000000;
	}
	#newsmenuTab {
		display : block;
		color : #ffffff;
		font-size : 16px;
		background-color : #000000;
		position : absolute;
		width : 24px;
		height : 30px;
		top : -2px;
		left : -36px;
		padding : 12px 4px 19px 8px;
		border-radius : 8px 0 0 8px;
	}
	.newsItem .image {
		width: 20%;
	}
	.newsItem .text {
		width: 77%;
		padding-left: 3%;
	}
	.addArrow_w {
		padding-left : 6vw;
		line-height : calc(10vw + 30px);
	}
	.newsFlex .newsRight.active {
		right : -2px;
	}
}
@media only screen and (max-width: 480px) {
	.newsWrapOuter {
		height : auto;
		padding-bottom : 12vw;
	}
	.normalTitle {
		font-size : 24px;
		height : 48px;
		padding-top : 24px;
	}
	.reverceTitle {
		font-size : 24px;
		height : 48px;
		padding-top : 24px;
	}
	.contactTitle {
		font-size : 24px;
		height : 62px;
		padding-top : 36px;
	}
	.newsItem a {
		flex-wrap : wrap;
	}
	.newsItem a .comm {
		width : 90%;
		padding-left : 0;
		margin-top : 6px;
	}
	.newsItem p {
		margin-right: 10vw;
		height: auto;
	}
	.newsListWrap .ttle.date span {
		position : absolute;
		top : -2px;
		left : calc(8vw + 80px);
	}
}

.pager {
	width: 100%;
	text-align: center;
}
.pager li {
	display: inline-block;
	font-size: 16px;
	line-height: 1.0;
	vertical-align: top;
}
.pager li span {
	display: inline-block;
	margin: 0 4px;
	width : 36px;
	height : 33px;
	line-height : 33px;
	padding-bottom : 3px;
	color: #ffffff;
	background-color : #0b162c;
	font-weight: bold;
	vertical-align: middle;
	border-radius : 50%;
}
.pager li a {
	display: inline-block;
	margin: 0 4px;
	width : 36px;
	height : 33px;
	line-height : 33px;
	padding-bottom : 3px;
	color: #0b162c;
	font-weight: bold;
	vertical-align: middle;
	transition: 0.3s;
}
.pager li em {
	display: inline-block;
	margin: 0 14px;
	color: #0b162c;
	font-style: normal;
	vertical-align: top;
}
.pager li a.gray {
	background-color : #b3b3b3;
	border : 1px solid #b3b3b3;
	font-family: 'Arsenal', sans-serif;
	font-size : 36px;
}
.pager li a:hover {
	color: #000000;
	background-color : #e4e4e4;
}

.cp_overLight {
	position: absolute;
	top: 100px;
	left: 0;
	z-index: 29;
	width : 100%;
}
.cp_overLightInner {
	width : 100%;
	max-width : 1200px;
	margin : 0 auto;
}
.cp_overLightInner h2 {
	color : #ffffff;
	font-size : 60px;
	font-weight : 900;
	padding : 36px 0 0 36px;
	line-height : 1.2;
	text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);
}
.cp_overLightInner p {
	color : #ffffff;
	font-size : 30px;
	font-weight : 400;
	padding : 0px 0 0 36px;
	text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);
}

.recruitWrap {
	width: 100%;
	position: relative;
	height: 40vw;
	max-height: 569px;
}
.recruitTable {
	width : 100%;
}
.recruitTable table {
	width : 100%;
	border-collapse: collapse;
	table-layout : fixed;
	word-wrap: break-word;
}
.recruitTable table th {
	font-size : 1rem;
	color : #4d4d4d;
	background-color : #f8f8f8;
	font-weight : 400;
	width : 25%;
	padding : 14px 24px;
	border-top : 1px solid #000000;
	border-bottom : 1px solid #000000;
	border-left : 1px solid #000000;
	text-align : left;
	
}
.recruitTable table td {
	font-size : 1rem;
	color : #000000;
	background-color : #ffffff;
	font-weight : 400;
	width : 75%;
	padding : 14px 24px;
	border-top : 1px solid #000000;
	border-bottom : 1px solid #000000;
	border-right : 1px solid #000000;
	word-wrap: break-word;
}

.recruitImg {
	position: relative;
	z-index: 1;
	width: 100%;
	height: 569px;
}

.recruitImg img {
	max-width: 1380px;
}

.rc_overLight {
	position: absolute;
	top: 0;
	left: calc(100% - 1136px);
	z-index: 2;
	width: 1136px;
	height: 569px;
	background: url(../img/rec_back01.png) no-repeat top left;
}

.rc_overDeep {
	position: absolute;
	top: 0;
	left: calc(100% - 902px);
	z-index: 3;
	width: 902px;
	height: 569px;
	background: url(../img/rec_back02.png) no-repeat top left;
}

.recruitItem {
	position: absolute;
	top: 170px;
	left: calc(100% - 988px);
	z-index: 4;
	width: 60%;
	max-width: 850px;
	min-width: 600px;
}

.recruitItem h2 {
	font-size: 48px;
	color: #454fb5;
	letter-spacing: 2px;
	margin: 0 0 30px 0;
	padding: 0 0 0 190px;
	font-family: 'Yu Mincho', YuMincho, sans-serif;
	text-shadow: 3px 3px 3px #ffffff, -3px -3px 3px #ffffff, 3px -3px 3px #ffffff, -3px 3px 3px #ffffff;
}

.recruitItem p {
	font-size: 18px;
	color: #454fb5;
	font-weight: 600;
	margin: 0;
	line-height: 2.0;
	padding: 0 0 0 196px;
	font-family: 'Yu Mincho', YuMincho, sans-serif;
	text-shadow: 2px 2px 3px #ffffff, -2px -2px 2px #ffffff, 2px -2px 2px #ffffff, -2px 2px 2px #ffffff;
}

.recruitItem h2 span {
	display: inline;
}

.recruitItem p span {
	display: block;
}

h2.recruitTitle {
	padding-bottom: 10px;
	border-bottom: 1px solid #d3d3d3;
	margin-bottom: 30px;
}

h2.recruitTitle span {
	display: inline-block;
	color: #010101;
	font-size: 30px;
	font-weight: 600;
	padding-left: 20px;
	border-left: 8px solid #454fb5;
	line-height: 1.0;
}
.recruitTable {
	width: 100%;
}
.recruitTable dl {
	display: table;
	width: 100%;
	border-bottom: 1px solid #dcdcdc;
}
.recruitTable dl.first {
	border-top: 1px solid #dcdcdc;
}
.recruitTable dt {
	display: table-cell;
	vertical-align: top;
	text-align: left;
	color: #000000;
	font-size: 18px;
	line-height: 1.8;
	width: 200px;
	font-weight : 500;
	padding: 24px 0 24px 16px;
}
.recruitTable dd {
	display: table-cell;
	vertical-align: top;
	text-align: left;
	color: #000000;
	font-size: 18px;
	line-height: 1.8;
	width: calc(100% - 280px);
	padding: 24px 0 24px 0;
	font-weight : 300;
}
.narrowWrap .button {
	text-align: center;
}
.smp_recText {
	display: none;
}
.toriWrap {
	padding : 60px 0 90px 0;
}
.toriWrap h2 {
	font-size : 24px;
	color : #000000;
	line-height : 70px;
	border-bottom : 1px solid #aaaaaa;
	padding : 0 16px;
	font-weight : 500;
}
.toriWrap h3 {
	font-size : 18px;
	color : #000000;
	line-height : 1.8;
	font-weight : 500;
	padding : 0 16px;
}
.toriWrap p {
	font-size : 18px;
	color : #000000;
	line-height : 1.8;
	font-weight : 300;
	padding : 0 16px;
}

@media only screen and (max-width: 1850px) {
	.rc_overLight {
		left: calc(100% - 61vw);
		width: 61vw;
	}
	.rc_overDeep {
		left: calc(100% - 48.5vw);
		width: 48.5vw;
	}
	.recruitItem h2 {
		font-size: calc(1.52vw + 19.9px);
	}
	.recruitItem p {
		font-size: calc(0.38vw + 11.0px);
	}
}

@media only screen and (max-width: 1680px) {
	.recruitItem {
		top: calc(12vw - 32px);
	}
	.recruitItem {
		left: calc(46% - 45px);
		width: calc(50vw + 70px);
	}
}

@media only screen and (max-width: 1380px) {
	.recruitImg img {
		width: 100%;
		max-width: 1380px;
		height: 40vw;
		object-fit: cover;
	}
	.cp_overLightInner h2 {
		font-size : calc(3.96vw + 5.4px);
		padding : calc(2.26vw + 4.8px) 0 0 calc(2.26vw + 4.8px);
	}
	.cp_overLightInner p {
		font-size : calc(1.51vw + 9.2px); 
		padding : 0px 0 0 calc(2.26vw + 4.8px);
	}
}

@media only screen and (max-width: 1270px) {
	.recruitItem p {
		line-height: 1.6;
	}
	.recruitItem p span {
		display: inline;
	}
	.recruitItem {
		left: calc(50% - 120px);
		top: calc(14vw - 32px);
		width: calc(53vw + 60px);
	}
}

@media only screen and (max-width: 1140px) {
	.rc_overLight {
		left: calc(100% - 71vw);
		width: 71vw;
	}
	.rc_overDeep {
		left: calc(100% - 58.5vw);
		width: 58.5vw;
	}
	.recruitItem {
		left: calc(40% - 120px);
		top: calc(14vw - 32px);
		width: calc(59vw + 80px);
	}
}

@media only screen and (max-width: 920px) {
	.rc_overLight {
		left: calc(100% - 74vw);
		width: 74vw;
	}
	.rc_overDeep {
		left: calc(100% - 61.5vw);
		width: 61.5vw;
	}
	.recruitItem {
		left: calc(37% - 140px);
		top: calc(13vw - 32px);
		width: calc(65vw + 80px);
	}
}
@media only screen and (max-width: 890px) {
	.cp_overLight {
		top: 60px;
	}
	.cp_overLeft {
		display : none;
	}
}

@media only screen and (max-width: 800px) {
	.recruitWrap {
		height: 60vw;
		max-height: 320px;
	}
	.recruitImg img {
		width: 100%;
		max-height: 320px;
		height: 60vw;
		object-fit: cover;
	}
	.recruitRightImg {
		display: none;
	}
	.rc_overLight {
		left: calc(100% - 78vw);
		width: 78vw;
	}
	.rc_overDeep {
		left: calc(100% - 62.5vw);
		width: 62.5vw;
	}
	.recruitItem {
		left: calc(40% - 160px);
		top: calc(6vw + 16px);
		width: calc(68vw + 80px);
		min-width: 0;
	}
	.recruitItem h2 {
		font-size: calc(2.08vw + 11.4px);
		line-height: 1.4;
		margin-bottom: 2vw;
	}
	.recruitItem h2 span {
		display: block;
	}
	.recruitItem p {
		font-size: calc(0.83vw + 9.4px);
		line-height: 1.4;
	}
	.recruitItem span {
		display: block;
	}
	.recruitItem .button {
		margin-top: 6vw;
		margin-bottom: 5vw;
	}
	h2.recruitTitle {
		padding-bottom: calc(0.6vw + 6px);
		margin-bottom: calc(1vw + 8px);
	}
	h2.recruitTitle span {
		font-size: calc(1.25vw + 20.0px);
	}
	.recruitTable table th {
		padding : 14px 2.4vw;

	}
	.recruitTable table td {
		padding : 14px 2.4vw;
	}
	.recruitTable dt {
		display: table-cell;
		vertical-align: top;
		text-align: left;
		color: #101010;
		font-size: calc(0.62vw + 11.0px);
		line-height: 1.8;
		width: 30vw;
		padding: calc(2.2vw + 6px) 0 calc(1vw + 6px) 0;
	}
	.recruitTable dd {
		display: table-cell;
		vertical-align: top;
		text-align: left;
		color: #101010;
		font-size: calc(0.62vw + 11.0px);
		line-height: 1.8;
		width: calc(100% - 34vw);
		padding: calc(2.2vw + 6px) 0 calc(1vw + 6px) 0;
	}
	.toriWrap {
		padding : 6vw 0 9vw 0;
	}
	.toriWrap h2 {
		font-size : calc(1.25vw + 14.0px);
		line-height : 2.6;
		border-bottom : 1px solid #aaaaaa;
		padding : 0 1.4vw;
	}
	.toriWrap h3 {
		font-size: calc(0.62vw + 11.0px);
		padding : 0 1.4vw;
	}
	.toriWrap p {
		font-size: calc(0.62vw + 11.0px);
		padding : 0 1.4vw;
	}
	.mgt100 {
		margin: 10vw 0 0 0;
	}
}

@media only screen and (max-width: 480px) {
	.recruitItem {
		top: 21vw;
		width: auto;
		min-width: 0;
	}

	.recruitItem h2 {
		font-size: calc(2.5vw + 12.0px);
		line-height: 1.4;
	}

	.recruitItem p {
		display: none;
	}

	.smp_recText {
		display: block;
		margin-top: 20px;
	}

	.smp_recText p {
		font-size: 14px;
		color: #454fb5;
		font-weight: 600;
		margin: 0;
		line-height: 1.6;
		padding: 0 4vw;
		font-family: 'Yu Mincho', YuMincho, sans-serif;
	}
}
.memshipComm  {
	line-height : 2.4;
	width : 100%;
	max-width : 780px;
}
.flex50Wrap {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
}
.profWrap {
	position: relative;
	width : 50%;
	height : 630px;
	padding-top : 20px;
	background : url(../img/bottom_left.jpg) no-repeat top center;
	background-size : cover;
	box-sizing: border-box;
}
.profWrapInner {
	width : 100%;
	max-width : 725px;
	position : absolute;
	top : 20px;
	right : 0;
}
.profMark {
	width : 90%;
	max-width : 440px;
	height : 443px;
	background-color : rgba(255, 255, 255, 0.7);
	padding : 30px;
	margin-top : -12px;
	box-sizing: border-box;
}
.profMark dl {
	display : table;
	width : 100%;
	border-top : 1px solid #000000;
}
.profMark dl.noborder {
	border-top-style : none;
}
.profMark dt {
	display : table-cell;
	vertical-align: middle;
	width : 28%;
	font-size : 14px;
	font-weight : 500;
	color : #000000;
	padding : 11px 2% 11px 5%;
}
.profMark dd {
	display : table-cell;
	vertical-align: middle;
	width : 61%;
	font-size : 14px;
	font-weight : 500;
	color : #000000;
	padding : 11px 2% 11px 2%;
}
.recWrap {
	position: relative;
	width : 50%;
	height : 630px;
	padding-top : 20px;
	background : url(../img/bottom_right.jpg) no-repeat top center;
	background-size : cover;
	box-sizing: border-box;
}
.recWrapInner {
	width : 100%;
	max-width : 725px;
	position : absolute;
	top : 20px;
	left : 0;
}
.recMark {
	width : 90%;
	max-width : 440px;
	height : 443px;
	padding : 30px;
	background : url(../img/recruit_inner.png) no-repeat top center;
	box-sizing: border-box;
	margin-top : -12px;
}
.recMark h3 {
	color : #085b33;
	font-size : 32px;
	font-weight : 700;
	line-height : 1.4;
	width : 260px;
	letter-spacing: 5px;
}
.recMark p {
	color : #000000;
	font-size : 14px;
	font-weight : 500;
	line-height : 27px;
	letter-spacing: 0px;
}
.recMark p.wid01 {
	width : 190px;
}
.recMark p.wid02 {
	width : 180px;
}
.detailBtn a {
	display : block;
	width : 205px;
	text-align : center;
	font-size : 1rem;
	color : #085b33;
	font-weight : 500;
	border : 1px solid #085b33;
	padding : 8px 0;
	position : relative;
	background-image : url(../img/br_arrow.png);
	background-position : right bottom;
	background-repeat: no-repeat;
	transition: 0.3s;
}
.detailBtn a.bg0 {
	background-color : transparent;
}
.detailBtn a.bg1 {
	background-color : rgba(255, 255, 255, 0.7);
}

.detailBtn a:hover {
	color :#000000;
	background-color : rgba(255, 255, 255, 0.9);
}

.companyText {
	text-align: left;
	color: #464646;
	font-size: 16px;
	line-height: 2.0;
	padding: 20px 0 12px 0;
}

.companyText span {
	display: block;
	margin-bottom: 24px;
}

.companyText .name {
	text-align: right;
	color: #464646;
	font-size: 16px;
	padding: 20px 0 0 0;
}
.recMark p.wid02 span {
	display : inline;
}

@media only screen and (max-width: 990px) {
	.recMark p.wid01 {
		width : 46%;
		margin-top : 0 !important;
		line-height : calc(3.68vw - 9.4px);
	}
	.recMark p.wid02 {
		width : 46%;
		line-height : calc(3.68vw - 9.4px);
	}
}
@media only screen and (max-width: 800px) {
	.flex50Wrap {
		display : block;
	}
	.profWrap {
		width : 100%;
		height : 630px;
	}
	.recWrap {
		width : 100%;
		height : 630px;
	}
	.profWrapInner {
		position : relative;
		top : 0;
		margin : 0 auto;
	}
	.recWrapInner {
		position : relative;
		top : 0;
		margin : 0 auto;
	}
	.recMark h3 {
		font-size : calc(2.5vw + 12.0px);
		width : 290px;
	}
	.companyText {
		font-size: calc(0.62vw + 11.0px);
		line-height: 1.8;
	}
	.companyText .name {
		font-size: calc(0.62vw + 11.0px);
		line-height: 1.8;
		padding: 20px 0 0 0;
	}
	.recMark p {
		font-size : 13px;
		line-height : 25px;
		letter-spacing: 0px;
	}
	.recMark p.wid01 {
		width : 70%;
		line-height : 25px;
		padding-top : 20px;
	}
	.recMark p.wid02 {
		width : 48%;
		line-height : 27px;
	}
	.recMark p.wid02 span {
		display : block;
		width : 90%;
		line-height : 27px;
	}
}
@media only screen and (max-width: 480px) {
	.profWrap {
		width : 100%;
		height : 610px;
	}
	.recWrap {
		width : 100%;
		height : 540px;
	}
	.profMark {
		padding : 16px;
		margin-top : 12px;
	}
	.recMark {
		padding : 16px;
		background : url(../img/recruit_inner_s.png) no-repeat top right;
		opacity : 0.9;
		margin-top : 12px;
	}
	.recMark h3 {
		letter-spacing: 2px;
		text-align : left !important;
		padding-bottom : 16px;
	}
	.recMark h3 br {
		display : none;
	}
	.recMark p {
		font-size : 13px;
		line-height : 25px;
		letter-spacing: 0px;
	}
	.recMark p.wid01 {
		width : 70%;
		line-height: 1.8;
		padding-top : 0px;
	}
	.recMark p.wid02 {
		width : 68%;
		line-height: 1.8;
	}
	.recMark p.wid02 span {
		display : block;
		width : 60%;
		line-height: 1.8;
	}
}
@media only screen and (max-width: 360px) {
	.recMark p.wid02 span {
		display : block;
		width : 45%;
		line-height: 1.8;
	}
}





/* 各ページ */

/* 仕事内容 */

.elsePage {
	margin-top : 0;
}
.pageTops {
	width : 100%;
	height : 569px;
}
.topTitle {
	text-align : center;
	color : #ffffff;
	font-size : 32px;
	font-weight : 400;
	background-position : center center;
	background-repeat : no-repeat;
	background-size : cover;
	height : 312px;
}
.topTitle .mainTitle {
	top : 250px;
}
.topTitle img {
	width : 95px;
}
.topTitle span {
	display : block;
}
.busiWrap {
	width : 100%;
	max-width : 1676px;
}
.middleWrap p {
	line-height : 2.2;
}
.middleWrap dl {
	line-height : 2.2;
	display : -webkit-flex;
	display : flex;
	flex-wrap : wrap;
}
.middleWrap dt {
	width : 2em;
}
.middleWrap dd {
	width : calc(100% - 2em);
}
.bisiFlex {
	
}
.bisiFlex .item {
	width : 31%;
	position : relative;
}
.bisiFlex .item h5 {
	background-color : #000000;
	color : #ffffff;
	font-weight : 500;
	border-radius : 24px;
	text-align : center;
	padding : 2px 0 4px 0;
}
.bisiFlex .item .waku {
	border : 4px solid #000000;
	padding : 20px 0 20px 32px;
	box-sizing: border-box;
	height : 180px;
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
	flex-wrap : wrap;
	align-items: center;
}
.bisiFlex .item .ewaku {
	border : 4px solid #000000;
	padding : 0 20px;
}
.bisiFlex .item .waku p {
	width : 100%;
}
.bisiFlex .item.warrow::after {
	content : "";
	position : absolute;
	right : -20.5%;
	top : 41%;
	background : url(../img/w_arrow.png) no-repeat 0 0;
	width : 91px;
	height : 51px;
}
@media only screen and (max-width: 960px) {
	.bisiFlex .item .waku {
		padding : 2vw 0 2vw 3vw;
		height : calc(12vw + 60px);
	}
	.bisiFlex .item .ewaku {
		border : 4px solid #000000;
		padding : 0 2vw;
	}
	.bisiFlex .item .waku p {
		width : 100%;
	}
	.bisiFlex .item.warrow::after {
		right : -20.5%;
		top : 41%;
		width : 9vw;
		height : 5vw;
		background-size : 100%;
	}
}
@media only screen and (max-width: 480px) {
	.bisiFlex .item {
		width : 100%;
	}
	.bisiFlex .item .waku {
		display : block;
		padding : 3vw 0 3vw 3vw;
		height : auto
	}
	.bisiFlex .item.warrow {
		margin-bottom : 12vw;
	}
	.bisiFlex .item.warrow::after {
		right : 50%;
		top : calc(100% + 5px);
		width : 5vw;
		height : 9vw;
		background : url(../img/w_arrow_t.png) no-repeat 0 0;
		background-size : 100%;
	}
	.middleWrap p {
		line-height : 1.8;
	}
	.middleWrap dl {
		line-height : 1.8;
	}
}
.pdfWrap {
	width : 80%;
	max-width : 484px;
}
.df640 .pdfWrap {
	width : 46%;
	max-width : 484px;
}
.pdfWrap a {
	display : block;
	margin-left : auto;
	margin-right : auto;
	width : 100%;
	border : 4px solid #000000;
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
	align-items: center;
	padding : 14px 40px 4px 40px;
	border-radius : 64px;
	line-height : 1.4;
	box-sizing: border-box;
}
.pdfWrap a h4 {
	position : relative;
	top : -4px;
}
@media only screen and (max-width: 960px) {
	.pdfWrap {
		width : 90%;
		max-width : 500px;
		margin : 0 auto;
	}
	.df640 .pdfWrap {
		width : 90%;
		max-width : 500px;
		margin : 0 auto;
	}
	.pdfWrap a {
		width : 100%;
		padding : 4vw 5vw 2vw 5vw;
		border-radius : 12vw;
	}
	.pdfWrap a img {
		width : calc(4vw + 13px);
	}
}
@media only screen and (max-width: 640px) {
	.pdfWrap a {
		width : 100%;
		padding : 4vw 5vw 2vw 5vw;
		border-radius : 12vw;
		margin : 3vw 0;
	}
	.pdfWrap a img {
		width : calc(4vw + 13px);
	}
}

.nyuFlex {

}
.nyuFlex .nyuItem {
	width : 22%;
	position : relative;
}
.nyuFlex .nyuItem .wrap {
	border : 3px solid #000000;
	border-radius : 10px;
	text-align : center;
	padding : 16px 0;
}
.nyuItem.addArrow::after {
  content: "";
  position: absolute;
  right: -14.5%;
  top: 27%;
  background: url(../img/arrow.png) no-repeat 0 0;
  width: 45px;
  height: 45px;
}
.telButton {
	width : 90%;
	max-width : 900px;
	background-color : #489256;
	border-radius : 6px;
	text-align : center;
	color : #ffffff;
}
.telButton a {
	display : inline-block;
	padding : 30px 0 30px 0;
}
.telButton .tel {
	background : url(../img/tel.png) no-repeat center left;
	padding-left : 50px;
	text-align : left;
	color : #ffffff;
	line-height : 48px;
	letter-spacing: 1px;
}
.telButton .time {
	background : url(../img/time.png) no-repeat center left;
	padding-left : 50px;
	text-align : left;
	color : #ffffff;
	line-height : 41px;
}
.telButton:hover {
	background-color : #489256;
}

.messageTitle {
	display: inline-block;
	color: #000000;
	position : relative;
	padding-right : 180px;
	font-weight : 400;
}
.messageTitle strong {
	display: inline-block;
	font-weight : 400;
	background-color : #ffffff;
	position : relative;
	padding-right : 20px;
	z-index : 2;
}
.messageTitle span {
	position : absolute;
	top : 50%;
	right : 0;
	width : 180px;
	height : 1px;
	font-size : 0;
	border-top : 1px solid #000000;
	z-index : 1;
}
.engTitle {
	display: block;
	color: #b9b9b9;
	font-size: 1.1rem;
	position: relative;
	letter-spacing: 1px;
	z-index: 1;
	font-weight: 400;
	font-family: 'Oswald', sans-serif;
}
@media only screen and (max-width: 960px) {
	.messageTitle {
		padding-right : calc(20vw + 20px);
	}
	.messageTitle::after {
		width : 20vw;
	}
}
@media only screen and (max-width: 640px) {
	.telButton a {
		padding : calc(2vw + 10px) 0;
	}
	.telButton .tel {
		background : url(../img/tel.png) no-repeat center left;
		background-size : calc(5vw + 10px);
		padding-left : calc(6vw + 12.0px);
		line-height : calc(6vw + 10.0px);
	}
	.telButton .time {
		background : url(../img/time.png) no-repeat center left;
		background-size : calc(5vw + 10px);
		padding-left : calc(6vw + 12.0px);
		line-height : calc(5vw + 12.0px);
	}
}
.selectTab {
	display : -webkit-flex;
	display : flex;
	flex-wrap : wrap;
}
.selectTab span {
	background-color : #ffffff;
	font-weight : 700;
	margin-right : 16px;
	color : #5770e1;
	border : 1px solid #5770e1;
	border-radius : 6px;
	padding : 10px 20px;
}
.selectTab a {
	background-color : #e6eefb;
	font-weight : 700;
	margin-right : 16px;
	color : #5770e1;
	border : 1px solid #e6eefb;
	border-radius : 6px;
	padding : 10px 20px;
	transition: 0.3s;
}
.selectTab a:hover {
	background-color : #5770e1;
	color : #e6eefb;
	border : 1px solid #e6eefb;
}

.worksWrap {
	display : block;
	width : 100%;;
}
.galleryItem {
	width : 100%;
	padding : 12px 0;
	display : table;
	table-layout: fixed;
}
.galleryItem p {
	display : table-cell;
}
.galleryItem .item1 {
	width : 20%;
	font-weight : 700;
}
.galleryItem .item1 a {
	color : #5770e1;
	transition: 0.3s;
}
.galleryItem .item1 a:hover {
	color : #0033ff;
}
.galleryItem .item2 {
	width : 47%;
	padding-right : 3%;
}
.galleryItem .item3 {
	width : 22%;
	padding-right : 3%;
}
.galleryItem .item4 {
	width : 5%;
}
.galleryTrans {
	width : 19.5%;
	padding : 0 13px;
	font-size : 0;
	height : 0;
}
.galleryItem .img img {
	width : 100%;
	height : 18vw;
	max-height : 184px;
	object-fit: cover;
}
.galleryItem .img span {
	display : block;
	width : 100%;
	height : 18vw;
	max-height : 184px;
	background-repeat : no-repeat;
	background-position : center center;
	background-size : cover;
}
.galleryItem .comm h3 {
	color : #000000;
	font-size : 16px;
	font-weight : 500;
	line-height : 2.0;
}
.galleryItem .comm p {
	color : #000000;
	font-size : 14px;
	font-weight : 500;
}
.galleryItem .comm p.bline {
	border-bottom : 1px dashed #afafaf;
	padding-bottom : 10px;
	margin-bottom : 6px;
}
.galleryMore {
	text-align : center;
}
.detailTitle {
	margin-top : 140px;
}
.detailTitle h2 {
	font-weight : 400;
}
.detailTitle h2::after {
	content : "";
	position : relative;
	display : block;
	margin : 4px auto;
	width : 64px;
	border-bottom : 6px solid #b4b4b4;
}
.detailFlex .mainPhoto {
	width : 50%;
}
.detailFlex .mainPhoto img {
	width : 94%;
}
.detailFlex .mainList {
	width : 47%;
	padding-left : 3%;
}
.detailFlex .mainList dl {
	width : 100%;
	display : table;
	border-top : 1px solid #bebebe;
}
.detailFlex .mainList dl.first {
	border-top : none;
}
.detailFlex .mainList dt {
	display : table-cell;
	font-size : 1rem;
	padding : 10px 0;
	width : 25%;
}
.detailFlex .mainList dd {
	display : table-cell;
	font-size : 1rem;
	padding : 10px 0;
	width : 75%;
}
.prMap iframe {
	width : 100%;
}
.prFlex {

}
.prFlex li {
	width : 32%;
}
.prFlex li img {
	width : 100%;
}
@media only screen and (max-width: 1560px) {
	.busiWrap .busiImg {
		width : calc(50vw + 100px);
	}
	.busiWrap .busiImgInner img {
		width : 100%;
		height : 42vw;
		max-height : 585px;
		object-fit : cover;
	}
}
@media only screen and (max-width: 1200px) {
	.busiWrap dt {
		width : 8vw;
		font-size : 5vw
	}
	.busiMain dd h3 {
		font-size : calc(1vw + 8.0px);
	}
	.busiMain dd p {
		font-size : calc(0.75vw + 7.0px);
		margin-top : calc(0.75vw + 7.0px);
	}
	.busiMain dl {
		padding : 0 10px;
		box-sizing: border-box;
	}
	.busiMain dl.mgt40 {
		margin-top : 2vw !important;
	}
	.detailTitle {
		margin-top : calc(12vw + 20px);
	}
}
@media only screen and (max-width: 1000px) {
	.busiMain .normalTitle {
		font-size : 24px;
		width : 200px;
		padding-left : 16px;
		text-align : left;
	}
}
@media only screen and (max-width: 800px) {
	.flexRev {
		display : block;
		margin-left : 0;
	}
	.flexFor {
		display : block;
		margin-right : 0;
	}
	.busiWrap .busiImg {
		width : 100%;
	}
	.busiWrap .busiImgInner img {
		width : 100%;
	}
	.busiMain {
		width : 100%;
	}
	.busiWrap dt {
		width : calc(8vw + 20px);
		font-size : calc(5.09vw + 17.5px);
	}
	.busiMain dd h3 {
		font-size : calc(1.25vw + 10.0px);
	}
	.busiMain dd p {
		font-size : calc(0.62vw + 11.0px);
		margin-top : calc(0.62vw + 11.0px);
	}
	.busiMain .normalTitle {
		margin-left : auto;
		margin-right : auto;
		padding-left : 0;
		padding-right : 10px;
		text-align : center;
	}
	.selectTab span {
		margin-right : 6px;
		padding : 1vw 2vw;
	}
	.selectTab a {
		margin-right : 6px;
		padding : 1vw 2vw;
	}
}
@media only screen and (max-width: 640px) {
	.detailFlex .mainPhoto {
		width : 100%;
		max-width : 530px;
		margin : 0 auto;
	}
	.detailFlex .mainPhoto img {
		width : 100%;
	}
	.detailFlex .mainList {
		width : 100%;
		padding-left : 0;
		margin-top : 5vw;
	}
	.nyuFlex .nyuItem {
		width : 48%;
		position : relative;
	}
	.nyuItem.addArrow::after {
	  content: none;
	}
	.nyuFlex .nyuItem.tline {
		margin-bottom : 6vw;
	}
}

@media only screen and (max-width: 480px) {
	.busiMain .normalTitle {
		font-size : 20px;
		width : 160px;
		padding-left : 1vw;
		letter-spacing: 0;
	}
}

/* 会社案内 */

.messageBlock {
	width : 100%
	box-sizing: border-box;
}
.messageInner {
	width : 70%;
	max-width : 850px;
}
.messageInner p {
	color : #000000;
	font-weight : 400;
	line-height : 2.0;
}
.messageBlock .image {
	width : 28vw;
	max-width : 274px;
}
.messageBlock .image img {
	width : 28vw;
	max-width : 274px;
}
.plofTable {
	width : 100%;
}
.plofTable table {
	width : 100%;
	border-collapse: collapse;
}
.plofTable table th {
	width : 25%;
	padding : 12px 0;
	text-align : left;
	vertical-align: middle;
	font-weight : 400;
	color : #000000;
}
.plofTable table td {
	width : 75%;
	padding : 12px 0;
	text-align : left;
	vertical-align: middle;
	font-weight : 400;
}
.pdfFlex .left {
	width : 50%;
}
.pdfFlex .right {
	width : 50%;
}
.pdfFlex .pdfWrap {
	width : 100%;
}

.serviceWrap a {
	color : #ffffff;
	font-weight : 500;
	display : inline-block;
	padding-left : 75px;
	line-height : 165px;
	background-color : #000000;
	width : 80%;
	max-width : 760px;
	text-align : left;
	position : relative;
}
.serviceWrap a::after {
	content : "→";
	position : absolute;
	top : 0%;
	right : 5%;
	color : #ffffff;
	font-weight : 500;
	font-size : 24px;
	transition: 0.3s;
}
.serviceWrap a:hover::after {
	right : 4%;
}
.map iframe {
  -webkit-filter: grayscale(1);
  filter: grayscale(1);
}
@media only screen and (max-width: 800px) {
	.serviceWrap a {
		line-height : calc(16vw + 20px);
		box-sizing: border-box;
		padding-left : 7.5vw;
	}
	.messageBlock {
		height : auto;
		padding-top : 0;
		padding-left : 0;
	}
	.messageWrap .messageInner {
		padding : 4vw 3vw;
	}
	.messageWrap .messageInner p {
		line-height : 1.8;
	}
	.messageInner .mgb30 {
		margin-bottom : 2vw !important;
	}
	.messageInner .mgt50 {
		margin-top : 3vw !important;
	}
}
@media only screen and (max-width: 640px) {
	.plofTable table {
		width : 100%;
		display : block;
	}
	.plofTable tbody {
		display : block;
	}
	.plofTable tr {
		display : block;
	}
	.plofTable table th {
		display : block;
		width : 100%;
		padding : 4vw 0 1.2vw 0;
	}
	.plofTable table td {
		display : block;
		width : 100%;
		padding : 1.2vw 0 3vw 0;
	}
}
@media only screen and (max-width: 640px) {
	.messageInner {
		width : 100%;
	}
	.messageBlock .image {
		width : 80%;
		max-width : 274px;
		margin : 5vw auto 5vw auto
	}
	.messageBlock .image img {
		width : 100%;
	}
	.messageInner p {
		line-height : 1.8;
	}
	.pdfFlex .left {
		width : 100%;
		text-align : center;
		padding-bottom : 12px;
	}
	.pdfFlex .right {
		width : 100%;
	}
}
@media only screen and (max-width: 400px) {
	.messageWrap .messageInner {
		padding : 56vw 0 8vw 0;
	}
	.messageWrap .messageInner div img{
		width : 180px;
	}
}

.imgback {
	background: url(../img/back.jpg) repeat top left;
	padding-top: 90px;
}
.contWrap {
	text-align: center;
	padding: 0 10px;
}
.contWrap .centerWord {
	margin: 50px 0 32px 0;
}
.contSlider {
	width: 100%;
	max-width: 790px;
	margin-left: auto;
	margin-right: auto;
	position : relative;
}
.contSlideInner {
	text-align: left;
	width: 100%;
	max-width: 790px;
}
.contSlideInner .image {
	font-size: 0;
	width : 100%;
	height : 60vw;
	max-height : 537px;
	position : relative;
}
.contSlideInner .image img {
	position : absolute;
	top : 0;
	left : 0;
	width : 100%;
	height : 60vw;
	max-height : 537px;
	object-fit: cover;
}
.contSlideInner .image span {
	display : block;
	position : absolute;
	top : 0;
	left : 0;
	width : 100%;
	height : 60vw;
	max-height : 537px;
	background-repeat : no-repeat;
	background-position : center center;
	background-size : cover;
}
.contSlideInner .comm {
	width: 100%;
	max-width: 790px;
	text-align: left;
	background-color: #ffffff;
	padding: 26px 36px 80px 36px;
	font-size: 0;
	box-sizing: border-box;
}
.contSlideInner .comm .check {
	font-size: 24px;
	line-height: 1.0;
	font-weight: 700;
	display: inline-block;
	padding-bottom: 4px;
	margin-bottom: 20px;
	color: #000000;
	border-bottom: 6px solid #000000;
}
.contSlideInner .comm p {
	font-size: 16px;
	color: #000000;
}
.feed-prev-btn {
	background-image: url(../img/pref.png);
	transition: 0.4s;
	left : -40px;
	z-index : 99;
}
.feed-next-btn {
	background-image: url(../img/next.png);
	transition: 0.4s;
	right : -40px;
	z-index : 99;
}
.feed-prev-btn:hover {
	opacity : 0.7;
}
.feed-next-btn:hover {
	opacity : 0.7;
}
.feed-prev-btn .bx-prev {
	opacity: 0;
	display: block;
}
.feed-next-btn .bx-next {
	opacity: 0;
	display: block;
}
.navi-btn {
	width: 78px;
	height: 78px;
	position : absolute;
	top : 380px;
}
.navi-btn a {
	display : block;
	height : 100%;
}

.co_feed-prev-btn {
	background-image: url(../img/prev_b.png);
	transition: 0.4s;
	z-index : 99;
}
.co_feed-next-btn {
	background-image: url(../img/next_b.png);
	transition: 0.4s;
	z-index : 99;
}
.co_feed-prev-btn:hover {
	opacity : 0.7;
}
.co_feed-next-btn:hover {
	opacity : 0.7;
}
.co_feed-prev-btn .bx-prev {
	opacity: 0;
	display: block;
}
.co_feed-next-btn .bx-next {
	opacity: 0;
	display: block;
}
.co-btn {
	position : relative;
	display : inline-block;
	width: 50px;
	height: 50px;
}
.co-btn a {
	display : block;
	height : 100%;
}
.rc_feed-prev-btn {
	background-image: url(../img/prev_w.png);
	transition: 0.4s;
	z-index : 99;
}
.rc_feed-next-btn {
	background-image: url(../img/next_w.png);
	transition: 0.4s;
	z-index : 99;
}
.rc_feed-prev-btn:hover {
	opacity : 0.7;
}
.rc_feed-next-btn:hover {
	opacity : 0.7;
}
.rc_feed-prev-btn .bx-prev {
	opacity: 0;
	display: block;
}
.rc_feed-next-btn .bx-next {
	opacity: 0;
	display: block;
}
.co-btn {
	position : relative;
	display : inline-block;
	width: 50px;
	height: 50px;
}
.co-btn a {
	display : block;
	height : 100%;
}
.rc-btn {
	position : relative;
	display : inline-block;
	width: 50px;
	height: 50px;
}
.rc-btn a {
	display : block;
	height : 100%;
}

.centerComm  {
	font-size : 16px;
	color : #000000;
	text-align : center;
	font-weight : 400;
}
.formButton  {
	text-align : center;
}
.formButton a {
	text-align : center;
	display : inline-block;
	font-size : 32px;
	color : #ffffff;
	font-weight : 700;
	width : 80%;
	max-width : 625px;
	padding : 20px 0 24px 0;
	line-height : 1.6;
	background-color : #000000;
	transition: 0.4s;
}
.formButton a img {
	position : relative;
	top : 10px;
	left : -12px;
}
.formButton a:hover {
	opacity : 0.7;
}
@media only screen and (max-width: 1060px) {
	.imgback {
		padding-top: 9vw;
	}
	.contWrap .centerWord {
		margin: 5vw 0 3vw 0;
	}
	.centerComm  {
		font-size : calc(0.41vw + 10.7px);
	}
	.contSlideInner .comm {
		padding: 4vw 3vw 8vw 3vw;
	}
	.contSlideInner .comm .check {
		font-size : calc(0.81vw + 15.4px);
		margin-bottom: 2vw;
		border-bottom: calc(0.4vw + 3px) solid #000000;
	}
	.contSlideInner .comm p {
		font-size : calc(0.41vw + 11.7px);
	}
	.navi-btn {
		width: calc(5.09vw + 23.9px);
		height: calc(5.09vw + 23.9px);
		background-size : cover;
		top : 38vw;
	}
	.feed-prev-btn {
		left : calc(-2.55vw - 12px);
	}
	.feed-next-btn {
		right : calc(-2.55vw - 12px);
	}
	.formButton a {
		font-size : calc(2.16vw + 9.1px);
		width : 90%;
		padding : calc(2vw + 6px) 0 calc(2vw + 8px) 0;
	}
	.formButton a img {
		position : relative;
		top : 0.6vw;
		left : -12px;
		width : calc(1.8vw + 18px);
	}
}

@media only screen and (max-width: 640px) {
	.mgb02 {
		padding-bottom: calc(4vw + 8px);
	}
	.map iframe {
		height : 400px;
	}
}

.compWrap {
	position: relative;
	font-size : 0;
}
.smp_compTitle {
	display: none;
}
.compImg {
	position: relative;
	width: 100%;
	z-index: 2;
}
.compImgRec {
	position: relative;
	width: 100%;
	z-index: 2;
}
.compImgInner {
	position: relative;
	display : inline-block;
	width: 60%;
	max-width: 1152px;
}
.compImgInnerRec {
	position: relative;
	display : inline-block;
	width: 60%;
	max-width: 928px;
}
.compImg img {
	width: 100%;
	max-width: 921px;
	height: 50vw;
	max-height: 614px;
	object-fit: cover;
}
.compImgRec img {
	width: 100%;
	max-width: 928px;
	height: 50vw;
	max-height: 675px;
	object-fit: cover;
}
.recback {
	background : url(../img/recruit_left.png) no-repeat 0 0;
}
.compMain {
	position: absolute;
	bottom : 0;
	z-index: 3;
	width: 52%;
	height: 36vw;
	max-height:366px;
	background-color: #ffffff;
	padding : 70px 80px;
	box-sizing: border-box;
}
.compOuter {
	position : relative;
	top : -100px;
}
.compMainRec {
	position: absolute;
	top: 120px;
	z-index: 3;
	width: 780px;
	height: 32.3vw;
	max-height: 438px;
	padding : 48px 80px;
	box-sizing: border-box;
}
.compMain .title {
	color: #000000;
	font-weight: 400;
	line-height: 1.4;
	text-align: left;
}
.recTitle {
	font-size: 34px;
	color: #000000;
	font-weight: 700;
	line-height: 1.4;
	text-align: left;
}
.leftWord {
	display: inline-block;
	font-weight: 400;
	line-height: 1.0;
	font-size: 18px;
	color: #ffffff;
	background-color: #000000;
	padding: 6px 12px 8px 12px;
	margin-top: 32px;
}
.rc_img {
	text-align: left;
}
.rc_shadow {
	right: 0;
}
.rc_main {
	right: 0;
}
.co_img {
	text-align: right;
}
.co_shadow {
	left: 0;
}
.compMain.co_main {
	left: 0;
}
.compMainRec.co_main {
	right : 830px;
}
.compMain .check {
	font-size: 24px;
	line-height: 1.0;
	font-weight: 700;
	display: inline-block;
	padding-bottom: 4px;
	margin-bottom: 20px;
}
.co_main .check {
	color: #000000;
	border-bottom: 6px solid #000000;
}

.rc_main .check {
	color: #000000;
	border-bottom: 6px solid #000000;
}

.compMain .word {
	font-size: 18px;
	line-height: 2.4;
	width: 80%;
	max-width: 825px;
}
.compMainRec .word {
	font-size: 16px;
	line-height: 2.0;
	width: 100%;
	max-width: 825px;
}
.co_main .word {
	color: #000000;
}
.rc_main .word {
	color: #000000;
}
.rc_main .normalTitleLeft {
	color: #000000 !important;
}
.compMain .buttons {
	width: 90%;
	max-width: 825px;
	text-align: right;
	margin-top: 36px;
}
.co_main .buttons {
	text-align: right;
}
.rc_main .buttons {
	text-align: left;
}
.headbdr {
	width : 90%;
	max-width : 540px;
}
.workbtn {
	display: inline-block;
	width: 80%;
	font-size : 16px;
	font-weight : 700;
	color: #000000;
	transition: 0.4s;
	position: relative;
	border-top : 1px solid #dadada;
	text-decoration: none;
	margin-left : auto;
	padding-top : 20px;
	position : relative;
	text-align : left;
}
.workbtn span {
	display: block;
	font-size : 16px;
	font-weight : 400;
	color: #b2b2b2;
}
.workbtn::before {
	content : "";
	position : absolute;
	top : 0;
	left : 0;
	font-size : 0;
	width : 0;
	height : 1px;
	background-color : #567ecb;
	transition: 0.6s;
}
.workbtn::after {
	content : "→";
	position : absolute;
	top : 32px;
	right : 0;
	font-size : 16px;
	font-weight : 400;
	color: #000000;
	transition: 0.4s;
}
.workbtn:hover::before {
	width : 100%;
}
.moreRev_w::after {
	position: absolute;
	content: ">";
	top: 26%;
	right: 12px;
	font-size: 32px;
	font-weight : 300;
	line-height: 1.0;
	color: #ffffff;
	font-family: 'Arsenal', sans-serif;
}

.moreRev_w:hover {
	color: #000000;
	background-color: #ffffff;
}

.moreRev_w:hover::after {
	color: #000000;
}

@media only screen and (max-width: 1660px) {
	.compMain .word {
		font-size: 16px;
		line-height: 1.9;
	}
	.co_main .word {
		margin-top: 16px;
	}
	.compMainRec {
		top: 7.2vw;
		width: 45%;
		height: auto;
		max-height: 438px;
		padding : 4vw 3vw;
	}
	.compMainRec.co_main {
		right : 52%;
	}
	.recback {
		background : url(../img/recruit_left.png) no-repeat 0 0;
		background-size : 52%;
	}
	.recTitle {
		font-size : calc(1.8vw + 3px);
	}
	.compImgRec img {
		width: 100%;
		max-width: 928px;
		height: 45vw;
		max-height: 675px;
		object-fit: cover;
	}
	.compMainRec .word {
		font-size : calc(0.35vw + 10.2px);
	}
}
@media only screen and (max-width: 1480px) {
	h2.normalTitleLeft {
		font-size: 28px;
	}
}
@media only screen and (max-width: 1240px) {
	h2.normalTitleLeft {
		font-size: 26px;
	}
}
@media only screen and (max-width: 1100px) {
	.workbtn {
		margin-top : -2vw;
	}
}
@media only screen and (max-width: 1000px) {
	.compMain {
		width : 480px;
	}
	.compMain.co_main {
		left: 0;
	}
	.compMain .word {
		margin-top : -3vw;
	}
	.rc_main {
		right : 0;
	}
	.rc_main .word {
		margin-top : -3vw;
	}
	h2.normalTitleLeft {
		font-size: 24px;
	}
	.co-btn {
		width: 32px;
		height: 32px;
		background-size : cover;
	}
	.rc-btn {
		width: 32px;
		height: 32px;
		background-size : cover;
	}
}
@media only screen and (max-width: 960px) {
	.compOuter {
		top : -10vw;
	}
}

@media only screen and (max-width: 860px) {
	.compImgInnerRec {
		position: relative;
		display : inline-block;
		width: 100%;
		max-width: 928px;
	}
	.compImgRec img {
		width: 100%;
		max-width: 928px;
		height: auto;
		max-height: 675px;
		object-fit: cover;
	}
	.compMainRec {
		position: relative;
		top: -6px;
		z-index: 3;
		width: 100%;
		height: auto;
		max-height: 1000px;
		padding : 5vw 8vw;
		box-sizing: border-box;
	}
	.compMainRec.co_main {
		right : 0;
	}
	.recback {
		background : none;
	}
	.recTitle {
		font-size : calc(2.59vw + 7.7px);
	}
	.compMainRec .word {
		font-size : calc(0.56vw + 11.2px);
		line-height : 1.8;
		padding-top : 16px;
	}

}
@media only screen and (max-width: 800px) {
	.pageTops  {
		height : calc(36vw + 60px);
		margin-top : 60px;
	}
	.topTitle  {
		padding-top : 14vw;
		font-size : calc(1.4vw + 19.5px);
	}
	.smp_compTitle {
		display: block;
	}
	.compImg {
		margin-top: 7vw;
	}
	.compImg img {
		width: 100%;
	}
	.compShadow {
		display: none;
		background-color: #dadcf0;
	}
	.compWrap {
		padding-bottom: 0;
	}
	.compMain {
		position: relative;
		top: -6px;
		z-index: 3;
		width: 80%;
		height: auto;
		padding: 6vw;
		margin : 0 auto;
		box-sizing: border-box;
	}
	.compMain .word {
		font-size : 14px;
		line-height: 1.8;
		width : 100%;
	}
	.compMain .newsTitle {
		display: none;
	}
	.compMain.co_main {
		left: 0;
	}
	.compMain p {
		font-size: calc(0.62vw + 11.0px);
		color: #444444;
		line-height: 1.6;
		width: 84%;
		margin: 0px auto 5vw auto;
	}
	.compMain .check {
		font-size: 18px;
		margin-bottom: 12px;
		width : 3.4em;
	}
	.co_img {
		text-align: center;
	}
	.rc_img {
		text-align: center;
	}
	.compImgInner {
		width: 80%;
	}
	.compImg img {
		height: 60vw;
	}
	.compMain .buttons {
		position : absolute;
		top : 12px;
		left : 0;
		width : 100%;
		text-align: center;
		margin-top: 0px;
	}
	.co_main .buttons {
		text-align: center;
	}
	.rc_main {
		right: 0;
	}
	.rc_main .buttons {
		text-align: center;
	}
	.workbtn {
		margin-top : -6vw;
	}
}
@media only screen and (max-width: 640px) {
	h2.normalTitleLeft {
		font-size : calc(2vw + 10.1px);
	}
	.compMain {
		width: calc(100% - 20px);
	}
	.compImgInner {
		width: calc(100% - 20px);
	}
	.compImg img {
		height: 68vw;
	}
}
@media only screen and (max-width: 480px) {
	.compMain {
		padding : 4vw; 3vw 6vw 3vw;
	}
	.leftWord {
		font-size: 12px;
	}
	.compMain .word {
		font-size : 12px;
	}
}
@media only screen and (max-width: 400px) {
	.moreRev_w {
		width: 180px;
		font-size: 14px;
		line-height: 48px;
	}
	.moreRev_w::after {
		top: 28%;
		font-size: 20px;
	}
	.compMainRec {
		padding : 6vw 3vw 6vw 4vw;
	}
}

.centerMark {
	text-align: center;
}
.centerMark .mark01 {
	width : 25vw;
	max-width : 144px;
}
.centerMark .mark02 {
	width : 22vw;
	max-width : 109px;
}
.centerMark .mark03 {
	width : 33vw;
	max-width : 222px;
}

/* 施工実績詳細 */

.detailWrap {
	width : 100%;
	max-width : 824px;
	padding-top : 60px;
}
.detailWrap .detailTitle {
	font-size : 36px;
	font-weight : 500;
	color : #8f8f8f;
	position : relative;
}
.detailWrap .detailTitle::after {
	content : "";
	display : block;
	width : 1px;
	height : 56px;
	font-size : 0;
	margin : 12px auto 0 auto;
	border-left : 2px solid #389757;
}
.detailWrap .photoWrap {
	
}
.detailWrap .photoMain {
	
}
.detailWrap .photoMain img {
	width : 100%;
	height : 62vw;
	max-height : 560px;
	object-fit: contain;
}
.detailWrap .photoThumb {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
    list-style: none;
}
.detailWrap .photoThumb img {
	
}
.detailWrap .sizeWrap {
	background-color : #ececec;
	padding : 32px 45px 12px 45px;
	box-sizing: border-box;
}
.detailWrap .sizeTable {
	display : table;
	border-collapse: collapse;
	width : 100%;
	font-size : 1rem;
	color : #797979;
	font-weight : 500;
	margin-bottom : 20px;
}
.detailWrap .sizeTable dt {
	display : table-cell;
	vertical-align: top;
	font-size : 1rem;
	color : #797979;
	width : 25%;
	padding : 16px 10px 16px 24px;
	box-sizing: border-box;
	background-color : #ffffff;
	border-right : 2px solid #ececec;
	position : relative;
}
.detailWrap .sizeTable dt::before {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 20px 0 0;
  border-color: #329d58 transparent transparent transparent;
  z-index: 10;
}
.detailWrap .sizeTable dd {
	display : table-cell;
	vertical-align: top;
	font-size : 1rem;
	color : #797979;
	width : 75%;
	padding : 16px 10px 16px 24px;
	box-sizing: border-box;
	background-color : #ffffff;
}
.detailMore {
	display : -webkit-flex;
	display : flex;
	-webkit-justify-content : space-between;
	justify-content : space-between;
	border-top : 1px solid #afafaf;
	border-bottom : 1px solid #afafaf;
	padding : 16px 0;
}
.detailMore div {
	width : 33.3%;
}
.detailMore a {
	font-size : 1rem;
	font-weight : 500;
	color : #797979;
	text-decoration: underline;
	transition: 0.3s;
}
.detailMore a:hover {
	color : #000000;
}
.detailMore a span {
	display : inline;
}
@media only screen and (max-width: 1080px) {
	.detailWrap .detailTitle {
		font-size : calc(2.37vw + 10.4px);
	}
	.detailWrap .detailTitle::after {
		height : calc(3.16vw + 21.9px);
	}
	.detailWrap .sizeWrap {
		padding : 4vw 4.5vw 1.2vw 4.5vw
	}
}
@media only screen and (max-width: 480px) {
	.detailWrap .sizeTable {
		display : block;
		margin-bottom : 16px;
	}
	.detailWrap .sizeTable dt {
		display : block;
		width : 100%;
		padding : 8px 10px 8px 24px;
		border-right : none;
		border-bottom : 1px solid #ececec;
	}
	.detailWrap .sizeTable dt::before {
		border-width: 16px 16px 0 0;
	}
	.detailWrap .sizeTable dd {
		display : block;
		width : 100%;
		padding : 8px 10px 8px 24px;
	}
	.detailMore a span {
		display : none;
	}
}

/* お問い合わせ */

.narrowWrap {
	width: 100%;
	max-width: 1068px;
	margin: 0 auto;
	padding: 0 8px;
	box-sizing: border-box;
}

.contactWrap  {
	width : calc(100% - 20px);
	max-width : 720px;
	margin : 0px auto 0 auto;
	padding : 0 10px;
	background-color : #ffffff;
}
.contactWrap h2 {
	font-size : 32px;
	color : #000000;
	line-height ; 1.8;
	font-weight : 700;
	margin-bottom : 24px;
	border-bottom : 1px solid #000000;
}
.contactForm {
	width : 100%;
}
.contactForm dl {
	display : table;
	width : 100%;
	border-collapse: collapse;
	table-layout : fixed;
	border-bottom : 1px solid #000000;
	word-wrap: break-word;
}
.contactForm dl.first {
	border-top : 1px solid #000000;
}
.contactForm dt {
	display : table-cell;
	vertical-align: middle;
	font-size : 1rem;
	color : #4d4d4d;
	background-color : #f8f8f8;
	font-weight : 400;
	width : 25%;
	padding : 14px 24px;
	border-left : 1px solid #000000;
	text-align : left;
}
.contactForm dt p {
	position : relative;
}
.contactForm dd {
	display : table-cell;
	vertical-align: middle;
	font-size : 1rem;
	color : #000000;
	background-color : #ffffff;
	font-weight : 400;
	width : 75%;
	padding : 14px 24px;
	border-right : 1px solid #000000;
	word-wrap: break-word;
}
.contactForm dd label {
	display : inline-block;
	width : 10em;
	color : #6d6d6d;
}
.contactForm dd label input {
	display : inline-block;
	margin-right : 16px;
}
.contactForm dt span  {
	position : absolute;
	top : 0px;
	right : 10px;
	display : inline-block;
	padding : 6px 12px;
	font-size : 14px;
	font-weight : bold;
	line-height : 1.0;
	color : #ff0000;
}
.privWrap  {
	margin-top : 20px;
	background-color : #ffffff;
	padding : 30px;
	font-size : 16px;
	width : 100%;
	box-sizing: border-box;
}
.privWrap h3 {
	font-size : 24px;
	font-weight : 700;
	color : #000000;
	text-align : center;
	margin-bottom : 36px;
}
.privWrap h4 {
	font-size : 1.15rem;
	font-weight : 700;
	color : #000000;
	margin-top : 24px;
}
.privWrap p {
	font-size : 1rem;
	font-weight : 400;
	color : #000000;
}
.privWrap dt {
	display : inline-block;
	vertical-align: top;
	width : 20px;
	font-size : 1rem;
	font-weight : 400;
	color : #000000;
}
.privWrap dd {
	display : inline-block;
	vertical-align: top;
	width : calc(100% - 30px);
	font-size : 1rem;
	font-weight : 400;
	color : #000000;
}
@media only screen and (max-width: 1200px) {
	.contactWrap h2 {
		font-size : calc(2.05vw + 11.4px);
		margin-bottom : 3.4vw;
	}
	.contactWrap p {
		font-size : calc(0.34vw + 11.9px);
	}
	.contactWrap p strong {
		font-size : calc(0.91vw + 13.1px);
	}
	.contactWrap p a {
		font-size : calc(0.68vw + 11.8px);
	}
}
@media only screen and (max-width: 860px) {
	.contactForm dt span  {
		top : 0px;
		right : -14px;
		font-size : 13px;
	}
}
@media only screen and (max-width: 800px) {
	.contactWrap  {
		width: calc(100% - 8vw);
		padding : 20px 4vw;
	}
	.contactWrap h3 {
		padding-bottom : 12px;
		margin-bottom : 40px;
	}
	.contactWrap h3 strong {
		font-size : 28px;
		padding-top : 6px;
	}
	.contactWrap .comm p {
		font-size : 18px;
		color : #000000;
		line-height : 1.8;
	}
	.compBottom  {
		margin-bottom : 12vw;
	}
	.contactForm dt span  {
		right : 6px;
	}
	.contactWrap dt {
		padding : 30px 50px 10px 0;
	}
	.contactForm dl {
		display : block;
	}
	.contactForm dl.first {
		border-top : 1px solid #000000;
	}
	.contactForm dt {
		display : block;
		width : 100%;
		padding : 10px 20px;
		border-left : 1px solid #000000;
		border-right : 1px solid #000000;
		text-align : left;
		box-sizing: border-box;
	}
	.contactForm dd {
		display : block;
		width : 100%;
		padding : 10px 20px;
		border-left : 1px solid #000000;
		border-right : 1px solid #000000;
		box-sizing: border-box;
	}
	.privWrap  {
		padding : 3vw;
		font-size : 1rem;
	}
}
@media only screen and (max-width: 680px) {
	.contactWrap dl {
		display : block;
		width : 100%;
		margin-bottom : 0px;
	}
	.contactWrap dt {
		display : block;
		width : calc(100% - 20px);
		padding : 10px;
		border-top : 1px solid #f9f9f9;
		text-align : left;
	}
	.contactWrap dd {
		display : block;
		width : calc(100% - 22px);
		padding : 10px;
		border-bottom : 1px solid #e5e8ed;
	}
	.contactForm dt span  {
		top : -3px;
	}
}
@media only screen and (max-width: 480px) {
	.contactWrap h3 {
		padding-bottom : 12px;
		margin-bottom : 32px;
	}
	.contactWrap h3 strong {
		font-size : 24px;
		padding-top : 6px;
	}
	.privWrap h3 {
		padding-bottom : 12px;
		margin-bottom : 32px;
	}
	.privWrap h3 strong {
		font-size : 24px;
		padding-top : 6px;
	}
	.contactWrap .comm p {
		font-size : 16px;
		color : #000000;
		line-height : 1.8;
	}
	.compBottom  {
		margin-bottom : 16vw;
	}
	.contactWrap dd div label {
		display : block;
		font-size : 13px;
		margin : 8px 0;;
		padding : 8px;
	}
	.contactForm dd label {
		display : inline-block;
		width : 80vw;
		color : #6d6d6d;
		margin : 8px 0 12px 0;
	}
}

/*お問い合わせ*/

.formTable option  {
	font-size : 14px;
	padding : 3px;
}
.formTable select  {
	font-size : 14px;
	padding : 3px;
}
.formBtn  {
	margin-bottom : 80px;
}
.form-field {
	border: 1px solid #ababab;
	background: #ffffff;
	color : #333333;
	padding : 6px;
	font-size : 16px;
	width: calc(90% - 80px);
}
input.form-field {
	max-width : 350px;
}
.form-name {
	border: 1px solid #ababab;
	background: #ffffff;
	color : #333333;
	padding : 6px;
	font-size : 16px;
	width: calc(70% - 80px);
	max-width: 300px;
}
.form-long {
	border: 1px solid #ababab;
	background: #ffffff;
	color : #333333;
	padding : 6px;
	font-size : 16px;
	width: calc(80% - 80px);
}
.inputarea1  {
	border: 1px solid #ababab;
	color : #333333;
	padding : 6px;
	font-size : 16px;
}
span.hissu {
	display : inline-block;
	vertical-align: top;
	padding-left : 8px;
	padding-top : 6px;
	font-size  : 14px;
	color : #fe0000;
}
.w120   {
	width: 120px !important;
}
.w240   {
	width: 240px !important;
}
#comment  {
	height : 110px;
	line-height : 22px;
}
.uploadArea  {
	border : 1px solid #cccccc;
	display : inline-block;
}
.uploadArea p.ttl {
	font-size : 13px;
	color : #ffffff;
	background-color : #0eb1dc;
	padding : 4px;
	display : inline-block;
}
.uploadArea div {
	padding : 8px 10px;
}
.thanks  { margin-bottom : 80px; }
.thanks h2  {
	font-size : 18px;
	line-height : 36px;
	text-align : center;
	color : #000000;
}
.thanks p  {
	width : 100%;
	max-width : 530px;
	margin : 10px auto;
	color : #000000;
}
a.hinbanbutton  {
	display : inline-block;
	padding : 8px 14px;
	background-color : #0eb1dc;
	color : #ffffff;
	font-size : 12px;
	font-weight : bold;
	text-decoration : none;
}
a.hinbanbutton:hover  {
	background-color : #27caf3;
	color : #ffffaa;
}

.form-field:focus {
   background: #fff;
   color: #725129;
}
.form-container h2 {
   text-shadow: #fdf2e4 0 1px 0;
   font-size:18px;
   margin: 0 0 10px 0;
   font-weight:bold;
   text-align:center;
}
.form-title {
   margin-bottom:10px;
   color: #725129;
   text-shadow: #fdf2e4 0 1px 0;
}
.submit-container {
	width: 400px;
	text-align: center;
	position : relative;
}
.submit-button {
	width: 400px;
	color: #FFF;
	border : none;
	padding: 24px 0 26px 0;
	font-size : 18px;
	font-weight: bold;
	text-decoration: none;
	vertical-align: middle;
	cursor : pointer;
	background-color : #28954d;
	position : relative;
}
.submit-container::after {
	content : ">";
	position : absolute;
	top : 10px;
	right : 30px;
	font-size : 32px;
	font-weight : 700;
	color :#ffffff;
	font-family : Arsenal, sans-serif;
}
.submit-button:hover  {
	opacity : 0.7;
}
.submit-button2 {
	width: 304px;
	color: #FFF;
	border : none;
	padding: 20px 0 24px 0;
	font-size : 18px;
	font-weight: bold;
	text-decoration: none;
	vertical-align: middle;
	cursor : pointer;
	background : url(../img/subm_back2.png) no-repeat 0 0;
}
.submit-button2:hover  {
	opacity : 0.7;
}
.contactTop dl {
	display : table;
	width : 100%;
}
.contactTop dl dt {
	display : table-cell;
	vertical-align: middle;
	text-align : left;
	width : 24%;
	padding-right : 5%;
	border-right : 1px solid #000000;
	font-size : 1.4rem;
	font-weight : 400;
	color : #000000;
}
.contactTop dl dd {
	display : table-cell;
	vertical-align: middle;
	text-align : left;
	width : 66%;
	padding-left : 5%;
	font-size : 1rem;
	font-weight : 400;
	color : #000000;
	line-height : 1.8;
}
.pp-container  {
	margin : 32px 0 12px 0;
	text-align : left;
	color : #000000;
	background-color : #f0f0f0;
	padding : 16px;
}
.pp-container h4 {
	font-size : 16px;
	text-align : center;
	margin-bottom : 16px;
	color : #000000;
}
.pp-container p {
	font-size : 14px;
	text-align : left;
	margin-bottom : 16px;
	color : #000000;
}
.pp-container a {
	display : block;
	font-size : 13px;
	text-align : left;
}
.pp-check  {
	text-align : center;
	font-size : 16px;
	font-weight : 500;
	color : #000000;
	margin : 0 20px 10px 0;
}
.pp-check input[type=checkbox] {
	width:			20px;
	height:			20px;
	-moz-transform:		scale(1.3);
	-webkit-transform:	scale(1.3);
	transform:		scale(1.3);
}
.pp-check label a {
	color : #000000;
	text-decoration: underline;
	text-decoration-color : #6d6d6d;
}
.pp-check span  {
	display : inline-block;
	vertical-align : top;
	margin-left : 6px;
	position : relative;
	top : -1px;
}
.errorText  {
	color : #ff0000;
	font-size : 13px;
}
.sendmes    {
	text-align : center;
	line-height : 1.6;
	margin-bottom : 120px;
}
.errorText  {
	font-size : 12px !important;
	color : #ff0000 !important;
}
.formLeft  {
	display : inline-block;
	vertical-align : top;
}
.formRight  {
	display : inline-block;
	font-size : 12px;
	color : #4b4b4b;
	padding-left : 24px;
}
.formRight a {
	display : inline-block;
	padding : 4px 0;
	color : #4b4b4b;
}
.formRight dt {
	display : inline-block;
	color : #4b4b4b;
	font-size : 12px;
	line-height : 20px;
	padding : 0px 0;
	width : 18px;
	text-align : left;
	vertical-align : top;
}
.formRight dd {
	display : inline-block;
	color : #4b4b4b;
	font-size : 12px;
	line-height : 20px;
	padding : 0px 0;
	width : calc(100% - 18px);
	text-align : left;
	vertical-align : top;
}
@media only screen and (max-width: 800px) {
	.contactTop dl {
		display : block;
		width : 100%;
	}
	.contactTop dl dt {
		display : block;
		text-align : left;
		width : 100%;
		padding : 0 0 1.5vw 0;
		border-right : none;
		border-bottom : 1px solid #000000;
		font-size : 1.4rem;
		
	}
	.contactTop dl dd {
		display : block;
		text-align : left;
		width : 100%;
		padding : 1.5vw 0 0 0;
	}
}
@media only screen and (max-width: 480px) {
	.form-field {
		padding : 5px;
		font-size : 14px;
		width: 96%;
	}
	.form-name {
		padding : 5px;
		font-size : 14px;
		width: calc(88% - 40px);
	}
	.form-long {
		padding : 5px;
		font-size : 14px;
		width: calc(92% - 40px);
	}
	.inputarea1  {
		padding : 5px;
		font-size : 14px;
	}
	.pp-check  {
		text-align : center;
		font-size : 14px;
		font-weight : 500;
		color : #000000;
		margin : 30px 0 40px 0;
	}
	.pp-check input[type=checkbox] {
		width:			20px;
		height:			20px;
		-moz-transform:		scale(1.2);
		-webkit-transform:	scale(1.2);
		transform:		scale(1.2);
	}
	.submit-container {
		width: 100%;
		text-align: center;
		position : relative;
	}
	.submit-button {
		width: 94%;
		padding: 14px 0 16px 0;
		font-size : 16px;
	}
	.submit-container::after {
		top : 3px;
		right : 24px;
		font-size : 28px;
	}
}

/* フッター包括---------------------------*/

footer {
	position: relative;
	z-index: 3;
	background-color: #0ffffff;
	padding-bottom : 200px;
}
.mgt0 {
	margin-top: 0 !important;
	padding: 0 !important;
}
.footlogo {
	width : 80%;
	max-width : 600px;
	border-top : 1px solid #000000;
	border-bottom : 1px solid #000000;
	padding : 16px 0 12px 0;
}
.footlogo img {
	width : 80%;
	max-width : 392px;
}
.footerTable {
	width: 100%;
	padding: 60px 0;
}
.footerTable .footMenu {
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	margin-top: 0px;
}
.footMenu a {
	display: block;
	font-size: 1rem;
	color: #000000;
	font-weight : 500;
	transition: 0.3s;
	padding: 0 10px;
	line-height :  1.1;
}
.footMenu a.sub {
	border-right : 1px solid #ffffff;
}
.footMenu a:hover {
	color: #28954d;
}
.copyright {
	text-align: center;
	font-size: 12px;
	color: #000000;
	padding: 40px 0 100px 0;
	position : relative;
}
.copyright span {
	position : absolute;
	left : calc(50% + 300px);
	top : 40px;
}
.wrapContact {
    cursor: pointer;
    display: block;
    position: fixed;
    right: 0;
    bottom: 0;
	width : 279px;
	height : 69px;
	font-size : 0;
	line-height : 0;
	z-index : 999;
}
.wrapContact {
	cursor: pointer;
	display: block;
	position: fixed;
	right: 0;
	bottom: 0;
	width: 279px;
	height: 69px;
	font-size: 0;
	line-height: 0;
	z-index: 999;
}
.footIns {
	position : relative;
	top : -4px;
}
@media only screen and (max-width: 1060px) {
	.footMenu a {
		font-size: 13px;
		padding: 0 14px;
	}
}
@media only screen and (max-width: 640px) {
	.footerTable {
		display : none;
	}
	.copyright span {
		position : absolute;
		left : auto;
		right : 10px;
		top : 40px;
	}
}
@media only screen and (max-width: 500px) {
	.footerTable {
		display : none;
	}
	.copyright span {
		position : relative;
		display : block;
		left : 0;
		right : 0;
		top : 0;
		text-align : center;
	}
}

/* 管理画面フッター */
#admin_contener {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.admin_footer {
	margin-top: auto;
	background-color: #474747;
	position: relative;
}

.admin_footer .footerCopy {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	text-align: right;
	color: #ffffff;
	font-size: 12px;
	padding: 32px 0;
}

.admin_footer .safety {
	position: absolute;
	top: 4px;
	left: 4px;
}

.wrapPageTopPc  {
    position: fixed;
    bottom : 20px;
    right: 6px;
    z-index: 99;
	text-align : center;
    width : 54px;
	cursor : pointer;
}
.wrapPageTopPc p {
    text-align : center;
	background-color : #000000;
	font-size : 14px;
	font-weight : bold;
	color : #ffffff;
	border : 2px solid #000000;
	border-radius : 14px;
	line-height : 1.4;
	padding : 6px 0 5px 0;
	transition: 0.4s;
}
.wrapPageTopPc p span {
	display : block;
	font-size : 14px;
}
.wrapPageTopPc p:hover {
	background-color : #ffffff;
	color : #000000;
}

.bshadow {
	box-shadow: rgba(115, 116, 117, 0.65) 2px 2px 4px 0px;
	-webkit-box-shadow: rgba(115, 116, 117, 0.65) 2px 2px 4px 0px;
	-moz-box-shadow: rgba(115, 116, 117, 0.65) 2px 2px 4px 0px;
}

.cshadow {
	border: 3px solid #ffffff;
	box-shadow: rgba(115, 116, 117, 0.65) 2px 2px 4px 0px;
	-webkit-box-shadow: rgba(115, 116, 117, 0.65) 2px 2px 4px 0px;
	-moz-box-shadow: rgba(115, 116, 117, 0.65) 2px 2px 4px 0px;
}

.servWrap00 {
	width: 960px;
	margin: 0 auto;
}

.servWrap01 {
	width: 1080px;
	margin: 0 auto;
}
