@charset "UTF-8";
/*
**
template style
**
** reset
** web font
** overall
** header
** gnav
** contents
** main
** side
** topicpath
** footer
** fixed
**
*/
/*==================================================

** reset
==================================================*/
/*==================================================

fonts
==================================================*/
/*Safariでヒラギノ角ゴシックをきれいに表示させるCSS*/
/*
@font-face {
	font-family: sans-serif;
	src: local(HiraginoSans-W3);
	font-weight: normal;
	font-display: swap;
}
@font-face {
	font-family: sans-serif;
	src: local(HiraginoSans-W6);
	font-weight: bold;
	font-display: swap;
}
*/
@font-face {
  font-family: "Hiragino Kaku Gothic Pro";
  src: local(HiraginoSans-W3);
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: "Hiragino Kaku Gothic Pro";
  src: local(HiraginoSans-W6);
  font-weight: bold;
  font-display: swap;
}
@font-face {
  font-family: "ヒラギノ角ゴ Pro W3";
  src: local(HiraginoSans-W3);
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: "ヒラギノ角ゴ Pro W3";
  src: local(HiraginoSans-W6);
  font-weight: bold;
  font-display: swap;
}
@font-face {
  font-family: "ヒラギノ角ゴ ProN W3";
  src: local(HiraginoSans-W3);
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: "ヒラギノ角ゴ ProN W3";
  src: local(HiraginoSans-W6);
  font-weight: bold;
  font-display: swap;
}
@font-face {
  font-family: "ＭＳ Ｐゴシック";
  src: local(HiraginoSans-W3);
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: "ＭＳ Ｐゴシック";
  src: local(HiraginoSans-W6);
  font-weight: bold;
  font-display: swap;
}
@font-face {
  font-family: "MS P Gothic";
  src: local(HiraginoSans-W3);
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: "MS P Gothic";
  src: local(HiraginoSans-W6);
  font-weight: bold;
  font-display: swap;
}
@font-face {
  font-family: "MS PGothic";
  src: local(HiraginoSans-W3);
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: "MS PGothic";
  src: local(HiraginoSans-W6);
  font-weight: bold;
  font-display: swap;
}
/*==================================================

sectioning	
==================================================*/
/* Box sizing rules */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/*	outline	*/
:where(html,
body) {
  margin: 0;
  padding: 0;
  border: 0;
  line-height: 1;
}

html {
  font-size: 62.5%;
}

body {
  font-family: "M PLUS Rounded 1c", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, Verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, sans-serif;
  font-weight: 400;
  font-size: 1.6rem;
  overflow-wrap: anywhere;
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  -webkit-backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
}

:where(p,
blockquote,
address,
small,
dt,
dd,
li,
th,
td) {
  font-style: normal;
  line-height: 1.6;
  overflow-wrap: break-word;
}

:where(div) {
  line-height: 1;
}

:where(article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section) {
  display: block;
}

/*	heading	*/
:where(h1,
h2,
h3,
h4,
h5,
h6) {
  margin: 0;
  padding: 0;
  vertical-align: top;
  font-weight: normal;
  font-size: 100%;
  line-height: 1.6;
  overflow-wrap: break-word;
}

/*==================================================

link	
==================================================*/
:where(a) {
  color: inherit;
  text-decoration: inherit;
  cursor: pointer;
  text-decoration-skip-ink: auto;
  touch-action: manipulation;
}

/*==================================================

content	
==================================================*/
/*	text	*/
:where(p,
blockquote) {
  margin: 0;
}

/*	list	*/
:where(ol,
ul,
dl,
dt,
dd,
menu,
summary) {
  margin: 0;
}

:where(ol,
ul,
menu,
summary) {
  padding: 0;
  list-style: none;
  list-style-position: inside;
}

/*	table	*/
:where(table) {
  border-collapse: collapse;
}

:where(th) {
  font-weight: normal;
}

/*	embed	*/
:where(img,
svg,
video,
canvas,
audio,
iframe,
embed,
object,
figure,
picture) {
  display: block;
}

