
/* =================================== */
/*	Basic Style 
/* =================================== */

@import url('https://fonts.googleapis.com/css?family=Cormorant+Garamond');

body {
    /*background-color:#fff;*/
	color: #555;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    line-height: 1.6;
	font-size: 14px;
}

ol, ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

figure{
	margin:0;
}

p {
    margin-bottom:15px;
}

a {
    color: #222;
	
    -webkit-transition: all .3s ease-in 0s;
       -moz-transition: all .3s ease-in 0s;
        -ms-transition: all .3s ease-in 0s;
         -o-transition: all .3s ease-in 0s;
            transition: all .3s ease-in 0s;
}

a[href^="tel:"] {
	cursor: default;
	text-decoration:none !important;
}

a[href^="tel:"]:hover{
	color:#222;
}


iframe {
    border: 0;
}

a, a:focus, a:hover {
    text-decoration: none;
    outline: 0;
}

a:focus, a:hover {
    color: #727272;
}

h1, h2, h3,
h4, h5, h6 {
	font-weight: normal;
	margin: 0 0 20px;
}

/* title */
h2{font-size:26px;}
h2.s{font-size:20px;}
h3{font-size:18px;}
h4{font-size:16px;}
h5{font-size:15px;}
h6{font-size:14px;}

.en{
	font-family: 'Cormorant Garamond', serif;
	letter-spacing: 0.05em;
}

.en2{
	font-family: 'Lato', sans-serif;
	letter-spacing: 0.02em;
}

h1.en{font-size:26px;}
h2.en{font-size:24px;}
h3.en{font-size:22px;}
h4.en{font-size:20px;}
h5.en{font-size:18px;}
h6.en{font-size:16px;}


/* title style 1 */
.tit-box{
	width:100%;
	font-family: 'Cormorant Garamond', serif;
}

.tit-box div{
	float:left;
}

.tit-box h2{
	font-size:46px;
	text-align:center;
	margin-bottom:30px;
	color:#000;
}

.tit-box div:nth-child(2){
	width:26%;
	margin:0 2%;
}

.tit-box div:nth-child(1),
.tit-box div:nth-child(3){
	border-bottom:1px solid #000;
	width:35%;
	height:40px;
}

.tit-box h2 span{
	display:block;
	font-size:12px;
	color:#666;
}

/* title style 2 */
.tit-lined{
	position:relative;
    margin-bottom:40px;
	color:#191919;
}

.tit-lined:after{
    content: '';
    position: absolute;
    height: 2px;
    background: #e6e8ea;
    width: 50px;
    bottom: -17px;
    left: 0;
}

/* title style 3 */
.tit-lined-d{
	border-bottom:4px double #4C4844;
	color:#333;
	padding-bottom:5px;
	margin-bottom:30px;
}


/* text */
.txt-cl{
	text-align:left;
}

@media (min-width: 768px) {
	.txt-cl{
		text-align:center;
	}
}

.txt_black{
	color:#191919;
}

.txt_white{
	color:#fff;
}

.txt_s{
	font-size:12px;
}

.txt-l{
	font-size:22px;
}

.txt-b{
	font-weight:bold;
}

.clear:before,
.clear:after {
    content: " ";
    display: table;
}
 
.clear:after {
   clear: both;
}
 
.clear {
   *zoom: 1;
}


/* button */
.btn:before {
    font-family: 'FontAwesome';
    content: '\f105';
    margin-right: 7px;
}



/* margin */
.mgnB0 {margin-bottom:0 !important;}
.mgnB5 {margin-bottom:5px !important;}
.mgnB10 {margin-bottom:10px !important;}
.mgnB15 {margin-bottom:15px !important;}
.mgnB20 {margin-bottom:20px !important;}
.mgnB30 {margin-bottom:30px !important;}
.mgnB40 {margin-bottom:40px !important;}
.mgnB50 {margin-bottom:50px !important;}
.mgnB60 {margin-bottom:60px !important;}
.mgnB70 {margin-bottom:70px !important;}
.mgnB80 {margin-bottom:80px !important;}

