@charset "utf-8";

html { background: #f8fbf8; overflow-y: scroll!important; }
body { min-width: 1240px; background: #f8fbf8; font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif"; font-weight: 500; font-style: normal; }

/*============================
#loading
============================*/
#js-loading { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background-color: #f8fbf8; z-index: 99999; display: flex; justify-content: center; align-items: center; pointer-events: auto; }
.logo_fadein p { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); opacity: 0; animation: fadeinout 2s ease-in-out forwards; width: 200px; height: 136px; }
.logo_fadein p img { width: 100%; height: auto; }
@keyframes fadeinout { 
	0% { opacity: 0; } 
	30% {opacity: 1; }
	70% {opacity: 1; } 
	100% { opacity: 0; } 
	}

/*============================
#header
============================*/
#header { position: relative; z-index: 1; }
#header nav { display: flex; align-items: center; justify-content: space-between; position: absolute; top: 40px; left: 50%; transform: translateX(-50%); z-index: 1000; padding: 20px 70px; width: 95%; border-radius: 60px; background-color: #f8fbf8; }
#header nav.is-fixed { position: fixed; top: 0; left: 50%; transform: translateX(-50%); width: 95%; padding: 10px 70px; border-radius: 0 0 60px 60px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08); background-color: #f8fbf8; z-index: 1000; }
#header nav.is-fixed .logo { width: 300px; padding-top: 3px; }
#header nav .logo { width: 337px; height: 76px; background-color: #F8FBF8!important; }
#header nav .logo a {}
#header nav .logo a img { width: 100%; height: auto; }
#header nav .globalNav {}
#header nav .globalNav .rightArea { display: flex; gap: 60px; }
#header nav .globalNav .rightArea ul { display: flex; gap: 40px; }
#header nav .globalNav .rightArea ul li {}
#header nav .globalNav .rightArea ul li a { position: relative; display: inline-block; text-decoration: none; color: inherit; font-size: 1.25em; font-weight: 500; transition: color 0.3s ease; }
#header nav .globalNav .rightArea ul li a::after { content: ''; position: absolute; left: 0; bottom: -4px; height: 2px; width: 100%; background-color: #9f44a8; opacity: 0.6; transform: scaleX(0); transform-origin: left; transition: transform 0.3s ease; }
#header nav .globalNav .rightArea ul li a span { display: inline-block; transition: transform 0.3s ease; }
#header nav .globalNav .rightArea ul li a:hover::after { transform: scaleX(1);}
#header nav .globalNav .rightArea ul li a:hover span { transform: translateY(-3px); }

#header nav .globalNav .rightArea .instagram {}
#header nav .globalNav .rightArea .instagram a { display: block; width: 28px; height: 28px; transition: 0.3s ease; }
#header nav .globalNav .rightArea .instagram a:hover { transform: translateY(-3px); }
#header nav .globalNav .rightArea .instagram a img { width: 100%; height: auto; }
#header aside.hamburgerMenu { display: none; }
#header aside.hamburgerMenu.is-fixed { position: fixed; top: 25px; right: 50px; z-index: 1001; }
#header aside.hamburgerMenu input.checkbox-toggle {}
#header aside.hamburgerMenu .hamburger {}
#header aside.hamburgerMenu .hamburger span.bar {}
#header aside.hamburgerMenu .menu {}
#header aside.hamburgerMenu .menu .wrapper {}
#header aside.hamburgerMenu .menu .wrapper .container {}
#header aside.hamburgerMenu .menu .wrapper .container .logo {}
#header aside.hamburgerMenu .menu .wrapper .container .logo a {}
#header aside.hamburgerMenu .menu .wrapper .container .logo a img {}
#header aside.hamburgerMenu .menu .wrapper .container ul {}
#header aside.hamburgerMenu .menu .wrapper .container ul li {}
#header aside.hamburgerMenu .menu .wrapper .container ul li a {}
#header aside.hamburgerMenu .menu .wrapper .container .instagram {}
#header aside.hamburgerMenu .menu .wrapper .container .instagram a {}
#header aside.hamburgerMenu .menu .wrapper .container .instagram a img {}
#header .rightbtn.sp { display: none; }

main { overflow: hidden; position: relative; z-index: 0; }

/*============================
#footer
============================*/
#footer { background-image: url("../../imageFile/global/bg_footer.png"); background-size: cover; background-repeat: no-repeat; }
#footer .topArea { justify-content: space-between; padding: 90px 0; background-color: #46340e; border-radius: 0 0 100px 100px; }
#footer .topArea ul { float: left; display: flex; flex-direction: column; flex-wrap: wrap; height: 180px; column-gap: 20px; padding: 0; margin: 0; list-style: none; width: 620px; }
#footer .topArea ul li { width: 300px; margin: 0; border-bottom: 1px solid rgba(255,255,255,0.1); }
#footer .topArea ul li a { display: block; font-size: 1.125em; padding: 20px 0 20px 20px; color: #fff; font-weight: 400; transition: 0.3s ease; }
#footer .topArea ul li a:hover { transform: translateX(4px); }
#footer .topArea .farm { float: right; background-color: #c8c2b7; }
#footer .topArea .farm a { display: block; }
#footer .topArea .farm a .lebel { text-align: center; background-color: #917e61; color: #fff; padding: 6px 0 5px; font-size: 0.875em; }
#footer .topArea .farm a .logo { width: 218px; height: 59px; transition: 0.3s ease; }
#footer .topArea .farm a:hover .logo { transform: scale(1.05); }
#footer .topArea .farm a .logo { margin: 20px 50px 15px 50px; }
#footer .topArea .farm a .logo img { width: 100%; height: auto; }
#footer .bottomArea { padding: 100px 0 90px; width: 100%; }
#footer .bottomArea .logo { float: left; width: 187px; height: 126px; }
#footer .bottomArea .logo a { display: block; }
#footer .bottomArea .logo a img { width: 100%; height: auto; }
#footer .bottomArea .info { float: right; }
#footer .bottomArea .info .time { color: #fff; }
#footer .bottomArea .info .address { margin-top: 10px; color: #fff; line-height: 1.5; }
#footer .bottomArea .info .tel { margin-top: 10px; color: #fff; }
#footer .bottomArea .info .tel a {}
#footer .bottomArea .info .instagram { position: relative; margin-top: 15px; color: #fff; }
#footer .bottomArea .info .instagram:before { content: ''; position: absolute; top: 50%; transform: translateY(-50%); background-image: url("../../imageFile/global/icon_ista_wh.svg"); width: 16px; height: 16px; left: 15px; pointer-events: none; }
#footer .bottomArea .info .instagram a { display: inline-block; border: 1px solid #fff; border-radius: 15px; padding: 4px 15px 6px 35px;  transition: 0.3s ease; }
#footer .bottomArea .info .instagram a:hover { background-color:rgba(255,255,255,0.3); }
#footer .bottomArea .info .instagram a span { font-size: 0.875em; }
#footer .copyright { text-align: center; padding-bottom: 15px; font-size: 0.75em; color: #fff; }