:where(img,
svg,
video) {
  block-size: auto;
  max-inline-size: 100%;
}

:where(img,
picture) {
  image-rendering: -webkit-optimize-contrast;
  border: 0;
  max-inline-size: 100%;
  max-block-size: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

:where(img[src$=".svg"]) {
  width: 100%;
}

:where(figure) {
  margin: 0;
  padding: 0;
}

:where(iframe) {
  border: none;
  width: 100%;
  vertical-align: bottom;
}

:where(video) {
  outline: none;
}

:where(svg) {
  stroke: none;
  fill: currentColor;
}

:where(svg):where(:not([fill])) {
  stroke: currentColor;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/*	semantics	*/
:where(ruby,
rt,
mark) {
  margin: 0;
  padding: 0;
  line-height: 1;
}

:where(small) {
  font-size: 100%;
}

:where(em,
cite,
dfn,
i,
strong,
b) {
  font-style: normal;
  font-weight: normal;
}

:where(ins,
del) {
  text-decoration: none;
}

:where(q) {
  quotes: none;
}

:where(sup) {
  vertical-align: super;
}

:where(sub) {
  vertical-align: sub;
}

:where(mark) {
  background: none;
}

/**/
:where(pre,
code,
kbd,
samp) {
  display: block;
  font: inherit;
}

/*==================================================

form
==================================================*/
:where(form) {
  margin: 0;
}

:where(input, select, textarea, button) {
  -webkit-appearance: none;
  box-shadow: none;
  border-radius: 0;
  margin: 0;
  padding: 0;
  font: inherit;
  outline: none;
  color: inherit;
  touch-action: manipulation;
}

:where(label, button, select) {
  cursor: pointer;
}

:where(input[type=file]) {
  cursor: auto;
}

:where(input[type=file])::-webkit-file-upload-button,
:where(input[type=file])::file-selector-button {
  cursor: pointer;
}

:where(fieldset) {
  font: inherit;
  margin: 0;
  padding: 0;
  border: 0;
}

:where(textarea) {
  resize: vertical;
  vertical-align: bottom;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset])[disabled] {
  cursor: not-allowed;
}

/*==================================================

** web font
==================================================*/
/*==================================================

** overall
==================================================*/
/*
*::selection {
	background:lighten($color-bk,20%);
	color:#fff;
}
*::-moz-selection {
	background: lighten($color-bk,20%);
	color:#fff;
}
*/
:where(html, body) {
  height: 100%;
  width: 100%;
}

@media screen and (max-width: 991px) {
  html.is-gnavopen {
    overflow: hidden;
  }
}
body {
  color: #662418;
  position: relative;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.wrap {
  position: relative;
}
@media screen and (min-width: 992px) {
  .wrap {
    padding-inline: 3.84%;
  }
}
@media screen and (max-width: 991px) {
  .wrap {
    padding-inline: 7%;
  }
}
:where(a, button) {
  transition: all 0.4s;
}
:where(a, button):hover {
  transition: all 0.6s;
}
:where(a, button):has(img):hover {
  opacity: 0.8;
}

/*==================================================

** header
==================================================*/
#header {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 999;
  width: 100%;
  transition: height 0s;
}
#header .wrap {
  height: 100px;
  background: #fff1ca;
  position: static;
}
#header .logo {
  width: min(11.6vw, 140px);
  position: absolute;
  left: 3.8%;
  top: 50%;
  transform: translateY(-50%);
}
#header .logo-a {
  display: block;
}
#header .logo_pai {
  width: min(11.6vw, 140px);
  position: absolute;
  right: 3.8%;
  top: 50%;
  transform: translateY(-50%);
}
#header .logo_pai-a {
  display: block;
}
@media screen and (max-width: 767px) {
  #header .logo_pai {
    width: 18vw;
    right: 41vw;
  }
}
#header .header-menu {
  display: none;
}

#menubtn {
  display: none;
}

