@charset "utf-8";
/*
Theme Name: LIVRE DESIGN
Description: LIVRE DESIGN
Theme URI: 
Author: LIVRE Co.,Ltd.
Version: 1.0.0
*/


/*  BODY
----------------------------------------------------------- */  

body {
	font-family: 'Averia Serif Libre', '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', 'メイリオ', sans-serif;
	font-size: 14px;
	line-height : 2.2;
	font-feature-settings : "palt" ;
	letter-spacing: 0.2em;
	margin: 0;
	padding: 0;
	color: #000;
	text-align: left;
}
a {
	text-decoration: none;
	color: #000;
}
img {
    max-width: 100%;
	height: auto;
}
a img:hover {
	opacity: 0.8;
	color: #fff;
}
hr {
  border: 1px solid #696969;
  margin: 20px 0;
}
ul {
    list-style: none;
}
iframe {
	max-width: 100%;
	margin: 0 0 5% 0;
	border: 1px #fff solid;
}

.bold {
	font-weight: bold;
}
.center {
	text-align:center;
}
.left {
	float: left;
}
.right {
	float: right;
}
.hidden {
    display:none !important
}
.pc {
	display: block!important;
}
.sp {
	display: none!important;
}

@media screen and (max-width: 768px) {

	.pc {
        display: none!important;
    }
    .sp {
        display: block!important;
    }
}


/* fadein
---------------------------------------------------- */

.fadein {
	opacity : 0;
	transform: translateY(40px);
	transition: all 1s;
}


/*  celtispack
----------------------------------------------------------- */
#csld-1 .container {
    padding-top: 75% !important;
}
.csld-wrapper {
    background: #fff!important;
}
article.img-info {
    background: none!important;
}
article.img-info .img-title {
    display: none!important;
}
.csld-thumbnav {
    background-color: #fff!important;
}


/*  マージン
----------------------------------------------------------- */ 

.m_t10 {
	margin: 10px 0 0 0;
}
.m_b10 {
	margin: 0 0 10px 0;
}
.m_t20 {
	margin: 20px 0 0 0;
}
.m_b20 {
	margin: 0 0 20px 0;
}
.m_t30 {
	margin: 30px 0 0 0;
}
.m_b30 {
	margin: 0 0 30px 0;
}
.m_t40 {
	margin-top: 40px;
}
.m_t50 {
	margin-top: 50px;
}
.m_t-20 {
	margin-top: -20px;
}
.m_t-30 {
	margin-top: -30px;
}
.m_t-40 {
	margin-top: -40px;
}
.m_t-50 {
	margin-top: -50px;
}
.m_5p {
	margin: 5% 0;
}
.m_tb5p {
	margin: 5% auto 5% auto;
}
.m_b15p {
	margin: 0 auto 15% auto;
}
.m_t10p {
	margin: 10% auto 0 auto;
}


/*  メインコンテンツ
----------------------------------------------------------- */  

#content {
    margin: 0 auto;
}
#content a {
	text-decoration: none;
	color: #000;
}
.wrap {
     overflow: hidden;
 }
.w1200 {
	width: 1200px;
	margin: 0 auto;
}
.w1100 {
	width: 1100px;
	margin: 0 auto;
}
.w1080 {
	width: 1080px;
	margin: 0 auto;
}
.w100 {
	width: 100%;
	margin: 0 auto;
}
.w90 {
	width: 90%;
	margin: 0 auto;
}
.w80 {
	width:80%;
	margin: 0 auto;
}
.w75 {
	width:75%;
	margin: 0 auto;
}
.w70 {
	width:70%;
	margin: 0 auto;
}
.w60 {
	width: 60%;
	margin: 0 auto;
	padding: 0 0;
}

.b_gr {
	background: #EFEFEF;
}
.pager{
	width: 100%;
	margin: 20px 0 20px 0;
	text-align:center;
}
/* ページャー */
#next {
    font-size: 85%;
    font-weight: lighter;
    text-align: center;
    padding-top: 30px;
    padding-bottom: 30px;
}
#blog-foot { /* パンくず */
	font-size:80%;
	text-align: left;
	margin: 20px 0 0 0;
	color:#999;
	letter-spacing: 0.15em;
}