.mgnT0 {margin-top:0 !important;}
.mgnT5 {margin-top:5px !important;}
.mgnT10 {margin-top:10px !important;}
.mgnT20 {margin-top:20px !important;}
.mgnT30 {margin-top:30px !important;}
.mgnT40 {margin-top:40px !important;}
.mgnT50 {margin-top:50px !important;}
.mgnT60 {margin-top:60px !important;}
.mgnT70 {margin-top:70px !important;}
.mgnT80 {margin-top:80px !important;}

.mgnL0 {margin-left:0 !important;}
.mgnL5 {margin-left:5px !important;}
.mgnL10 {margin-left:10px !important;}
.mgnL15 {margin-left:15px !important;}
.mgnL20 {margin-left:20px !important;}
.mgnL30 {margin-left:30px !important;}
.mgnL40 {margin-left:40px !important;}
.mgnL50 {margin-left:50px !important;}
.mgnL100 {margin-left:100px !important;}

.mgnR0 {margin-right:0 !important;}
.mgnR1 {margin-right:1px !important;}
.mgnR5 {margin-right:5px !important;}
.mgnR10 {margin-right:10px !important;}
.mgnR15 {margin-right:15px !important;}
.mgnR20 {margin-right:20px !important;}
.mgnR30 {margin-right:30px !important;}
.mgnR40 {margin-right:40px !important;}
.mgnR45 {margin-right:45px !important;}
.mgnR50 {margin-right:50px !important;}
.mgnR90 {margin-right:90px !important;}
.mgnR100 {margin-right:100px !important;}

.pdnT0{padding-top:0 !important;}
.pdnB0{padding-bottom:0 !important;}



/* backgdounr */
.bg-white{
	background:#fff !important;
}

.bg-whitesmoke{
	background:#f4f4f4 !important;
}


/* section */
.section-def{
	padding:100px 0;
}

/*body > section{
	padding: 100px 0;
}
*/
/*.sec-title {}

.sec-title h2 {
  color: #191919;
  font-weight: 800;
}

.sec-sub-title {
	margin: 35px 0 45px;
}

.sec-sub-title p {
	font-weight: 600;
	line-height: 24px;
	font-size: 18px;
	color: #5b646e;
}*/

.devider {
  margin-top: 30px;
}

.devider i {
  color: #cccccc;
}

.devider:before,
.devider:after {
  content: "_____";
  color: #e6e8ea;
  position: relative;
  bottom: 6px;
}

/*.devider:before {
  right: 10px;
}

.devider:after {
  left: 10px;
}*/



#preloader {
  background-color: #fff;
  height: 100%;
  position: fixed;
  width: 100%;
  z-index: 1100;
}

#preloader > img {
  left: 47%;
  position: absolute;
  top: 48%;
}


/*=========================================
	Header
==========================================*/

#navigation {
  /*background-color: rgba(16, 22, 54, 0.2);*/
  background-color: rgba(255,255,255, 0);
  border: 0 none;
  margin: 0;
  
    -webkit-transition: background-color 800ms linear;
       -moz-transition: background-color 800ms linear;
	    -ms-transition: background-color 800ms linear;
         -o-transition: background-color 800ms linear;
			transition: background-color 800ms linear;
}

/* top動画の開始位置を下げた分の調整 --------*/
/*body.top {
	background:#000;
}

.top #navigation {
	background-color: rgba(0,0,0,1);	
}*/
/*-----------------------------------------*/ 

.navbar-toggle i {
	color: #333;
}

.navbar-brand {
  padding: 0;
}

.navbar-nav li a {
	border-top: 1px solid transparent;
	color:#fff;
	font-weight:500;
	letter-spacing:1px;
	font-family: 'Cormorant Garamond', serif;
}

.header_scroll li a{
	color:#191919;
}

.logo_second,
.header_scroll .logo_first{
	opacity:0;
}

.header_scroll .logo_second{
	opacity:1;
	margin-left:-147px;
}


.navbar-nav li a.current,
.navbar-nav li a:focus,
.navbar-nav li a:hover {
	background-color: transparent;
	border-top: 1px solid #767069;
	color: #767069;
}

.navbar-nav li.tel a{
	font-family: 'Lato', sans-serif;
}

