@charset "utf-8";
/* CSS Document */

/* =============================================================================
   Reset
   ========================================================================== */

*{
	padding:0px;
	margin:0px;
}

html {
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
}

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td {
	margin:0;
	padding:0;
}
table {
	border-collapse:collapse;
	border-spacing:0;
}
fieldset,img {
	border:0;
}
address,caption,cite,code,dfn,em,th,var {
	font-style:normal;
	font-weight:normal;
}
ol,ul {
	list-style:none;
	overflow:hidden;
}
caption,th {
	text-align:left;
}
h1,h2,h3,h4,h5,h6 {
	font-size:100%;
	font-weight:normal;
}
q:before,q:after {
	content:'';
}
abbr,acronym { border:0;
}
img{
	vertical-align:bottom;
}
form {
	margin: 0px;
	padding: 0px;
}
.clearfix::after {
	content: "";
	display: table;
	clear: both;
}

/* =============================================================================
   Link
   ========================================================================== */

a {
	transition: color .3s;
}

#footer a, .texteffect a {
	position: relative;
	display: inline-block;
	transition: .3s;
}

#footer a::after, .texteffect a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	width: 0;
	height: 1px;
	transition: .3s;
}

#footer a:hover::after, .texteffect a:hover::after {
	width: 100%;
}

a:link, a:hover ,a:visited{
	/* text-decoration:underline; */
}

a:hover, a:hover img {
	filter:Alpha(opacity=100) ;
	opacity:1.0 ;
	-moz-opacity:1.0;
}


/* =============================================================================
   Base
   ========================================================================== */

body {
	font-size: 16px;
	line-height:2.2;
	text-align: center;
	font-weight: 500;
	letter-spacing:0.01rem;
}

#wrapper {
}

#main {
	padding: 4% 0;
}

.container {
	max-width:1280px;
	margin:0 auto;
	overflow:hidden;
}

.box {
	padding: 4% 0;
}

.photo {
	text-align:center;
}

.photo img {
	max-width: 100%;
}

.thum {
	float:left;
}

.thumr {
	float:right;
}

.ttl{
	padding: 0 0 4%;
}

.ttl span{
	display: block;
}

.ttl .en {
    font-size: 4.5rem;
    letter-spacing: 0.07em;
}

.ttl .jp {
    font-size: 2.1rem;
    letter-spacing: 0.1em;
    line-height: 1;
}

#main .comment {
    margin: 4% 0;
}

.date{
	letter-spacing: 0.1rem;
}

.btn_more {
    margin: 2% 0;
    opacity: 1;
    display:inline-block;
}

.btn_more span {
  display:inline-block;
  float:right;
  margin-left:-20px;
  padding-right:15px;
  position:relative;
  z-index:500;
}

.btn_more:after {
	content: '›';
    display: inline-block;
    margin:0 20px 0 -20px;
}

.btn_more a {
    letter-spacing: 0.05em;
    padding: 18px 80px;
}

.btn_more a:hover {
	transition: all 0.3s ease-in-out 0s;
}

.btn_more a:link, .btn_more a:hover, .btn_more a:visited{
	text-decoration:none;
}


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

#header {
	/* 
	position: fixed;
	top:0;
	left:0;	
	*/
	z-index: 5000;
	width: 100%;
	-moz-transition: all 0.3s ease-in-out 0s;
	-o-transition: all 0.3s ease-in-out 0s;
	-webkit-transition: all 0.3s ease-in-out 0s;
	transition: all 0.3s ease-in-out 0s;
}

#header #logo {
    float: left;
    padding: 0% 0 0% 1%;
    text-align: left;
}

#header #logo img {
    transition: all 0.3s ease-in-out 0s;
	width: 90%;
}

#header #logo a {
   display: block;
}

#header #logo a:hover img {
    opacity: 0.5;
}

#data {
    text-align:left;
    float:right;
}

#data a {
	text-decoration: none;
}

