@charset "UTF-8";



/* 
 * ---------------------------------------------------------------------------------------
 * インデックス
 * 
 * .index
 *     h1
 *     h2
 *     .index-personlist
 *         .index-person
 *             .index-picture
 *             .index-title
 *                 .index-name
 *                 .index-joined
 * ---------------------------------------------------------------------------------------
 */

.frame-content .index {
	box-sizing: border-box;
	margin: 0 auto;
	overflow: hidden;
	padding: 0 40px;
	max-width: 1020px;
}
.frame-content .index h1 {
	font-size: 2.5em;
	margin: 80px 0;
	text-align: center;
}
.frame-content .index h2 {
	font-size: 1.5555555555555555555555555555556em;
	margin-top: 60px;
}
.frame-content .index .index-personlist {
	color: #ddd;
	margin-left: -56px;
	width: 996px;
}
.frame-content .index .index-personlist:after {
	clear: both;
	content: "";
	display: table;
}
.frame-content .index .index-person {
	float: left;
	margin: 40px 0 0 56px;
	position: relative;
	width: 442px;
}
.frame-content .index .index-person a {
	color: #000;
	display: block;
	position: relative;
	text-decoration: none;
}
.frame-content .index .index-person .index-title {
	left: 0;
	line-height: 1.6;
	padding: 20px 30px;
	position: absolute;
	top: 0;
}
.frame-content .index .index-person .index-name {
	font-size: 1.5555555555555555555555555555556em;
}
.frame-content .index .index-person .index-joined {
	font-size: 0.77777777777777777777777777777778em;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .index .index-personlist {
		width: auto;
	}
	.frame-content .index .index-person {
		box-sizing: border-box;
		margin-left: 0;
		padding-left: 56px;
		width: 50%;
	}
	.frame-content .index .index-person .index-picture {
		display: block;
		height: 180px;
		overflow: hidden;
		position: relative;
		width: 100%;
	}
	.frame-content .index .index-person .index-picture img {
		display: block;
		height: 180px;
		left: 50%;
		margin-left: -221px;
		position: absolute;
		top: 0;
		width: 442px;
		max-width: none;
	}
	.frame-content .index .index-person .index-title {
		left: 56px;
	}
	.frame-content .index .index-person a .index-title {
		left: 0;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .index {
		padding: 0 20px;
	}
	.frame-content .index h1 {
		font-size: 2em;
		margin: 60px 0;
	}
	.frame-content .index h2 {
		font-size: 1em;
		margin-top: 40px;
	}
	.frame-content .index .index-personlist {
		margin: 0 -20px;
		width: auto;
	}
	.frame-content .index .index-person {
		float: none;
		margin: 20px 0 0;
		width: 100%;
	}
	.frame-content .index .index-person .index-picture img {
		width: 100%;
	}
	.frame-content .index .index-person .index-title {
		padding: 20px;
	}
	.frame-content .index .index-person .index-name {
		font-size: 1.4285714285714285714285714285714em;
	}
	.frame-content .index .index-person .index-joined {
		font-size: 0.85714285714285714285714285714286em;
	}
}

.ie8 .frame-content .index .index-person a:hover .index-title,
.ie8 .frame-content .index .index-person a:active .index-title {
	color: #666;
	-ms-filter: "";
}

/* 
 * ---------------------------------------------------------------------------------------
 * 多段
 * 
 * .column
 * ---------------------------------------------------------------------------------------
 */

.frame-content .column {
	margin: 0 auto;
	max-width: 1020px;
}
.frame-content .column:after {
	clear: both;
	content: "";
	display: table;
}

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

.frame-content .cover {
	position: relative;
}
.frame-content .cover .cover-title {
	box-sizing: border-box;
	left: 50%;
	margin-left: -510px;
	padding: 0 40px;
	position: absolute;
	top: 0;
	width: 1020px;
}
.frame-content .cover .cover-maintitle {
	font-size: 2.5em;
	line-height: 1.6;
	margin-top: 40px;
}
.frame-content .cover .cover-subtitle {
	font-size: 1.3333333333333333333333333333333em;
	line-height: 1.6;
	margin-top: 10px;
}
.frame-content .cover .cover-subtitle span {
	font-size: 0.75em;
	margin-right: 0.5em;
}
.frame-content .cover .cover-subtitle br {
	display: none;
}
.frame-content .cover .cover-mission {
	bottom: 30px;
	box-sizing: border-box;
	left: 50%;
	margin-left: -510px;
	padding: 0 40px;
	position: absolute;
	width: 1020px;
}
.frame-content .cover .cover-mission span {
	font-size: 0.77777777777777777777777777777778em;
	margin-right: 20px;
}
.frame-content .cover .cover-mission 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: 0;
		position: static;
		width: 100%;
	}
	.frame-content .cover .cover-maintitle {
		font-size: 2.2222222222222222222222222222222em;
	}
	.frame-content .cover .cover-subtitle {
		font-size: 1.1666666666666666666666666666667em;
	}
	.frame-content .cover .cover-subtitle span {
		font-size: 0.71428571428571428571428571428571em;
	}
	.frame-content .cover .cover-mission {
		left: 0;
		margin-left: 0;
		width: 100%;
	}
	.frame-content .cover .cover-mission span {
		font-size: 0.66666666666666666666666666666667em;
	}
	.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 {
		margin: 0;
		padding: 0 20px;
		position: static;
		text-align: center;
		width: 100%;
	}
	.frame-content .cover .cover-maintitle {
		font-size: 2em;
		margin: 20px -20px 0;
	}
	.frame-content .cover .cover-subtitle {
		font-size: 1.2857142857142857142857142857143em;
	}
	.frame-content .cover .cover-subtitle span {
		font-size: 0.66666666666666666666666666666667em;
		margin-right: 0;
	}
	.frame-content .cover .cover-subtitle br {
		display: block;
	}
	.frame-content .cover .cover-mission {
		left: 0;
		margin-left: 0;
		padding: 0 20px;
		width: 100%;
	}
	.frame-content .cover .cover-mission span {
		display: block;
		margin: 0 0 10px;
	}
	.frame-content .cover .cover-picture {
		margin: 40px -15.686274509803921568627450980392% 0;
	}
}

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

