/*-------色str-------*/


/*青*/




/*-------色end-------*/

@charset "utf-8";
@media screen and (max-width:767px) {
	/* reset css
	---------------------- */
													
	@font-face {
		font-family: 'Arial Black';
		font-style: normal;
		font-weight: 400;
		src: local('Arial Black'), url('ariblk_0.ttf') format('ttf');
	}
	html {
		width: 100%;
		height: 100%;
	}
	* {
		box-sizing: border-box;
	}
	body {
		position: relative;
		width: 100%;
		min-width: 100%;
		font-size: 15px;
		-webkit-overflow-scrolling: touch;
	}
	a:link {
		color: #444;
	}
	
	/* LAYOUT
	---------------------- */
	#page {
		position: relative;
		width: 100%;
		margin: 0 auto;
		-webkit-transition: all .2s;
		-moz-transition: all .2s;
		-o-transition: all .2s;
		transition: all .2s;
	}
	
	/* header */
	#header {
		min-width: 100%;
		background:#fff;
		border-bottom:2px solid #004e9c;
		padding: 0 2% 8px;
		position:static;
	}
	#header h1 {
		width: 100%;
	}
	#header .header {
		width: 100%;
		margin: 0 auto;
	}
	#header .header:after {
		content:" ";
		display:table;
		clear:both;
	}
	#header .header .head-logo {
		width: 55%;
		max-width:200px;
		padding-top:5px;
		float:left;
	}
	#header .header .head-logo img {
		width: 100%;
	}
	#header .header .head-inquiry {
		display: none;
	}
	
	/* navigation */
	#sp_navi {
		width: 22%;
		max-width:80px;
		float:right;
		display:block;
	}
	#sp_navi li {
		position: absolute;
		width: 40px;
		display:block;
		background:#000;
		right:40px;
	}
	#gnavi > ul > li:after {
		content:none;
	}
	#sp_navi img {
		width: 100%;
		display:block;
	}
	#sp_navi li#gnavi_open {
		position:fixed;
		background:#004e9c;
		width:40px;
		height:40px;
		top:0;
		z-index:100;
		right:0;
		left:auto;
		z-index:10000;
	}
	#drawer_underlay {
		position: absolute;
		width: 100%;
		height: 100%;
		background: rgba(0, 0, 0, 0.5);
		top: 0;
		left: 0;
		z-index:10;
	}
	#gnavi {
		position: fixed;
		width: 100%;
		min-width: 100%;
		height: 65%;
		font-size: 110%;
		border-top: inherit;
		border-bottom: inherit;
		padding: 20px 5%;
		background: #000;
		overflow-x: hidden;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		top: -65%;
		left:0;
		-webkit-transition: all .2s;
		-moz-transition: all .2s;
		-o-transition: all .2s;
		transition: all .2s;
		z-index:1000;
		cursor: none;
	}
	#gnavi.open {
		-webkit-transform: translateY(100%);
		-moz-transform: translateY(100%);
		transform: translateY(100%);
	}
	#gnavi_open.trans {
		position:fixed;
		right:0;
		top:0;
	}
	#gnavi_open:before, #gnavi_open:after, #gnavi_open span:after {
		position:absolute;
		content:"　";
		background:#fff;
		width:3px;
		height:25px;
		right:19px;
		transition:0.5s;
	}
	#gnavi_open:before {
		-webkit-transform: rotate(90deg);
		-ms-transform:rotate(90deg);
		transform:rotate(90deg);
		top:-1px;
	}
	#gnavi_open:after {
		-webkit-transform: rotate(90deg);
		-ms-transform:rotate(90deg);
		transform:rotate(90deg);
		top:8px;
	}
	#gnavi_open span:after {
		-webkit-transform: rotate(90deg);
		-ms-transform:rotate(90deg);
		transform:rotate(90deg);
		top:17px;
	}
	#gnavi_open.trans:before {
		-webkit-transform:rotate(135deg);
		-ms-transform:rotate(135deg);
		transform:rotate(135deg);
		top:8px;
		background:#fff;
	}
	#gnavi_open.trans:after {
		-webkit-transform: rotate(-45deg);
		-ms-transform:rotate(-45deg);
		transform:rotate(-45deg);
	}
	#gnavi_open.trans span:after {
		-webkit-transform:rotate(45deg);
		-ms-transform:rotate(45deg);
		transform:rotate(45deg);
		top:8px;
		background:#fff;
	}
	#close {
		font-size: 0.8rem;
		color: #fff;
		padding: 5px;
		text-align:center;
		border: 1px solid #555;
		background: #222;
	}
	#close span {
		font-family: "ＭＳ Ｐゴシック", Osaka, "ヒラギノ角ゴ Pro W3";
		font-size: 130%;
	}
	#gnavi > ul {
		width: 100%;
		padding: 5% 0;
	}
	#gnavi > ul > li {
		width: 100%;
		padding: 0px;
		border-bottom: 1px solid #666;
		float: none;
	}
	#gnavi > ul > li > a {
		position: relative;
		display: block;
		text-decoration: none;
		text-align: left;
		letter-spacing: 2px;
		line-height: 1.5;
		color: #fff;
		padding: 14px 0;
		background: #000;
	}
	#gnavi > ul > li > a:hover {
		color:#fff;
	}
	#gnavi > ul > li > a:hover:before {
		content: none;
	}
	#gnavi > ul > li > a:after {
		content: none;
	}
	#gnavi .sns_icon {
		text-align:center;
		padding:0;
	}
	#gnavi .sns_icon li {
		width:25px;
		display:inline-block;
		margin-right:20px;
		border-bottom:none;
	}
	#gnavi ul.sns_icon li:after {
		content:none;
	}
	.sns_icon li:last-child {
		margin-right:0;
	}
	.sns_icon li:hover {
		opacity:0.8;
	}
	#gnavi .sns_icon li a {
		padding:0;
	}
	#gnavi + #visual {
		border-bottom: 0px;
	}
	#contents {
	}
	#contents .contents_header {
		width: 100%;
	}
	#contents .contents_header .head_inner {
		width: 100%;
	}
	
	/* visual */
	#visual {
		min-width: 100%;
		height:auto;
	}
	#visual .visual {
		width: 100%;
		position:static;
	    -webkit-transform: none;
	    -ms-transform: none;
   		transform: none;
	}
	#visual .visual img {
		width:100%;
	}
	.visual_img {
		position:absolute;
		width: 100%;
    	max-width: 120px;
		top:50%;
		left:50%;
		-webkit-transform: translate(-50%,-50%);
		-ms-transform: translate(-50%,-50%);
		transform: translate(-50%,-50%);
	}
	
	/* スライダー用str 使わない場合は消す */
	
	#visual .custom-slick-prev, #visual .custom-slick-next {
		display:none!important;
	}
	
	/* スライダー用end */
	
	#contents .section > .section_title {
		width: 100%;
	}
	.section .section_inner {
		width: 100%;
		padding: 40px 10px 20px;
	}

