@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;
	}
	#page.open {
		position: fixed;
		-webkit-transform: translate3d(-80%, 0, 0);
		-moz-transform: translate3d(-80%, 0, 0);
		transform: translate3d(-80%, 0, 0);
	}

	/* header */
	#header {
		min-width: 100%;
	}
	#header .header {
		margin: 0 auto;
		padding: 23px 3% 15px;
		width: 100%;
	}
	#header .header .head-logo {
		margin: 0 auto;
		padding-right: 15%;
		width: 75%;
	}
	#header .header .head-logo img {
		width: 100%;
		display: block;
	}
	#header .header .head-inquiry {
		display: none;
	}

	/* navigation */
	#sp_navi {
		text-align: right;
		width: 25%;
		display: table-cell;
	}
	#sp_navi:after {
		content: " ";
		display: table;
		clear: both;
	}
	#sp_navi li {
		width: 45%;
		float: left;
	}
	#sp_navi li:first-child {
		margin-right: 10%;
	}
	#sp_navi img {
		width: 100%;
		display: block;
	}
	#drawer_underlay {
		height: 100%;
		width: 100%;
		background: rgba(0, 0, 0, 0.5);
		position: absolute;
		top: 0;
		left: 0;
	}
	#gnavi {
		font-size: 110%;
		border-top: inherit;
		border-bottom: inherit;
		padding: 20px 5%;
		height: 100%;
		width: 80%;
		min-width: 80%;
		background: #000;
		position: fixed;
		overflow-x: hidden;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		right: -80%;
		top: 0px;
		-webkit-transition: all .2s;
		-moz-transition: all .2s;
		-o-transition: all .2s;
		transition: all .2s;
	}
	#gnavi.open {
		-webkit-transform: translate3d(-100%, 0, 0);
		-moz-transform: translate3d(-100%, 0, 0);
		transform: translate3d(-100%, 0, 0);
	}
	#close {
		color: #fff;
		font-size: 0.85rem;
		text-align: center;
		border: 1px solid #555;
		padding: 7px 0 5px;
		width: 100%;
		background: #222;
	}
	#gnavi > ul {
		padding: 5% 0;
		width: 100%;
	}
	#gnavi > ul > li {
		border-bottom: 1px solid #666;
		padding: 0px;
		width: 100%;
		float: none;
	}
	#gnavi > ul > li:nth-child(2) {
		width: 100%;
	}
	#gnavi > ul > li > a {
		color: #fff;
		font-weight: normal;
		text-decoration: none;
		text-align: left;
		letter-spacing: 2px;
		line-height: 1.5;
		padding: 13px 4px 11px;
		background: #000;
		display: block;
		position: relative;
	}
	#gnavi > ul > li:last-child > a {
		padding: 13px 4px 11px;
	}
	#gnavi > ul > li > a:hover {
		color: #fff;
	}
	#gnavi > ul > li > a:after {
		content: none
	}
	#gnavi + #visual {
		border-bottom: 0px;
	}
	#contents .contents_header {
		padding: 40px 0 35px;
		background: url(img/s-title-sp.png) no-repeat top center / cover #172a4c;
	}
	#contents .contents_header .head_inner {
		width: 100%;
	}
	#contents1 #contents {
		background: url(img/top-concept-bg01-pc.png) no-repeat bottom left / 60%, url(img/top-concept-bg02-pc.png) no-repeat bottom right /  60%;
	}
	#contents .contents_header .head_inner > .title {
		font-size: 5.5vw;
		letter-spacing: 3px;
	}

	/* contents */
	#visual {
		border-bottom: 5px solid #096dda;
		min-width: 100%;
	}
	.visual {
		width: 100%;
	}
	.section {
		padding: 60px 0 40px;
	}
	#contents .section:last-child {
		padding-bottom: 70px;
	}
	#contents .section > .section_title {
		font-size: 5.5vw;
		margin: 0 0 40px;
		padding: 0 0 5px;
	}
	#contents .section > .section_title:after {
		height: 2px;
		width: 60px;
	}
	.section .section_inner {
		padding: 0 3%;
		width: 100%;
	}
	.child_content_section {
		margin-bottom: 40px;
	}
	#contents .child_content_section > .section_title {
		font-size: 5vw;
		border-bottom: 2px solid #096dda;
		margin-bottom: 20px;
		padding: 0 10px 3px;
	}
	.child_content_section > .section_inner {
		padding: 0 10px;
	}

	/* #pagetop */
	#pagetop:hover {
		opacity: 1;
	}
	#pagetop.fixed {
		right: 9px;
		bottom: 50px;
		display: block;
		z-index: 10;
		-webkit-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
	}
	#pagetop {
		width: 11%;
	}
	#pagetop a img {
		width: 100%;
	}


	/* footer */
	.footer {
		min-width: 100%;
	}
	.footer_inner {
		padding: 60px 0 0;
		width: 100%;
		display: block;
		align-items: stretch;
		justify-content: flex-start;
	}
	.footer_info {
		margin: 0 0 45px;
	}
	.footerlogo {
		border-bottom: 1px solid #096dda;
		margin: 0 auto 10px;
		padding: 0 5% 7px;
		width: 80%;
	}
	.footerlogo img {
		width: 100%;
	}
	.footer_address {
		font-size: 0.85rem;
		text-align: center;
	}
	.footernavi ul {
		text-align: center;
		border-top: 1px solid #096dda;
	}
	.footernavi ul:after {
		content: "";
		display: block;
		clear: both;
	}
	.footernavi li {
		width: 50%;
		display: block;
		float: left;
	}
	.footernavi li:nth-child(odd) {
		border-right: 1px solid #096dda;
	}
	.footernavi li:not(:last-child) {
		border-bottom: 1px solid #096dda;
		margin-right: 0;
	}
	.footernavi li:before {
		content: none;
	}
	.footernavi li a {
		color: #000033;
		font-size: 0.85rem;
		text-align: center;
		padding: 7px 0;
		display: block;
	}
	.footernavi li a:hover {
		text-decoration: none;
	}
	.copy {
		text-align: center;
		margin: 0 auto;
		padding: 7px 0 13px;
		width: 100%;
	}
	.copy img {
		margin: 0 auto;
		display: block;
		top: 2px;
		left: auto;
	}
	.copy a {
		color: #fff;
		font-size: 2vw;
		text-decoration: none;
	}

	/* 戻る */
	.return {
		display: none;
	}

	/* 各固定ページ用
	---------------------- */
	/* greeting.html */
	#contents .company_office_list {
		margin: 0px;
	}
	/* access.html */
	.access_map {
		padding: 0 10px;
		width: 100%;
	}
	.access_map .map_set {
		box-shadow: inherit;
		height: 200px;
		width: 100%;
	}
	.access_map .map_set .guide {
		font-size: 85%;
		padding: 13px 10px;
	}

	/* privacy.html */

	.privacy_section {
		padding:30px 0 40px;
	}
	.privacy_section_inner {
		padding:0 10px;
		width:100%;
	}
	#contents .privacy_set_title {
		font-size: 0.9rem;
		border-left: 3px solid #096dda;
		margin-bottom:20px;
	}
	.privacy_set_inner {
		padding: 0 5px 15px;
	}

	/* inquiry.html */
	.inquiry_everywhere_block {
		text-align: left;
		padding: 60px 5% 40px;
	}
	.inquiry_info {
		width: 100%;
		display: block;
	}
	.inquiry_info .set {
		width: 100%;
	}
	.inquiry_info .set:first-child {
		margin: 0 0 35px;
	}
	.inquiry_info .no {
		margin-bottom: 5px;
	}
	.inquiry_info .no a {
		font-size: 2rem;
		font-family: Quicksand, 游ゴシック体, "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	}
	.inquiry_info .no.fax a {
		color: #656565;
		pointer-events: none;
	}
	#contents .inquiry_info .time {
		font-size: 0.8rem;
		margin-bottom: 0;
	}
	.attent_block {
		padding: 0;
	}
	.attent_block .set {
		padding: 0;
	}
	.attent_block .title:before {
		font: normal normal normal 14px/1 FontAwesome;
	}
	.thanks_title {
		font-size:1.6rem;
		margin-bottom:0;
	}
	.thanks_msg {
		font-size:105%;
		line-height:1.8;
	}
	.important_text {
		text-align: left;
	}
	#MailForm table {
		border:0;
		margin: 5px auto 0;
		width: 100%;
	}
	#MailForm th, #MailForm td {
		border: none;
		width: 100%;
		display: block;
	}
	#MailForm th {
		padding: 0 0 3px;
		background: none;
	}
	#MailForm th:before {
		color: #096dda;
		font: normal normal normal 14px/1 FontAwesome;
		line-height: 1;
		margin-right: 5px;
		content: "\025a0";
	}
	#MailForm th span {
		left: auto;
		right: 5px;
	}
	#MailForm td {
		margin-bottom: 35px;
		padding: 0;
	}
	#MailForm input, #MailForm textarea {
		width: 100%;
	}
	#MailForm .form3 {
		vertical-align: middle;
		width: 3%;
	}
	#MailForm .form25 {
		width: 100%;
	}
	#MailForm .form45 {
		width: 100%;
	}
	#MailForm .form60 {
		width: 100%;
	}
	#MailForm .form90 {
		width: 100%;
	}
	.confirm_txt {
		text-align: left;
	}
	.send_btn {
		color: #fff;
		font-size: 1rem;
		letter-spacing: 2px;
		padding: 15px 0;
		background: url(img/arrow02.png) no-repeat center right 30px / 7px #096dda;
		transition: none;
	}
	.send_btn:hover {
		color: #fff;
		background: url(img/arrow02.png) no-repeat center right 30px / 7px #096dda;
	}
	.submit_btn {
		width: 90%;
	}
	.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;
	}

	/* formmail.cgi:send confirm */
	.send_confirm_table {
		padding: 17px 0 30px;
	}
	.send_confirm_table table {
		border-collapse: collapse;
		margin: 0 auto;
		width: 100%;
	}
	.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;
		margin-bottom: 5px;
		padding: 10px 15px;
		width: 100%;
		background: #f5f5f5;
	}
	.send_confirm_table table td {
		margin-bottom: 30px;
	}

	/* base styles
	---------------------- */
	.table_base {
		padding: 0;
	}
	.table_base table {
		border-collapse: collapse;
		border:0;
		margin: 0 auto;
		width: 100%;
	}
	.table_base table th, .table_base table td {
		font-weight: normal;
		border: 0px;
		padding: 12px 12px 5px;
		display: block;
	}
	.table_base table td span.map_jump {
		margin-left: 0;
		top: 0;
	}
	.table_base table td span.map_jump a:hover {
		opacity: 1;
	}
	.table_base table tbody th {
		text-align: left;
		width: 100%;
	}
	.table_base table tbody td {
		margin-bottom: 30px;
	}
	.content_inner {
		padding: 0 0 25px;
	}
	.content_inner .images_r,
	.content_inner .images_l {
		padding: 0 0 10px;
		float: none;
	}
	.content_inner .msg_l,
	.content_inner .msg_r {
		line-height: 2;
		float: none;
	}
	.w_margin400 .images_r, .w_margin400 .images_l {
		width: 100%;
	}
	.w_margin400 .msg_l, .w_margin400 .msg_r {
		width: 100%;
	}
	.breadcrumbs ul {
		margin: 0 auto;
		padding: 0 5px;
		width: 100%;
	}

	/* 各ページ用スタイル
	---------------------- */
	.only_pc {
		display: none;
	}
	.only_sp {
		display: block;
	}
	.tel a {
		color: #000033;
		pointer-events:inherit;
	}
	.btn_base {
		width: 100%;
	}
	.btn_base a {
		color: #fff;
		font-size: 0.9rem;
		padding: 11px 0 8px;
		background: url(img/arrow02.png) no-repeat center right 30px / 7px #096dda;
		transition: none;
	}
	.btn_base a:hover {
		color: #fff;
		background: url(img/arrow02.png) no-repeat center right 30px / 7px #096dda;
	}
	.everywhere_block {
		text-align: left;
		line-height: 1.8;
		margin: 0 auto 40px;
		padding: 20px 5% 0;
		width: 100%;
	}

	/* privacy.html */
	#contents ul.privacy_list li {
		text-indent:-45px;
		margin-bottom: 10px;
		padding-left:35px;
	}
	#contents dl.privacy_item dt {
		margin-bottom: 10px;
	}
	#contents dl.privacy_item dd {
		margin-bottom: 30px;
		padding-left: 0;
	}


	/* -------------------
	index.html */

	/* .top_concept */
	.top_concept {
		padding: 70px 3% 60px;
		background: url(img/top-concept-bg01-sp.png) no-repeat bottom left / 60%, url(img/top-concept-bg02-sp.png) no-repeat bottom right / 60%;
	}
	.top_concept_title {
		font-size: 5.5vw;
		margin: 0 0 30px;
	}
	.top_concept_inner {
		font-size: 0.95rem;
		line-height: 2;
		text-align: left;
	}

	/* .top_work */
	.top_work {
		padding: 70% 0 60px;
		background: url(img/top-work-img-sp.png) no-repeat top 80px center / 90%, url(img/top-work-bg-sp.jpg) no-repeat top center / 100%;
	}
	.top_work_inner {
		width: 100%;
	}
	.top_work_contents {
		margin: 0 auto;
		padding: 40px 25px;
		width: 80%;
		float: none;
	}
	.top_work_title {
		font-size: 5.5vw;
		margin: 0 0 27px;
		padding: 0 0 5px;
	}
	.top_work_title:after {
		height: 2px;
		width: 60px;
	}
	.top_work_text {
		font-size: 3.5vw;
		margin: 0 0 25px;
	}

	/* .top_service */
	.top_service {
		padding: 70% 0 60px;
		background: url(img/top-service-img-sp.png) no-repeat top 80px center / 90%, url(img/top-service-bg-sp.jpg) no-repeat top center / 100%;
	}
	.top_service_inner {
		width: 100%;
	}
	.top_service_contents {
		margin: 0 auto;
		padding: 40px 35px;
		width: 80%;
	}
	.top_service_title {
		font-size: 5.5vw;
		margin: 0 0 27px;
		padding: 0 0 5px;
	}
	.top_service_title:after {
		height: 2px;
		width: 60px;
	}
	.top_service_text {
		font-size: 3.5vw;
		margin: 0 0 25px;
	}

	/* .top_company */
	.top_company {
		padding: 100px 3% 80px;
		background: url(img/top-company-bg-sp.jpg) no-repeat top center / cover;
	}
	.top_company_inner {
		width: 100%;
	}
	.top_company_contents {
		width: 100%;
		float: none;
	}
	.top_company_title {
		font-size: 5.5vw;
		text-align: center;
		margin: 0 0 40px;
		padding: 0 0 8px;
	}
	.top_company_title:after {
		height: 2px;
		width: 60px;
		left: 50%;
		transform: translateX(-50%);
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
	}
	.top_company_text {
		font-size: 0.95rem;
		margin: 0 0 30px;
	}
	.top_company .btn_base {
		margin: 0 auto;
		width: 90%;
	}
	.top_company .btn_base a {
		color: #096dda;
		background: url(img/arrow01.png) no-repeat center right 30px / 7px rgba(255,255,255,0.9);
	}
	.top_company .btn_base a:hover {
		color: #096dda;
		background: url(img/arrow01.png) no-repeat center right 30px / 7px rgba(255,255,255,0.9);
	}


	/* -------------------
	greeting.html */

	/* .work_block */
	.work_block {
		display: block;
		flex-wrap: nowrap;
		justify-content: flex-start;
	}
	.work_section {
		width: 100%;
	}
	.work_section:not(:last-child) {
		margin: 0 0 40px;
	}
	.work_section_title {
		font-size: 0.95rem;
		margin: 0 0 15px;
		padding: 0 5px 3px;
	}
	.work_section_title:before {
		font-size: 1.7rem;
		top: 2px;
	}


	/* -------------------
	contents1.html */

	/* .service_concept */
	.service_concept {
		text-align: left;
		margin: 0 0 30px;
	}
	.service_concept .title {
		font-size: 4.5vw;
		line-height: 1.5;
		margin: 0 0 20px;
	}
	#contents .service_list {
		margin: 0 auto 60px;
		padding: 27px 40px 30px;
		width: 100%;
	}
	.service_list li {
		width: 100%;
		float: none;
	}
	.service_list li:not(:last-child) {
		margin: 0 0 5px;
	}
	.service_list li:before {
		font: normal normal normal 14px/1 FontAwesome;
		top: 1px;
	}

	/* .facility_list */
	#contents .facility_list {
		margin: 0 0 60px;
		padding: 30px 25px 7px;
		display: block;
		flex-wrap: nowrap;
	}
	.facility_list li {
		font-size: 0.85rem;
		margin: 0 0 25px;
		padding: 0 10px 13px;
		width: 100%;
		float: none;
	}
	.facility_list li:nth-of-type(odd) {
		margin-right: 0;
	}
	.facility_list li span {
		font-family: Quicksand, 游ゴシック体, "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
		font-size: 1.3rem;
		padding: 0 10px 0 0;
	}

	/* .facility_images */
	.facility_images li {
		margin-bottom: 40px;
		width: 100%;
		float: none;
	}
	.facility_images li:nth-of-type(odd) {
		margin-right: 0;
	}
}