@media screen and (max-width: 768px) {
	
	.w1200 {
		width: 90%;
		margin: 0px auto;
	}
	.w1100 {
		width: 90%;
		margin: 0px auto;
	}
	.w1080 {
		width: 90%;
		margin: 0px auto;
	}
	.w100 {
		width: 100%;
		margin: 0px auto;
	}
	.w90 {
		width: 90%;
		margin: 0px auto;
	}
	.w85 {
		width: 90%;
		margin: 0px auto;
	}
	.w80 {
		width: 90%;
		margin: 0px auto;
	}
	.w75 {
		width: 90%;
		margin: 0px auto;
	}
	.w70 {
		width: 85%;
		margin: 0px auto;
	}
	.w60 {
		width: 85%;
		margin: 0px auto;
	}
}



/*  flexbox
----------------------------------------------------------- */  

.fbox {
	display: flex;
	width: 100%;
	justify-content: space-between;
	flex-wrap: wrap; 
}
.fbox:before{
    content:"";
    display:block;
    width: 32%;
    height:0;
    order:1;
}
.fbox:after{
    content:"";
    display:block;
    width: 32%;
    height:0;
}
.fbox img{
	width: 100%;
	height: auto;
}
.w_top {
	width: 100%;
    height: auto;
	margin: 0 auto;
}
/*2列*/
.fbox .item2 {
	width: 49%;
	padding: 0 0;
}
/*3列*/
.fbox .item3 {
	width: 32%;
	padding: 0 0 5% 0;
}
.fbox .item3 img{
	width: 100%;
	height: 300px;
	object-fit: cover;
}
.post_in {
	position: relative;
	margin: 0 0 0 0;
}
.i_title {
	font-size: 1em;
	letter-spacing: 0.05em;
	margin: 5px 0 0 0;
}
.i_title a {
	color:#808080;
}
.i_title:hover {
	border-bottom: 1px solid #696969;
}
.i_date {
	font-size: 0.8em;
	letter-spacing: 0.1em;
	line-height: 1.8em;
	margin: 0 0 0 0;
	color:#808080;
}
.i_date a{
	color:#808080;
}


@media screen and (max-width: 768px) {
	
    .fbox {
		width: 100%;
		margin: 0 0 10% 0;
	}
	.fbox .item2 {
		width: 100%;
		margin: 0 0;
		padding: 0 0;
	}
	.fbox .item3 {
		width: 100%;
		margin: 0 0 20% 0;
	}
	.fbox .item3 img{
		height: 100%;
	}
}



/*  WORKS
----------------------------------------------------------- */

.w_mid {
	font-size: 0.9em;
	font-weight: bold;
	letter-spacing: 0.05em;
	margin: 5% auto 0 auto;
	text-align: left;
	color: #696969;
}
.w_tit {
	font-size: 2em;
	line-height: 1.8;
	letter-spacing: 0.05em;
	margin: 0 auto;
	padding: 0 0 5% 0;
	text-align: left;
}
.w_tit2 {
	font-size: 1em;
	letter-spacing: 0.05em;
	margin: 3% auto 0 auto;
	text-align: left;
}
.w_tex {
	font-size: 1em;
	letter-spacing: 0.05em;
	margin: 0 auto;
	text-align: left;
}
.w_link {
	font-size: 1em;
	letter-spacing: 0.05em;
	margin: 4% auto;
	text-align: left;
}
.w_link a{
	text-decoration: underline;
	color: #004F82;
}
.w_box {
	display: flex;
	width: 100%;
	justify-content: space-between;
	flex-wrap: wrap; 
}
.w_box img{
	width: 100%;
	height: auto;
}
.w_box .witem_l {
	width: 30%;
	padding: 2% 2% 5% 0;
}
.w_box .witem_r {
	width: 66%;
	padding: 2% 0 5% 0;
}

@media screen and (max-width: 768px) {
	
	.w_tit {
		font-size: 2em;
		margin: 2% auto;
	}
	.w_tit2 {
		font-size: 0.9em;
		margin: 5% auto 0 auto;
	}
	.w_tex {
		font-size: 1.1em;
		margin: 0 auto;
	}
	.w_box {
		width: 100%;
	}
	.w_box .witem_l{
		width: 100%;
		padding: 2% 0 5% 0;
	}
	.w_box .witem_r{
		width: 100%;
	}
	.w_box .witem2 {
		width: 100%;
		margin: 0 0;
	}
}

/*  タイトル
----------------------------------------------------------- */  

