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


/*----------------------------------------初期設定リセットここから▼------------------------------------------*/
* {
	margin:0;
	padding:0;
	font-size: initial;
	font-size: 62.5%;
	font-style: normal;
	font-weight: normal;
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝','Yu Mincho', '游明朝体', 'YuMincho','ＭＳ Ｐ明朝', 'MS PMincho', serif;
	box-sizing: border-box;
}
/*----------------------------------------初期設定リセットここまで▼------------------------------------------*/


/*----------------------------------------ナビここから▼----------------------------------------------------*/
header {
  height: 70px;
  width: 100%;
  padding: 0px 15px;
  background-color: rgba(0,0,0,0.80);
  position: fixed;
  top: 0;
  z-index: 10;
  display: flex;
}
header nav {
  margin: 0 0 0 auto;
}
header ul {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
}
header a {
  color: #FFFFFF;
  font-weight: 900;
  text-decoration: none;
  display: block;
  line-height: 70px;
  padding: 0 1.5em;
}
header a:hover {
  color: #ff0000;
}
header .logo a img {
  vertical-align: middle;
}
header .personalcomputer ul li a {
  font-size:  calc(10px + 4 * (100vw - 320px)/880);
}
header .smartphone {
  display: none;
}

/*-----以下、ハンバーガーメニューの設定-----*/
@media (max-width: 768px) {
  header .personalcomputer {
    display: none;
  }
  #hamburger {
    background-color: transparent;
    position: relative;
    cursor: pointer;
    margin: 0 0 0 auto;
    height: 60px;
    width: 60px;
  }
  header .icon span {
    position: absolute;
    left: 15px;
    width: 30px;
    height: 4px;
    background-color: #808080;
    border-radius: 8px;
    transition: ease 0.75s;
  }
  header .icon span:nth-of-type(1) {
    top: 20px;
  }
  header .icon span:nth-of-type(2) {
    top: 32px;
  }
  header .icon span:nth-of-type(3) {
    bottom: 12px;
  }
  header .close span:nth-of-type(1) {
    transform: rotate(45deg);
    top: 28px;
  }
  header .close span:nth-of-type(2) {
    opacity: 0;
  }
  header .close span:nth-of-type(3) {
    transform: rotate(-45deg);
    top: 28px;
  }
  header .smartphone {
    top: 70px;
    left: 0px;
    position: absolute;
    z-index: 10;
    width: 100%;
    background-color: rgba(34, 49, 52, 0.9);
  }
  header .smartphone ul li a {
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	color: #ffffff;
  }
  header .smartphone ul li a:hover {
	color: #A9A9A9;
	}
  header ul {
    flex-direction: column;
  }
  header a {
    text-align: center; 
    border-top: solid 0.5px rgba(255, 255, 255, 0.6);
  }
}
/*----------------------------------------ナビここまで▲----------------------------------------------------*/


/*----------------------------------------bodyここから▼---------------------------------------------------*/
body {
  width: 100%;
  height: 100vh;
  background-image: linear-gradient(rgba(255, 255, 255, .6), rgba(255, 255, 255, .6)),
	                url("../images/mandala.png"),
	                url("../images/mandala.png"),
	                url("../images/haikei.jpg");
  background-attachment: fixed,fixed,fixed,fixed;
  background-repeat: no-repeat,no-repeat,no-repeat,no-repeat;
  background-size: 1000px,29.8%,29.8%,cover;
  background-position: center,-21% 55%,121% 55%,center;
}
@media screen and (max-width: 768px) {
	body {
		background-image: url("../images/haikei.jpg");
	}
}
/*----------------------------------------bodyここまで▲---------------------------------------------------*/


/*----------------------------------------contentsここから▼-----------------------------------------------*/

/*----------------------トップイメージここから▼---------------------*/
#box {
	position: relative;
	width: 100%;
	max-width: 1000px;
	height: 100vh;
	margin: 0 auto;
}
#box img {
	position: absolute;
	width: 100%;
	max-width: 60%;
	top: 55%;
	left: 50%;
	transform : translate(-50%,-50%);
}