#data i {
	margin: 0 2px 0 0;
}

#data_box{
	float: left;
	width: 400px;
	letter-spacing:0.03rem;
}

#data_box a:hover {
	opacity:0.5;
}

#data_inner{
	font-weight:bold;
	line-height: 1rem;
    padding: 5px 0;
}

.bn_line {
	font-size:0.78rem;
	margin: 0 10px 0 0;
	float: left;
}

.bn_mail {
	font-size:0.78rem;
}

.bn_tel {
	font-size: 2.68rem;
	line-height: 1em;
}

.bn_contact {
	text-align:center;
	width: 140px;
	float: right;
	transition: 0.5s;
}

#data .bn_contact a {
	display: block;
	height: 80px;
	line-height: 80px;
}

#base{
	font-size:0.68rem;
	padding:8px 0;
}

#base a{
	text-decoration: none;
}

#sitename{
	float:left;
}

#sitename a{
}

/* =============================================================================
   Breadcrumb
   ========================================================================== */

#breadcrumb{
	float:right;
}

#breadcrumb ol{
}

#breadcrumb li{
	float:left;
	text-align: right;
}

#breadcrumb li::after{
	content: '›';
	display: inline-block;
	padding: 0 5px; /*左右に余白*/
}

#breadcrumb li:last-child::after{
	display: none;
}

#breadcrumb li a{
}

/* =============================================================================
   Navi
   ========================================================================== */

#gnavi {
    width:100%;
}

#gnavi ul {
}

#gnavi li {
    float: left;
    width: calc(100% / 9);
}

#gnavi li a {
    text-decoration: none;
    padding: 25px 0;
    display: block;
    transition: 0.5s;
}

#gnavi li img {
}

#gnavi li.contact {
	margin: 0;
}

#gnavi li.contact a {
	padding: 25px 50px;
	transition: all 0.3s ease-in-out 0s;
}

.fixed {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 10000;
}

/* Overlay style */
.overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 10000;
}

/* Overlay closing cross */
.overlay .overlay-close {
	position: absolute;
	right: 1.5%;
	top: 0.5%;
	overflow: hidden;
	border: none;
	background: url(../img/cross.png) no-repeat center center / 100% auto;
	color: transparent;
	outline: none;
	z-index: 10000;
	width:7%;
	height:6%;
}

/* Menu style */
.overlay nav {
	text-align: left;
	position: relative;
	top: 50vh;
	height: 70vh;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.overlay ul {
	list-style: none;
	margin: 0 auto;
	display: inline-block;
	height: 100%;
	position: relative;
}

.overlay ul li {
	/* 	height: 20%; */
	height: calc(100% / 9);	
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	display:inline-block;
	width:100%;
	text-align:center;
}

.overlay ul li a {
	font-size: 1rem;
	font-weight: 300;
	display: block;
	-webkit-transition: color 0.2s;
	transition: color 0.2s;
	text-decoration:none;
	/* padding:2% 0; */
}

.overlay ul li a::before{
}

/* Effects */
.overlay-scale {
	visibility: hidden;
	opacity: 0;
	-webkit-transform: scale(0.9);
	transform: scale(0.9);
	-webkit-transition: -webkit-transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
	transition: transform 0.2s, opacity 0.2s, visibility 0s 0.2s;
}

.overlay-scale.open {
	visibility: visible;
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1);
	-webkit-transition: -webkit-transform 0.4s, opacity 0.4s;
	transition: transform 0.4s, opacity 0.4s;
}
.genericon{
	vertical-align:middle;
	display:inline;
}
.genericon:before{
	/* content: '\f429';
	color:#FFF; */
	margin:0 2% 0 0;
}
@media screen and (max-height: 30.5em) {
	.overlay nav {
		height: 70%;
		font-size: 34px;
	}
	.overlay ul li {
		min-height: 34px;
	}
}