.tit_1 {
	 font-family: 'Averia Serif Libre';
	font-size: 1.6em;
	font-weight:bold;
	text-align: left;
}
.tit_2 {
	 font-family: 'Averia Serif Libre';
    font-size: 1.4em;
    letter-spacing: 0.1em;
    padding: 0 0;
    margin: 3% 0;
}

@media screen and (max-width: 767px) {

	.tit_1 {
		width: 100%;
		height: auto;
		font-size: 1.2em;
		padding: 5% 0% 2% 0;
	}
}



/*  テキスト
----------------------------------------------------------- */  

.t14 {
	font-size: 14px;
}
.t15 {
	font-size: 15px;
}
.t16 {
	font-size: 16px;
}
.t20 {
	font-size: 20px;
}
.t25 {
	font-size: 25px;
}
.t30 {
	font-size: 30px;
}
.lslh {
	letter-spacing: 0.2em;
	line-height: 2.2em;
}


/* 固定ページ
----------------------------------------------------------- */

.page_detail {
    width: 100%;
	margin-top: 2%;
    padding: 10px 0px 0px 0px;
}
.content_detail .txt-c {
	font-size: 1.5em;
	line-height: 2em;
	text-align: center;
}

.content_detail .photo-lib li img{
	height: auto;
	width: 100%;
}

@media screen and (max-width: 768px) {

	.page_detail {
		margin-top: 15%;
	}
}


/* シングルページ
----------------------------------------------------------- */ 

.single-l {
    width: 65%;
    float:left;
}
.single-r {
    width: 30%;
	padding: 0 0 0 10px;
    float: right;
}

.s_tit {
    font-size: 1.6em;
    font-weight: bold;
    line-height: 1.4;
	margin: 0px 0 5% 0;
}
.s_box {
    padding: 10px 0;
    overflow: hidden;
	border-bottom: solid 1px;
}
.cat a img {
    margin: 1% 0% 1% 0%;
	height: 30px;
	width: auto;
}
.s_date {
	color: #58595B;
    font-size: 14px;
	letter-spacing: 1px;
}
.s_tag a {
	text-decoration:none;
	color: #000000;
    font-size: 13px;
	letter-spacing: 1px;
}

@media screen and (max-width: 768px) {

	.single-l {
		width: 100%;
		margin: 0 auto;
	}
	.single-r {
	}
}


/* header1
----------------------------------------------------------- */  

#header {
	width: 100%;
	background: #fff;
	padding: 0 0 3% 0;
}
#header h1 {
	display: none;
}
#header .h_tit {
	 font-family: 'Averia Serif Libre';
	font-size: 1.4em;
	text-align: left;
	margin: 3% 0 0 0;
}
#header .h_tit a {
	font-family: 'Averia Serif Libre', cursive;
	font-size: 1.2em;
	letter-spacing: 0.05em;
	text-decoration: none;
	color: #000;
}
#header .h_tit a:hover {
	border-bottom: 1px solid #696969;
}
#header .hmenu {
	width: 100%;
    text-align: right;
    padding: 0 0;
}
@media screen and (max-width: 768px) {
	
	#header .h_tit {
		margin: 4% 0 0 0;
	}
	#header .logo {
		width: 100%;
		text-align: left;
		padding: 0 0;
		margin: -18% 0 0 0;
	}
	#header .logo img{
		width: 75%;
		height: auto;
	}
}


/*  PC NAV
----------------------------------------------------------- */

#nav {
	margin: -50px 0 0 0;
}
#nav  a:hover {
	border-bottom: 1px solid #696969;
	display: inline-block
}
#nav ul {
	list-style: none;
	margin: auto;
	letter-spacing: 0.1em;
	z-index: 50;
}
.main-navigation {
margin: 0 auto;
}
ul.nav-menu,
div.nav-menu > ul {
	margin: 0;
	padding: 0;
}
.nav-menu li {
	display: inline-block;
	position: relative;
	margin: 0 0;
}
.nav-menu li a {
	color: #333;
    display: block;
    font-size: 1em;
    padding: 10px 8px;
}
.nav-menu li:hover > a,
.nav-menu li a:hover {

	position: relative;
}
.nav-menu .sub-menu,
.nav-menu .children {
	display: none;
	padding: 0;
	position: absolute;
	text-align:left;
}
.nav-menu .sub-menu ul,
.nav-menu .children ul {
	border-left: 0;
	left: 0;
	top: 0;
	text-align:left;
}
.sub-menu li,
.sub-menu li a,
.sub-menu li a:hover{
	padding: 0 0 0 15px;
	position: relative;
	line-height: 2.8;
}
.sub-menu li :before {
    border-top: 1px solid;
    content: "";
    position: absolute;
    top: 50%;
    left: 0%;
    width: 5px;
}
ul.nav-menu ul a,
.nav-menu ul ul a {
	color: #333;
	margin: 0;
	width: auto;
}
ul.nav-menu ul a:hover,
.nav-menu ul ul a:hover {
	color: #696969;
}
ul.nav-menu li:hover > ul,
.nav-menu ul li:hover > ul {
	display: block;
}
.nav-menu .current_page_item > a,
.nav-menu .current_page_ancestor > a,
.nav-menu .current-menu-item > a,
.nav-menu .current-menu-ancestor > a {
	color: #333;
}


