@charset "UTF-8";

body,div,pre,p,blockquote,form,fieldset,input,textarea,select,option,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,table,th,td,embed,object{margin: 0;padding: 0;vertical-align: baseline;}h1,h2,h3,h4,h5,h6 {font-style: normal;font-weight: normal;font-size: 100%;}table{border-spacing:0;}* html table{border-collapse:collapse;}*:first-child+html table{border-collapse:collapse;}caption,th{text-align:left; font-weight:normal;}table,th,td,img {border:0;}img,input{vertical-align:top;}q:before,q:after{content:'';}strong,em,address{font-weight:normal;font-stretch:normal;font-style:normal;}ul{list-style:none;}article,aside,canvas,details,figcaption,figure,footer,header,hgroup,menu,nav,section,summary{display:block;}

/* 基本設定 */
html {
	overflow-y: scroll;	
	min-height: 100vh;
	height: -webkit-fill-available;
	color: #333;
}

body {
	word-break: break-all;
	min-height: 100vh;
	min-height: -webkit-fill-available;
	line-height: 1.5;
}
img { 
	max-width: 100%;
	height: auto; 
}

/* レスポンシブ */
@media screen and (max-width:767px) {
	.pc,.pctb .tb { display: none; } 
}
@media screen and (min-width:768px) and ( max-width:1024px) {
	.sp,.pc { display: none; }
}
@media screen and (min-width:1025px) {
	.sp,.sptb .tb { display: none; }
}

/* WP */
.form .c,.form .t,.check .f,.check .t,.thankyou .f,.thankyou .c { display: none; }

a,a:link,a:visited,a:hover,a:active {  color: #eb9322; }

@media screen and (max-width: 767px) {
	body {
		padding-top: 60px;
	}	
}

/*=========================================================

common

=========================================================*/

.headingB {
	color: #999;
	font-style: italic;
	font-weight: bold;
	font-size: 10px;
	text-align: center;
	letter-spacing: 2px;
}

.headingM {
	font-style: italic;
	font-weight: bold;
	font-size: 24px;	
	text-align: center;
	letter-spacing: 6px;
}

.headingM:after {
	content: "";
	display: block;
	background: #2098d6;
	width: 50px;
	height: 6px;
	margin: 10px auto;
}

.headingA {
	font-style: italic;
	font-weight: bold;
	font-size: 16px;	
	text-align: center;
	margin-bottom: 60px;
	letter-spacing: 2px;
}

@media screen and (max-width: 767px) {
	.headingB {
		font-size: 10px;
	}

	.headingM {
		font-size: 18px;	
	}

	.headingM:after {
		width: 40px;
		height: 4px;
	}

	.headingA {
		font-size: 12px;	
		margin-bottom: 30px;
	}
}

/*=========================================================

header

=========================================================*/

#header {
	width: 100%;
}

#header .inner {
	max-width: 1000px;
	height: 100px;
	padding: 20px;
	margin: 0 auto;
	line-height: 1;
	box-sizing: border-box;
}

#header h1 {
	display: table;
	float: left;
}

#header h1 .logo {
	display: table-cell;
	vertical-align: middle;
}

#header h1 .logo img {
	height: 60px;
	width: auto;
}

#header h1 .name {
	display: table-cell;
	vertical-align: middle;
	font-size: 14px;
	font-weight: bold;
	padding-left: 20px;
}

#header p {
	display: table;
	height: 60px;
	text-align: right;
	float: right;
}

#header p span {
	display: table-cell;
	vertical-align: middle;
}

#header p span a {
	display: block;
	background: #2098d6;
	color: #fff;
	border-radius: 5px;
	padding: 13px 20px;
	text-decoration: none;
	font-size: 14px;
	font-weight: bold;
}