#navi {
    height: 83px;
    padding: 2px 5px 0 0;
    position: fixed;
    right: 0;
    text-align: right;
    top: 0;
    width: 80px;
    z-index: 5500;
	display:none;
}

#trigger-overlay{
	border:none;
	background:none;
}

#navi span {
    display: block;
    height: 1px;
    margin: 30% 0;
    width: 26px;
}

#navi span:last-of-type {
    margin-bottom: 20%;
}

#navi .menu {
    font-size: 0.55rem;
    line-height: 1;
    text-align: center;
}

#nav-menu {
    text-align: center;
	letter-spacing:0.08em;
	line-height:1.4;
	width:90%;
	margin:0 auto;
}

#nav-menu a:link {
	padding: 2% 0;
	display:block;
}

.nav-tel{
	font-size:1.1rem;
}

.nav-time{
}

#bottomNavi {
	display: none;	
}

#bottomNavi i{
	font-size: 1.88rem;
}

/* =============================================================================
   Effect
   ========================================================================== */

/*
	ホバーで拡大・モーション
*/

.moved img {
	vertical-align: bottom;
}
.moved figure {
	width: 240px;
	height: 240px;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
}
.moved figcaption p {
	font-size: 12px;
}
.moved figure:after {
	position: absolute;
	content: "";
	display: block;
	width: 90%;
	height: 1px;
	left: 5%;
	top: 50%;

	-webkit-transform: scale(0);
	-moz-transform: scale(0);
	transform: scale(0);
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	transition: all .3s ease-out;
}
.moved figure:hover:after {
	-webkit-transform: scale(1);
	-moz-transform: scale(1);
	transform: scale(1);
}
.moved figcaption .txt,
.moved figcaption .title {
	position: absolute;
	text-align: center;
	width: 100%;
	opacity: 0;
	-webkit-transition: all .3s ease-out .4s;
	-moz-transition: all .3s ease-out .4s;
	transition: all .3s ease-out .4s;
}

.moved figcaption .title {
	bottom: 51%;
	-webkit-transform: translateY(-30px);
	-moz-transform: translateY(-30px);
	transform: translateY(-30px);
	overflow:hidden;
	text-overflow: ellipsis;
	white-space:nowrap;
	width: 92%;
	left:12px;
}

.moved figcaption .txt {
	top: 52%;
	-webkit-transform: translateY(30px);
	-moz-transform: translateY(30px);
	transform: translateY(30px);
	overflow:hidden;
	text-overflow: ellipsis;
	white-space:nowrap;
	width: 92%;
	left:12px;
}

.moved figure:hover figcaption .txt,
.moved figure:hover figcaption .title {
	opacity: 1;
	-webkit-transform: translateY(0);
	-moz-transform: translateY(0);
	transform: translateY(0);
}

.moved figure img {
	-webkit-transition: all 1.2s ease-out;
	-moz-transition: all 1.2s ease-out;
	transition: all 1.2s ease-out;
}

.moved figure:hover img {
	opacity: .4;
	-webkit-transform: scale(1.3);
	-moz-transform: scale(1.3);
	transform: scale(1.3);
}

/*----- フェードイン -----*/
.inviewfadeIn {
	opacity: 0;
	transition: .8s;
}

.fadeIn {
	opacity: 1.0;
}

/*----- 上へスライド -----*/
.inviewUp {
	transform: translate(0, 40px);
	-webkit-transform: translate(0, 40px);
	transition: .8s;
}

.Up {
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0);
}

/*----- ズームイン -----*/
.inviewzoomIn {
	transform: scale(0, 0);
	-webkit-transform: scale(0, 0);
	transition: .8s;
}

.zoomIn {
	transform: scale(1, 1);
	-webkit-transform: scale(1, 1);
}

/*----- フェードインしながら上へスライド -----*/
.inviewfadeInUp {
	opacity: 0;
	transform: translate(0, 60px);
	-webkit-transform: translate(0, 60px);
	transition: .8s;
}

.fadeInUp {
	opacity: 1.0;
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0);
}