/*  SP NAV
----------------------------------------------------------- */

.menu{
    height: 20px;
    position: fixed;
    right: 3%;
    top: 3%;
    width: 30px;
    z-index: 210;
}
.menu__line{
    background: #000000;
    display: block;
    height: 3px;
    position: absolute;
    transition:transform .3s;
    width: 100%;
}
.menu__line--center{
    top: 9px;
}
.menu__line--bottom{
    bottom: 0;
}
.menu__line--top.active{
    top: 8px;
    transform: rotate(45deg);
}
.menu__line--center.active{
    transform:scaleX(0);
}
.menu__line--bottom.active{
    bottom: 10px;
    transform: rotate(135deg);
}

/*gnav*/
.gnav{
    background: rgba(255,255,255,0.95);
    display: none;
	width: 100%;
    height: 100%;
    position: fixed;
    z-index: 105;
	top: 0;
}
.gnav__wrap{
    align-items:center;
    /*display: flex;*/
    height: 100%;
    justify-content: center;
    position: absolute;
    width: 100%;
}
.gnav__menu{
    width: 100%;
}
.gnav__menu ul{
	margin: 0 0;
	padding: 0 0;
}
.gnav__menu__item{
    margin: 40px 0;
}
.gnav__menu__item a{
	 font-family: 'Averia Serif Libre';
    color: #000000;
    font-size: 1.5em;
    transition: .5s;
	letter-spacing: 0.15em;
}
.gnav__menu__item a:hover{
    color: #666;
}




@media screen and (max-width: 768px) {

    .menu{
		right: 4.5%;
		top: 4%;
		}
	.sub-menu li,
	.sub-menu li a,
	.sub-menu li a:hover{
		padding: 0 0 0 15px;
		position: relative;
		line-height: 2.8;
	}
	.sub-menu li :before {
		border-top: 1px solid;
		content: "";
		position: absolute;
		top: 50%;
		left: 0%;
		width: 5px;
	}
}


/* footer
----------------------------------------------------------- */   
   
#footer {
	width: 100%;
	overflow: hidden;
}
#footer .push {
	height: 50px;
}
#footer .foot_in {
	margin-bottom: 40px;
	border-bottom: 1px solid #bbb;
}
#footer .foot_left {
	 font-family: 'Averia Serif Libre';
	text-align: left;
	font-size: 13px;
	line-height: 3;
	letter-spacing: 1px;
}
#footer .foot_left a{
	font-family: 'Averia Serif Libre', cursive;
    font-weight: 100;
	color: #000000;
}
#footer .foot_right {
	font-size: 10px;
	float: right;
	text-align: right;
	line-height: 3;
	letter-spacing: 0.5px;
}

@media screen and (max-width: 768px) {

	#footer .foot_left {
	}
	#footer .foot_right {
		float: left;
	}
}


/*  トップへ戻るボタン
----------------------------------------------------------- */ 

/*ボタンの領域*/
#re-top {
	position:fixed; /*画面に固定*/
	bottom:0%; /*画面下へ*/
	right:0%; /*画面右へ*/
	z-index:10; /*レイヤー順序を上に*/
	background-color:transparent; /*領域の背景色（透明）*/
}
/*丸ボタン*/
.re-topB {
	position:relative;
	display:block; 
	background-color:rgba(0,0,0,0.3); /*丸ボタンの色*/
	color:rgb(255,255,255); /*三角と文字色*/
	text-decoration:none;
	font-weight:bold;
	font-size:12px;
	width:50px;
	height:50px;
	text-align:center;
	line-height:20px;
	padding-top:30px;
}
/*三角部分*/
.re-topB:before {
	font-family: FontAwesome;
	content:'\f106';
	position:absolute;
	top:15px;
	left:2px;
	width:100%;
	text-align:center;
	font-size:40px;
}