.contents_header {
	padding: 25px 0 20px;
}
.contents_header .head_inner > .title {
	font-size: 1.6rem;
}
		
	/* footer */
	.footer {
		min-width: 100%;
	}
	.footer .footer_inner {
		width:100%;
		padding: 30px 0px 10px;
		display:block;
	}
	.footer_logo {
		width:60%;
		margin:0 auto 10px;
	}
	.footer_info {
		text-align:center;
	}
	.footer_address {
		font-size:0.7rem;
	}
	.footer_tel {
		font-size:0.7rem;
	}
	.footer_tel a {
		color:#ffffff;
	}
	.copy {
		font-size: 2vw;
		text-align: center;
		width: 100%;
		margin: 0 auto;
	}
	.copy img {
		margin: 0 auto;
		display: block;
	}
	.copy a {
		color:#fff;
		text-decoration: none;
	}
	
	/* 戻る */
	.return {
		text-align:right;
		width:100%;
		margin:0 auto;
		position:relative;
		line-height:0;
	}
	.return a {
		width:60px;
		right:50%;
		bottom:-30px;
		-webkit-transform: translateX(50%);
		-ms-transform: translateX(50%);
		transform: translateX(50%);
	}
	.return a img {
		width:100%;
	}

	
	/* 各ページ用スタイル
	---------------------- */
	.only_pc {
		display: none;
	}
	.only_sp {
		display: block;
	}
	.tel a {
		pointer-events:inherit;
	}
	

	/* .news */
	
	.news {
		padding:50px 20px 60px;
	}
	.news_inner {
		width:100%;
		padding:20px;
		display:block;
	}
	.news_title {
		width:100%;
		font-size:1.1rem;
		border:none;
		display:block;
	}
	.news_list {
		width:100%;
		padding:0;
		display:block;
	}
	.news_list li {
		margin-bottom:15px;
	}
	.news_date {
		width:100%;
		float:none;
	}
	.news_msg {	
		width:100%;
		float:none;
	}


	/*.concept*/
	
	.concept_inner {
		width:100%;
		padding:40px 20px;
	}
	.concept_title {
		font-size:1.0rem;
		font-weight:normal;
		text-align:center;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	#contents .concept_catch {
		font-size:1.3rem;
		margin-bottom:10px;
	}
	.concept_main_msg {
		text-align:left;
		line-height:1.8;
	}
		
	/*.service*/
	
	.service {
		padding:90px 0;
	}
	.service_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.service_inner {
		width:100%;
		padding:0 15px;
	}
	.service_set {
		width:100%;
		min-height:160px;
		margin-bottom:30px;
		overflow:inherit;
	}
	.service_img {
		position: initial;
		width:100%;
	}
	.service_img span {
		height:190px;
	}
	.service_msg {
		position: relative;
		width:94%;
		margin: 0 auto;
		padding:20px 15px 18px;
		background: rgba(0,0,0,0.9);
		top: -10px;
		transform: initial;
	}
	.service_set_title {
		font-size:0.9rem;
		padding-bottom:8px;
		margin-bottom:15px;
	}
	.service_text {
		font-size:0.8rem;
	}
	
	/*.dual_protection*/
	
	.dual_protection {
		padding:0 0 90px;
		position:relative;
	}
	.dual_protection_inner {
		width:100%;
		margin-bottom:20px;
		display:block;
	}
		
	/*.company*/
	
	.company {
		width:100%;
		float:none;
		padding:70px 20px 50px;
		border-right:none;
		border-bottom:1px solid #c9caca;
	}
	.company_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.company_table dt {
		padding:20px 10px 0 10px;
	}
	.company_table dd {
		padding:0 10px 20px 10px;
	}

	
	/* mailform */