/* Zoom In #1 */
.hover01 figure img {
	-webkit-transform: scale(1);
	transform: scale(1);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover01 figure:hover img {
	-webkit-transform: scale(1.3);
	transform: scale(1.3);
}


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

#footer {
    padding: 4% 0;
    text-align: center;
    width: 100%;
}

#footer ul {
    margin: 2.5% 0;
}

#footer li {
    display: inline-block;
    font-size: 0.88rem;
    margin: 0 0.88%;
}

#footer a {
    text-decoration: none;
}

#footer h2 {
	margin:0 0 3%;
}

#footer h2 a {
	position: static;
}

#footer h2 img {
    transition: all 0.3s ease-in-out 0s;
}

#footer h2 a:hover img {
    opacity: 0.5;
}

address {
	font-size: 0.66rem;
}

/* =============================================================================
   Scroll
   ========================================================================== */

#scrollUp { 
	position: fixed;
	bottom: 15px;
	right: 15px;
	z-index:1000;
}

#scrollUp i { 
	font-size: 2rem;
	line-height: 1.8;
}

#scrollUp a {
	width: 60px;
	height: 60px;
	display:block;
	text-align: center;
	z-index: 11;
	border:none;
	transition: all 0.3s ease 0s;
}

/* =============================================================================
   Device
   ========================================================================== */

@media screen and (max-width: 768px){
	body{
		font-size: 14px;
	}
	
	.container{
		width: 90%;
		margin: 0 auto;
	}
	
	.box{
		padding: 12% 0;
	}
	
	#header {
		background-size: contain !important;
	}
	
	#header #logo {
		float: none;
		width: 99%;
	}
	
	#data{
		display: none;
	}
	
	.ttl {
		padding: 0 0 12%;
	}
		
	.ttl .en{
		font-size: 2rem;
	}
	
	.ttl .jp{
		font-size: 1.33rem;
		line-height: 1.8rem;
	}
	
	#main .date{
		font-size: 0.67rem;
	}
	
	#main .title{
		font-size: 1.13rem;
    	line-height: 1.8rem;
		margin: 4% 0;
	}
	
	#main .comment{
		text-align: justify;
		margin: 8% 0;
	}
	
	#gnavi{
		display: none;
	}
	
	#gnavi .container {
		width: 100%;
	}	
	
	#gnavi li{
		display: none;
	}
	
	#gnavi li:nth-child(n + 6){
		display: none;
	}
	
	#navi {
		display: block;
	}
	
	#base {
    	font-size: 0.55rem;
    	padding: 1% 0;
	}
	
	#breadcrumb{
		display: none;
	}
	
	.btn_more{
		margin: 12% 0;
	}
	
	.btn_more a{
		margin: 12% 0;
	}
	
	#footer {
		padding:2% 0 18%;
	}

	#footer ul {
		text-align:left;
	}
	
	#footer li {
		display:block;
		margin:0;
		font-size:0.66rem;
	}
	
	#footer li:last-child {
		border:none;
	}	
	
	
	#footer li a {
		display:block;
		margin:0;
		padding:2% 5%;
	}
	
	address{
		font-size: 0.55rem;
		letter-spacing: 0.15rem;
	}
	
	#scrollUp {
		display: none !important;
	}
	
	#bottomNavi {
		display: block;
		bottom: 0;
		font-size: 0.88rem;
		overflow: hidden;
		position: fixed;
		width: 100%;
		z-index: 100;
	}

	#bottomNavi ul {
		margin:0;
	}

	#bottomNavi ul li {
		float: left;
		font-size: 0.66rem;
		text-align: center;
		width: calc(100% / 5);
	}

	#bottomNavi li a {
		display: block;
		padding: 8px 0 3px;
		text-decoration: none;
	}

	#bottomNavi li span{
		display:block;
		line-height: 1.3rem;
	}

	#bottomNavi li img{
		max-width: 30px;
	}	
}