@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;
	}
	a:hover {
		color: #888;
	}
	
	/* 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 h1 {
		display: none;
	}
	#header {
		min-width: 100%;
		padding: 20px 0;
	}
	#header .header {
		position: relative;
		width: 100%;
		margin: 0 auto;
		padding: 0px;
	}
	#header .header .head-logo {
		width: 70%;
		margin: 0 auto;
		padding-left: 3%;
	}
	#header .header .head-logo img {
		width: 100%;
	}
	#header .header .head-inquiry {
		display: none;
	}
	
	/* navigation */
	#gnavi_open {
		position: absolute;
		width: 10%;
		right: 15px;
		top: 0px;
	}
	#gnavi_open img {
		width: 100%;
	}
	#drawer_underlay {
		position: absolute;
		width: 100%;
		height: 100%;
		background: rgba(0, 0, 0, 0.5);
		top: 0px;
		left: 0px;
	}
	#gnavi {
		position: fixed;
		width: 80%;
		min-width: 80%;
		height: 100%;
		font-size: 110%;
		border-top: inherit;
		border-bottom: inherit;
		padding: 20px 5%;
		background: #000;
		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 {
		width: 100%;
		font-size: 120%;
		color: #fff;
		padding: 5px 5%;
		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:nth-child(2) {
		width: 100%;
	}
	#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;
		top: 0;
		transition: 0s;
	}
	#gnavi > ul li > a:before {
		display: none;
	}
	#gnavi > ul li > a:after {
		content: none;
	}
	#gnavi ul li.navi_slide {
		position: relative;
		cursor: default;
		border-bottom: 0px;
	}
	#gnavi ul li.navi_slide > a {
		cursor: default;
	}
	#gnavi li.navi_slide > ul {
		display: block;
		position: inherit;
		width: 100%;
		height: inherit;
		font-size: 90%;
		margin: 0 0 20px;
		padding: 0 0;
		border-bottom: inherit;
		overflow: hidden;
		zoom: 1;
		z-index: 5000;
		border-radius: 0 0 4px 4px;
		background: #222;
		left: 0;
		transform: inherit;
	}
	#gnavi li.navi_slide > ul li {
		width: 100%;
		color: #595757;
		text-align: center;
		border-bottom: 1px dashed #666;
		margin: 0;
		float: none;
	}
	#gnavi li.navi_slide > ul li:last-child {
		border: 0px;
	}
	#gnavi li.navi_slide > ul li a {
		display: block;
		position: inherit;
		text-align: left;
		text-decoration: none;
		text-shadow: inherit;
		letter-spacing: 1px;
		color: #fff;
		margin: 0 auto;
		padding: 15px 5%;
		background: none;
		box-shadow: none;
	}
	#gnavi + #visual {
		border-bottom: 0px;
	}
	#contents {
		width: 100%;
	}
	#contents .contents_header {
		width: 100%;
	}
	#contents .contents_header .head_inner {
		width: 100%;
	}
	#contents .contents_header .head_inner > .title {
		font-size: 160%;
	}
	
	/* contents */
	#visual {
		min-width: 100%;
	}
	#visual .visual {
		width: 100%;
		height: auto;
	}
	#visual_slider {
		position: inherit;
		width: 100%;
		left: auto;
		transform: inherit;
	}
	.section {
		padding: 40px 0 30px;
	}
	#contents .section:last-child {
		padding-bottom: 60px;
	}
	#contents .section .section_top_msg {
		position: relative;
		width: 100%;
		padding: 20px 20px 20px;
		margin-bottom: 0px;
	}
	#contents .section .section_top_msg:before {
		position: absolute;
		content: "　";
		top: 0;
		left: 15px;
	}
	#contents .section .section_top_msg:after {
		position: absolute;
		content: "　";
		bottom: 0;
		right: 15px;
	}
	.section .section_top_msg .main_msg {
		padding-top: 30px;
		line-height: 1.8;
		text-align: left;
	}
	#contents .section .section_title {
		font-size: 150%;
		margin: 0px;
	}
	.section > .section_inner {
		width: 100%;
		padding: 20px 15px;
	}
	
	/* footer */
	.footer {
		min-width: 100%;
	}
	.footer .footer_inner {
		width: 100%;
		padding: 0px;
	}
	.footer_inner a {
		text-decoration: none;
		font-size: 90%;
	}
	.footernavi {
		width: 100%;
		padding: 0;
		margin-bottom: 20px;
		border-bottom: none;
	}
	.footernavi ul {
		width: 100%;
		padding: 0;
	}
	.footernavi li {
		width: 50%;
		font-size: 100%;
		margin-right: 0;
		border-bottom: 1px solid #c9caca;
	}
	.footernavi li:nth-child(odd) {
		border-right: 1px solid #c9caca;
	}
	.footernavi li:after {
		content: " ";
		font-size: 20px;
		color: #C3C3C3;
		margin-left: 0px;
	}
	.footernavi li:nth-child(1):before {
		content: " ";
		margin-right: 0px;
	}
	.footernavi li a {
		font-size: 80%;
		text-decoration: none;
		padding: 12px 10px;
		display: block;
		text-align: left;
	}
	.footernavi li a:before {
		content: ">";
		margin-right: 5px;
	}
	.footernavi li a:hover {
		color: #000;
		text-decoration: none;
	}
	.footer_bottom {
		width: 100%;
		margin: 0 auto 30px;
		text-align: center;
	}
	.footer_logo {
		width: 80%;
		float: none;
		margin: 0 auto 20px;
	}
	.footer_logo img {
		width: 100%;
	}
	.footer_address {
		font-size: 80%;
	}
	.footer_address li span {
		display: block;
	}
	.copy {
		font-size: 80%;
		text-align: center;
		width: 100%;
		margin: 0 auto;
		padding: 5px 0 10px;
	}
	.copy img {
		margin: 0 auto;
		display: block;
	}
	.copy a {
		color: #fff;
		text-decoration: none;
	}
	
	/* 戻る */
	#pagetop {
		display: none;
	}
	.return {
		left: 44%;
		top: -35px;
	}
	.return a {
		width: 70%;
		display: inline-block;
		padding: 5px 12px 5px;
		background: #2c53b6;
		border-radius: 5px 5px 0 0;
	}
	.return a img {
		width: 100%;
		margin: 0 auto;
	}
	.return a:hover {
		background: #5d7dcf;
	}
	
	/* 各固定ページ用
	---------------------- */
	/* greeting.html */
									
	#contents .company_office_list {
		margin: 0px;
	}
	
	/* access.html */
	.access_map {
		width: 100%;
		padding: 15px 10px;
	}
	.access_map .map_set #map {
		width: 100%;
		height: 200px;
		box-shadow: inherit;
	}
	.access_map .map_set .guide {
		font-size: 85%;
		padding: 13px 10px;
	}
	
	/* inquiry.html */
	.attent_block {
		padding: 0;
	}
	.attent_block .set {
		padding: 0;
	}
	.inquiry_info .set {
		width: inherit;
		padding: 0 0 20px;
		float: inherit;
	}
	.inquiry_info .set.freebox {
		padding: 20px 0;
	}
	.inquiry_info .set .title {
		font-size: 130%;
	}
	.inquiry_info .no {
		font-size: 210%;
	}
	.inquiry_info .tel .no span {
		font-size: 55%;
	}
	#inquiry .inquiry_inner {
		margin: 0;
		padding: 10px 0 0;
		border-bottom: 0px;
		background: none;
	}
	#inquiry .inquiry_inset {
		padding: 0px;
		background: none;
		border: 0px;
	}
	#MailForm table {
		width: 100%;
	}
	#MailForm th, #MailForm td {
		display: block;
		width: 100%;
	}
	#MailForm th {
		padding: 12px 0 0;
		border: none;
		background: none;
	}
	#MailForm th:before {
		content: "■";
		font-size: 160%;
		color: #000;
		line-height: 1;
	}
	#MailForm th span {
		left: auto;
		right: 20px;
	}
	#MailForm td {
		border: none;
		padding: 5px 0 30px;
	}
	#MailForm input, #MailForm textarea {
		width: 100%;
	}
	#MailForm textarea {
	}
	#MailForm .form3 {
		vertical-align: middle;
		width: 3%;
	}
	#MailForm .form25 {
		width: 100%;
	}
	#MailForm .form45 {
		width: 100%;
	}
	#MailForm .form60 {
		width: 100%;
	}
	#MailForm .form90 {
		width: 100%;
	}
	.send_btn {
		font-size: 100%;
		padding: 15px 10px;
	}
	.submit_btn {
		width: 80%;
		margin-bottom: 15px;
	}
	.reset_btn {
		width: 80%;
	}
	.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 {
		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;
	}
	
	/* base styles
	---------------------- */
	.table_base table {
		width: 100%;
		margin: 0 auto;
		border-collapse: collapse;
	}
	.table_base table th, .table_base table td {
		font-weight: normal;
		padding: 12px 12px;
		border: 0px;
		display: block;
	}
	.table_base table td span.map_jump a:hover {
		opacity: 1;
	}
	.table_base table tbody th {
		text-align: left;
		width: 100%;
		background: #f1f1f1;
	}
	.table_base table tbody td {
		margin-bottom: 20px;
		padding-left: 20px;
	}
	.content_inner {
		padding: 30px 0 25px;
	}
	.content_inner .images_r, .content_inner .images_l {
		padding: 0 0% 10px;
		float: inherit;
	}
	.w_margin270 .images_r, .w_margin270 .images_l {
		width: 100%;
	}
	.w_margin270 .msg_l, .w_margin270 .msg_r {
		padding-right: 0px;
		padding-left: 0px;
	}
	.w_margin320 .images_r, .w_margin320 .images_l {
		width: 100%;
	}
	.w_margin320 .msg_l, .w_margin320 .msg_r {
		padding-right: 0px;
		padding-left: 0px;
	}
	.breadcrumbs {
		display: none;
	}
	
	/* 各ページ用スタイル
	---------------------- */
	/* sp_br */
		
	.sp_br {
		padding-top: 5px;
		display: block;
	}
	
	/* .btn_base */
	.btn_base {
	}
	.btn_base a {
		width: auto;
		font-size: 90%;
	}
	.btn_base a:hover {
		box-shadow: 3px 3px 0px #000;
		top: -3px;
		left: -3px;
	}
	.no_sp {
		display: none;
	}
	.main_midasi {
		position: relative;
		font-size: 135%;
		font-weight: normal;
		letter-spacing: 0px;
		color: #6a4a17;
		padding: 13px 20px;
		border-top: 3px solid #866532;
	}
	.main_midasi:before {
		content: " ";
		position: absolute;
		left: inherit;
		top: inherit;
	}
	.section_header {
		position: relative;
	}
	.section_header .archive_link {
		position: absolute;
		right: 20px;
		top: 17px;
	}
	.section_header .archive_link a:before {
		content: " ";
		position: relative;
		margin-right: 5px;
		top: 2px;
	}
	#privacy #contents h4 {
		font-size: 120%;
	}
	
	/* -------------------
	index.html */
	/* .top_contents */
	
	.top_contents {
		width: 100%;
		padding: 10px 0 40px;
		background: url(img/background-img01-sp.jpg) no-repeat left top;
		background-size: contain;
	}
	.top_contents_title {
		width: 80%;
		padding-left: 30px;
		margin-bottom: 35px;
	}
	.top_contents_title img {
		width: 100%;
		display: block;
	}
	.top_contents_inner {
		margin: 0 auto;
		width: 100%;
		padding: 0 15px 10px 15px;
	}
	.top_contents_inner .img {
		width: 90%;
		margin: 0 auto 15px;
	}
	.top_contents_inner .img img {
		width: 100%;
	}
	.top_contents_inner .msg_block {
		position: inherit;
		width: 100%;
		padding: 40px 0 0 30px;
		background: url(img/box-line01.png) no-repeat left 10px top 10px, linear-gradient(130deg, rgba(241, 241, 241, 1), rgba(241, 241, 241, 1));
		background-size: 50%;
		bottom: 0;
		right: 0;
	}
	.top_contents_inner .msg_block .inbox_block {
		padding: 0 30px 20px 0;
		line-height: 1.8;
		background: url(img/box-line02.png) no-repeat right 10px bottom 10px;
		background-size: 50%;
	}
	
	/* .top_gallery */
	.top_gallery {
		padding: 50px 0 20px;
	}
	.top_gallery_title {
		width: 65%;
		margin: 0 auto;
		margin-bottom: 40px;
	}
	.top_gallery_title img {
		width: 100%;
	}
	.top_gallery_inner {
		width: 100%;
		padding: 0 10px;
	}
	#contents .top_gallery_list ul {
		margin-bottom: 20px;
	}
	.top_gallery_list ul li {
		width: 32%;
		float: left;
		margin: 0 2% 10px 0;
	}
	.top_gallery_list ul li img {
		width: 100%;
		display: block;
	}
	.top_gallery_list ul li:nth-child(4n) {
		margin-right: 2%;
	}
	.top_gallery_list ul li:nth-child(3n) {
		margin-right: 0;
	}
	.top_gallery .btn_base {
		text-align: right;
	}
	.top_gallery .btn_base a {
		width: 50%;
	}
	
	/* .top_voice */
	.top_voice_inner {
		padding: 0;
		background: none;
		margin: 0 auto;
		width: 100%;
	}
	.top_voice_inner .main_block {
		position: relative;
		padding: 0;
	}
	.top_voice .right_block {
		width: 50%;
		text-align: right;
		float: right;
	}
	.top_voice .right_block img {
		width: 100%;
		display: block;
	}
	.top_voice .left_block {
		width: 50%;
		float: left;
	}
	.top_voice_title {
		width: 70%;
		margin: 0 auto;
		padding-top: 30px;
		margin-bottom: 40px;
	}
	.top_voice_title img {
		width: 100%;
	}
	.top_voice .msg_block {
		position: absolute;
		width: 95%;
		padding: 25px 0 0 25px;
		background: url(img/box-line01.png) no-repeat left 10px top 10px, linear-gradient(130deg, rgba(243, 243, 243, 0.9), rgba(243, 243, 243, 0.9));
		background-size: 50%;
		bottom: 10px;
		left: 2%;
	}
	.top_voice .msg_block .inbox_block {
		font-size: 3vw;
		font-weight: normal;
		padding: 0 25px 15px 0;
		background: url(img/box-line02.png) no-repeat right 10px bottom 10px;
		background-size: 50%;
	}
	#contents .top_voice .msg_block .inbox_block > p {
		margin-bottom: 6px;
	}
	
	/* .top_quality */
	.top_quality_inner {
		padding: 0;
		background: none;
		margin: 0 auto;
		width: 100%;
	}
	.top_quality_inner .main_block {
		position: relative;
		padding: 0;
	}
	.top_quality .left_block {
		width: 50%;
	}
	.top_quality .right_block {
		width: 50%;
		float: left;
	}
	.top_quality .right_block img {
		width: 100%;
		display: block;
	}
	.top_quality_title {
		width: 70%;
		margin: 0 auto;
		padding-top: 30px;
		margin-bottom: 40px;
	}
	.top_quality_title img {
		width: 100%;
		display: block;
	}
	.top_quality .msg_block {
		position: absolute;
		width: 95%;
		padding: 25px 0 0 25px;
		background: url(img/box-line01.png) no-repeat left 10px top 10px, linear-gradient(130deg, rgba(243, 243, 243, 0.9), rgba(243, 243, 243, 0.9));
		background-size: 50%;
		bottom: 10px;
		left: 2%;
	}
	.top_quality .msg_block .inbox_block {
		font-size: 3vw;
		font-weight: normal;
		padding: 0 25px 15px 0;
		background: url(img/box-line02.png) no-repeat right 10px bottom 10px;
		background-size: 50%;
	}
	
	/* .top_flow */
	.top_flow {
		padding: 40px 15px;
		border-top: 1px solid #c9caca;
	}
	.top_flow_title {
		width: 65%;
		margin: 0 auto;
		margin-bottom: 40px;
	}
	.top_flow_title img {
		width: 100%;
		display: block;
	}
	.top_flow_inner {
		width: 100%;
		padding: 0;
	}
	.top_flow_list ul li {
		width: 100%;
		display: table;
		padding: 5px;
	}
	.top_flow_list ul li:nth-child(-n+3) {
		margin: 0 0 35px 0;
	}
	.top_flow_list ul li:nth-child(-n+3):after {
		content: url(img/arrow02-sp.png);
		top: auto;
		bottom: -25%;
		right: auto;
		left: 50%;
		margin-top: 0;
		transform: translateX(-50%);
	}
	.top_flow_list ul li .img {
		width: 35%;
		display: table-cell;
		vertical-align: middle;
	}
	.top_flow_list ul li .msg {
		display: table-cell;
		padding: 0 5px;
		vertical-align: top;
	}
	#contents .top_flow_list ul li .msg .title {
		font-size: 95%;
		font-weight: bold;
		text-align: center;
		padding-bottom: 2px;
		margin-bottom: 6px;
		border-bottom: 1px dashed #000;
	}
	#contents .top_flow_list ul li .msg .txt {
		font-size: 75%;
		padding: 0 5px;
		margin-bottom: 0;
	}
	
	/* .top_info */
	.top_info {
		padding: 15px 0;
	}
	.top_info_inner {
		width: 100%;
		padding: 0 15px;
	}
	.top_info ul li {
		width: 47%;
		margin-right: 6%;
	}
	.top_info ul li a {
		transition: 0s;
	}
	.top_info ul li a:hover {
		opacity: 1;
	}
	
	/* -------------------
	contents1.html */
	/* .service_block */
		
	.service_block .side_line {
		margin-bottom: 50px;
	}
	.service_block .side_line:last-child {
		margin-bottom: 0;
	}
	.service_block .service_set {
		width: 100%;
		float: none;
		margin: 0 0 50px 0;
	}
	.service_block .side_line .service_set:nth-child(even) {
		margin-bottom: 0;
	}
	.service_block .msg {
		line-height: 1.8;
	}
	.service_block dl dt {
		padding-left: 15px;
	}
	
	/* -------------------
	contents2.html */
	/* .works_block */
		
	.works_block {
		padding-top: 10px;
	}
	.works_block ul li {
		width: 33%;
		margin: 0 0.5% 5px 0;
		overflow: hidden;
	}
	.works_block ul li:hover img {
		transform: scale(1);
	}
	.works_block ul li:nth-child(4n) {
		margin-right: 0.5%;
	}
	.works_block ul li:nth-child(3n) {
		margin-right: 0;
	}
	.works_block ul li img {
		transition: 0s;
	}
	
	/* .voice_block */
	.voice_block {
		padding: 0;
	}
	.voice_block .voice_set {
		padding-bottom: 50px;
		margin-bottom: 50px;
		border-bottom: 1px dashed #c9caca;
	}
	.voice_block .voice_set .head_block {
		margin-bottom: 20px;
	}
	.voice_block .voice_set .head_block:after {
		content: " ";
		display: table;
		clear: both;
	}
	.voice_block .voice_set .img {
		width: 25%;
	}
	.voice_block .voice_set .title {
		font-size: 105%;
		width: 70%;
		float: right;
	}
	.voice_block .voice_set .title span.name {
		font-size: 80%;
	}
	.voice_block .voice_set .msg {
		width: 100%;
		float: none;
		line-height: 1.8;
	}
}