/* mailform */

	.mailform {
		width:100%;
		padding:40px 10px 0;
		float:none;
		border-left:none;
		border-top:1px solid #fff;
	}
	.mailform_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.mailform_inner {
		width:100%;
		padding:0 10px;
	}
	.attent_block {
		padding:0;
	}
	.inquiry_inset {
		padding:0;
		background:none;
	}
	.inquiry_inset_title {
		font-size:0.95rem;
	}
	.mailform table {
		width: 100%;
		border:0;
	}
	.mailform th, .mailform td {
		display: block;
		width: 100%;
		border: none;
	}
	.mailform th {
		padding: 0 0 3px;
		background: none;
	}
	.mailform th span {
		left: auto;
		right: 5px;
	}
	.mailform td {
		padding: 0;
		margin-bottom: 25px;
	}
	.mailform tr:last-child td {
		margin-bottom:0;
	}
	.mailform input, .mailform textarea {
		width: 100%;
	}
	.mailform .form3 {
		vertical-align: middle;
		width: 3%;
	}
	.send_btn {
		font-size: 100%;
		padding: 15px 10px;
	}
	.submit_btn {
		width: 80%;
		margin-bottom: 15px;
	}
	.inputarea li {
		margin: 0 15px 0 0;
		float: left;
	}
	.send_inner .send_btn_inner .btn_return {
		margin-bottom: 25px;
	}
	input[type="submit"], input[type="button"] {
		border-radius: 0;
		-webkit-box-sizing: content-box;
		-webkit-appearance: button;
		appearance: button;
		border: none;
		box-sizing: border-box;
		cursor: pointer;
	}
	input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration {
		display: none;
	}
	input[type="submit"]::focus, input[type="button"]::focus {
		outline-offset: -2px;
	}