#word1 {
	position: absolute;
	width: 100%;
	max-width: 900px;
	margin: 0 auto;
	text-align: center;
	top: 49%;
	left: 50%;
	transform : translate(-50%,-50%);
}
#word1 p:nth-child(1) {
	font-size: calc(18px + 8 * (100vw - 320px)/880);
	padding-top: 280px;
}
#word1 p:nth-child(2) {
	font-size: calc(24px + 24 * (100vw - 320px)/880);
	font-weight: 900;
	text-shadow: 2px 1px 1px #ffffff;
	padding: 1.0rem 0 1.2rem 0;
}
#word1 p:nth-child(3) {
	font-size: calc(14px + 10 * (100vw - 320px)/880);
}
#word1 p:nth-child(4) {
	padding-top: 170px;
	font-size: calc(18px + 6 * (100vw - 320px)/880);
	letter-spacing: 0.6em;
}
@media screen and (max-width: 768px) {
	#box img {
	width: 100%;
	max-width: 85%;
	top: 50%;
	left: 50%;
	transform : translate(-50%,-50%);
	}
	#word1 p:nth-child(1) {
		padding-top: 200px;
	}
	#word1 p:nth-child(1),#word1 p:nth-child(2),#word1 p:nth-child(3) {
		text-shadow: 1px 1px 1px #ffffff;
	}
	#word1 p:nth-child(4) {
		color: #ffffff;
	}
}
/*-----------------------トップイメージここまで▲----------------------*/


/*--------------------768px以下の背景設定ここから▼--------------------*/
@media screen and (max-width: 768px) {
	.back-color {
		width: calc(100% - 2rem); /* paddingが効くようにする */
		margin: 0 auto;
		background-color: rgba(255, 255, 255, .6);
		border-radius: 8px;
	}
}
/*--------------------768px以下の背景設定ここまで▲--------------------*/


/*--------------------------Welcomeここから▼-------------------------*/
#welcome {
	width: 100%;
	max-width: 680px;
	margin:0 auto 0 auto;
	padding: 3rem 0.5rem 3rem 0.5rem;
	text-align: center;
	background-color: rgba(255,255,255,0.30);
	border-radius: 8px;
}
#welcome p:nth-child(1) {
	font-size: calc(24px + 10 * (100vw - 320px)/880);
	font-weight: 900;
	text-shadow: 2px 1px 1px #ffffff;
}
#welcome p:nth-child(2) {
	font-size: calc(14px + 4 * (100vw - 320px)/880);
	line-height: 2.2;
	padding-top: 2rem;
}
@media screen and (max-width: 768px) {
	#welcome {
		width: calc(100% - 2rem); /* paddingが効くようにする */
		background-color: rgba(255,255,255,0.60);
	}
}

/*--------------------------Welcomeここまで▲-------------------------*/


/*----------------------------sessionsここから▼-------------------------*/

.line {
	width: 100%;
	max-width: 240px;
	margin: 0 auto 0 auto;
	border-top: solid 1.6px #000000;
}
.menu {
	width: 100%;
	max-width: 300px;
	margin: 12rem auto 0 auto;
}
.menu p {
	font-size: calc(24px + 10 * (100vw - 320px)/880);
	font-weight: 900;
	text-shadow: 2px 1px 1px #ffffff;
	text-align: center;
}