.navbar-nav li.tel a.current,
.navbar-nav li.tel a:focus,
.navbar-nav li.tel a:hover {
	background-color: transparent;
	border-top: 1px solid transparent;
	color:#191919;
}

.navbar{
	min-height:85px;
}

#logo {
	margin:10px 0 0 0;
	/*width:210px;*/
	font-size:14px;
}

#logo img{
	width:55px;
}


/* navbar collapse for iPad (bootstrap) */
@media (max-width: 991px) {
    .navbar-header {
        float: none;
    }
    .navbar-toggle {
        display: block;
    }
    .navbar-collapse {
        border-top: 1px solid transparent;
        /*box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);*/
		width: 100%;
    }
    .navbar-collapse.collapse {
        display: none!important;
    }
    .navbar-nav {
        float: none!important;
        margin: 7.5px -15px;
    }
    .navbar-nav>li {
        float: none;
    }
    .navbar-nav>li>a {
        padding-top: 10px;
        padding-bottom: 10px;
    }
    .navbar-text {
        float: none;
        margin: 15px 0;
    }
    .navbar-collapse.collapse.in {
        display: block!important;
		width: 100%;
    }
    .collapsing {
        overflow: hidden!important;
    }
	
	.navbar-inverse .navbar-toggle {
    	border-color: #fff;
	}
	
	.nav > li > a{
		text-align:center;
	}
	
	#navigation.animated-header {
    	padding: 20px 0;
		background-color: rgba(0,0,0,0.6);
	}
	
	.navbar-nav li a.current,
	.navbar-nav li a:focus,
	.navbar-nav li a:hover {
		background-color: transparent;
		border-top: 1px solid transparent;
		color: #767069;
	}
	
	.navbar-toggle i{
		font-size:22px;
	}
	
}


/*=========================================
	Footer
==========================================*/


.footer {
  background-color:#f4f4f4;
  color:#4C4C4C;
  padding-top:40px;
  padding-bottom:20px;
}

.nav-footer li{
	float:left;
	margin-right:20px;
	font-size:14px;
}

.copyright {
  color:#B5B5B5;
  letter-spacing: 1px;
  font-size:13px;
}

/*.copyright a{
	color:#B5B5B5;
}

.copyright a:hover{
	color:#CECECE;
}*/


/* page top */
#back-top {
  bottom: 20px;
  position: fixed;
  right: 25px;
  z-index: 9;
}


/* nav-top-footer */
dl.nav-top-footer{
	font-family: 'Cormorant Garamond', serif;
	margin-bottom:10px;
}

dl.nav-top-footer dt{
	float:left;
	width:10%;
	font-weight:700;
	line-height:1;
	margin:0;
	padding-top:5px;
}

dl.nav-top-footer dd{
	display:inline-block;
	border-left:1px solid #ccc;
	line-height:1;
	padding:0 10px;
	margin:0;
}

dl.nav-top-footer dd:first-child(1){
	margin-left:10%;
}

dl.nav-top-footer dd:last-child{
	border-right:1px solid #ccc;
}

dl.nav-top-footer dt a{
	color:#064668;	
}


/* vm list */
table.vm-list{
	font-size:12px;
	font-family: 'Cormorant Garamond', serif;
	margin-bottom:0;
}

table.vm-list th{
	width:60px;
}



/* footer fixed btn */
.footer-btn{
	display:table;
	table-layout:fixed;
	position:fixed;
	left:10px;
	bottom:10px;
	z-index:9999999;
}
	
.footer-btn div{
	display:table-cell;
	text-align:center;
	vertical-align:middle;
	width:150px;
}
	
.footer-btn div a{
	background:#422B2F;
	color:#fff;
	display:block;
	padding:10px 0;
}
	
.footer-btn div a:hover{
	text-decoration:none;
}
	
.footer-btn div a{
	border:1px solid #937A7F;
	border-right:none;
}

.footer-btn div:last-child{
	width:200px;
	border-right:1px solid #937A7F;
}

.footer-btn-tel{
	font-size:13px;
	font-family: 'Lato', sans-serif;
	margin-left:10px;
}

/* fix btn */
.btn-fix{
	position:fixed;
	right:10px;
	bottom:50px;
}