.message_section {
	margin: 0 auto;
	padding: 30px 3% 0;
	width: 100%;
}
	.attent_block {
		width:100%;
		padding:0 20px;
	}
	.privacy_escription .title {
		font-size:1.0rem;
	}
	.privacy_block {
		height:150px;
		font-size:0.75rem;
		padding:30px 20px;
	}
	.thanks_section {
	padding: 30px 3% 0;
}
	/* formmail.cgi:send confirm */
	.send_confirm_table {
		padding: 17px 0 30px;
	}
	.send_confirm_table table {
		width: 100%;
		margin: 0 auto;
		border-collapse: collapse;
	}
	.send_confirm_table table th, .send_confirm_table table td {
		border: 0px solid #ccc;
		padding: 17px 20px;
		background: #fff;
		display: block;
	}
	#contents .send_confirm_table table th {
		text-align: left;
		width: 100%;
		background: #f5f5f5;
		margin-bottom: 5px;
		padding: 10px 15px;
	}
	.send_confirm_table table td {
		margin-bottom: 30px;
	}
		
	/*.send_section*/
	
	.send_section {
		padding:80px 0 0;
	}
	.send_section_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.send_section_inner {
		width:100%;
		padding:0 30px;
	}
		
	/*.breadcrumbs*/

	.breadcrumbs ul {
		width: 100%;
		padding:0 10px;
	}
	.breadcrumbs ul li {
		font-size: 0.6rem;
	}
		
	/*.price*/
	
	.price {
		padding:60px 0;
	}
	.price_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.price_inner {
		width:100%;
		padding:0 20px;
	}
	.price_list li {
		width:100%;
		float:none;
		border-bottom:1px solid #000;
		box-sizing:border-box;
		padding:15px 30px 5px;
		margin:0 0 0 0;
	}
	.price_list li:nth-child(2n) {
		margin-right:0;
	}
	.price_list li:nth-child(-n+2) {
		border-top:none;
	}
	.price_list li:nth-child(1) {
		border-top:1px solid #000;
	}
	.price_name {
		width:100%;
		text-align:left;
	}
	.price_value {
		width:100%;
		text-align:right;
	}
	/*.exit_concept*/
	
	.exit_concept {
		padding:60px 0;
	}
	.exit_concept_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.exit_concept_inner {
		width:100%;
		padding:0 20px;
	}
	#contents .exit_concept_catch {
		font-size: 1.1rem;
    	margin-bottom: 20px;
	}


	/*.exit_service*/
	
	.exit_service {
		padding:60px 0;
	}
	.exit_service_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.exit_service_inner {
		width:100%;
		display:block;
		padding:0 20px;
	}
	.exit_service_set {
		width:100%;
		margin:0 0 30px 0;
	}
	.exit_service_set:last-child {
		margin:0;
	}
	.exit_service_set_title {
		font-size:0.95rem;
	    padding: 0 0 5px 5px;
	    margin-bottom: 10px;
	}
	.exit_service_text {
		font-size:0.9rem;
		padding:0 5px;
	}

	/*.works*/
	
	.works {
		padding:60px 0 40px;
	}
	.works_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
	}
	.works_inner {
		width:100%;
		padding:0 20px;
	}
	.works_list {
		width:100%;
	}
	.works_list li {
		width:47.5%;
		margin:0 5% 20px 0;
	}
	.works_list li:nth-child(3n) {
		margin-right:5%;
	}
	.works_list li:nth-child(2n) {
		margin-right:0;
	}


	/*.recruit*/
	
	.recruit {
		padding:60px 0;
	}
	.recruit_title {
		font-size:1.0rem;
		padding:50px 0;
		background:url(img/blue/section-title-img.png) no-repeat center center / 160px;
		margin-bottom:20px;
        text-shadow: 1px 1px #000000;
	}
	.recruit_inner {
		width:100%;
		padding:0;
	}
	.recruit_table th, .recruit_table td {
		padding: 20px 15px;
		font-size:0.8rem;
	}
	.recruit_table tr:last-child th, .recruit_table tr:last-child td {
		padding-bottom:20px;
	}
	.recruit_table td span.map_jump {
		display:block;
		top: 0;
		margin-left: 0;
	}
	.recruit_table td span.map_jump a:hover {
		text-decoration:none;
	}
	.recruit_table th {
		width: 30%;
		vertical-align:top;
	}
	.recruit_table td {
		padding-left: 30px;
	}

}