@charset "UTF-8";
/*========*/
/* ヘッダ */
/*========*/
/* 日本語 */
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  /* padding: 20px 40px; */
  background-color: #FFF;
  -webkit-box-shadow: 0 3px 2px -2px rgba(0, 0, 0, 0.15);
          box-shadow: 0 3px 2px -2px rgba(0, 0, 0, 0.15);
  z-index: 10;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 1023px) {
  header {
    flex-direction: column;
    background-color: rgba(255, 255, 255, 0.8)
  }
}
header .contents {
  width: 332px;
}
header .header-logo {
  padding: 10px 40px;
  text-align: center;
}
@media (max-width: 1023px) {
  header .contents {
    width: 100%;
  }
  header .header-logo {
    padding: 10px 16px;
    /* max-width: 62px; */
  }
}
header .header-logo img {
  width: auto;
  max-width: inherit;
  height: 100px;
  padding: 6px;
}
@media (max-width: 1023px) {
  header .header-logo img {
    height: 80px;
  }
}

@media (max-width: 1023px) {
  header .menu {
    position: absolute;
    top: 55px;
    right: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 72px;
    height: 58px;
    padding: 0 16px;
    cursor: pointer;
    z-index: 15;
  }
  header .menu .menu-inner {
    position: relative;
    width: 40px;
    height: 22px;
  }
  header .menu .menu-inner span {
    position: absolute;
    right: 0;
    display: block;
    width: 40px;
    height: 0;
    border-top: 2px solid #180A06;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
  }
  header .menu .menu-inner span:first-child {
    top: 0;
  }
  header .menu .menu-inner span:nth-child(2) {
    top: 11px;
  }
  header .menu .menu-inner span:last-child {
    top: 22px;
  }
  header .menu.open .menu-inner span:first-child {
    top: 11px;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  header .menu.open .menu-inner span:last-child {
    top: 11px;
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
  }
  header .menu.open .menu-inner span:nth-child(2) {
    opacity: 0;
  }
}
/* 外国語 */
/* header.foreign {
  position: absolute;
  text-align: center;
  background: transparent;
  box-shadow: none;
}
header.foreign .contents{
  position: relative;
}
header.foreign .h-txt {
  position: absolute;
  top: 30px;
  right: 16px;
  max-width: 216px;
}
@media (max-width: 1023px) {
  header.foreign .h-txt {
    justify-content: flex-end;
    top: 25px;
    right: 32px;
    max-width: 107px;
  }
}
header.foreign .list-lang {
  position: absolute;
  top: 38px;
  right: 260px;
  display: flex;
  width: 168px;
  font-size: 14px;
  z-index: 1;
}
@media (max-width: 1023px) {
  header.foreign .list-lang {
    top: 8px;
    right: 16px;
    font-size: 13px;
  }
}
header.foreign .list-lang li + li::before {
  content: "/";
  margin: 0 4px;
  color: #FFF;
}
header.foreign .list-lang a {
  color: #FFF;
  font-weight: bold;
} */



/* ナビゲーション
--------------------------------*/
nav.g-nv {
  /* position: absolute; */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  /* width: calc(100% - 200px); */
  padding: 10px 20px 10px 20px;
  /* top: 30px; */
  /* right: 40px; */
  z-index: 11;
  background: #f5f3f1;
  width: calc(100% -208px);
  flex:1;
  justify-content: center;
}

@media (max-width: 1100px) {
  nav.g-nv {
    padding: 10px 10px;
  }
}
@media (min-width: 1024px) {
  nav.g-nv {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
}
@media (max-width: 1023px) {
  nav.g-nv {
    display: none;
    position: absolute;
    width: 100%;
    /* height: calc(100vh - 58px); */
    height: calc(100dvh - 52px);
    top: 52px;
    left: 0;
    padding: 32px 16px;
    background-color: #FFF;
    overflow-y: auto;
  }
}
nav.g-nv .menu-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;

  /* gap: 0 24px; */
}
@media (max-width: 1023px) {
  nav.g-nv .menu-nav {
      gap: 0 24px;
      flex-direction: column;
      align-items: center;
  }
}
@media (max-width: 1300px) {
  nav.g-nv .menu-nav {
    font-size: 14px;
  }
}
nav.g-nv .menu-nav a {
  display: block;
  padding: 3px 16px 2px 0;
  color: #606060;
}
@media (max-width: 1200px) {
  nav.g-nv .menu-nav a{
    padding: 3px 6px 2px 0;
  }
}
@media (max-width: 1100px) {
  nav.g-nv .menu-nav a{
    padding: 3px 3px 2px 0;
  }
}

nav.g-nv .menu-nav a::before{
  content:"|";
  color:#606060;
  padding-right: 16px;
}
@media (max-width: 1200px) {
  nav.g-nv .menu-nav a::before{
    padding-right: 8px;
  }
}
@media (max-width: 1200px) {
  nav.g-nv .menu-nav a::before{
    padding-right: 3px;
  }
}
@media (max-width: 1100px) {
  nav.g-nv .menu-nav a::before{
    padding-right: 1.5px;
  }
}

nav.g-nv .menu-nav li:nth-child(2) a::before{
  content:"";
  padding-right: 0px;
}
@media (max-width: 1023px) {
  nav.g-nv .menu-nav a,
  nav.g-nv .menu-nav span {
    color: #751300;
    text-align: center;
    font-size: 16px;
  }
  nav.g-nv .menu-nav a::before{
    content: "";
  }
}
nav.g-nv .link-area{
  display: flex;
  justify-content: space-between;
  width: 100%;
  flex-direction: row-reverse;
  align-items: center;
}
nav.g-nv .link-area .link-area-warp{
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /* align-items: center; */
  flex-direction: column;
  gap:5px;
}
@media (max-width: 1023px) {
  nav.g-nv .link-area {
    display: block;
  }
}
nav.g-nv .contact-bt {
  width: 190px;
}
@media (max-width: 1023px) {
  nav.g-nv .contact-bt {
    width: 100%;
    max-width: 345px;
    margin: 24px auto;
  }
}
nav.g-nv .contact-bt .com-bt {
  padding: 12px 16px;
  background-color: #f5f3f1;
  color: #751300;
  font-size: 14px;
}
@media (max-width: 1023px) {
  nav.g-nv .contact-bt .com-bt {
    font-size: 16px;
  }
}
nav.g-nv .contact-bt .com-bt:hover {
  background-color: #751300;
  border-color: #f5f3f1;
  color: #f5f3f1;
}
nav.g-nv .list-lang {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /* width: 168px; */
  font-size: 14px;
}
@media (max-width: 1023px) {
  nav.g-nv .list-lang {
    margin: 0 auto;
  }
}
nav.g-nv .list-lang li + li::before {
  content: "/";
  color:#751300;
  margin: 0 4px;
}
nav.g-nv .list-lang a {
  color:#751300;
  margin: 0 4px;
}

nav.g-nv .link-area-title{
  font-size: 20px;
  letter-spacing: 0.1em;
}
@media (max-width: 1200px) {
  header nav.g-nv .link-area-title{
    font-size: 18px;
    letter-spacing: 0.1em;
  }
}


@media (max-width: 1023px) {
  header nav.g-nv .link-area-title{
    display: none !important;
  }
  header .link-area-title{
    display: block !important;
    padding: 15px;
    text-align: center;
    font-size: 14px;
    background: #f5f3f1;
  }
}