@media screen and (max-width: 991px) {
  #header .wrap {
    justify-content: space-between;
    position: static;
  }
  #header .logo {
    position: relative;
    width: 140px;
    left: auto;
    top: auto;
    transform: none;
    z-index: 9;
  }
  .is-open #header {
    height: 100%;
  }
  #header .header-menu {
    border: none;
    background: none;
    display: block;
    position: relative;
    z-index: 9;
    font-size: 4.358974359vw;
    font-weight: 800;
    color: #420e10;
    letter-spacing: 0.05em;
  }
  #header .header-menu-txt {
    display: inline-block;
    background: linear-gradient(to right, #ffe279, #ffe279) repeat-x left bottom/100% 2.5641025641vw;
    line-height: 1;
  }
  #menubtn {
    display: block;
    width: 96px;
    border: none;
    background: none;
    position: relative;
    z-index: 9;
  }
}
@media screen and (max-width: 767px) {
  #header .wrap {
    height: 53px;
  }
  #header .logo {
    width: 78px;
  }
  .is-gnavopen #header {
    height: 100%;
  }
  #menubtn {
    width: 48px;
  }
}
/*==================================================

** gnav
==================================================*/
#gnav .gnav-close {
  display: none;
}
#gnav .gnav-menu {
  gap: 0 min(3.1vw, 60px);
}
#gnav .gnav-menu-a {
  display: block;
  font-size: min(2vw, 2.4rem);
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: -0.01em;
}
#gnav .gnav-menu-a:hover {
  opacity: 0.8;
}
#gnav .gnav-menu-txt {
  display: inline-block;
  background: linear-gradient(to right, #ffe279, #ffe279) repeat-x left bottom/100% 15px;
}
#gnav .gnav-menu-soon {
  display: block;
  font-size: min(1.1vw, 1.4rem);
  font-weight: 800;
  font-style: italic;
  line-height: 1.5;
  letter-spacing: 0.05em;
  color: #d17d38;
  position: relative;
  z-index: 1;
  padding-top: 14px;
}
#gnav .gnav-menu-soon::before {
  content: "???";
  font-size: min(2vw, 2.4rem);
  font-style: normal;
  line-height: 1;
  color: #ffe279;
  letter-spacing: 0.1em;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
#gnav .gnav-sns {
  display: none;
}

@media screen and (min-width: 992px) {
  #gnav {
    display: block !important;
  }
}
@media screen and (max-width: 991px) {
  #gnav {
    display: none;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    background: #fff1ca;
  }
  #gnav .gnav-wrap {
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: none;
    overflow: -moz-scrollbars-none;
    padding-block: calc(1.2820512821vw + 100px) 15.3846153846vw;
  }
  #gnav .gnav-wrap::-webkit-scrollbar {
    display: none;
  }
  #gnav .gnav-close {
    border: none;
    background: none;
    display: block;
    width: max-content;
    margin-inline: auto;
    font-size: 2.0512820513vw;
    font-weight: 800;
    letter-spacing: 0.05em;
    color: #3b090c;
  }
  #gnav .gnav-close::before {
    content: "";
    display: block;
    width: 5.1282051282vw;
    aspect-ratio: 1;
    background: url("../img/common/menu_btn_close.svg") no-repeat center center/contain;
    margin-inline: auto;
    margin-bottom: 1.0256410256vw;
  }
  #gnav .gnav-menu {
    margin-top: 8.3333333333vw;
    gap: 8.9743589744vw 0;
    flex-direction: column;
    align-items: center;
  }
  #gnav .gnav-menu-a {
    font-size: 5.8974358974vw;
    color: #420e10;
  }
  #gnav .gnav-menu-a:hover {
    opacity: 1;
  }
  #gnav .gnav-menu-txt {
    background-size: 100% 2.5641025641vw;
  }
  #gnav .gnav-menu-txt {
    display: inline-block;
    background: linear-gradient(to right, #ffe279, #ffe279) repeat-x left bottom/100% 1.9230769231vw;
    line-height: 1;
  }
  #gnav .gnav-menu-soon {
    font-size: 2.5641025641vw;
    padding-top: 3.5897435897vw;
    color: #b58348;
  }
  #gnav .gnav-menu-soon::before {
    font-size: 6.1538461538vw;
  }
  #gnav .gnav-sns {
    margin-top: 30.7692307692vw;
    display: flex;
    justify-content: center;
    gap: 0 2.5641025641vw;
    position: relative;
  }
  #gnav .gnav-sns::after {
    content: "";
    display: block;
    width: 119.4871794872vw;
    aspect-ratio: 923/1095;
    background: url("../img/common/mene_bg_sp.webp") no-repeat center center/contain;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -17.9487179487vw;
    z-index: -1;
  }
  #gnav .gnav-sns-li {
    width: 7.9487179487vw;
  }
  #gnav .gnav-sns img {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #gnav .gnav-wrap {
    padding-block: calc(1.2820512821vw + 53px) 6.4102564103vw;
  }
}
/*==================================================

** contents
==================================================*/
#contents {
  padding-top: 100px;
}
@media screen and (max-width: 767px) {
  #contents {
    padding-top: 53px;
  }
}