.btn-fix img{
	width:120px;
}
.vmg-logo {
    width: 94%;
    max-width: 800px;
    margin: 0 auto;
    padding: 0 0 40px;
    float: none;
}
.vmg-logo a:hover {
    opacity: 0.7;
}
.vmg-logo img {
	width: 100%;
}

/*=========================================
	Slider
==========================================*/

#slider {
	padding: 0;
}

#slider .carousel-inner .item {
  background-size: cover;
}

.carousel-caption {
  top: 55%;
}

.carousel-caption h2 {
  font-size: 36px;
  font-weight: 300;
  letter-spacing: 0.2em;
  margin-bottom:20px;
}

.carousel-caption h2 span {
  font-weight: 800;
}

.carousel-caption h3 {
  font-size: 24px;
  font-weight: 300;
  margin: 6px 0 20px;
}

.carousel-caption p {
  color: #fff;
  font-size: 12px;
  font-weight: 300;
}

/*.carousel-caption p:before,
.carousel-caption p:after {
color: #BFBFBF;
content: "___";
position: relative;
top: -8px;
}*/

.carousel-caption p:before {
  right: 20px;
}

.carousel-caption p:after {
  left: 20px;
}

.social-links {
  margin-top: 5%;
}

.social-links li {
	display: inline-block;
}

.social-links li a {
  color: rgba(255, 255, 255, 0.3);
  display: block;
  margin: 0 6px;
}

.social-links li a:hover {
  color: #fff;
}

.carousel-indicators {
  bottom: 10px;
  left: inherit;
  margin: 0;
  right: 30px;
  top: 49%;
  width: 0;
}

.carousel-indicators li {
  border: 1px solid rgba(255, 255, 255, 0.3);
  height: 8px;
  width: 8px;
}

.carousel-indicators .active {
  height: 8px;
  width: 8px;
}

/*=========================================
	Big Video
==========================================*/
#big-video-wrap{
	z-index:-1;
}

.top_movie{
	/*background-color:transparent;
	height:100%;*/	
	width: 100vw;
  	height: 100vh;
}

.caption-movie{
	color:#fff;
	font-size:40px;
	position:absolute;
	top:48%;
}

.caption-movie img{
	width:779px;
}


/*=========================================
	Owl Carousel
==========================================*/
.owl-gallery .owl-nav .owl-next {
  right: 0;
  position: absolute;
}

.owl-gallery .owl-nav .owl-prev {
  left: 0;
  position: absolute;
}

.owl-gallery .owl-controls {
  position: absolute;
  text-align: center;
  width: 100%;
  margin:-20px auto;
  top: 45%;
}

.owl-gallery .owl-controls .owl-nav [class*="owl-"] {
  background: none repeat scroll 0 0 #fff;
  border: 0 solid #fff;
  border-radius: 100%;
  color: #242424;
  cursor: pointer;
  display: inline-block;
  font-size: 28px;
  height: 50px;
  line-height: 50px;
  margin: 0 30px;
  padding: 0;
  text-align: center;
  width: 50px;
}

.owl-gallery .owl-controls .owl-nav [class*="owl-"]:hover{
	color: #242424;
}


.section-white .owl-gallery .owl-controls .owl-nav [class*="owl-"] {
  background: #f5f5f5;
}

.owl-gallery .owl-item {
  width:100%;
  text-align:center;
}

.owl-gallery img {
  /*margin:20px auto 0;
  max-width: 100px;*/
  width:100%;
}

.owl-gallery h3 {
  font-size: 16px !important;
  margin: 20px 0 5px;
}

.owl-gallery small {
  font-size:13px;
  font-style: italic;
}

.owl-gallery p {
  font-weight: 300;
  margin:0 0 20px;
  color:#888;
  font-size:14px;
  background:#f5f5f5;
  padding:15px;
}


/*=========================================
	table_rwd
==========================================*/
.table_rwd{
	margin-bottom:40px;
}

.table_rwd dl{
	display:table;
	border-bottom:1px solid #ddd;
	width:100%;
	margin-bottom:0;
}

