@charset "utf-8";
/*@reset*/
* {
  margin: 0;
  padding: 0;
}
img {
  max-width: 100%;
  vertical-align: middle;
}
a {
  color: #2f3131;
  text-decoration: none;
  transition: 0.5s;
}
ul,ol {
  list-style: none;
}
html{
  -webkit-text-size-adjust: 100%;
}
/*end@reset*/
/*@cf*/
.cf:after {
  content: "";
  display: block;
  clear: both;
}
/*end@cf*/
/*@common*/
@media screen and (max-width:1100px) {
  html {
    font-size: 87.5%;
  }
}
#wrap {
  overflow: hidden;
}
body {
 font-family: 'Noto Sans JP', sans-serif;
 line-height: 1.5;
 color: #2f3131;
 position: relative;
 background-color: #f9f9f9;
}
/*iPhone background*/
body::before {
  content:"";
  display:block;
  position:fixed;
  top:0;
  left:0;
  z-index:-1;
  width:100%;
  height:200vh;
}
.w1100 {
  width: 81.54188%;
  margin: 0 auto;
/*  background-color: yellow;*/
}
.w1024 {
  width: 75.90808%;
  margin: 0 auto;
/*  background-color: pink;*/
}
@media screen and (max-width:768px) {
  .w1100 {
    width: 94%;
  }
  .w1024 {
    width: 90%;
  }
}
/*end@common*/

/*@h1+nav*/
.header-nav {
  transform: translateY(-10%);
  position: fixed;
  z-index: 9999;
  top: 0;
  transition: 0.5s;
  z-index: 9999;
  background-color: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(5px);
  height: 100px;
  width: 100%;
}
.nav-box {
  /* background-color: #2f3131; */
  max-width: 1600px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 15px 100px;
}
.header-logo {
  width: 150px;
  margin-top: 5px;
  z-index: 9999;
}
.header-logo img {
  filter: drop-shadow(0px 0px 0.5px rgba(0, 0, 0, 1));
}
.header-logo a:hover {
  opacity: 0.6;
}
.header-nav ul li ul{
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  padding: 10px 10px;
  padding-top: 5px;
  transform: translate(35px,0px);
  background-color: rgba(0, 0, 0, 0.7);
}
.header-nav ul li ul li {
  border-bottom: 1.5px solid #f9ba32;
}
.header-nav ul li ul li:nth-child(2) {
  margin-top: 5px;
}
.gNav {
  width: auto;
  /* background-color: #2f3131; */
}
.gNav ul {
  display: flex;
}
.gNav ul a {
  color: #fff;
  letter-spacing: 0.08rem;
  text-shadow: 0 0 3px #2f3131,0 0 3px #2f3131;
  font-size: 13px;
  /* font-size: 1.05vw; */
  white-space: nowrap;
}
.gNav-li {
  padding: 2px 0px;
  padding-left: 30px;
  position: relative; /* リンクが親要素に相対配置されるようにする */
}
.gNav-li:hover ul {
  display: block; /* リンクにホバーしたときにサブメニューを表示 */
}
.gNav ul a:hover {
  border-radius: 6px;
  transition: 0.4s;
  color: #ffcd60;
}
.gNav-li img {
  max-width: 30px;
  transform: translateY(-2px);
}
.gNav-li img:hover {
  opacity: 0.6;
  transition: 0.5s;
}
@media screen and (max-width:1100px){
  .nav-box {
    margin: 10px 30px;
  }
  .header-logo {
    margin: 8px 5px;
  }
  .header-logo img {
    width: 130px;
    filter: drop-shadow(1px 1px 0px rgba(255, 255, 255, 1));
  }
  .gNav {
    display: none;
  }
  .header-nav {
    margin: 0;
    background-color: transparent;
    backdrop-filter: none;
    padding: 0;
    height: auto;
    position: absolute;
  }
  .gNav ul {
    justify-content: center;
    margin: 0 auto;
  }
  .gNav ul a {
    padding: 0 20px;
    font-size: 1rem;
  }
  #nav-entry {
    padding: none;
    border: none;
    box-shadow: none;
    transform: translateX(4px);
  }
}
.fixed {
  background-color: white;
  box-shadow:  0 0 3px #ccc;
}
/*end@h1+nav*/



/*@footer*/
.footer {
  text-align: center;
  position: relative;
  margin-top: 10%;
}
.footer-top {
  background-color: #f8f1e5;
  color: #818181;
  font-size: 0.85rem;
  font-weight: 500;
  padding-top: 1%;
}
.footer-flex {
  display: flex;
  padding: 20px 0;
  align-items: stretch;
}
.footer-top .footer-logo {
  width: 180px;
  margin-bottom: 10px;
  transform: translateX(-1.5%);
}
.footer-top .footer-add {
  text-align: left;
  line-height: 1.55rem;
}
.footer-add span {
  font-size: 0.9rem;
}
.footer-flex-item1 {
  /* background-color: #9c3b6d; */
  width: 26vw;
  border-right: 1px solid #818181;
  padding-bottom: 3%;
}
.footer-top ul {
  text-align: left;
  justify-content: center;
  margin-bottom: 20px;
  margin-left: 11vw;
  padding-top: 5px;
}
.footer-top ul li a {
  color: #818181;
  border-bottom: 1px solid #818181;
  line-height: 35px;
}
.footer-top ul li a:hover {
  color: #f9ba32;
}
.copy small {
  font-size: 0.7rem;
  color: #fff;
  white-space: nowrap; 
}
.copy {
  background-color: #2f3131;
  padding: 4px 0;
}

