  @charset "utf-8";
/****************************************
		1. 基本設定 
*****************************************/

/*
Copyright (c) 2010, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
http://developer.yahoo.com/yui/license.html
version: 3.3.0
build: 3167
　↓YUI3 CSS Reset　ブラウザー固有のスタイルをリセットします↓　*/
body,div,dl,dt,dd,
ul,ol,li,h1,h2,h3,h4,h5,h6,
pre,code,form,fieldset,legend,
input,textarea,p,blockquote,th,td {
	margin:0;
	padding:0;
}
table {
	border-collapse:collapse;
	border-spacing:0;
}

/*
Copyright (c) 2010, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
http://developer.yahoo.com/yui/license.html
version: 3.3.0
build: 3167
↓YUI3 CSS Fonts　フォントサイズを相対指定する↓*/


/*---↓リンクに対する共通設定↓---*/
*{
	margin:0;
	padding:0;
	line-height:1.5;
	list-style:none;
}
/*アンダーtopボタン*/
.pagetop {
	position: fixed;
	bottom: -200px;
	right: 20px;
	z-index:9999;
}
.pagetop a {
	display: block;
	width: 86px;
	height: 110px;
}

img{
	border:none;
}
a, a:link,/*未訪問のリンクを指定*/
a:visited,/*訪問済みのリンクを指定*/
a:hover,/*マウスオーバーした時のリンク部分を指定*/
a:active,/*クリック時のリンク部分を指定*/
a{
	text-decoration:none;
}
body{	
	overflow-x:hidden;
}
/* clearfix
----------------------------------------------------*/
.clearfix{ /zoom: 1; }
.clearfix:after{ content: ''; display: block; clear: both; }
/* box-sizing
----------------------------------------------------*/
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
/*送信ボタン*/
input[type="submit"] {
  -webkit-appearance: none;
}
input[type="reset"] {
  -webkit-appearance: none;
}

header{
  position: absolute;
}
footer{
  background: linear-gradient(0deg, #f5f2e9, #ccbca9);
  padding-top: 1px;
  position: relative;
}
footer .nav-menu{
  display: flex;
  justify-content: space-evenly;
  margin: 20px auto 60px;
}
footer .nav-menu a{
  color: #535353;
}
footer .footer_logo{
  text-align: center;
  margin-bottom: 120px;
}
footer .footer_back img{
  display: block;
  width: 100%;
}
.under_box{
  background: #3b341a;
  color: #fff;
  font-size: 70%;
  text-align: center;
  padding: 2px 0;
}
.footer__nav__backtop {
  display: block;
  height: 44px;
  position: absolute;
  bottom: 100px;
  left: calc(50% - 37px);
  width: 75px
}

.footer__nav__backtop:before {
  background-color: #535353;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.footer__nav__backtop:after {
  border-color: #535353;
  border-style: solid;
  border-width: 2px 0 0 2px;
  content: "";
  display: block;
  height: 51px;
  left: calc(50% - 25.5px);
  pointer-events: none;
  position: absolute;
  top: 18px;
  transform: translate(0) rotate(45deg);
  width: 51px;
}
/*--- ハンバーガーメニュー ---*/
.hamburger {
  position: fixed;
  right: 7px;
  top: 9px;
  display: inline-block;
  vertical-align: middle;
  width: 60px;
  height: 60px;
  background: 0 0;
  border-radius: 85px 0 0;
  margin: 0 auto 5px;
  z-index: 900;
}

.hamburger .hamburger-button {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 120;
  cursor: pointer
}

.hamburger .hamburger-button span {
  position: absolute;
  width: 50%;
  height: .2em;
  right: 6px;
  left: 0;
  top: 9px;
  bottom: 0;
  margin: auto;
  background-color: #a6937c;
  border-radius: .1em;
  transition: all .5s ease 0s;
  transform: rotate(0deg)
}

.hamburger .hamburger-button span.top {
  transform: translateY(-.5em)
}

.hamburger .hamburger-button span.bottom {
  transform: translateY(.5em)
}

.hamburger-active .hamburger-button span.middle {
  background: 0 0
}

.hamburger-active .hamburger-button span.top {
  transform: rotate(-45deg) translateY(0);
  background: #fff;
}

.hamburger-active .hamburger-button span.bottom {
  transform: rotate(45deg) translateY(0);
  background: #fff;
}

.hamburger .hamburger-menu {
  position: fixed;
  width: 100%;
  left: 100%;
  top: 0;
  bottom: 0;
  min-height: 100dvh;
  z-index: 90;
  overflow-y: auto;
  background-color: transparent;
  transition: all .5s ease 0s
}

.hamburger-active .hamburger-menu {
  left: 0;
  background-color: #f2f2f2;
  display: flex;
  align-items: center;
  justify-content: center
}

.hamburger .hamburger-menu .hamburger-submenu {
  transform: translateY(1em);
  opacity: 0
}

.hamburger-active .hamburger-menu .hamburger-submenu {
  opacity: 1;
  transform: translateY(0)
}

.hamburger-active .hamburger-menu .hamburger-submenu:nth-child(1) {
  transition: all .5s ease .5s
}

.hamburger-active .hamburger-menu .hamburger-submenu:nth-child(2) {
  transition: all .5s ease .8s
}

.hamburger-active .hamburger-menu .hamburger-submenu:nth-child(3) {
  transition: all .5s ease 1.1s
}

.hamburger .hamburger-menu>a {
  display: block;
  text-decoration: none;
  color: #535353;
  height: 35px;
  letter-spacing: 1px;
}

.nav_item_first a {
  height: 40px !important;
  line-height: 40px !important
}

.nav_item_laxt a {
  height: 45px !important;
  line-height: 45px !important
}

.hamburger-active .hamburger-button span {
  background: #ccbca9;
}

.hamburger-submenu {
  position: relative;
  background: #f3f3f3;
  margin: 0 auto
}

.hamburger_span {
  position: fixed;
  right: 10px;
  top: 13px;
  display: inline-block;
  vertical-align: middle;
  z-index: 120;
  width: 60px;
  height: 60px;
  outline: 2px solid #ccbca9;
  margin: 0 auto 5px;
  background: #fff;
}
.hamburger-active .hamburger_span{
  background: #ccbca9;
}

.hamburger_container {
  width: 90%;
  height: 90%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: #fff;
  border-radius: 10px;
  position: relative;
}
.hamburger_container::before{
  content: '';
  background: url(../img/logo.png) no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  width: 40%;
  height: 100px;
  bottom: 0;
  right: 0;
}

.hamburger_menulist{
  width: 70%;
}
.hamburger_menulist li{
  font-size: 120%;
  margin: 0 0 20px;
  text-align: center;
  font-family: "Sawarabi Mincho";
}

.hamburger_menulist li a {
  display: block;
  text-align: center;
  color: #535353;
  letter-spacing: 1px;
  font-size: 108%;
}

/*--- ハンバーガーメニュー end ---*/