@media screen and (max-width: 767px) {
	#header {
		position: fixed;
		top: 0;
		left: 0;
		background: #fff;
		box-shadow: 1px 1px 1px 1px rgba(0, 0, 0, 0.1);
	}
	#header .inner {
		height: 60px;
		padding: 10px;
	}
	#header h1 {
		height: 40px;
	}
	#header h1 .logo img {
		height: 40px;	
	}
	#header h1 .name {
		font-size: 10px;
		padding-left: 10px;
		line-height: 1.2;
	}
	#header p {
		height: 40px;
	}
	#header p span a {
		padding: 10px 10px;
		font-size: 12px;
	}
}

/*=========================================================

main visual

=========================================================*/

#mainVisual {
	background: #fff3e0 url("../images/main-bg.png");
	height: 440px;
}

#mainVisual .inner {
	width: 100%;
	max-width: 1000px;
	height: 440px;
	padding: 0 20px;
	margin: 0 auto;
	display: table;
	box-sizing: border-box;
}

#mainVisual .text {
	display: table-cell;
	vertical-align: middle;
	box-sizing: border-box;
	min-width: 50%;
}

#mainVisual .text h2 {
	color: #2098d6;
	font-size: 26px;
	font-style: italic;
	font-weight: bold;
	letter-spacing: 6px;
	line-height: 1.5;
	margin-bottom: 5px;
}

#mainVisual .text p {
	font-size: 16px;
	font-style: italic;
	font-weight: bold;
	letter-spacing: 2px;
	margin-left: 5px;
}

#mainVisual .image {
	display: table-cell;
	vertical-align: middle;
	padding: 30px 0 30px 30px;
	text-align: center;
	box-sizing: border-box;
}

#mainVisual .image img {
	width: auto;
	height: auto;
	max-height: 380px;
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
	#mainVisual .text h2 {
		font-size: 24px;
		letter-spacing: 3px;
	}

	#mainVisual .text p {
		font-size: 15px;
		letter-spacing: 1px;
	}	
}

@media screen and (max-width: 767px) {
	#mainVisual {
		height: auto;
	}
	#mainVisual .inner {
		display: block;
		height: auto;
		padding: 15px 10px;
	}
	#mainVisual .text {
		display: block;
		height: auto;
		text-align: center;
		width: 100%;
		padding: 0 0 15px;
	}
	#mainVisual .text h2 {
		font-size: 20px;
		letter-spacing: 1px;
	}

	#mainVisual .text p {
		font-size: 10px;
		letter-spacing: 2px;
	}	
	#mainVisual .image {
		display: block;
		height: auto;
		text-align: center;
		width: 100%;
		padding: 0;
	}	
	#mainVisual .image img {
		width: 75%;
		height: auto;
		max-height:none
	}
}

/*=========================================================

works

=========================================================*/

#works {
	padding: 60px 0;
	background: url("../images/works_bg.jpg");
	background-size: cover;
}

#works .inner {
	width: 100%;
	max-width: 1000px;
	padding: 0 20px;
	margin: 0 auto;
	box-sizing: border-box;
}

#works article {
	display: table;
	width: 100%;
	margin-bottom: 30px;
	background: #fff;
	padding: 50px;
	box-sizing: border-box;
	border-radius: 5px;
}

#works article:last-child {
	margin-bottom: 0;
}

#works .image {
	display: table-cell;
	width: 400px;
	text-align: center;
	padding: 0 50px 0 0;
	box-sizing: border-box;
	vertical-align: top;
}

#works .image img {
	border: 1px solid #ccc;
}

#works .image p {
	margin-top: 10px;
	font-size: 14px;
	font-weight: bold;
}

#works .text {
	display: table-cell;
	width: 460px;
	vertical-align: top;
}

#works .text h3 {
	font-size: 18px;
	color: #2098d6;
	font-weight: bold;
	margin-bottom: 10px;
}

#works .text p {
	font-size: 14px;
	line-height: 1.8;
}

#works .text a {
	margin-top: 20px;
	font-size: 14px;
}

