@charset "utf-8";
.cd-container {
	font-family:"メイリオ","Meiryo","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック", "MS P Gothic","Osaka", Verdana, Arial, Helvetica, sans-serif;
}
/** 
 *
 * table
 *
 */
.table{
	margin-left:0;
}
@media only screen and (min-width: 768px) {
	.table{
		float:left;
		width:470px;
		margin-left:30px;
		font-size: 14px;
	}
}
.table table{
	border-collapse:separate;
	border-spacing: 0 5px;
}
.table table th,
.table table td{
	padding:5px 1em;
}
@media only screen and (min-width: 768px) {
	.table > ul > li{
		line-height: 1.6;
	}
}
.table table th{
	border-right:1px solid #ddd;
	white-space: nowrap;
	width:5.8em;
}

.profile_img{
	text-align:center;
	margin:0 0 50px;
}
@media only screen and (min-width: 768px) {
	.profile_img{
		float:left;
	}
}
.profile_img img{
	width:200px;
	height:auto;
	border:5px solid #fff;
	overflow:hidden;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
/** 
 *
 * gallery
 *
 */
.gallery{
}
.gallery li{
	float:left;
	width:120px;
	height:90px;
	margin:0 13px 25px 11px;
	border:5px solid #fff;
	overflow:hidden;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
@media only screen and (min-width: 768px) {
	.gallery li{
		width:160px;
		height:120px;
		margin:0 32px 25px 0;
	}
}
.gallery li a{
	-webkit-tap-highlight-color:rgba(0,0,0,0);
}

.gallery li a:hover img{
	opacity:0.7
}
/** 
 *
 * contact
 *
 */
.formwrap{
	background:#fff;
	padding:50px 0;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
@media only screen and (min-width: 768px) {
	.formwrap{
		padding:50px;
	}
}
.form{
	font-size:14px;
	border-top:1px solid #ddd;
	border-left:1px solid #ddd;
}
.form li textarea{
	width:100%;
	height:100px;
	font-size:1.2em;
}
.form li input {
	width:100%;
	font-size:1.2em;
}
@media only screen and (min-width: 768px) {
	.form li input{
		width:300px;
	}
}
.form ul{
	display:block;
	width:100%;
}
@media only screen and (min-width: 768px) {
	.form ul{
		display:table;
		table-layout:fixed;
	}
}
.form li{
	display:block;
	padding:15px;
	border-right:1px solid #ddd;
	border-bottom:1px solid #ddd;
	vertical-align:top;
}
@media only screen and (min-width: 768px) {
	.form li{
		display:table-cell;
	}
}
.form li.th{
	width:auto;
	background:#fafafa;
}
@media only screen and (min-width: 768px) {
	.form li.th{
		width:35%;
	}
}

.button {
	margin:50px 0 0;
	text-align:center;
}
.button input {
	font-size:1.2em;
	width:100px;
	margin:0 10px;
}
.red{
	color:#fff;
	background:#aaa;
	border:1px solid #aaa;
	border-radius:5px;
	-moz-border-radius:5px; 
	-webkit-border-radius:5px;
	padding:1px 5px;
	margin-left:5px;
}
.error-message{
	color:#c00;
}