.scroll-space1 {
	display: flex;
	width: 100%;
	max-width: 900px;
	margin: 80px auto 0 auto;
	justify-content: space-between;
}
.scroll-space2 {
	display: flex;
	flex-direction: row-reverse; /*-----逆並びにする-----*/
	width: 100%;
	max-width: 900px;
	margin: 80px auto 0 auto;
	justify-content: space-between;
}
.scroll-space1 img,.scroll-space2 img {
	width: 100%;
	max-width: 300px;
	border: 8px solid;
    border-image: linear-gradient(to right bottom,#e0d9b6,#b4983a) 1 / 10px;
    outline: 6px outset #efe9cc;
    padding: 5px;
    background: #FFF;
    box-shadow: 3px 6px 20px #000000;
	margin-bottom: 3rem;
}
.scroll-space1 p,.scroll-space2 p {
	font-size:  calc(12px + 3 * (100vw - 320px)/880);
	line-height: 2.0;
	width: 100%;
	max-width: 600px;
}
.scroll-space1 .title span, .scroll-space2 .title span {
	font-size: calc(14px + 6 * (100vw - 320px)/880);
	font-weight: 900;
	margin-bottom: 1.6rem;
	background-color: rgba(255,255,255,0.30);
	border-radius: 8px;
	display: inline-block;
}
.fadein1,.fadein2,.fadein1-contents,.fadein2-contents {
    opacity: 0;
    transform: translate(0,30px);/*---右0px、下100px---*/
    transition: all 2.5s;
}
.fadein1:first-child {
	margin-right: 5rem;
}
.fadein2:first-child {
	margin-left: 5rem;
}
.scrollin{
    opacity: 1 !important;
    transform: translate(0, 0) !important;
}
@media screen and (max-width: 768px) {
	.scroll-space1,.scroll-space2 {
		display: block;
		width: 100%;
		max-width: 100%;
		padding: 0 0.5rem 0 0.5rem;
	}
	.scroll-space1 p,.scroll-space2 p {
		margin: 0 auto;
	}
	.scroll-space1 img,.scroll-space2 img {
		display: block;
		width: calc(100% - 2rem); /* paddingが効くようにする */
		margin: 0 auto 3.2rem auto;
	}
	.fadein1:first-child {
	margin-right: 0rem;
	}
	.fadein2:first-child {
	margin-left: 0rem;
	}
	.title span {
		margin-top: 1.8rem;
	}
}
	
/*----------------------------sessionsここまで▲-------------------------*/

/*----------------------------詳しく見る▼-------------------------------*/
.more-box {
  width: 15rem;
  height: 5rem;
  text-align: center;
  position: relative;
  background-color: rgba(255,255,255,0.50);
  border: solid 0.1rem  #a9a9a9;
  margin: 8rem auto 8rem auto;
}
.more-box a {
	text-decoration: none;
}
.more {
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease;
}
.more p {
  font-size: calc(12px + 4 * (100vw - 320px)/880);
  line-height: 5rem;
  color: #000000;
  white-space: nowrap;
}
.dark-cover {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  opacity: .3;
  transition: background-color 0.3s ease;
}
.dark-cover:hover {
  background-color: black;
}
@media screen and (max-width: 768px) {
	.more-box {
		width: 12rem;
		height: 5rem;
	}
	.more p {
		line-height: 5rem;
		font-size:  calc(14px + 2 * (100vw - 320px)/880);
	}
}
@media screen and (max-width: 480px) {
	.more-box {
		margin: 4rem auto 4rem auto;
	}
}
/*----------------------------詳しく見る▲-------------------------------*/


/*----------------------------profile▼--------------------------------*/
#profile {
	display: flex;
	width: 100%;
	max-width: 480px;
	margin: 10rem auto 10rem auto;
	justify-content: space-between;
}
.profile-inner img {
	width: 100%;
	max-width: 240px;
}
.profile-inner p:first-child {
	font-size: calc(18px + 4 * (100vw - 320px)/880);
	font-weight: 900;
}
.profile-inner p {
	font-size: calc(12px + 4 * (100vw - 320px)/880);
	line-height: 2.4;
}
@media screen and (max-width: 768px) {
	#profile {
		display: block;
		text-align: center;
		padding: 0 0.5rem 0 0.5rem;
		margin: 5rem auto 10rem auto;
	}
	.profile-inner img {
	width: 100%;
	max-width: 180px;
}
}
/*----------------------------profile▲--------------------------------*/


/*----------------------------scheduleここから▼--------------------------------*/
#schedule {
	display: flex;
	justify-content: center;
	padding: 12rem 0 5rem 0;
}
#schedule p {
	font-size: calc(12px + 4 * (100vw - 320px)/880);
	font-weight: 900;
}
#schedule img {
	animation: flash 2.4s linear infinite;
}
@keyframes flash {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@media screen and (max-width: 768px) {
	#schedule {
		padding: 8rem 0 2rem 0;
	}
}

