@charset "UTF-8";



/* 
 * ---------------------------------------------------------------------------------------
 * インデックス
 * 
 * .index
 *     h1
 *     .index-projectlist
 *         .index-project
 *             .index-visual
 *                 .index-picture
 *                 .index-subtitle
 *             .index-maintitle
 *             .index-person
 *                 span
 * ---------------------------------------------------------------------------------------
 */

.frame-content .index {
	box-sizing: border-box;
	margin: 0 auto;
	padding: 0 40px;
	max-width: 1020px;
}
.frame-content .index h1 {
	font-size: 2.5em;
	margin: 80px 0;
	text-align: center;
}
.frame-content .index .index-projectlist {
}
.frame-content .index .index-project {
	color: #ddd;
	margin-top: 60px;
	width: 100%;
}
.frame-content .index .index-project:after {
	clear: both;
	content: "";
	display: table;
}
.frame-content .index .index-project a {
	color: #000;
	display: block;
	text-decoration: none;
}
.frame-content .index .index-project .index-visual {
	float: left;
	margin-right: -400px;
	position: relative;
	width: 100%;
}
.frame-content .index .index-project .index-picture {
}
.frame-content .index .index-project .index-subtitle {
	box-sizing: border-box;
	color: #fff;
	display: block;
	font-size: 1.1666666666666666666666666666667em;
	left: 0;
	line-height: 1.6;
	padding: 90px 30px 0;
	position: absolute;
	top: 0;
	width: 100%;
}
.frame-content .index .index-project .index-maintitle {
	border-top: 2px solid #ddd;
	display: block;
	float: right;
	font-size: 1.6666666666666666666666666666667em;
	line-height: 1.6;
	padding-top: 20px;
	width: 360px;
}
.frame-content .index .index-project a .index-maintitle {
	border-color: #000;
}
.frame-content .index .index-project .index-person {
	display: block;
	float: right;
	line-height: 1.6;
	margin-top: 10px;
	width: 360px;
}
.frame-content .index .index-project .index-person span {
	font-size: 0.66666666666666666666666666666667em;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .index .index-project .index-visual {
		height: 240px;
		overflow: hidden;
	}
	.frame-content .index .index-project .index-picture {
		left: 50%;
		margin-left: -470px;
		position: absolute;
		top: 0;
		width: 940px;
		z-index: -1;
	}
	.frame-content .index .index-project .index-subtitle {
		border-right: 400px solid #fff;
		height: 100%;
		position: static;
	}
	.frame-content .index .index-project .index-maintitle,
	.frame-content .index .index-project .index-person {
		position: relative;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .index {
		padding: 0;
	}
	.frame-content .index h1 {
		font-size: 2em;
		margin: 60px 0;
	}
	.frame-content .index .index-project {
		margin-top: 40px;
	}
	.frame-content .index .index-project .index-visual {
		display: block;
		float: none;
		margin-right: 0;
	}
	.frame-content .index .index-project .index-picture img {
		width: 100%;
	}
	.frame-content .index .index-project .index-subtitle {
		font-size: 1.2857142857142857142857142857143em;
		font-size: 1em;
		margin-top: 16%;
		padding: 0 20px;
	}
	.frame-content .index .index-project .index-maintitle {
		border: none;
		box-sizing: border-box;
		float: none;
		font-size: 1.7142857142857142857142857142857em;
		margin-top: 20px;
		padding: 0 20px;
		text-align: center;
		width: 100%;
	}
	.frame-content .index .index-project .index-person {
		box-sizing: border-box;
		float: none;
		font-size: 1.2857142857142857142857142857143em;
		padding: 0 20px;
		text-align: center;
		width: 100%;
	}
}

.ie8 .frame-content .index .index-project a:hover .index-subtitle,
.ie8 .frame-content .index .index-project a:active .index-subtitle {
	-ms-filter: "";
}
.ie8 .frame-content .index .index-project a:hover .index-maintitle,
.ie8 .frame-content .index .index-project a:hover .index-person,
.ie8 .frame-content .index .index-project a:active .index-maintitle,
.ie8 .frame-content .index .index-project a:active .index-person {
	color: #666;
	-ms-filter: "";
	position: relative;
}

/* 
 * ---------------------------------------------------------------------------------------
 * カバー
 * 
 * .cover
 *     .cover-title
 *         .cover-subtitle
 *         .cover-maintitle
 *     .cover-person
 *         span
 *     .cover-picture
 * ---------------------------------------------------------------------------------------
 */

.frame-content .cover {
	position: relative;
}
.frame-content .cover .cover-title {
	box-sizing: border-box;
	color: #fff;
	left: 50%;
	line-height: 1.6;
	margin-left: -510px;
	padding: 0 40px;
	position: absolute;
	top: 0;
	width: 1020px;
}
.frame-content .cover .cover-subtitle {
	font-size: 1.3333333333333333333333333333333em;
	margin-top: 50px;
}
.frame-content .cover .cover-maintitle {
	font-size: 2.5em;
}
.frame-content .cover .cover-person {
	bottom: 30px;
	box-sizing: border-box;
	color: #fff;
	font-size: 1.3333333333333333333333333333333em;
	left: 50%;
	line-height: 1.6;
	margin-left: -510px;
	padding: 0 40px;
	position: absolute;
	width: 1020px;
}
.frame-content .cover .cover-person span {
	font-size: 0.58333333333333333333333333333333em;
	margin-right: 20px;
}
.frame-content .cover .cover-person br {
	display: none;
}
.frame-content .cover .cover-picture img {
	width: 100%;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .cover {
		height: 400px;
		overflow: hidden;
	}
	.frame-content .cover .cover-title {
		margin-left: 0;
		position: static;
		width: 100%;
	}
	.frame-content .cover .cover-subtitle {
		font-size: 1em;
	}
	.frame-content .cover .cover-maintitle {
		font-size: 2.2222222222222222222222222222222em;
	}
	.frame-content .cover .cover-person {
		font-size: 1.1666666666666666666666666666667em;
		left: 0;
		margin-left: 0;
		width: 100%;
	}
	.frame-content .cover .cover-person span {
		font-size: 0.57142857142857142857142857142857em;
	}
	.frame-content .cover .cover-picture {
		left: 50%;
		margin-left: -510px;
		position: absolute;
		top: 0;
		width: 1020px;
		z-index: -1;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .cover {
		overflow: hidden;
	}
	.frame-content .cover .cover-title {
		color: #000;
		margin-left: 0;
		padding: 0;
		position: static;
		text-align: center;
		width: 100%;
	}
	.frame-content .cover .cover-subtitle {
		font-size: 1.1428571428571428571428571428571em;
		margin-top: 20px;
	}
	.frame-content .cover .cover-maintitle {
		font-size: 2em;
	}
	.frame-content .cover .cover-person {
		color: #000;
		font-size: 1.2857142857142857142857142857143em;
		margin: 10px 0 0;
		padding: 0 20px;
		position: static;
		text-align: center;
		width: 100%;
	}
	.frame-content .cover .cover-person span {
		font-size: 0.66666666666666666666666666666667em;
		margin-right: 0;
	}
	.frame-content .cover .cover-person br {
		display: block;
	}
	.frame-content .cover .cover-picture {
		margin: 40px -15.686274509803921568627450980392% 0;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * リード文
 * 
 * .lead
 * ---------------------------------------------------------------------------------------
 */

.frame-content .lead {
	box-sizing: border-box;
	margin: 60px auto 0;
	padding: 0 123px;
	max-width: 1020px;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .lead {
		padding: 0 40px;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .lead {
		margin-top: 40px;
		padding: 0 20px;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * 関係者
 * 
 * .person
 *     .person-list
 *         .person-profile
 *             .person-picture
 *             .person-name
 *             .person-section
 * ---------------------------------------------------------------------------------------
 */

.frame-content .person {
	box-sizing: border-box;
	margin: 60px auto 0;
	padding: 0 123px;
	text-align: center;
	max-width: 1020px;
}
.frame-content .person .person-profile {
	display: inline-block;
	margin: 0 20px;
	text-align: left;
	vertical-align: top;
	width: 210px;
}
.frame-content .person .person-name {
	font-size: 1.1666666666666666666666666666667em;
	margin-top: 10px;
}
.frame-content .person .person-section {
	font-size: 0.66666666666666666666666666666667em;
	line-height: 1.8;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .person {
		padding: 0 40px;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .person {
		margin-top: 40px;
		padding: 0 20px;
	}
	.frame-content .person .person-list {
		display: inline-block;
	}
	.frame-content .person .person-profile {
		display: block;
		margin: 20px 0 0;
		width: auto;
	}
	.frame-content .person .person-profile:after {
		clear: both;
		content: "";
		display: table;
	}
	.frame-content .person .person-profile:first-child {
		margin: 0;
	}
	.frame-content .person .person-picture {
		float: left;
		padding-top: 0.5em;
		width: 60px;
	}
	.frame-content .person .person-name {
		font-size: 1.2857142857142857142857142857143em;
		margin: 0 0 0 80px;
	}
	.frame-content .person .person-section {
		font-size: 0.78571428571428571428571428571429em;
		margin-left: 80px;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * 話
 * 
 * .talk
 *     h2
 *     p
 *     .talk-figure
 * ---------------------------------------------------------------------------------------
 */

.frame-content .talk {
	box-sizing: border-box;
	margin: 0 auto;
	padding: 0 123px;
	max-width: 1020px;
}
.frame-content .talk h2 {
	font-size: 1.5555555555555555555555555555556em;
	margin: 60px 0;
}
.frame-content .talk p {
	margin-top: 20px;
}
.frame-content .talk .talk-figure {
	margin: 60px 0;
	text-align: center;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .talk {
		padding: 0 40px;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .talk {
		padding: 0 20px;
	}
	.frame-content .talk h2 {
		font-size: 1.4285714285714285714285714285714em;
		margin: 40px -20px;
		text-align: center;
	}
	.frame-content .talk p {
		margin-top: 10px;
	}
	.frame-content .talk .talk-figure {
		margin: 40px auto;
		width: 60%;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * 写真
 * 
 * .picture
 * ---------------------------------------------------------------------------------------
 */

.frame-content .picture {
	box-sizing: border-box;
	margin: 80px auto 0;
	padding: 0 40px;
	max-width: 1020px;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .picture {
		padding: 0;
	}
	.frame-content .picture img {
		width: 100%;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .picture {
		margin-top: 40px;
		padding: 0;
	}
	.frame-content .picture img {
		width: 100%;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * プロジェクト紹介
 * 
 * .link
 *     h2
 *     ul
 *         span
 * ---------------------------------------------------------------------------------------
 */

.frame-content .link {
	box-sizing: border-box;
	margin: 0 auto;
	padding: 0 40px;
	max-width: 1020px;
}
.frame-content .link h2 {
	margin-top: 80px;
	text-align: center;
}
.frame-content .link ul {
	color: #ddd;
	line-height: 1.6;
	width: 100%;
}
.frame-content .link ul:after {
	clear: both;
	content: "";
	display: table;
}
.frame-content .link ul li {
	box-sizing: border-box;
	float: left;
	font-size: 1.3333333333333333333333333333333em;
	min-height: 5.3em;
	margin-top: 50px;
	padding: 10px 20px 0;
	position: relative;
	text-align: center;
	width: 33.333333333333333333333333333333%;
}
.frame-content .link ul li a {
	color: #000;
	display: block;
	margin-top: -10px;
	padding-top: 10px;
	position: relative;
	text-decoration: none;
}
.frame-content .link ul li span {
	bottom: 100%;
	box-sizing: border-box;
	font-size: 0.5em;
	left: 0;
	line-height: 1.2;
	padding: 0 20px;
	position: absolute;
	width: 100%;
}
.frame-content .link ul li a span {
	padding: 0;
}
.frame-content .link ul li span + br {
	display: none;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .link ul {
		margin: 0 auto;
		width: 620px;
	}
	.frame-content .link ul li {
		width: 50%;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .link {
		padding: 0 20px;
	}
	.frame-content .link h2 {
		font-size: 1.2857142857142857142857142857143em;
		margin-top: 60px;
	}
	.frame-content .link ul li {
		font-size: 1.4285714285714285714285714285714em;
		min-height: 0;
		padding: 10px 0 0;
		width: 100%;
	}
	.frame-content .link ul li span {
		padding: 0;
	}
}

.ie8 .frame-content .link ul li a:hover,
.ie8 .frame-content .link ul li a:active {
	color: #666;
	-ms-filter: "";
}