@media screen and (max-width:640px){
  .footer-flex {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
  .footer-top .footer-logo {
    width: 160px;
    margin-bottom: 10px;
    transform: translateX(5%);
  }
  .footer-top .footer-add {
    text-align: center;
  }
  .footer-flex-item1 {
    width: 200px;
    border-right: none;
    padding-bottom: 5%;
  }
  .footer-top ul {
    margin-bottom: 20px;
    margin-left: 0;
    padding: 10px 30px;
    background-color: #f9f9f9a1;
    border-radius: 10px;
  }
}
/*end@footer*/

/*@top-back*/
#top-back a {
  display: none; /* 最初は非表示 */
  position: fixed;
  bottom: 50px;
  right: 80px;
  font-size: 2.5rem;
  color: #f9ba32;
  text-decoration: none; /* デフォルトのリンク装飾を削除 */
  z-index: 999;
}
#top-back img {
  width: 40px;
}
#top-back a.show {
  display: block; /* スクロール位置が特定の値以上になったら表示 */
}
#top-back a:hover {
  opacity: 0.6;
}
@media screen and (max-width:640px) {
  #top-back {
    display: none;
  }
}
/*end@top-back*/

/*humburger btn*/
.btn-open {
  font-size: 2em;
  position: absolute;
  z-index: 10000;
  display: none;
}
.btn-open:hover {
  cursor: pointer;
}
.btn-color {
  color: #fff;
}
@media screen and (max-width:1100px){
  .btn-open {
    display: block;
  }
  .panel-open {
    width: 100vw;
    height: 115vh;
    position: fixed;
    background-color: rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    z-index: 9999;
  }
  .panel-open .gNav {
    display: block;
  }
  .panel-open .header-logo {
    display: none;
  }
  .panel-open ul {
    flex-direction: column;
    /* margin-top: 3em; */
    font-size: 0.85rem;
  }
  .panel-open ul li {
    margin-bottom: 2em;
    padding: 0 80px;
    border-bottom: #f8f1e5 solid 1px;
  }
  .panel-open ul li ul{
    display: block;
    padding: 0;
    transform: translate(0px,310px);
    background-color: transparent;
  }
  .header-nav ul li ul li {
    border: 1px solid #f9ba32;
    padding: 5px 67px;
    margin-bottom: 0;
    margin-top: 0;
    background-color: rgba(0, 0, 0, 0.7);
  }
  .header-nav ul li ul li a {
    font-size: 0.75rem;
  }
  .panel-open li a {
    color: #fff;
    font-weight: bold;
  }
   .btn-open {
    position: fixed;
    top: 10px;
    right: 10px;
    z-index: 10000;
    width: 50px;
    height: 50px;
    cursor: pointer;
    background-color: rgba(255, 255, 255, 0.6);
    border-radius: 5px;
    box-shadow: 0 0 3px #2f3131;
  }
  .btn-open span {
    display: inline-block;
    transition: 0.3s;
    position: absolute;
    left: 14px;
    border-radius: 2px;
    background-color: #2f3131;
    width: 45%;
    height: 2px;
  }
  .btn-open span:nth-of-type(1) {
    top: 16px;
  }
  .btn-open span:nth-of-type(2) {
    top: 24px;
  }
  .btn-open span:nth-of-type(3) {
    top: 32px;
  }
  .btn-open.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) translateX(-3px) rotate(-45deg);
  }
  .btn-open.active span:nth-of-type(2) {
    opacity: 0;
  }
  .btn-open.active span:nth-of-type(3) {
    top: 30px;
    left: 18px;
    transform: translateY(-6px) translateX(-3px) rotate(45deg);
  }
}

@media screen and (max-width:640px){
  a:hover {
    opacity: 1;
  }
  .btn-open {
    top: 0.3em;
    right: 0.5em;
  }
}

/*スクロールバー全体*/
::-webkit-scrollbar {
  width: 10px;
}
/*スクロールバーのレール部分*/
::-webkit-scrollbar-track {
  border-radius: 10px;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.1) inset;
  background-color: #959b93;
}
/*スクロールバーの動く部分*/
::-webkit-scrollbar-thumb {
  background-color: #ffb632;
  border-radius: 10px;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.1) inset;
}

.comingsoon {
  text-align: center;
  font-size: 25px;
  margin-top: 100px;
}