/*-------色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: 85%;
		-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;
	}
	#cover {
		width:100%;
		margin:0 auto 30px;
	}
	article {
		padding:0;
	}
    .contents_header .head_inner > .title {
		color: #333;
		font-size: 1.3rem;
 		text-align: center;
		padding: 20px;
	}
	
	/* header */
	#header {
		min-width: 100%;
		width:100%;
		position:static;
		float:none;
		background:#004e9c;
	}
	#header .header {
		width: 100%;
		margin: 0 auto;
	}
	#header .header:after {
		content:" ";
		display:table;
		clear:both;
	}
	#header .header .head-logo {
		width: 55%;
		max-width:200px;
		height:auto;
		float:left;
		margin-bottom:0;
	}
	#header .header .head-logo img {
		width: 100%;
	}
	#header .header .head-inquiry {
		display: none;
	}
	
	/* navigation */
	#sp_navi {
		float:right;
		display:block;
	}
	#sp_navi li {
		position:absolute;
		width: 40px;
		display:block;
		background:#fff;
		right:40px;
		top:0;
		z-index:10;
	}
	#gnavi > ul > li:after {
		content:none;
	}
	#sp_navi img {
		width: 100%;
		display:block;
	}
	#sp_navi li#gnavi_open {
		position:fixed;
		width:40px;
		height:40px;
		z-index:100;
		background:#004e9c;
		right:0;
		left:auto;
		z-index:1000;
	}
	#drawer_underlay {
		position: absolute;
		width: 100%;
		height: 100%;
		background: rgba(0, 0, 0, 0.5);
		top: 0;
		left: 0;
		z-index:1;
	}
	#gnavi {
		position: fixed;
		width: 100%;
		min-width: 100%;
		height: 60%;
		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: -60%;
		left:0;
		-webkit-transition: all .2s;
		-moz-transition: all .2s;
		-o-transition: all .2s;
		transition: all .2s;
		z-index:10;
	}
	#gnavi.open {
		-webkit-transform: translateY(100%);
		-moz-transform: translateY(100%);
		transform: translateY(100%);
	}
	#gnavi_open.trans {
		position:fixed;
	}
	#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;
		    text-shadow: 0 0 0 #fff;
		padding: 14px 0;
		background: #000;
	}
	#gnavi > ul > li > a:before {
		content:none;
	}
	#gnavi > ul > li > a:hover {
		color:#fff;
	}
	#gnavi > ul > li > a:hover:before {
		content: none;
	}
	#gnavi > ul > li > a:hover:after {
		content: none;
	}
	#gnavi + #visual {
		border-bottom: 0px;
	}
	#contents {
		width:100%;
		float:none;
	}
	#contents .contents_header {
		width: 100%;
	}
	#contents .contents_header .head_inner {
		width: 100%;
	}
	
	/* contents */
	#visual {
		min-width: 100%;
		height:auto;
		overflow:hidden;
		margin-bottom:15px;
	}
	#visual .visual {
		width: 100%;
		max-width:100%;
		position:static;
	    -webkit-transform: none;
	    -ms-transform: none;
   		transform: none;
	}
	#visual .visual img {
		width:100%;
	}
	
	/* スライダー用str 使わない場合は消す */
	
	#visual .custom-slick-prev, #visual .custom-slick-next {
		display:none!important;
	}
	.slick-dots {
		width:100%!important;
	}
	
	/* スライダー用end */


	.section {
	}
	#contents .section > .section_title {
		width: 100%;
	}
	.section .section_inner {
		width: 100%;
		padding: 40px 10px 20px;
	}
	
	/*.sns_icon*/
	
	.sns_icon {
		width:100%;
		padding:0 5px;
		text-align:center;
		margin-bottom:0;
	}
	.sns_icon li {
		width:7%;
	}
	.sns_icon li img {
		width:100%;
		
	}
	.sns_icon li:hover {
		opacity:1;
	}

	/* footer */
	.footer {
		min-width: 100%;
	}
	.footer .footer_inner {
		width:100%;
		padding: 30px 0px 20px;
		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:#fff;
	}
	.copy {
		font-size: 2vw;
		text-align: center;
		width: 100%;
		margin: 0 auto;
	}
	.copy img {
		margin: 0 auto;
		display: block;
		top:0;
	}
	.copy a {
		color:#fff;
		text-decoration: none;
	}
	
	/* 戻る */
	.return {
		position:relative;
		line-height:0;
	}
	.return a img {
		width:50px;
	}

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

	/*.concept*/
	
	.concept {
		padding:50px 10px 30px;
	}
	.concept_inner {
		width:100%;
		padding:0 10px 15px;
		background-size: 100%;
		background-position:top 50px center;
	}
	.concept_main {
		width:100%;
		text-align:center;
	}
	.concept_msg {
		width:100%;
		float:none;
		text-align:center;
		margin-bottom:20px;
	}
	.concept_title {
		font-size:1.2rem;
		margin:0 auto 60px;
		line-height:1.4;
		letter-spacing:0.8px;
	}
	.concept_msg {
		padding:15px 25px 5px;
	}
	#contents .concept_catch {
		font-size:1.05rem;
		text-align:left;
	}
	.concept_text {
		text-align:left;
	}
	.concept_catch:before {
		width:3px;
		top:-15px;
		left:-15px;
	}


	/*.service*/
	
	.service {
		padding:70px 0;
		
	}
	.service_inner {
		padding-bottom:40px;
	}
	.service_inner:after {
		top:40px;
		left:0;
	}
	.service_title {
		width:100px;
		display:flex;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.service_set:nth-child(odd) {
		flex-direction: none;
	}
	.service_set:nth-child(odd) .service_msg {
		text-align:left;
	}
	.service_list {
		padding:0 20px;
	}
	.service_set {
		display:block;
		text-align:left;
		margin-bottom:40px;
	}
	.service_img {
		width:100%;
		margin-bottom:10px;
	}
	.service_img span {
		height:200px;
		position:relative;
		overflow:hidden;
		display:block;
	}
	.service_msg {
		width:100%;
		padding-top:10px;
	}
	.service_set_title {
		font-size:1.1rem;
	}


	/*.company*/
	
	.company {
		width:100%;
		padding:70px 0 60px;
	}
	.title_position {
		float:none;
	}
	.company_title {
		width:100px;
		display:flex;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.company_inner {
		width:100%;
		padding:0 10px;
	}
	.company_table {
		width: 100%;
	}
	.company_table th, .company_table td {
	}
	.company_table td span.map_jump a {
		font-size: 0.75rem;
	}
	.company_table td span.map_jump a:hover {
		opacity:1;
	}
	.company_table th {
		width: 30%;
		font-size:0.85rem;
		padding:15px 20px 15px 5px;
		vertical-align:top;
	}
	.company_table th:after {
		width:3px;
		height:3px;
		top:20px;
	}
	.company_table td {
		font-size:0.8rem;
		padding-left: 20px;
	}
	


	/* .news */
	
	.news {
		padding:80px 0 50px;
	}
	.news_inner {
		width:100%;
		display:block;
		padding:0 20px;
	}
	.news_head {
		width:100%;
		display:block;
		border-right:none;
	}
	.news_title {
		width:100px;
		display:flex;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.news_body {
		width:100%;
		padding:0;
		display:block;
	}
	.news_list li {
		margin-bottom:0;
		padding:10px 0;
	}
	.news_date {
		width:100%;
		float:none;
	}
	.news_msg {
		padding-left:0;
	}

	/* mailform */
	
	.mailform {
		padding:70px 0 60px;
	}
	.mailform_title {
		width:100px;
		display:flex;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.mailform_inner:after {
		top:40px;
		left:0;
	}
	.mailform_inner {
		width:100%;
	}
	.inquiry_inset {
		width:100%;
		padding: 0 20px;
		margin:0 auto 20px;
	}
	.inquiry_inset_title {
		font-size:1.6rem;
	}
	#contents .important_list {
		margin-bottom:45px;
	}
	.important_list li {
		font-size:0.75rem;
	}
	.mailform span.required, .mailform span.any {
		font-size: 0.7rem;
	}
	#contents .mailform table {
		width: 100%;
		font-size:0.9rem;
		margin: 5px auto 25px;
	}
	.mailform th, .mailform td {
		padding:0;
		border:none;
		display:block;
		width:100%;
	}
	.mailform tr {
		border-top:1px solid #fff;
		border-bottom:1px solid #fff;
	}
	.mailform tr:last-child td {
		padding-bottom:0;
	}
	.mailform th {
		background:none;
		padding:15px 15px 10px;
	}
	.mailform td {
		color: #bcbcbc;
		margin-bottom:20px;
	}
	.mailform input, .mailform textarea {
		width: 100%;
		font-family: "Arial", "メイリオ", "Meiryo", verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
		font-size: 0.8rem;
		padding:12px;
	}
	#contents .btn_top_msg {
		margin-bottom:5px;
		text-align:left;
	}
	.send_btn_inner {
		text-align: center;
		padding: 10px 0;
	}
	.send_btn {
		font-size: 0.95rem;
		padding: 10px 30px;
	}
	.send_btn:hover {
		opacity:1;
	}
	.submit_btn {
		width: 80%;
	}
	.attent_block {
		width:100%;
		margin:0 auto;
	}
	.message_section {
		padding: 60px 0 0;
		width: 100%;
	}
	.thanks_section {
		padding: 60px 3% 0;
	}
	.thanks_title {
		font-size:1.4rem;
		margin-bottom:10px;
	}
	.thanks_msg {
		font-size:90%;
		text-align:left;
		line-height:1.8;
	}
	.privacy_escription {
		margin-bottom:40px;
	}
	.privacy_escription .title {
		font-size:1.0rem;
		position:relative;
	}
	.privacy_block {
		width:90%;
		height:200px;
		font-size:0.8rem;
		padding:0;
		margin:0 auto;
	}
	.privacy_block_title {
		font-size:0.95rem;
		font-weight:normal;
	}
	.privacy_set_title {
		font-size:0.85rem;
		font-weight:normal;
	}
	
	/*.send_section*/
	
	.send_section {
	}
	.send_section_title {
		font-size: 1.1rem;
	}
	.send_section_inner {
		width:100%;
	}
	
	/*.breadcrumbs*/
	
	.breadcrumbs {
		padding: 5px 0;
	}
	.breadcrumbs ul {
		width: 100%;
		padding:0 5px;
	}
	.breadcrumbs ul:after {
		content: " ";
		display: table;
		clear: both;
	}
	.breadcrumbs ul li {
		font-size: 0.7rem;
		margin-right: 5px;
		float: left;
	}
	.breadcrumbs ul li a {
		color: #111;
		display: inline-block;
		margin-right: 4px;
	}
	.breadcrumbs ul li a:hover {
		text-decoration: none;
	}
	

	/*.exit_service*/
	
	.exit_service {
		padding:70px 0;
	}
	.exit_service_inner {
		padding-bottom:40px;
	}
	.exit_service_title {
		width:100px;
		display:flex;
		float:none;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.exit_service_title:before {
		height:3px;
		bottom:25px;
	}
	.exit_service_title span {
		font-size: 0.85rem;
		padding-top:0;
	}
	.exit_service_inner {
		width:100%;
		display:block;
	}
	.exit_service_inner:before {
		left:0;
		top:40px;
	}
	.exit_service_list {
		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:1rem;
	    padding: 0 0 5px 5px;
	    margin-bottom: 10px;
	}
	#contents .exit_service_text {
		font-size:0.9rem;
		padding:0 5px;
		margin-bottom:0;
	}		


	/*.exit_concept*/
	
	.exit_concept {
		padding:70px 0;
	}
	.exit_concept_title {
		width:100px;
		display:flex;
		float:none;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.exit_concept_inner {
		width:100%;
		padding:0 20px;
	}
	section:nth-child(odd) .exit_concept_main {
		padding:0;
	}
	.exit_concept_main {
		padding:0;
	}
	#contents .exit_concept_catch {
		font-size: 1rem;
    	margin-bottom: 20px;
	}
	.exit_concept_msg {
		line-height: 1.8;
	}
	
	/*.recruit*/
	
	.recruit {
		padding:70px 0;
	}
	.recruit_title {
		width:100px;
		display:flex;
		float:none;
		margin:0 auto 40px;
		font-size:1.1rem;
	}
	.recruit_inner {
		width:100%;
		padding:0 20px;
	}
	.recruit_table {
		width:100%;
	}
	.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 th {
		width: 30%;
		vertical-align:top;
	}
	.recruit_table td {
		padding-left: 30px;
	}

	
	/*.price*/
	
	.price {
		padding:70px 0;
	}
	.price_title {
		width:100px;
		display:flex;
		float:none;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.price_inner {
		width:100%;
		padding:0 20px;
	}
	.price_list li {
		padding:15px 20px 5px;
	}
	.price_name {
		font-size:0.85rem;
		width:100%;
		text-align:left;
	}
	.price_value {
		font-size:1rem;
		width:100%;
		text-align:right;
	}


	/*.works*/
	
	.works {
		padding:70px 0;
	}
	.works_title {
		width:100px;
		display:flex;
		float:none;
		margin:0 auto 40px;
		font-size:1.2rem;
	}
	.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;
	}

    /*.inquiry.html*/
    #contents .send_confirm_table table {
            border-bottom: 1px solid #ccc;
    }   
    #contents .send_confirm_table table th,
    #contents .send_confirm_table td {
        display: block;
        width: 100%;
        border-bottom: none;
        font-size: 100%;
    }
	


}