.table_rwd dl dt{
	display:table-cell;
	width:52%;
	padding:10px;
	vertical-align:middle;
}

.table_rwd dl dd{
	display:table-cell;
	width:48%;
	padding:10px;
	vertical-align:middle;
}


/*=========================================
	Youtube
==========================================*/
.iframe_wrap_movie{
	position: relative;
	width: 100%;
    padding-top: 56.25%;
    margin-bottom: 20px;
}

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


/*=========================================
	Footer button
==========================================*/
.btn_sns{
	background-color: #191919;
    color: #fff;
    height: 42px;
    padding: 10px 0 0;
    width: 42px;
}

.logo_footer{
	text-align:center;
}

.logo_footer img{
	width:210px;
}



/*=========================================
	TOP
==========================================*/

/* main visual */
.main-visual{
	background:url(../img/top/main_visual.jpg) top center no-repeat;
	height:800px;
	position:relative;
}

.logo-mainvisual{
	background-color:rgba(255,255,255,0.4);
	padding:30px 40px;
	display:inline-block;
	margin-top:240px;
}

.logo-mainvisual img {
	max-width: 200px;
	width: 100%;
}

/* news メイン下 */
#news {
	position:absolute;
	left:0;
	bottom:0;
	width:100%;
    background-color: rgba(255,255,255,0.7);
    color: #222;
	padding:20px 0;
}

dl.news-list{
	margin:0;
}

dl.news-list dt{
	width:15%;
	float:left;
	font-size:16px;
	font-weight:normal;
	letter-spacing:1px;
}

dl.news-list dd{
	margin-left:10%;
}

/* link area */
.area-link div img{
	margin-bottom:20px;
}

.area-link div h4{
	margin-bottom:10px;
}


/* news */
.area-news{
	display:table;
	margin-bottom:30px;
}

.area-news div{
	display:table-cell;
	vertical-align:top;
}

.area-news div:first-child{
	width:20%;
}

.area-news div:last-child{
	width:80%;
	padding-left:20px;
}

.area-news dl dt span{
	font-size:14px;
	margin-left:10px;
}

.area-news dl dt{
	font-size:16px;
	margin-bottom:10px;
	font-weight:normal;
}

.area-news dl dt h3{
	font-size:16px;
	margin:10px 0 0;
}

/* plan */
.card{
	box-shadow: 0 1px 2px #ccc;	
	margin:0 10px 20px;
}

.card-content{
	padding: 20px;	
}



/*----------------*/

.bnr-mnw{
	background:#fff;
	padding:30px 0 0 !important;
	margin:0 0 -70px;
}

.bg-concept{
	background:url(../img/top/photo_concept.jpg) 0 0 no-repeat fixed;
	background-size:cover;
	width:100%;
	padding:350px 0;
	text-align:center;
}


.bg-plan{
	background:url(../img/top/photo_plan.jpg) 0 0 no-repeat fixed;
	background-size:cover;
	width:100%;
	padding:200px 100px;
	text-align:left;
}

.gmap{
	height:410px;
}



/*=========================================
	Concept
==========================================*/
.tit_concept img{
	width:420px;
}


/*=========================================
	Gallery
==========================================*/
.tit_gallery img{
	width:300px;
}

/*=========================================
	Plan
==========================================*/

/* Plan TOP, TOP PAGE Fair */
.post-item{
	margin-bottom:30px;
}

.post-item .thumbnail{
	margin-bottom:20px;
}

.post-item .excerpt h3{
	font-size:16px;
}

.post-item .arrow{
	display:none;
}

/* detail */
.subtit_plan{
	font-size:14px;
	font-weight:bold;
	color:#000;
}

.plan_price{
	color:#C30D23;
}

.plan_item table{
	width:100%;
	margin:10px 0 20px;
}

.plan_item table td,
.plan_item table th {
    padding: 12px;
    border: 1px solid #ddd;
    font-size: 14px;
}

/*=========================================
	Access
==========================================*/

.img_access{
	width:130px;
	margin:0 15px 0 0;
	vertical-align:text-top;
}





/* ボタンサイズ変更 */

.btn-lg, .btn-group-lg > .btn {
	padding: 16px 20px;
}



