/* ----------------------------------------------------
※ Topページで使用するCSSのみが書いてあります
※ Topページのみで読み込まれます
---------------------------------------------------- */

/* MainVisual
------------------------------------------------------------------------------*/

#visual {}
.mainV_wrap {}


/* bxSlider-メインビジュアル設定
--------------------------------------*/

.mainV {
  background-color: #fff;/* for_test */
  overflow: hidden;
  padding: 41.45% 0 0;/* 画角1+1.414 */
  position: relative;
}

.mainV .mainVimg {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}

.mainV .mainVimg ul {
  margin: 0;
  padding: 0;
}

.mainV .mainVimg li {
  list-style: none;
  width: 100%;
}

.mainV .mainVimg li img {
/*	max-width: none;*/
	width: 100%;
}

.bx-wrapper {
  background: #fff;
	border: none;
  margin-bottom: 0;
}

.bx-wrapper .bx-viewport {
  box-shadow: none;
  left: 0;
}

.bx-controls {
  left: 0;
  position: absolute;
  right: 0;
  top: 50%;
  width: 100%;
  z-index: 1500;
}

.custom-pager {
  bottom: 20px;
  left: 0;
  position: absolute;
  right: 0;
  width: 100%;
  z-index: 1500;
}

.custom-pager .bx-pager {
  text-align: center;
}

.custom-pager .bx-pager .bx-pager-item {
  display: inline-block;
  margin: 0 6px;
}

.bx-pager.bx-default-pager a {
  background: #ddd;
  border-radius: 50%;
  color: #ddd;
  display: block;
  font-size: 9px;
  line-height: 12px;
  width: 12px;
}

.bx-pager.bx-default-pager a:hover,
.bx-pager.bx-default-pager a.active {
  background: #2b2b2b;
  color: transparent;
  opacity: 1;
  transition: none;
}

.bx-wrapper .bx-loading {
  background: url(../img/bx_loader.gif) center center no-repeat #fff;
}

.bx-wrapper .bx-prev {
  background: url(../img/controls.png) no-repeat 0 -32px;
}

.bx-wrapper .bx-next {
  background: url(../img/controls.png) no-repeat -43px -32px;
}

.bx-wrapper .bx-controls-auto .bx-start {
  background: url(../img/controls.png) -86px -11px no-repeat;
}

.bx-wrapper .bx-controls-auto .bx-stop {
  background: url(../img/controls.png) -86px -44px no-repeat;
}


/* ----- MV text ----- */

.mainV .mainVtxt {
	left: 0;
	position: absolute;
	text-align: center;
	top: 23%;
	width: 100%;
	z-index: 1000;
}

.mainV .mainVtxt .page-title {
	margin: 0;
}

.mainV .mainVtxt .page-title.tk-genmin {
	font-family: "source-han-serif-japanese", 'Yu Mincho', serif;
	font-style: normal;
	font-weight: 400;
}

.mainV .mainVtxt .title-mansion-name {
	color: #fff;
	display: block;
	margin-bottom: 15px;
	text-align: center;
	text-shadow: 3px 3px 10px rgba(0,0,0,.45);
}

.mainV .mainVtxt .title-mansion-name .ja {
	display: block;
	font-size: 56px;
	font-weight: 600;
	margin: 0 auto;
	padding: 0 5% 8px;
	width: 1000px;
}

.mainV .mainVtxt .title-mansion-name .en {
	display: block;
	font-family: 'Times New Roman', 'Yu Mincho', serif;
	font-size: 66px;
	font-weight: 400;
	letter-spacing: 6px;
	margin: 0 auto;
	padding: 0 5%;
	width: 1000px;
}

.mainV .mainVtxt .title-sub-txt {
	background: url(../img/mv_txt_bg_blue.png) center repeat-y;
	display: block;
	margin: 0 auto;
	padding: 12px 0 23px;
	position: relative;
	text-align: center;
	width: 1000px;
}

.mainV .mainVtxt .title-sub-txt:before {
	background: url(../img/mv_txt_bg_line.png) center no-repeat;
	content: "";
	display: block;
	height: 3px;
	left: 50%;
	margin-left: -500px;
	position: absolute;
	top: -2px;
	width: 1000px;
}

.mainV .mainVtxt .title-sub-txt:after {
	background: url(../img/mv_txt_bg_line.png) center no-repeat;
	bottom: -1px;
	content: "";
	display: block;
	height: 3px;
	left: 50%;
	margin-left: -500px;
	position: absolute;
	width: 1000px;
}

.mainV .mainVtxt .title-sub-txt span {
	color: #fff;
	display: block;
	font-size: 24px;
	font-weight: 300;
	letter-spacing: 2px;
	line-height: 1.4;
	padding: 8px 8% 0;
	margin: 0 auto;
	max-width: 900px;
}


@media screen and (max-width: 1200px) {
	/*--- 表示領域が1200px以下の場合に適用するスタイル ---*/
	.mainV .mainVtxt .title-mansion-name .ja {
		font-size: 54px;
		font-weight: 500;
		width: 90%;
	}

	.mainV .mainVtxt .title-mansion-name .en {
		font-size: 64px;
		width: 90%;
	}

	.mainV .mainVtxt .title-sub-txt {
		padding: 8px 0 23px;
		width: 100%;
	}

	.mainV .mainVtxt .title-sub-txt span {
		font-size: 21px;
		line-height: 1.3;
		padding-top: 10px;
	}
}