/*---カレンダー▼---*/
#schedule-box {
	width: 100%;
	max-width: 500px;
	margin: 0 auto;
}
#schedule-box p {
	font-size: calc(12px + 4 * (100vw - 320px)/880);
	text-align: center;
	margin-top: 5rem;
}
#schedule-box img {
	width: 100%;
	max-width: 500px;
	padding: 5rem 0.5rem 5rem 0.5rem;
}
/*---カレンダー▲---*/

/*----------------------------scheduleここまで▲--------------------------------*/


/*----------------------------contactここから▼--------------------------------*/
#contact {
	width: 100%;
	max-width: 800px;
	margin: 5rem auto 5rem auto;
	text-align: center;
}
#contact p {
	font-size: calc(14px + 4 * (100vw - 320px)/880);
	padding-bottom: 3rem;
}
#contact img:hover {
	transform:scale(1.05);
	opacity:0.8;
	transition:0.3s;
}
#chair {
	width: 100%;
	max-width: 15%;;
	margin: 0 auto 3.6rem auto;
}
#chair img {
	width: 100%;
}

@media screen and (max-width: 768px) {
	#contact {
		padding: 3rem 0.5rem 5rem 0.5rem;
	}
	#chair {
		width: 100%;
		max-width: 35%;
	}
}
/*----------------------------contactここまで▲--------------------------------*/


/*----------------------------------------contentsここまで▲-----------------------------------------------*/


/*----------------------------------------フッターナビここから▼----------------------------------------*/
footer {
	clear: both;
}
#footer-nav #footer-nav-inner {
	width: 100%;
	max-width: 63%;
	margin: 0 auto;
}
#footer-nav #footer-nav-inner ul {
	display: flex;
} 
#footer-nav #footer-nav-inner ul li {
	list-style-type: none;
	flex: 1;
	border-bottom: 0;
	border-right: 1px solid #a9a9a9;
	font-size: calc(14px + 6 * (100vw - 320px)/880);
	}
#footer-nav #footer-nav-inner ul li:last-child {
	border-right: none;
}
#footer-nav #footer-nav-inner ul li a{
	display: block;
	text-decoration: none;
	text-align: center;
	color: #ffffff;
}
#footer-nav #footer-nav-inner ul li a:hover {
	color: #ff0000;
}
@media screen and (max-width: 768px) {
#footer-nav {
	display: none;
	}
}
/*----------------------------------------フッターナビここまで▲----------------------------------------*/


/*----------------------------------------フッターここから▼----------------------------------------*/
/*----フッターを最下部で固定▼----*/
.flex {
	display: flex;
    flex-direction: column;
    min-height: 100vh;
}
/*----フッターを最下部で固定▲---*/
footer {
	background-color: rgba(0,0,0,0.95);
	padding: 35px 0 15px 0;
	width: 100%;
	margin-top: auto;/*----◀フッターを最下部で固定----*/
}
	#footer-inner4 {
	width: 100%;
	margin: 3.6rem auto 1.8rem auto;
	text-align: center;
	font-size: calc(16px + 2 * (100vw - 320px)/880);
	color: #ffffff;
}
@media screen and (max-width: 768px) {
	footer {
		padding: 1.5rem 0;
	}
	#footer-inner4 {
		margin: 0 auto;
	}
}
/*----------------------------------------フッターここまで▲----------------------------------------*/


/*----------------------------------------トップへ戻るボタンここから▼----------------------------------------*/
#page_top {
    position: fixed;
    right: 10px;
    bottom: 10px;
    margin: 0;
    z-index: 20;
}
#page_top a{
    position: relative;
    display: flex;
    width: 60px;
    height: 60px;
    justify-content: center;
    background-color: rgba(199,136,34,0.50);
    transition: opacity .6s ease;
    color: #FFF;
    align-items: center;
    text-decoration: none;
    font-size: 40px;
    border-radius:100%;
}
#page_top a:hover {
    opacity: .3;
}
@media screen and (max-width:768px) {
#page_top a {
    width: 50px;
    height: 50px;
}
}
/*----------------------------------------トップへ戻るボタンここまで▲----------------------------------------*/