@media screen and (max-width: 767px) {

	#works {
		padding: 30px 0;
	}

	#works .inner {
		width: auto;
		padding: 0 20px;
		margin: 0 auto;
		box-sizing: border-box;
	}
	
	#works article {
		display: block;
		padding: 20px;
	}
	
	#works .image {
		display: block;
		width: 100%;
		padding: 0 0 20px;
	}
	
	#works .image img {
		width: 75%;
	}

	#works .text {
		display: table-cell;
		width: 460px;
		vertical-align: middle;
	}

	#works .text h3 {
		font-size: 16px;
	}

	#works .text p {
		font-size: 13px;
	}

}


/*=========================================================

company

=========================================================*/

#company {
	padding: 60px 0;
}

#company .inner {
	width: 100%;
	max-width: 1000px;
	padding: 0 20px;
	margin: 0 auto;
	box-sizing: border-box;
}
#company .inner .wrap {
	width: 100%;
	display: table;
}

#company .info {
	width: 75%;
	display: table-cell;
	padding-right: 50px;
	vertical-align: top;
}


#company .info table {
	border-top: 1px solid #ccc;
	font-size: 14px;
	width: 100%;
}

#company .info th {
	border-bottom: 1px solid #ccc;
	padding: 25px 30px 25px 0;
	font-weight: bold;
}

#company .info td {
	border-bottom: 1px solid #ccc;
	padding: 25px 0;
}

#company .greeting {
	display: table-cell;
	vertical-align: top;
}

#company .greeting .photo {
	position: relative;
	overflow: hidden;
	border-radius: 5px;
	margin-bottom: 20px;
}

#company .greeting img {
	width: 100%;
	height: auto;
}

#company .greeting h3 {
	background: #2098d6;
	text-align: center;
	color: #fff;
	padding: 10px;
	width: 100%;
	box-sizing: border-box;
	bottom: 0;
	left: 0;
	position: absolute;
}

#company .greeting h3 span {
	font-size: 14px;
	font-weight: bold;
}

#company .greeting h3 em {
	font-size: 16px;
	font-weight: bold;
}

#company .greeting .message {
	background: #fff3e0;
	padding: 20px;
	font-size: 14px;
	border-radius: 5px;
}

@media screen and (max-width: 767px) {

	#company {
		padding: 30px 0;
	}

	#company .inner {
		width: 100%;
		max-width: 1000px;
		padding: 0 20px;
		margin: 0 auto;
		box-sizing: border-box;
	}

	#company .info {
		width: 100%;
		display: block;
		padding: 0;
		margin-bottom: 30px;
	}	
	
	#company .info table {
		font-size: 13px;
	}
	/*
	#company .info table {
		width: 100%;
		display: block;
		font-size: 13px;
	}

	#company .info th {
		display: block;
		padding: 10px 0;
	}

	#company .info td {
		display: block;
		padding: 15px 0;
	}
	*/
	
	#company .greeting {
		width: 100%;
		display: block;
		padding: 0;
	}	

	#company .greeting h3 span {
		font-size: 14px;
		font-weight: bold;
	}

	#company .greeting h3 em {
		font-size: 16px;
		font-weight: bold;
	}
	
	#company .greeting .photo {
		margin: 0 auto 20px;
		max-width: 250px;
	}

	#company .greeting .message {
		background: #fff3e0;
		padding: 20px;
		font-size: 14px;
		border-radius: 5px;
	}

}

/*=========================================================

footer

=========================================================*/

#footer {
	padding: 60px 0;
	background: #2098d6;
	color: #fff;
	text-align: center;
	font-size: 14px;
}

.map iframe {
	margin: 0 0 -6px;
	padding: 0;
	width: 100%;
	height: 300px;
}

@media screen and (max-width: 767px) {
	#footer {
		font-size: 12px;
		padding: 30px 0;
	}	
}