@charset "utf-8";
/*===確認用アウトライン
* {
  outline: 1px solid red;
}*/
/* CSS Document */
html {
  scroll-behavior: smooth;
  /*font-size: 62.5%;*/ /*1rem=10px*/
}
body {
  font-family: 'Shippori Mincho', serif;
  color: #333333;
  line-height: 1.5;
}
img {
  width: 100%;
  height: auto;
}
.SEC_container {
  width: 80vw;
  margin: 0 auto 15vh;
  padding-bottom: 15vh;
  border-bottom: dotted 1px #333333;
  word-break: break-all;
}
.SEC_container2 {
  width: 80vw;
  margin: 0 auto 10vh;
  word-break: break-all;
}
.SEC_container_last {
  width: 80vw;
  margin: 0 auto 10vh;
  padding-bottom: 50vh;
  word-break: break-all;
}
:root {
  --80px: clamp(3.438rem, 3.058rem + 1.62vw, 5rem);
  --55px: clamp(2.5rem, 2.272rem + 0.97vw, 3.438rem);
  --40px: clamp(1.875rem, 1.723rem + 0.65vw, 2.5rem);
  --35px: clamp(1.625rem, 1.488rem + 0.58vw, 2.188rem);
  --30px: clamp(1.5rem, 1.409rem + 0.39vw, 1.875rem);
  --24px: clamp(1.25rem, 1.189rem + 0.26vw, 1.5rem);
  --20px: clamp(1.125rem, 1.095rem + 0.13vw, 1.25rem);
  --18px: clamp(1rem, 0.97rem + 0.13vw, 1.125rem);
  --15px: clamp(0.813rem, 0.782rem + 0.13vw, 0.938rem);
}
.min80px {
  font-size: var(--80px);
}
.min55px {
  font-size: var(--55px);
}
.min40px {
  font-size: var(--40px);
}
.min35px {
  font-size: var(--35px);
}
.min30px {
  font-size: var(--30px);
}
.min24px {
  font-size: var(--24px);
}
.min20px {
  font-size: var(--20px);
}
.min18px {
  font-size: var(--18px);
}
.min15px {
  font-size: var(--15px);
}
.min12px {
  font-size: 12px;
}
.caption {
  font-size: 10px;
}
/*共通*/
.F_c {
  font-family: 'Cinzel', serif;
  text-transform: capitalize;
}
.F_C {
  font-family: 'Cinzel', serif;
  text-transform: uppercase;
}
.img-pc {
  display: inline-block;
}
.img-sp {
  display: none;
}
.only_sp {
  display: none;
}
h1 {
  color: #ffffff;
  text-align: center;
  line-height: 1.5em;
  text-shadow: 0 1px 1.5px rgba(1, 7, 32, 0.7);
}
/*改行残りを防ぐ*/
.tw_p {
  text-wrap: pretty;
}
/*========サブページロゴ==========*/
.sub_logo {
  position: absolute;
  top: 3vh;
  left: 3vw;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  z-index: 650;
}
.sub_logo img {
  width: clamp(7.5rem, 6.625rem + 4.38vw, 11.875rem);
  height: auto;
  filter: drop-shadow(0 1px 1.5px rgba(1, 7, 32, 0.7));
}
.sub_logo_text {
  margin: 0;
  text-align: start;
  color: #ffffff;
  text-shadow: 0 1px 1.5px rgba(1, 7, 32, 0.7);
}
/*====共通項目========================*/
.grid_2items_SS {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(60px, 50%, 120px), 1fr));
  align-items: flex-start;
}
.grid_2items_S {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(50px, 50%, 200px), 1fr));
  align-items: flex-start;
}
.grid_2items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(200px, 50%, 400px), 1fr));
  align-items: flex-start;
}
.grid_2items_1_4 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(120px, 50%, 220px), 1fr));
  align-items: flex-start;
}
.grid_3items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(200px, 30%, 300px), 1fr));
  align-items: flex-start;
}
.grid_4items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(200px, 25%, 220px), 1fr));
  align-items: flex-start;
}
.mar_05E {
  margin-bottom: 0.5em;
}
.mar_1E {
  margin-bottom: 1.0em;
}
.mar_2E {
  margin-bottom: 2.0em;
}
.mar_3E {
  margin-bottom: 3.0em;
}
.mar_4E {
  margin-bottom: 4.0em;
}
.mar_5E {
  margin-bottom: 5.0em;
}
.mar_12vh{
	margin-bottom: 12vh;
}
.mar_8E {
  margin-bottom: 8.0em;
}
.mar_15vh {
  margin-bottom: 15vh;
}
/*=======3列グリッドのgap=============*/
.gap_3clumn {
  gap: 6.0em 4.0em;
}
.gap_03EM {
  gap: 0.3em;
}
.gap_1EM {
  gap: 1.0em;
}
.gap_2EM {
  gap: 2.0em;
}
.gap_3EM {
  gap: 3.0em;
}
.gap_5EM {
  gap: 5.0em;
}
.gap_12EM {
  gap: 12.0em;
}
.align_c {
  align-items: center;
}
/*======メニュー===================

==================================*/
/*=============余白を無くす============*/
.menu_header {
  display: none;
}
.drawer_hidden {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
#menu_btn_check {
  margin: 0;
  padding: 0;
}
/* ナビを固定で表示 */
.menu_content {
  position: fixed;
  background-image: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 17, 68, 0.8) 100%);
  width: 100%;
  z-index: 400;
}
/*ナビを横に並べる*/
.nav_list {
  display: flex;
  justify-content: space-evenly;
  width: 50vw;
  line-height: 1.2;
  margin: 2.0em 1.5em 0 auto;
  gap: min(1.0em, 10px);
  padding-bottom: 2.5em;
}
/*他項目*/
.nav_item {
  text-align: center;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.7);
}
.link:link, .link:visited {
  color: #ffffff;
  text-decoration: none;
}
.nav_item a:hover {
  color: ffffff;
  text-shadow: 0 0 10px #ffffff;
}
.nav_item_underline {
  padding-bottom: 5px;
  position: relative;
}
.nav_item_underline::before {
  background-color: #ffffff;
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  transform-origin: center top;
  transform: scale(0, 1);
  transition: transform 0.3s;
}
.nav_item_underline:hover::before {
  transform: scale(1, 1);
}
/*請求ボタン*/
#Button_1 span, #Button_2 span {
  writing-mode: horizontal-tb;
  font-size: var(--15px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.8);
  padding-bottom: 0.6em;
  margin-bottom: 0.6em;
}
#Button_1, #Button_2 {
  writing-mode: vertical-rl;
  position: fixed;
  top: 12vh;
  right: 0px;
  font-size: var(--18px);
  letter-spacing: 0.12rem;
  white-space: nowrap;
  color: rgb(255 255 255/0.8);
  background-color: rgba(0, 17, 68, 0.8);
  padding: 14px 8px;
  box-shadow: 0 2px 2px rgba(0, 17, 68, 0.3);
  z-index: 500;
}
#Button_2 {
  top: calc(12vh + 9em);
}
#Button_1:hover, #Button_2:hover {
  color: #ffffff;
  background-color: rgba(0, 17, 68, 1);
  text-shadow: 0 0 10px #ffffff;
}
/*トップページボタン*/
/* ページトップボタン */
#page-top {
  position: fixed;
  bottom: 100px;
  right: -30px;
  width: 6em;
  transform: rotate(90deg);
  text-align: end;
  border-bottom: 1px;
  border-bottom-style: solid;
  border-bottom-color: #666666;
  z-index: 501;
}
#page-top a {
  font-family: 'Cinzel', serif;
  display: block;
  color: #666666;
  text-decoration: none;
  font-size: 16px;
  font-weight: bold;
  padding: 0 0.5em 0 0;
}
#page-top::before {
  content: "";
  display: block;
  position: absolute;
  bottom: -1px;
  left: 0px;
  width: 15px;
  border-top: 1px solid #666666;
  transform: rotate(-35deg);
  transform-origin: left top;
}
/*=========フッター===========

=============================*/
.SEC_container_foot {
  position: relative;
  background-color: #e1e2e4;
  padding: 30vh 10vw 20vh;
}
/*ロゴ*/
.footer_logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 5vh;
}
.SEC_container_foot::before {
  content: "";
  position: absolute;
  bottom: 99%;
  left: 0;
  right: 0;
  aspect-ratio: 1920 / 439;
  max-height: 439px;
  background: url("../images/common/footer.png") no-repeat center top / contain;
  z-index: -1;
}
h2 {
  line-height: 2.5;
  margin-bottom: 3.5em;
}
.footer_logo img {
  width: 245px;
  height: auto;
  filter: brightness(0) saturate(100%) invert(0%) sepia(47%) saturate(3%) hue-rotate(177deg) brightness(104%) contrast(60%);
}
.logo_position {
  display: inline-block;
  position: absolute;
  top: 5vh;
  left: 10vw;
}
.footer_container {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin: 0 auto 4.0em;
  padding-top: 5vh;
}
footer ul {
  line-height: 2.5;
  text-indent: 1.5em;
}
.footer_left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.footer_li_item {
  position: relative;
}
.footer_li_item:hover {
  color: #999999;
}
.footer_li_item::before {
  background-color: #333333;
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  transform-origin: center left;
  transform: scale(0, 1);
  transition: transform 0.3s;
}
.footer_li_item:hover::before {
  background-color: #999999;
  transform: scale(1, 1);
}
a[aria-current="page"]::before {
  content: "▶";
  font-size: 0.8em;
  position: absolute;
  top: 0.3em;
  left: -1.5em;
}
.footer_right {
  display: flex;
  align-items: flex-end;
  flex-direction: column;
  padding-bottom: 10px;
}
.footer_right img {
  width: 180px;
  line-height: auto;
  margin-bottom: 1.2em;
}
.shop_tel {
  font-size: var(--20px);
  width: 100%;
  letter-spacing: 0.25em;
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.5em;
}
.shop_add {
  font-size: var(--15px);
  width: 100%;
  display: flex;
  justify-content: space-between;
}

