@charset "UTF-8";


/*
 * A better looking default horizontal rule
 */

 hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}



@media screen and (max-width: 768px) {
.inner { margin-left: 0px; padding: 5%;}
}

@media screen and (min-width: 768px) {
.inner { width:100%; max-width:1200px; padding:5% 10%; margin: 0 auto; }
}


/* Image */

	.image {
		border-radius: 0.375em;
		border: 0;
		display: inline-block;
		position: relative;
	}

		.image img {
			border-radius: 0.375em;
			display: block;
			width: 100%;
		}

	a.image {
		overflow: hidden;
	}

		a.image img {
			-moz-transition: -moz-transform 0.2s ease;
			-webkit-transition: -webkit-transform 0.2s ease;
			-ms-transition: -ms-transform 0.2s ease;
			transition: transform 0.2s ease;
		}

		a.image:hover img {
			-moz-transform: scale(1.075);
			-webkit-transform: scale(1.075);
			-ms-transform: scale(1.075);
			transform: scale(1.075);
		}








/* クラス「row」内のブロック要素の高さを揃える */
.row-eq-height {
    display: flex;
    flex-wrap: wrap;
}

/* マウスオーバーで画像拡大表示 */
.img-zoom {
	overflow: hidden;
	width: 100%;
	height: auto;
}
.img-zoom img {
	display: block;
	transition-duration: 0.3s;
}
.img-zoom img:hover {
	transform: scale(1.1);
	transition-duration: 0.3s;
}

/* 天地中央揃え */
.flex-container {
	width: 100%;
    	height: 100%;
    	display: inline-flex;
    	justify-content: center;
    	align-items: center;
}
.flex-inner {
	display: inline-block;
	width: 100%; /*table横幅拡張用*/
}

.caption-container {
	padding: 0 30px; 
}
@media screen and (max-width: 720px) {
	.caption-container {
		padding: 0; 
	}
}

.img-padding {
	padding: 0 1em; 
}
@media screen and (max-width: 720px) {
	.img-padding {
		padding: 0; 
	}
}

.lh-s {line-height: 1.5;}
.lh-m {line-height: 1.75;}
.lh-l {line-height: 2  ;}

.mb10 {margin-bottom: 10px}
.mb20 {margin-bottom: 20px}
.mb30 {margin-bottom: 30px}
.mb40 {margin-bottom: 40px}
.mb50 {margin-bottom: 50px}
.mb60 {margin-bottom: 60px}
.mb70 {margin-bottom: 70px}
.mb80 {margin-bottom: 80px}

.mb1em {margin-bottom: 1em}
.mb2em {margin-bottom: 2em}
.mb3em {margin-bottom: 3em}
.mb4em {margin-bottom: 4em}
.mb5em {margin-bottom: 5em}

body {font-size: 1.5rem;line-height: 1.75;margin-bottom: 1em;}
h2 {font-size: 2rem;line-height: 1.5;margin-bottom: 1em;}
h3 {font-size: 2rem;line-height: 1.5;margin-bottom: 1em;}
h4 {font-size: 1.5rem;line-height: 1.5;margin-bottom: 1em;}
dt, dd {font-size: 1.5rem;line-height: 1.75;}

@media screen and (max-width: 576px) {
	body {font-size: 1.3rem;line-height: 1.75;margin-bottom: 1em;}
	h2 {font-size: 1.8rem;line-height: 1.5;margin-bottom: 1em;}
	h3 {font-size: 1.8rem;line-height: 1.5;margin-bottom: 1em;}
	h4 {font-size: 1.6rem;line-height: 1.5;margin-bottom: 1em;}
	dt, dd {font-size: 1.3rem;line-height: 1.75;}
	p {font-size: 1.3rem;line-height: 1.5;}
}





/* Button */
.btn-flat-black {
  color: #fff;
  background: #1a1a1a;
  transition: .4s;
  font-weight: 700;
  font-size: 85%;
  letter-spacing: 0.05em;
  border: none;
  border-radius: 0;
  padding: 0 20px;
  line-height: 3em;
}

.btn-flat-black:hover {
  background: #808080;
  text-decoration: none;
  color: #fff;
}



/*プロフィール*/
.btn_box a {
	width: auto;
	display: inline-block;
	margin-bottom: 1em; 
}

@media screen and (max-width: 767px) {
	.btn_box a {
		width: 95%;
	}
}


/*追記分*/

#gallerytalk .btn_box a.btn-flat-black {
	color: #fff;
	font-size: 1.4rem;
}

#gallerytalk .next_page {
	text-align: right;
	float: right;
}

#gallerytalk .previous_page {
	text-align: left;
	float: left;
}


@media screen and (max-width: 767px) {
	#header { margin-left: 0px; padding: 2% 5% 1%;}
	#gallerytalk .next_page, #gallerytalk .previous_page {float: none;text-align:center;}
	.btn_box a {margin: 0 1em 1em 1em;}
}

@media screen and (min-width: 768px) {
	#header { width:100%; max-width:1200px; padding:1% 10%; margin: 0 auto; }
}

#gallerytalk ul, #headline_image ul {
	padding-left: 0;
}

#gallerytalk ul li, #headline_image ul li {
	list-style: none;
	font-size: 1.8rem;
}

#gallerytalk ul li, #headline_image ul li.current {
	text-decoration: underline;
}

span.tooltiptxt {
	border-bottom: 1px dotted;
	cursor: pointer;
	margin: 0 0.2rem;
	display: inline-block;
	color: #b38000;
}

.row .dl-horizontal dt {
	text-align: left;
}

.row .dl-horizontal dt, .row .dl-horizontal dd {
	line-height: 1.6;
}

.caption_r, .caption_l {
	font-size: 85%;
}

.col-md-12 .img img {
	width: 100%;
	
}

#headline_image .col-md-12 {
	line-height: 1.6;
}

#headline_image .g-fullheight--xs {
	height: 100%;
}

#headline_image .col-md-12 a {
	color: #fff;
	font-weight: 600;
}

#headline_image .col-md-12 h1 {
	font-size: 2.2rem;
	font-weight: 600;
	line-height: 1.4;
}

#gallerytalk h2 {
	font-size: 26px;
	font-weight: 400;
	line-height: 1.3;
}

#gallerytalk h3 {
	position: relative;
	font-size: 24px;
}

#gallerytalk h3::before {
	content: attr(data-number);
	display: inline-block;
	margin-right: 10px;
	color: #bdbdbd;
	font-size: 24px;
	font-weight: 600;
}

@media screen and (max-width: 767px) {
	#headline_image .g-fullheight--xs {
		background: none;
	}
	#headline_image .col-md-12 {
		padding: 5% 2% 3%;
		color: #333;
		border-bottom: 1px dotted #333;
		margin: 0 5% 0;
	}
	#headline_image .col-md-12 a {
		color: #333;
	}
	.sp-none {
		display: none;
	}
}

@media screen and (min-width: 768px) {
	.row .dl-horizontal dt {
		width: 120px;
	}
	.row .dl-horizontal dd {
		margin-left: 120px;
	}
	#headline_image .col-md-12 {
		max-width:1200px;
		margin:10px auto;
		padding: 30px 400px 30px 10%;
		color: #fff;
		background-image: url(../img/piretti.jpg);
		background-position: right 10% center !important;
		background-repeat: no-repeat;

	}
	#headline_image .g-fullheight--xs {
		background-color: #000;
	}
	.pc-none {
		display: none;
	}
}

@media screen and (min-width: 992px) {
	.caption_r {
		text-align: right;
	}
}