@media screen and (max-width: 960px) {
	/*--- 表示領域が960px以下の場合に適用するスタイル ---*/
	.mainV .mainVtxt {
		top: 20%;
	}

	.mainV .mainVtxt .title-mansion-name .ja {
		font-size: 50px;
	}

	.mainV .mainVtxt .title-mansion-name .en {
		font-size: 56px;
		letter-spacing: 4px;
		line-height: 1;
	}

	.mainV .mainVtxt .title-sub-txt {
		padding: 5px 0 20px;
	}

	.mainV .mainVtxt .title-sub-txt span {
		font-size: 18px;
	}
}


/* nav
------------------------------------------------------------------------------*/

#nav {}


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

#main.top_page {
	border: none;
	padding: 2% 0 4%;
}

#main .inner {
  max-width: inherit;
}


/* caption-tile-menu-タイル状に並んだメニュー
--------------------------------------*/

.main .caption-tile-menu {
  margin: 90px auto 0;
  max-width: 1200px;
  padding-bottom: 60px;
  text-align: center;
  width: 100%;
}

.main .caption-tile-menu .tile-block {
	background-color: #1b1b1b;
	border: 1px solid #fff;
	box-sizing: border-box;
	display: inline-block;
	float: left;
	height: 260px;
	margin: 0;
	min-width: 350px;
	overflow: hidden;
	padding: 0;
	position: relative;
	width: 33.33%;
}

.main .caption-tile-menu .tile-block a {
  display: block;
  height: 260px;
  overflow: hidden;
}

.main .caption-tile-menu .tile-block a:hover {
  -ms-filter: "alpha(opacity=100)";
  opacity: 1;
}

.main .caption-tile-menu .tile-block .tile-bg-img {
  display: block;
  -ms-filter: "alpha(opacity=90)";
  opacity: .9;
  width: 100%;
}


/* キャプションブロックをホバーしたときに動きをつけるとき用*/

.main .caption-tile-menu .tile-block a:hover img {
  -ms-filter: "alpha(opacity=60)";
  opacity: .6;
}

.main .caption-tile-menu .tile-block .hd3 {
  left: 0;
  margin: 0;
  padding: 0;
  position: absolute;
  right: 0;
  text-align: left;
  top: 0;
  height: 260px;
  width: 100%;
}

.main .caption-tile-menu .tile-block .hd3 .inr-wrap {
  background: url(../img/overlay2.png) repeat;
  left: 2%;
  margin-top: -64px;
  padding: 8% 0 8% 6%;
  position: absolute;
  right: 0;
	text-shadow: 2px 2px 4px rgba(0,0,0,.25);
  top: 50%;
  width: 90%;
}

.main .caption-tile-menu .tile-block .hd3 .inr-wrap .en {
  color: #fff;
  display: block;
	font-family: 'Times New Roman', 'Yu Mincho', serif;
  font-size: 36px;
  font-weight: normal;
	letter-spacing: 3px;
	line-height: 1;
  text-transform: uppercase;
}

.main .caption-tile-menu .tile-block .hd3 .ja {
  color: #fff;
  display: block;
  font-family: "source-han-serif-japanese", sans-serif;
  font-size: 12px;
  font-weight: 200;
  letter-spacing: 1px;
	margin-bottom: 6px;
}


@media screen and (max-width: 1200px) {
	/*--- 表示領域が1200px以下の場合に適用するスタイル ---*/
	.main .caption-tile-menu .tile-block,
	.main .caption-tile-menu .tile-block a,
	.main .caption-tile-menu .tile-block .hd3 {
		height: 230px;
	}

	.main .caption-tile-menu .tile-block .hd3 .inr-wrap {
		margin-top: -60px;
		padding: 7% 0 8% 6%;
	}

	.main .caption-tile-menu .tile-block .hd3 .inr-wrap .en {
		font-size: 32px;
	}
}


@media screen and (max-width: 1080px) {
	/*--- 表示領域が1080px以下の場合に適用するスタイル ---*/
	.main .caption-tile-menu .tile-block {
		height: 200px;
		min-width: inherit;
	}

	.main .caption-tile-menu .tile-block a,
	.main .caption-tile-menu .tile-block .hd3 {
		height: 200px;
	}

	.main .caption-tile-menu .tile-block .hd3 .inr-wrap {
		margin-top: -65px;
	}

	.main .caption-tile-menu .tile-block .hd3 .inr-wrap .en {
		font-size: 28px;
	}
}


@media screen and (max-width: 960px) {
	/*--- 表示領域が960px以下の場合に適用するスタイル ---*/
	.main .caption-tile-menu .tile-block,
	.main .caption-tile-menu .tile-block a,
	.main .caption-tile-menu .tile-block .hd3 {
		height: 180px;
	}

	.main .caption-tile-menu .tile-block .hd3 .inr-wrap {
		margin-top: -50px;
	}

	.main .caption-tile-menu .tile-block .hd3 .ja {
		font-size: 11px;
	}

	.main .caption-tile-menu .tile-block .hd3 .inr-wrap .en {
		font-size: 24px;
	}
}


@media screen and (max-width: 870px) {
	/*--- 表示領域が870px以下の場合に適用するスタイル ---*/
	.main .caption-tile-menu .tile-block,
	.main .caption-tile-menu .tile-block a,
	.main .caption-tile-menu .tile-block .hd3 {
		height: 160px;
	}

	.main .caption-tile-menu .tile-block .hd3 .inr-wrap .en {
		font-size: 21px;
	}
}


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

#footer {}