.frame-content .talk {
	box-sizing: border-box;
	float: left;
	padding: 0 40px;
	width: 605px;
}
.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 {
		float: none;
		width: 100%;
	}
	.frame-content .talk .talk-figure img {
		width: 100%;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .talk {
		float: none;
		padding: 0 20px;
		width: 100%;
	}
	.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 0;
	}
	.frame-content .talk .talk-figure img {
		width: 100%;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * CAREER STEP
 * 
 * .career
 *     h2
 *     table
 * ---------------------------------------------------------------------------------------
 */

.frame-content .career {
	box-sizing: border-box;
	float: right;
	padding: 0 40px;
	width: 412px;
}
.frame-content .career h2 {
	font-size: 1.3333333333333333333333333333333em;
	margin-top: 100px;
	text-align: center;
}
.frame-content .career table {
	margin-top: 40px;
	width: 100%;
}
.frame-content .career table tr {
	border-top: 2px solid #000;
	border-bottom: 2px solid #000;
}
.frame-content .career table th {
	padding: 10px 0;
	vertical-align: middle;
	width: 7em;
}
.frame-content .career table th span {
	font-size: 0.55555555555555555555555555555556em;
}
.frame-content .career table td {
	font-size: 0.72222222222222222222222222222222em;
	padding: 10px 0;
	vertical-align: middle;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .career {
		float: none;
		width: 100%;
	}
	.frame-content .career h2 {
		margin-top: 80px;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .career {
		float: none;
		padding: 0 20px;
		width: 100%;
	}
	.frame-content .career h2 {
		font-size: 1.2857142857142857142857142857143em;
		margin-top: 60px;
	}
	.frame-content .career table {
		margin-top: 30px;
	}
	.frame-content .career table th span {
		font-size: 0.71428571428571428571428571428571em;
	}
	.frame-content .career table td {
		font-size: 0.85714285714285714285714285714286em;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * 一日の生活
 * 
 * .schedule
 *     h2
 *     dl
 *         span
 * ---------------------------------------------------------------------------------------
 */

.frame-content .schedule {
	box-sizing: border-box;
	float: right;
	padding: 0 40px;
	width: 412px;
}
.frame-content .schedule h2 {
	font-size: 1.3333333333333333333333333333333em;
	margin-top: 60px;
	text-align: center;
}
.frame-content .schedule dl {
	margin-top: 30px;
	position: relative;
	width: 100%;
}
.frame-content .schedule dl:before {
	border: 1px solid #000;
	content: "";
	height: 100%;
	left: 2.2em;
	position: absolute;
	top: 0;
	width: 0;
}
.frame-content .schedule dl:after {
	clear: both;
	content: "";
	display: table;
}
.frame-content .schedule dl dt {
	background-color: #fff;
	clear: both;
	float: left;
	margin-top: 20px;
	padding: 10px 1em;
	position: relative;
	width: 5em;
}
.frame-content .schedule dl dt:first-child {
	margin-top: 0;
}
.frame-content .schedule dl dd {
	line-height: 1.6;
	margin: 20px 0 0 7em;
	padding-top: 10px;
}
.frame-content .schedule dl dd span {
	display: block;
	font-size: 0.72222222222222222222222222222222em;
	margin-top: 10px;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .schedule {
		float: none;
		width: 100%;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .schedule {
		float: none;
		padding: 0 20px;
		width: 100%;
	}
	.frame-content .schedule h2 {
		font-size: 1.2857142857142857142857142857143em;
		margin-top: 40px;
	}
	.frame-content .schedule dl {
		margin-top: 0;
	}
	.frame-content .schedule dl dd span {
		font-size: 0.85714285714285714285714285714286em;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * ワンシーン
 * 
 * .scene
 *     .scene-content
 *         p
 *             img
 * ---------------------------------------------------------------------------------------
 */

.frame-content .scene {
	box-sizing: border-box;
	float: right;
	padding: 0 40px;
	width: 412px;
}
.frame-content .scene .scene-content {
	background-color: #f5f5f5;
	font-size: 0.72222222222222222222222222222222em;
	margin-top: 60px;
	padding: 30px;
}
.frame-content .scene p {
	margin-top: 20px;
}
.frame-content .scene p:first-child {
	margin-top: 0;
}
.frame-content .scene img {
	width: 100%;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .scene {
		float: none;
		width: 100%;
	}
	.frame-content .scene .scene-content {
		box-sizing: border-box;
		width: 100%;
	}
	.frame-content .scene .scene-content:after {
		clear: both;
		content: "";
		display: table;
	}
	.frame-content .scene p {
		box-sizing: border-box;
		float: right;
		margin-top: 0;
		padding-left: 15px;
		width: 50%;
	}
	.frame-content .scene p:first-child {
		float: left;
		padding-right: 15px;
		padding-left: 0;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .scene {
		float: none;
		padding: 0 20px;
		width: 100%;
	}
	.frame-content .scene .scene-content {
		font-size: 1em;
		margin-top: 40px;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * プロフィール
 * 
 * .profile
 *     .profile-content
 *         .profile-picture
 *         .profile-name
 *         .profile-section
 *         .profile-text
 * ---------------------------------------------------------------------------------------
 */

.frame-content .profile {
	box-sizing: border-box;
	float: right;
	padding: 0 40px;
	width: 412px;
}
.frame-content .profile .profile-content {
	border: 2px solid #000;
	font-size: 0.72222222222222222222222222222222em;
	margin: 60px 0 0;
	padding: 28px;
}
.frame-content .profile .profile-picture {
	float: left;
	margin: 0 28px 28px 0;
	width: 120px;
}
.frame-content .profile .profile-name {
	font-size: 1.6153846153846153846153846153846em;
	padding-left: 148px;
}
.frame-content .profile .profile-section {
	font-size: 0.84615384615384615384615384615385em;
	line-height: 1.6;
	margin-top: 5px;
	padding-left: 148px;
}
.frame-content .profile .profile-text {
	clear: both;
	margin-top: 28px;
}

@media only screen and (min-width: 720px) and (max-width: 1039px) {
	.frame-content .profile {
		float: none;
		width: 100%;
	}
}

@media only screen and (max-width: 719px) {
	.frame-content .profile {
		float: none;
		padding: 0 20px;
		width: 100%;
	}
	.frame-content .profile .profile-content {
		font-size: 1em;
		margin-top: 40px;
	}
	.frame-content .profile .profile-picture {
		width: 60px;
	}
	.frame-content .profile .profile-name {
		font-size: 1.2857142857142857142857142857143em;
		padding-left: 88px;
	}
	.frame-content .profile .profile-section {
		font-size: 0.78571428571428571428571428571429em;
		padding-left: 88px;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * 写真
 * 
 * .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: 60px;
		padding: 0;
	}
}

/* 
 * ---------------------------------------------------------------------------------------
 * 社員紹介
 * 
 * .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;
	margin-top: 50px;
	padding: 10px 20px 0;
	position: relative;
	text-align: center;
	width: 25%;
}
.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;
}
.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: 580px;
	}
	.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;
		padding: 10px 0 0;
		width: 50%;
	}
	.frame-content .link ul li span {
		padding: 0;
	}
	.frame-content .link ul li span br {
		display: block;
	}
}

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