.footer_button {
  width: 14.0em;
  text-align: center;
  background-color: #272727;
  border: solid 1px #272727;
  color: #ffffff;
  padding: 0.4em 2.0em;
  margin:0 auto 10vh;
}
.footer_button:hover{
  background-color: #ffffff;
  color: #272727;
  border: solid 1px #272727;
}
/*=========レスポンシブ=====================

=======SP対応・ブレイクポイント768px=========*/
@media (max-width: 768px) {
  /*ーーーーーーーーーー
ハンバーガーメニュー
ーーーーーーーーーーー*/
  .nav_list {
    display: block; /*ナビを縦に並べる*/
    width: 100vw;
    background-color: none;
    margin: 0;
  }
  .menu_btn {
    position: fixed;
    border-radius: 0 0 0 30px;
    top: 0px;
    right: -8px;
    display: flex;
    height: 55px;
    width: 55px;
    justify-content: center;
    align-items: center;
    z-index: 750;
    filter: drop-shadow(1px 1px 2px #001144) drop-shadow(-1px -1px 2px #001144) drop-shadow(-1px 1px 2px #001144) drop-shadow(1px -1px 2px #001144);
  }
  .menu_btn::after {
    content: "MENU";
    font-family: sans-serif;
    position: absolute;
    bottom: 2px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10px;
    color: #ffffff;
    letter-spacing: 0.1em;
  }
  /* メニュー開いたらMENU文字を消す */
  #menu_btn_check:checked ~ .menu_btn::after {
    content: none;
  }
  #menu_btn_check:checked ~ .menu_btn {
    filter: none;
  }
  .menu_btn span, .menu_btn span:before, .menu_btn span:after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #ffffff;
    position: absolute;
  }
  .menu_btn span:before {
    bottom: 8px;
  }
  .menu_btn span:after {
    top: 8px;
  }
  #menu_btn_check:checked ~ .menu_btn span {
    background-color: rgba(255, 255, 255, 0); /*メニューオープン時は真ん中の線を透明にする*/
  }
  #menu_btn_check:checked ~ .menu_btn span::before {
    bottom: 0;
    transform: rotate(45deg);
  }
  #menu_btn_check:checked ~ .menu_btn span {
    background-color: rgba(255, 255, 255, 0); /*メニューオープン時は真ん中の線を透明にする*/
  }
  #menu_btn_check:checked ~ .menu_btn span::before {
    bottom: 0;
    transform: rotate(45deg);
  }
  #menu_btn_check:checked ~ .menu_btn span::after {
    top: 0;
    transform: rotate(-45deg);
  }
  :checked ~ .menu_btn span::after {
    top: 0;
    transform: rotate(-45deg);
  }
  #menu_btn_check {
    display: none;
  }
  .menu_content ul {
    padding: 10vh 10vw;
    margin-bottom: 5.0em;
  }
  .menu_content ul li {
    list-style: none;
  }
  .menu_content ul li a {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding-top: 15px;
    text-align: center;
    position: relative;
  }
  /*×でメニューをを外へ出す*/
  .menu_content {
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 100%; /*leftの値を変更してメニューを画面外へ*/
    z-index: 700;
    transition: all 0.5s; /*アニメーション設定*/
    background-image: none;
    background-color: rgba(0, 0, 0, 0.8);
  }
  #menu_btn_check:checked ~ .menu_content {
    left: 0; /*メニューを画面内へ*/
  }
  .link {
    display: inline-block;
    margin-bottom: 5.0em;
  }
  .nav_item_underline::before {
    bottom: 5.0em;
    width: 50%;
    position: absolute;
    left: 25%;
  }
  .menu_header {
    display: block;
    text-align: center;
  }
  .menu_header img {
    width: 210px;
  }
  .shop_name {
    color: #ffffff;
    margin-top: 10px;
    font-size: 12px;
    letter-spacing: 0.1em;
  }
  #menu_btn_check ~ .menu_content .menu_header {
    opacity: 1;
    transform: translateY(-22vh);
  }
  /*請求ボタン*/
  #Button_1 span, #Button_2 span {
    font-size: 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.8);
    padding-bottom: 0.6em;
    margin-bottom: 0.6em;
  }
  #Button_1, #Button_2 {
    writing-mode: vertical-rl;
    position: fixed;
    top: 12vh;
    right: 0px;
    font-size: 14px;
    letter-spacing: 0.12rem;
    color: rgb(255 255 255/0.8);
    background-color: rgba(0, 17, 68, 0.8);
    padding: 10px 6px;
    box-shadow: 0 2px 2px rgba(0, 17, 68, 0.3);
    z-index: 500;
  }
  #Button_2 {
    top: calc(12vh + 9em);
  }
  #Button_1:hover, #Button_2:hover {
    color: #ffffff;
    background-color: rgba(0, 17, 68, 1);
    text-shadow: 0 0 10px #ffffff;
  }
  /*ト
/*=====その他=====================*/
  .img-pc {
    display: none;
  }
  .img-sp {
    display: inline-block;
  }
  .only_sp {
    display: inline;
  }
  .shop_tel {
    font-size: var(--18px);
  }
  .logo_position {
    display: inline-block;
    position: absolute;
    top: -25vh;
    left: 10vw;
  }
  .SEC_container_foot {
    padding: 0 10vw 20vh;
  }
  .logo_position {
    top: -25vh;
  }
}
@media (max-width: 610px) {
  .footer_container {
    display: block;
  }
  .footer_left {
    margin-bottom: 10vh;
  }
  .shop_tel {
    font-size: var(--18px);
  }
  .shop_tel, .shop_add {
    width: 290px;
  }
  .sub_logo {
    top: 1vh;
    left: 1vw;
  }
  .sub_logo_text {
    font-size: 10px
  }
  .sub_logo img {
    margin-bottom: 2px;
  }
}