@charset "UTF-8";

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

	fonts

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

@font-face {
  font-family: 'icomoon';
  src:  url('fonts/icomoon.eot?66jr75');
  src:  url('fonts/icomoon.eot?66jr75#iefix') format('embedded-opentype'),
    url('fonts/icomoon.ttf?66jr75') format('truetype'),
    url('fonts/icomoon.woff?66jr75') format('woff'),
    url('fonts/icomoon.svg?66jr75#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
}

[class^="icon-"]:before, [class*=" icon-"]:before,
[class^="icon-"]:after, [class*=" icon-"]:after,
*:before, *:after {
	font-family: 'icomoon';
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
  line-height: 1;
	vertical-align: baseline;

	/* Better Font Rendering =========== */
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/*.icon-arrow:before {
  content: "\e900";
}
.icon-instagram:before {
  content: "\e901";
}
.icon-facebook:before {
  content: "\e902";
}
.icon-twitter:before {
  content: "\e903";
}
.icon-youtube:before {
  content: "\e904";
}
.icon-photos:before {
  content: "\e905";
}
.icon-movies:before {
  content: "\e906";
}
.icon-arrow_top:before {
  content: "\e907";
}
.icon-arrow_right:before {
  content: "\e908";
}
.icon-arrow_bottom:before {
  content: "\e909";
}
.icon-arrow_left:before {
  content: "\e90a";
}
*/


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

	基本設定

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

body,html {
	color: #333;
}

a {
	color: #3363a3;
  text-decoration: underline;
}

.strong {
	color: #E5004F;
}

.lead {
	letter-spacing: .1em;
}

.map {
	height: 400px;
	position: relative;
}

.map > iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

p.size-small {
	font-size: .85em;
}

hr {
	margin-top: 2em;
	margin-bottom: 2em;
}

.movie {
	position: relative;
}

.movie:after {
	content: '';
	width: 100%;
	padding-top: 56.25%;
	display: block;
}

.movie > iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

@media (max-width: 768px) {
	body,html {
		/*min-width: 375px;*/
	}
	.map {
		height: 240px;
	}

}


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

	基本コンテンツ設定

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

.contents-wrapper {
}

.section > *, .inner {
	max-width: 1280px;
}

.fade {
	display: none;
	opacity: 0;
	-webkit-transition: 1s ease;
	-ms-transition: 1s ease;
	transition: 1s ease;
}

.fade.active {
	display: block;
	opacity: 1;
}

/*---------------------------------------------------------------
	header
---------------------------------------------------------------*/

.contents-header {
}

.header_top {
	margin-top: 40px !important;
}

.scroll_header {
	width: 100%;
	max-width: inherit;
	margin-top: 0 !important;
	padding: 30px 40px;
	background-color: rgba(255,255,255,1);
}

.scroll_header.fixed {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
}

.scroll_header .header_logo {
	width: 151px;
	position: absolute;
	top: 50%;
	left: 40px;
	transform: translateY(-50%);
}

.header_top .scroll_header:not(.fixed) .header_logo {
	display: none;
}



@media (min-width: 769px) {
	.scroll_header .gnav {
		margin-top: 0 !important;
		padding-left: 460px;
	}
	:not(.header_top) .scroll_header .gnav .list {
		justify-content: flex-end;
	}
	.header_top .scroll_header:not(.fixed) {
		max-width: 1280px;
	}
	.header_top .scroll_header:not(.fixed) .gnav {
		padding-left: 0;
	}
	.header_top .scroll_header:not(.fixed) .gnav .list {
		justify-content: space-between;
	}
}

@media (max-width: 768px) {
	.contents-header .scroll_header {
		padding: 15px;
	}
	.contents-header .scroll_header .header_logo {
		width: 226px;
		padding-right: 56px;
		position: static;
		transform: none;
	}
	.contents-header .section-header .gcol > .col {
		padding-top: 0;
	}
}


/* h1
-----------------------------------------------------*/
.header_logo {
  text-align: center;
}

.header_logo a {
  font-size: 1rem;
  text-decoration: none;
  outline: none;
  display: block;
}

.header_logo img {
	width: 100%;
}


/*---------------------------------------------------------------
	main
---------------------------------------------------------------*/

.contents-main {
  padding-top: 80px;
  padding-bottom: 80px;
	background-color: #fff;
}

@media (max-width: 768px) {
  .contents-main {
		padding-top: 40px;
		padding-bottom: 40px;
  }
}


/*---------------------------------------------------------------
	billboard
---------------------------------------------------------------*/

.billboard {
	height: calc(100vh - 160px);
/*	background: url("../_images/bg.png");
	background-repeat: no-repeat;
	background-size: cover;
	background-attachment: fixed;
	background-position: center;*/
}

.billboard:after {
	content: '';
	width: 100vw;
	height: calc(100vh - 160px);
	background: url("../_images/bg.png");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	display: block;
	position: fixed;
}

.contents-billboard > * {
	max-width: none;
}

.contents-billboard .section-header,
.contents-billboard .news {
	width: 100%;
	max-width: 500px;
	margin: 0;
	position: absolute;
	left: 0;
}

.contents-billboard .section-header {
	top: 15vh;
	padding-right: 0;
}

.contents-billboard .news {
	padding: 20px 20px 20px 40px;
	background-color: #fff;
	bottom: 0;
}

.contents-billboard .section-billboard {
	height: 100vh;
	margin-top: 0 !important;
	z-index: -1;
}

.contents-billboard .billboard {
	width: 100%;
	height: calc(100vh - 70px);
	margin: 0 0 0 140px;
	padding: 0;
	position: absolute;
	bottom: 0;
	left: 0;
}

.contents-billboard .billboard > * {
	width: 100%;
	height: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transition: 4s ease;
	-ms-transition: 4s ease;
	transition: 4s ease;
	opacity: 0;
	z-index: -1;
}

.contents-billboard .billboard > .current {
	opacity: 1;
}

.contents-billboard .list.type-sns {
	margin-top: 30px;
	text-align: left;
}

.contents-billboard .scroll {
	padding-bottom: 4.5em;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-size: 10px;
	color: #717174;
	letter-spacing: .1em;
	line-height: 1;
	position: absolute;
	top: -9.5em;
	left: 120px;
	display: inline-block;
}

.contents-billboard .scroll:before {
	content: '';
	width: .7em;
	height: .7em;
	border-top: solid 1px #717174;
	border-right: solid 1px #717174;
	display: inline-block;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%) rotate(135deg);
}

.contents-billboard .scroll:after {
	content: '';
	width: 1px;
	height: 4em;
	vertical-align: middle;
	background-color: #717174;
	display: inline-block;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
}

.contents-billboard .list.type-news {
	margin-top: 0;
}

@media (max-width: 768px) {
	.contents-billboard {
		height: auto;
	}
	.contents-billboard .section-header {
		width: 75%;
		padding: 20px;
		background-color: #fff;
		top: 0;
	}
	.contents-billboard .billboard {
		margin: 0 0 0 15px;
	}
	.contents-billboard .news {
		padding: 15px;
		position: relative;
	}
	.contents-billboard .news .btn {
		color: #333;
		border-color: #d9d9d9;
		background-color: #d9d9d9;
	}
	.contents-billboard .scroll {
		left: 2px;
	}
}


/*---------------------------------------------------------------
	footer
---------------------------------------------------------------*/

.contents-footer {
	padding: 20px;
	background-color: #000;
}

.copyright {
	margin: 0 !important;
	color: #fff;
	font-size: 10px;
	text-align: right;
}

@media (max-width: 768px) {
	.copyright {
		text-align: center;
	}
}

/*---------------------------------------------------------------
	section-
---------------------------------------------------------------*/

.section > hr {
	margin-top: 40px;
	margin-bottom: 40px;
}

.section.size-small > * {
	max-width: 1060px;
}

[class^="section-"].separate {
	padding-top: 40px;
	padding-bottom: 80px;
}


.section-header + [class^="section-"] {
  margin-top: 40px;
}


@media (max-width: 768px) {
	[class^="section-"].separate {
		display: none;
	}
	[class^="section-"].separate + [class^="section-"] {
		margin-top: 20px;
	}
	
}



/*---------------------------------------------------------------
	area
---------------------------------------------------------------*/

[class*=" area-"].section {
	padding-top: 80px;
	padding-bottom: 80px;
}

@media (max-width: 768px) {
	[class*=" area-"].section {
		padding-top: 40px;
		padding-bottom: 40px;
	}
	[class^="section-"][class*=" area-"] {
		padding-left: 0;
		padding-right: 0;
	}
	[class^="section-"].area-full + [class^="section-"].area-full {
		margin-top: 0;
	}
	.aside .area-full {
		margin-left: -15px;
		margin-right: -15px;
	}
}



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

	汎用スタイル

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

.ruby {
	margin-top: .5em;
	color: #3363a3;
	text-align: center;
	display: block;
}

.caption {
	font-size: .85rem;
	color: #717174;
}

.kakomi {
  padding: 40px;
}

* + .kakomi {
  margin-top: 20px;
}

.kakomi + .kakomi {
  margin-top: 2px;
}

.kakomi.type-fill {
  background-color: #e6e6e6;
}

img.shadow {
	box-shadow:3px 3px 2px 0px rgba(0,0,0,0.4);
}


/*---------------------------------------------------------------
	thumbnail
---------------------------------------------------------------*/

.thumbnail {
	overflow: hidden;
}

.thumbnail:after {
	padding-top: 66.7%;
  position: relative;
  z-index: 1;
}

.thumbnail > img {
	width: 100%;
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	transform-origin: top left;
	display: block;
	-webkit-transition: 1s ease;
	-ms-transition: 1s ease;
	transition: 1s ease;
  z-index: 0;
}

.thumbnail:hover > img {
	transform: scale(1.2) translate(-50%,-50%);
}

.thumbnail .caption {
	display: none;
}

.modal_area .thumbnail > img {
	position: static;
	transform: none;
}

.modal_area .thumbnail:after {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}

.modal_area .thumbnail .caption {
	display: block;
}


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

	btn

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

.btn,
button {
  width: 100%;
	max-width: 600px;
	min-width: inherit;
	margin-top: 1em;
	padding: 2em;
  border-radius: 4px;
	font-size: 1.28rem;
	font-weight: normal;
	text-align: center !important;
	line-height: 1;
	letter-spacing: .1em;
	color: #333;
	border-color: #333;
	background-color: transparent;
}

.btn:after {
	margin-left: 1em;
	content: "\e900";
	line-height: inherit;
	display: inline-block;
	transform: scale(.6);
	position: relative;
	top: 2px;
}

.btn.down:after {
	transform: scale(.6) rotate(90deg);
}

.btn.size-large {
	border-radius: 0;
}

.btn.size-small {
  width: auto;
	padding-top: 1em;
	padding-bottom: 1em;
	font-size: .9rem;
}

@media (max-width: 768px) {
	.btn,
	button {
		padding: 1em;
		font-size: 1.28rem !important;
		color: #fff;
		border-color: #333;
		border-radius: 4px !important;
		background-color: #333;
	}
	.btn.english {
		color: #333;
		border-color: #d9d9d9;
		background-color: #d9d9d9;
	}
}


/*---------------------------------------------------------------
	icon
---------------------------------------------------------------*/

.btn.type-icon {
  min-width: inherit;
  border-width: 2px;
  position: relative;
}

.btn.type-icon:after {
	padding-left: .25em;
  color: #fff;
  font-size: 2.5em;
	vertical-align: middle;
  display: inline;
}


/* icon
-----------------------------------------------------*/

.btn.type-icon.ic_headphone:after {
  content: '\e902';
}

.btn.type-icon.ic_buy:after {
  content: '\e903';
}


/* submit
-----------------------------------------------------*/

.btn.type-submit {
	margin-top: 40px;
	font-size: 1.42em;
}



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

	gnav

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

.gnav {
	margin-top: 80px !important;
}

.gnav .list {
	-js-display: flex;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
  flex-flow: row nowrap;
  justify-content: space-between;
  align-items: center;
}

.gnav .list > li + li {
	margin-top: 0;
}

.gnav .list > li .label {
	min-width: 4em;
/*  padding: 0 1em;*/
  color: #333;
  text-align: center;
  text-decoration: none;
/*	line-height: 1;
	letter-spacing: .1em;*/
  display: block;
  position: relative;
  overflow: hidden;
}

.gnav .list > li .label .ruby {
	font-size: .8em;
}


@media (max-width: 768px) {
	.gnav {
		width: 100%;
		height: 100vh;
		margin-top: 0 !important;
		padding-top: 56px;
		border: none;
		background-color: #fff;
		position: fixed;
		top: 0;
		left: 100vw;
		z-index: 10;
		-webkit-transition: 0.3s ease;
    -ms-transition: 0.3s ease;
    transition: 0.3s ease;
	}
	
	.gnav.active {
		left: 0;
	}
	.gnav > .inner {
		padding: 0;
	}
	.gnav .list {
		margin: 0;
		display: block;
	}
	.gnav .list > li {
    margin-top: 0;
		border-bottom: solid 1px #d3d4d6;
	}
	.gnav .list > :first-child {
		border-top: solid 1px #d3d4d6;
	}
	.gnav .list > li .label {
		padding: 1.5em 1em;
	}
}

/* ------------------------------------------------------------------
 gnav-trigger
------------------------------------------------------------------ */

.gnav-trigger {
	width: 56px;
	height: 56px;
	margin: 0 !important;
	background-color: transparent;
	cursor: pointer;
	position: fixed;
	top: 5px;
	right: 0;
	z-index: 10;
}

.gnav-trigger > .label {
	width: 32px;
	height: 4px;
	background-color: #333;
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.gnav-trigger > .label:before,
.gnav-trigger > .label:after {
	content: '';
	width: 100%;
	height: 4px;
	font-size: 0 !important;
	line-height: 0;
	background-color: #333;
	display: block;
	position: absolute;
	left: 0;
	-webkit-transition: all .3s ease;
	transition: all .3s ease;
}

.gnav-trigger > .label:before {
	top: -10px;
}

.gnav-trigger > .label:after {
	bottom: -10px;
}

.gnav-trigger.active > .label {
	background-color: transparent;
}

.gnav-trigger.active > .label:before,
.gnav-trigger.active > .label:after {
	top: 50%;
	left: 50%;
	transform-origin: left top 0;
}

.gnav-trigger.active > .label:before {
	transform: rotate(45deg) translate(-50%, -50%);
}

.gnav-trigger.active > .label:after {
	transform: rotate(-45deg) translate(-50%, -50%);
}

/*.gnav-close {
	cursor: pointer;
}

.gnav-close > .label {
	padding: 1rem;
	text-align: right !important;
}

.gnav-close > .label:after {
	content: '\e903' !important;
	margin-right: -.1em;
}*/


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

	見出し

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

.title {
 font-weight: normal;
}

.title.size-middle {
	font-size: 1.57em;
}

.title .strong {
	padding-right: .1em;
	font-size: 150%;
}

.title > .status {
	margin-bottom: 1em;
	padding: .5em 1em;
	color: #fff;
	font-size: 1rem;
	line-height: 1;
	border-radius: 4px;
	background-color: #5285ca;
	display: inline-block;
}

.title .ruby {
	font-size: .7em;
}

.title > .label > .small {
	font-size: .75em;
}


.title.align-left .ruby {
  text-align: left;
}

@media (max-width: 768px) {
	.title {
		font-size: 1.14em;
	}
	.title.size-middle {
		font-size: 1.28em;
	}
	.title.size-large {
		font-size: 1.57em;
	}
}


/*---------------------------------------------------------------
	type
---------------------------------------------------------------*/

/* vertical
-----------------------------------------------------*/
.title.type-vertical {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}


/* color
-----------------------------------------------------*/
.title.type-color > .label {
	color: #3363a3;
}


/* line_left
-----------------------------------------------------*/
.title.type-line_left > .label {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: .5em;
	border-left: 10px solid #006937;
}

/* fill
-----------------------------------------------------*/
.title.type-fill > .label {
	text-align: left;
	background-color: #5285ca;
}

.section.area-contact .title.type-fill > .label {
	color: #5285ca;
	background-color: #cadbf3;
}

/* border
-----------------------------------------------------*/
.title.type-border > .label {
	color: #2D9A42;
	text-align: left;
  border-radius: 5px;
	border: solid 2px #2D9A42;
}


/* complementary
-----------------------------------------------------*/
.title.type-complementary {
	color: #e06666 !important;
}

/* line_middle
-----------------------------------------------------*/

.title.type-line_middle > .label:before,
.title.type-line_middle > .label:after {
	border-bottom: double 4px #cadbf3;
	background-color: transparent;
}

/* line_bottom
-----------------------------------------------------*/

.title.type-line_bottom {
	font-weight: normal;
}

.title.type-line_bottom > .label {
	width: auto;
	padding-bottom: .5em;
	border: none;
	display: inline-block;
}

.title.type-line_bottom > .label:after {
	content: '';
	width: 40%;
	height: 1px;
	background-color: #333;
	display: block;
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
}

.title.type-line_bottom.align-left > .label:after {
  left: 0;
  transform: none;
}


/* image
-----------------------------------------------------*/

[class*=" type-image_"].title {
  margin-bottom: 40px;
}

.title.type-image_right {
  text-align: left;
}

.title.type-image_left {
  text-align: right;
}


[class*=" type-image_"].title > .label {
  position: absolute;
  bottom: 25%;
}

.title.type-image_right > .label {
  text-align: right;
  right: 0;
}

.title.type-image_left > .label {
  text-align: left;
  left: 0;
}

[class*=" type-image_"].title > .thumbnail {
  width: 65.5555%;
  display: inline-block;
}

@media (max-width: 768px) {
  [class*=" type-image_"].title > .label {
    margin-top: .5em;
    font-size: 1.14rem;
    text-align: left;
    position: static;
  }
  [class*=" type-image_"].title > .thumbnail {
    width: 100%;
  }
}


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

	リスト

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

.list.type-disc > li.title {
	margin-bottom: 0;
	padding: .5em;
	background-color: #f2f2f2;
}

.list.type-disc > li.title:before {
	display: none;
}


/* news
-----------------------------------------------------*/

.list.type-news > li {
	padding-top: .5em;
	padding-bottom: .5em;
  padding-left: 8em;
	font-size: .9rem;
  line-height: inherit;
  position: relative;
}

.list.type-news > :first-child {
  margin-top: 0;
}

.list.type-news > li:before {
	content: ''attr(title)'';
  width: 7em;
	font-size: .9rem;
  text-align: left;
	font-weight: normal;
  line-height: inherit;
  display: block;
  position: absolute;
  left: 0;
  z-index: 1;
}


/* table
-----------------------------------------------------*/

.list.type-table > li {
	padding-left: 5.5em;
}

.list.type-table > li:before {
	width: 5em;
	height: auto;
	text-align: left;
	font-weight: normal;
	background-color: transparent;
}

.list.type-table.size-large > li {
	padding-left: 8.5em;
}

.list.type-table.size-large > li:before {
	width: 8em;
}

@media (max-width: 768px) {
	.list.type-table.split-half > li {
		width: auto;
		display: block;
	}
}


/* sns
-----------------------------------------------------*/

.list.type-sns {
}

.list.type-sns > li {
	display: inline-block;
}

.list.type-sns > li + li {
	margin-left: 1rem;
}

.list.type-sns > li a {
	width: 30px;
	height: 30px;
	text-align: center;
	color: #fff;
	border-radius: 50%;
	background-color: #808080;
	display: block;
	position: relative;
}

.list.type-sns > li a:before {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	display: inline-block;
}

.list.type-sns > li .facebook:before {
	content: "\e902";
}

.list.type-sns > li .instagram:before {
	content: "\e901";
}

.list.type-sns > li .twitter:before {
	content: "\e903";
}

.list.type-sns > li .youtube:before {
	content: "\e904";
}


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

	accordion

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

[class*=" accordion"] {
  position: relative;
  cursor: pointer;
}

.content {
  -webkit-transition: 0.3s ease;
  -ms-transition: 0.3s ease;
  transition: 0.3s ease;
}

.accordion + .content,
.accordion-pc + .content {
	margin-top: 20px;
	padding: 0;
  height: 0;
	border-width: 0;
  overflow: hidden;
}

.accordion:after,
.accordion-pc:after {
	transform: scale(.6) rotate(90deg);
}

.accordion-sp {
  text-align: inherit;
  cursor: auto;
}

.accordion-sp:after {
  display: none;
}

[class*=" accordion"].active + .content {
  height: auto;
	padding: 2em 0;
}

[class*=" accordion"].active + .content * {
  font-size: 1rem;
}

[class*=" accordion"].active.hide {
	display: none;
}

@media (max-width: 768px) {
  .accordion-sp {
    text-align: left;
    cursor: pointer;
  }
  .accordion-sp:after {
		display: inline-block;
    transform: scale(.6) rotate(90deg);
  }
  .accordion-sp + .content {
    height: 0;
    overflow: hidden;
  }
  .accordion-pc {
    text-align: inherit;
    cursor: auto;
  }
  .accordion-pc:after {
    display: none;
  }
  .accordion-pc + .content {
    height: auto;
    overflow: auto;
  }
}

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

	portfolio

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

.portfolio_sample {
	position: relative;
}

.portfolio_sample > .col {
	width: 34.5% !important;
}

.portfolio_sample > :first-child {
	width: 65.5% !important;
}

.portfolio_sample > :first-child .thumbnail > img {
	width: auto;
	height: 100%;
}

.portfolio_sample > :last-child {
	position: absolute;
	right: 0;
	bottom: 0;
}

.portfolio_sample > :first-child .thumbnail:after {
	padding-top: calc(66.7% + 40px);
}

.portfolio_sample .thumbnail + .thumbnail {
	margin-top: 40px;
}

.ic-photos:before,
.ic-movies:before {
	color: #333;
	font-size: 5em;
	display: block;
}

.ic-photos:before {
  content: "\e905";
}
.ic-movies:before {
  content: "\e906";
}

/* ------------------------------------------------------------------
 portfolio_area
------------------------------------------------------------------ */

@media (max-width: 768px) {
	.portfolio_area {
		padding-top: 80px;
		padding-bottom: 80px;
		background-image: url("../_images/portfolio_01.jpg");
		background-position: center;
		background-repeat: no-repeat;
		background-size: cover;
	}
	.portfolio_area .btn {
		border-color: #fff;
		background-color: transparent;
	}
}

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

	profile

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

.title.type-vertical.profile_head {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

.title.type-vertical.profile_head > .label {
	text-align: left;
	font-weight: normal;
	font-family: serif;
}

.title.type-vertical.size-large.profile_head {
	font-size: 2.5em;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.title.type-vertical.profile_head > .label:first-line {
	font-size: 1.71rem;
}

.title.type-vertical.profile_head > .label .ruby {
	margin-top: 0;
	margin-right: 1em;
	padding-right: 1em;
	font-size: 1.16rem;
	font-family: sans-serif;
	color: #333;
	text-align: left;
	border-right: solid 1px #d3d4d6;
}

.title.type-vertical.profile_head > .label .ruby:first-line {
	font-size: .9rem;
}


@media (max-width: 768px) {
	.title.type-vertical.size-large.profile_head {
		margin-left: auto;
		margin-right: auto;
		position: static;
		transform: none;
	}
}


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

	books

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

/* ------------------------------------------------------------------
 area-books
------------------------------------------------------------------ */

.section.area-books {
	background-color: #ebe2ec;
	background-image: url("../_images/area_books_bg.jpg");
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: contain;
	position: relative;
}

.section.area-books > * {
	position: relative;
	z-index: 1;
}

.section.area-books:before {
	content: '';
	width: 100%;
	display: block;
	position: absolute;
	left: 0;
	z-index: 0;
}

.section.area-books:before {
	height: 200px;
	background: -moz-linear-gradient(top, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(top, rgba(255,255,255,1) 0%,rgba(255,255,255,0) 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(255,255,255,0) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#00ffffff',GradientType=0 ); /* IE6-9 */
	top: 0;
}

/*.section.area-books:after {
	height: 300px;
	background-image: url("../_images/area_books_bg.jpg");
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: cover;
	bottom: 0;
}*/

.section.area-books img {
	max-width: 240px;
}

.section.area-books hr {
	border-top-color: #fff;
}

@media (min-width: 769px) {
	.section.area-books .btn {
		background-color: #fff;
		border-color: #fff;
	}
}


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

	contact

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

.area-contact {
	margin-top: 0 !important;
}

.area-contact > .col {
	padding: 80px !important;
	text-align: center;
	position: relative;
	z-index: 0;
}

.area-contact > .col + .col {
	border-left: solid 1px #d3d4d6;
}

@media (min-width: 769px) {
	.area-contact > :last-child:after,
	.area-contact > :last-child * {
		-webkit-transition: 0.3s ease;
		-ms-transition: 0.3s ease;
		transition: 0.3s ease;
	}

	.area-contact > :last-child:after {
		content: '';
		width: 100%;
		height: 100%;
		background-image: url("../_images/area_contact_bg.jpg");
		background-repeat: no-repeat;
		background-position: center;
		background-size: cover;
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		opacity: 0;
		z-index: -1;
	}

	.area-contact > :last-child:hover:after {
		opacity: 1;
	}

	.area-contact > :last-child:hover * {
		color: #fff;
	}

	.area-contact > :last-child:hover .title.type-line_bottom > .label:after {
		background-color: #fff;
	}

	.area-contact > :last-child:hover .btn {
		background-color: #333;
	}
}

@media (max-width: 768px) {
	.gcol.area-contact > .col {
		padding: 40px 15px !important;
	}
	.area-contact > .col + .col {
		border-left: none;
	}
	.area-contact hr {
		width: calc(100% - 60px);
		position: absolute;
		left: 50%;
		bottom: 0;
		transform: translateX(-50%);
	}
}


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

	goods

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

.area-goods {
	background-image: url("../_images/area_goods_bg.jpg");
	background-position: bottom center;
	background-repeat: no-repeat;
	background-size: cover;
}

.area-goods .gcol {
	background-color: #fff;
}

.area-goods .gcol > :first-child {
	overflow: hidden;
}

.area-goods .gcol > :first-child img {
	width: auto;
	height: 100%;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
}

.area-goods .gcol > :last-child {
	padding: 40px;
}

.area-goods .btn {
	color: #333;
	border-color: #333;
	background-color: #fff;
}

@media (max-width: 768px) {
	.area-goods .gcol {
		background-color: transparent;
	}
	.area-goods .gcol > :last-child {
		padding: 0;
	}
	.area-goods .gcol > :first-child img {
		width: 100%;
		height: auto;
		position: static;
		transform: none;
	}
  .area-goods .btn {
    color: #333;
    border-color: #fff;
    background-color: #fff;
  }
}


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

	photos & Movies

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

.photos_list [class*=" accordion"] {
	margin-top: 40px;
}

.photos_list .thumbnail {
	cursor: pointer;
}


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

	goods_list

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

.goods_list {
  align-items: flex-end;
  position: relative;
}

.goods_list:before,
.goods_list:after {
  content: '';
  width: 30px;
  height: 100%;
  background: #fff;
  display: block;
  position: absolute;
  top: 0;
  z-index: 1;
}

.goods_list:before {
  left: 0;
}

.goods_list:after {
  right: 0;
}

.goods_list > .col {
  padding-bottom: 40px;
  border-bottom: solid 1px #ebe2ec;
}

.goods_list.book > .col {
	border-bottom: none;
}

.goods_list a {
  color: #000;
  text-decoration: none;
  display: block;
}

.goods_list .btn {
	margin-left: 0;
	color: #595757;
	border-color: #d9d9d9;
	background-color: #d9d9d9;
}

.goods_list .detail {
  margin-top: 1em;
  padding-bottom: 1.5em;
  position: relative;
}

.goods_list .title {
  min-height: 2em;
  margin-bottom: 0;
}

.goods_list .price {
  margin-top: .5em;
  color: #333;
}

.goods_list .price:before {
  content: '¥';
  padding-right: .25em;
}

.goods_list .soldout .detail:after {
  content: 'SOLD OUT';
  margin-top: .5em;
  color: #ea5532;
  display: block;
  position: absolute;
  bottom: 0;
}


@media (max-width: 768px) {
  .goods_list:before,
  .goods_list:after {
    width: 15px;
  }
}

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

	form

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

input,
textarea {
  border-color: #707070;
}

.form.type-label {
	margin-top: 0;
}

.form.type-checkbox,
.form.type-input,
.form.type-radio,
.form.type-select > .label,
.form.type-textarea,
.form.type-label {
  font-size: 1rem;
	color: #222;
}

.form.type-label {
	text-align: left;
	display: block;
}

.label-required:after {
	content: '*';
	color: #ff3b3b;
	background-color: transparent;
}

.change_required .label-required.star:after {
	content: '★';
}

.form + .form {
	margin-left: 2em;
}

.form.type-checkbox > .label:before,
.form.type-input,
.form.type-select > .label,
.form.type-textarea,
.form.type-pre {
	border-radius: 5px;
}

.form.type-checkbox > .label:before,
.form.type-radio > .label:before {
	border-color: #d3d4d6;
}

.form.type-input,
.form.type-select > .label,
.form.type-textarea {
	border: none;
	background-color: #f0f0f0;
}

.form.type-input,
.form.type-select > .label,
.form.type-pre {
	padding-top: .75em;
	padding-bottom: .75em;
}

.form.type-radio > .label:before {
  border-radius: 50%;
}

.form.type-checkbox > :checked + .label:before,
.form.type-radio > :checked + .label:before {
  background-color: #3363a3;
}

.form.type-checkbox > :checked + .label:before {
	border-color: #2D9A42;
	box-shadow: none;
	background-color: #2D9A42;
}

.form.type-checkbox > :checked + .label:after {
	content: "\e920";
	color: #fff;
	font-size: 1.75em;
	position: absolute;
	top: 50%;
	left: 0;
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

.form.type-checkbox > .label,
.form.type-radio > .label {
	padding-left: 2em;
}

.form.type-checkbox > .label:before,
.form.type-radio > .label:before {
	width: 1.5em;
	height: 1.5em;
}

.form.type-select {
	min-width: inherit;
}

.form.type-select > .label {
	padding-right: 3em;
  background: rgb(255,255,255); /* Old browsers */
  background: -moz-linear-gradient(top, rgba(255,255,255,1) 0%, rgba(245,245,245,1) 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top, rgba(255,255,255,1) 0%,rgba(245,245,245,1) 100%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(245,245,245,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#f5f5f5',GradientType=0 ); /* IE6-9 */
}

.form.type-select > .label:after {
	content: '\e907';
	font-size: 2.5em;
	color: #006937;
	position: absolute;
	top: 50%;
	right: 0;
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

.form-group {
	margin: 0;
	text-align: left;
}

.form-group .form,
.form-group .form + .form{
	margin-right: 1em;
	margin-left: 0;
	display: inline-block !important;
}

.form.type-pre {
	margin: 0 !important;
}

@media (max-width: 768px) {
}




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

	table

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


/* type-fill
-----------------------------------------------------*/
.table.type-fill > tbody > tr > th,
.table.type-fill > tbody > tr > td {
	padding: 1.5rem;
}

.table.type-fill > tbody > tr > th {
	color: #fff;
	line-height: 1.4;
	background-color: #2D9A42;
}

.table.type-fill > tbody > tr > td {
	background-color: #F8F8F8;
}


/* type-border
-----------------------------------------------------*/

.table.type-border {
	border-spacing: 0;
	border-bottom: solid 1px #cadbf3;
}

.table.type-border > tbody > tr > th,
.table.type-border > tbody > tr > td {
	padding: 1.5em 0;
	border-top: solid 1px #cadbf3;
}

.table.type-border > tbody > tr > th {
	width: 10em;
	color: #5285ca;
}

.table.type-border > tbody > tr > th + td {
	padding-left: 1em;
}

@media (max-width: 768px) {
	.table.type-border > tbody > tr > th {
		margin-bottom: .5em;
		padding: .5em;
		background-color: #cadbf3;
	}
	.table.type-border > tbody > tr + tr {
		margin-top: 1rem;
	}
	.table.type-border > tbody > tr > th > label {
		color: #5285ca;
	}
  .table.type-border:not(.hold),
  .table.type-border:not(.hold) > tbody > tr > th + td {
    border: none;
  }
}


/*---------------------------------------------------------------
	responsive
---------------------------------------------------------------*/

@media (max-width: 768px) {
	[class*=" hold-"].table > tbody > tr > td {
		padding: 0;
	}
}


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

	modal

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

.modal_area {
	padding: 0;
}

.modal_area .modal_close {
	width: 40px;
	height: 40px;
	right: -50px;
}

.modal_area .modal_arrow {
	width: 40px;
	height: 40px;
	border: solid 1px #fff;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: block;
	cursor: pointer;
	-webkit-transition: 0.3s ease;
	-ms-transition: 0.3s ease;
	transition: 0.3s ease;
}

.modal_area.photos {
	padding-left: 60px;
	padding-right: 60px;
}

.modal_area .modal_arrow:hover {
	background-color: #fff;
}

.modal_area .modal_arrow.next {
	right: -50px;
}

.modal_area .modal_arrow.prev {
	left: -50px;
}


.modal_area .modal_arrow:before {
	font-size: 2em;
	color: #fff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	display: inline-block;
	-webkit-transition: 0.3s ease;
	-ms-transition: 0.3s ease;
	transition: 0.3s ease;
}

.modal_area .modal_arrow:hover:before {
	color: #000;
}

.modal_area .modal_arrow.next:before {
	content: "\e908";
}

.modal_area .modal_arrow.prev:before {
	content: "\e90a";
}