/*==================================================

** main
==================================================*/
/* pagettl
#pagettl {}
 */
/* main style */
.main :where(a, span) {
  rotate: 0.03deg;
}
.main :where(p, address) {
  rotate: 0.03deg;
}
.main :where(p, address) + :where(p, address) {
  margin-top: 0px;
}
.main :where(ol, ul) {
  counter-reset: number;
}
.main :where(ol, ul) li {
  rotate: 0.03deg;
  position: relative;
}
.main :where(ol, ul) li > :first-child {
  margin-top: 0;
}
.main :where(ol, ul) > li {
  counter-increment: number;
}
.main :where(table),
.main .tbl {
  width: 100%;
}
.main :where(table) th,
.main :where(table) td,
.main .tbl th,
.main .tbl td {
  width: auto;
  text-align: left;
  vertical-align: top;
  rotate: 0.03deg;
}
.main :where(table) th > :first-child,
.main :where(table) td > :first-child,
.main .tbl th > :first-child,
.main .tbl td > :first-child {
  margin-top: 0;
}
.main :where(dl) dt,
.main :where(dl) dd {
  rotate: 0.03deg;
}
.main :where(dl) dt > :first-child,
.main :where(dl) dd > :first-child {
  margin-top: 0;
}
.main :where(blockquote) {
  display: block;
  padding: 20px;
}
.main :where(blockquote):before, .main :where(blockquote):after {
  display: block;
}
.main :where(blockquote):before {
  content: "“";
  text-align: left;
}
.main :where(blockquote):after {
  content: "”";
  text-align: right;
}
.main em {
  font-style: italic;
}
.main strong {
  font-weight: 800;
}
.main :where(h1, h2, h3, h4, h5, h6) {
  rotate: 0.03deg;
}
.main :where(h1) + *,
.main .h1 + * {
  margin-top: 0;
}
.main :where(h1) + p,
.main .h1 + p {
  margin-top: 0;
}
.main :where(h2) + *,
.main .h2 + * {
  margin-top: 0;
}
.main :where(h2) + p,
.main .h2 + p {
  margin-top: 0;
}
.main :where(h3) + *,
.main .h3 + * {
  margin-top: 0;
}
.main :where(h3) + p,
.main .h3 + p {
  margin-top: 0;
}
.main :where(h4) + *,
.main .h4 + * {
  margin-top: 0;
}
.main :where(h4) + p,
.main .h4 + p {
  margin-top: 0;
}
.main :where(h5) + *,
.main .h5 + * {
  margin-top: 0;
}
.main :where(h5) + p,
.main .h5 + p {
  margin-top: 0;
}
/*==================================================

** side
#side {
}
==================================================*/
/*==================================================

** topicpath

#topicpath {
    ol {
        @include wrap;
    }
    li {
        display: inline;
    }
    span {
        //タームなどが連続する時用
        + span {
            &:before {
                content: ",";
                margin: 0 5px;
            }
        }
    }
    a {
    }
}
==================================================*/
/*==================================================

** footer
#footer {
}
==================================================*/
/*==================================================

** fixed
#pagetop {
    display: none;
    position: fixed;
    z-index: 99;
    a {
    }
}
==================================================*/