/* レスポンシブページネーション
---------------------------------------------------- */
   
.pagination{
	list-style-type: none;
	padding-left: 0;
	margin: 30px 0;
}
.pagination,
.pagination li a {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}
.pagination a {
	font-weight: 300;
	padding-top: 1px;
	text-decoration:none;
	border: 1px solid #ddd;
	border-left-width: 0;
	min-width:36px;
	min-height:36px;
	color: #333;
}
.pagination li:not([class*="current"]) a:hover {
	background-color: #eee;
}
.pagination li:first-of-type a {
	border-left-width: 1px;
}
.pagination li.first span,
.pagination li.last span,
.pagination li.previous span,
.pagination li.next span {
	/* screen readers only */
	position: absolute;
	top: -9999px;
	left: -9999px;
}
.pagination li.first a::before,
.pagination li.last a::after,
.pagination li.previous a::before,
.pagination li.next a::after {
	display: inline-block;
	font-family: Fontawesome;
	font-size: inherit;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	transform: translate(0, 0);
}
.pagination li.first a::before { content: "\f100"; }
.pagination li.last a::after { content: "\f101"; }
.pagination li.previous a::before { content: "\f104"; }
.pagination li.next a::after { content: "\f105"; }
.pagination li.current a {
	background-color: #ddd;
	cursor: default;
	pointer-events: none;
}
.pagination > li:first-child > a {
	border-bottom-left-radius: 4px;
	border-top-left-radius: 4px;
}
.pagination > li:last-child > a {
	border-bottom-right-radius: 4px;
	border-top-right-radius: 4px;
}
#post .section .post-data {
	margin-bottom: 1em;
}
.addtoany_list {
	display: inline-block !important;
	margin-bottom: 3em;
}



/* instashow-gallery　マウスオンカラー
---------------------------------------------------- */
.instashow-gallery .instashow-gallery-media-cover {
    background: #808080 !important;
}

.instashow-gallery .instashow-gallery-control-arrow::after, .instashow-gallery .instashow-gallery-control-arrow::before {
    background: #808080 !important;
}

/* SNS-box
---------------------------------------------------- */
.sns_box {
  position: absolute;
  overflow: hidden;
  top: 43%;
  left: 3.5%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  margin: auto;
  position: fixed;
  z-index: 100;
}

.sns_box2 {
	position: absolute;
    overflow: hidden;
    top: 0%;
    bottom: 0;
    left: 64%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  margin: 12% auto 5% auto;
  height: 44px;
  min-width: 268px;
}

.sns_button {
  border-radius: 100%;
  -moz-transition: all 280ms ease;
  -o-transition: all 280ms ease;
  -webkit-transition: all 280ms ease;
  transition: all 280ms ease;
}
.sns_button a {
  display: table-cell;
  width: 44px;
  height: 44px;
  color: #000;
  text-align: center;
  vertical-align: middle;
  -moz-transition: all 280ms ease;
  -o-transition: all 280ms ease;
  -webkit-transition: all 280ms ease;
  transition: all 280ms ease;
}
.sns_button i {
  font-size: 20px;
  vertical-align: middle;
  padding: 0 0 0 3px;
}
.sns_button:hover {
  box-shadow: inset 0 0 0 22px #000;
  color: #fff;
}

.sns_button + .sns_button {
  margin: 15px 0 0 0;
}

.twitter:hover a {
  color: #fff;
}
.facebook:hover a {
  color: #fff;
}
.instagram:hover a {
  color: #fff;
}
.vimeo:hover a {
  color: #fff;
}
.mail:hover a {
  color: #fff;
}

@media screen and (max-width: 768px) {

	.sns_button {
		float: left;
		border-radius: 100%;
		-moz-transition: all 280ms ease;
		-o-transition: all 280ms ease;
		-webkit-transition: all 280ms ease;
		transition: all 280ms ease;
	}
	.sns_button a {
		display: table-cell;
		width: 44px;
		height: 44px;
		color: #000;
		text-align: center;
		vertical-align: middle;
		-moz-transition: all 280ms ease;
		-o-transition: all 280ms ease;
		-webkit-transition: all 280ms ease;
		transition: all 280ms ease;
	}
	.sns_button + .sns_button {
		margin: 0 0 0 15px;
	}
}