@charset "UTF-8";

/* ////////////////////////////////////////////////////////////////////
///// 全ページ共通CSS ///////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// */
/* ==================================================
FONT SETTING
================================================== */
html {
  font-size: 2.97vw;
}
@media screen and (min-width: 768px) {
  html {
    font-size: 2.47vw;
  }
}
@media screen and (min-width: 961px) {
  html {
    font-size: 1.35vw;
  }
}
@media screen and (min-width: 1281px) {
  html {
    font-size: 17px;
  }
}

html body {
  /*ゴシック系*/
  font-family: "m-plus-1p", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.05em;
  background: #f5eee4;
  line-height: 1.7;
  -ms-font-feature-settings: "normal";
  font-feature-settings: "palt";
  overflow-x: hidden;
}
.fwBold {
  font-family: "m-plus-1p", sans-serif;
  font-weight: 700;
  font-style: normal;
}
.enGothic {
  font-family: "veneer", "m-plus-1p", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.1em;
}

:root {
  --fs48: 6vw;
  --fs36: 5.8vw;
  --fs32: 5.6vw;
  --fs28: 5vw;
  --fs24: 4.6vw;
  --fs20: 3.8vw;
  --fs18: 3.6vw;
  --fs16: 3vw;
}
@media screen and (min-width: 768px) {
  :root {
  }
}
@media screen and (min-width: 961px) {
  :root {
  }
}
.fs48 {
  font-size: clamp(30px, var(--fs48), 48px);
  letter-spacing: 0.04em;
}

.fs36 {
  font-size: clamp(28px, var(--fs28), 36px);
  letter-spacing: 0.06em;
}
.fs32 {
  font-size: clamp(24px, var(--fs32), 32px);
}
.fs28 {
  font-size: clamp(20px, var(--fs28), 28px);
}
.fs24 {
  font-size: clamp(18px, var(--fs24), 24px);
}
.fs20 {
  font-size: clamp(16px, var(--fs20), 20px);
}
.fs18 {
  font-size: clamp(13px, var(--fs18), 18px);
  letter-spacing: 0.1em;
}
.fs16 {
  font-size: clamp(14px, var(--fs16), 16px);
}

.fwBold {
  font-weight: 600;
}
@media screen and (min-width: 961px) {
  .pcFBig {
    font-size: 120%;
  }
}

/* ==================================================
font line height
================================================== */
.js-setLoad .spinner {
  width: 84vw;
  height: 10vw;
  max-width: 420px;
  max-height: 50px;
}
/* ==================================================
color
================================================== */
:root {
  --clrWh: #fff;
  --clrBe1: #eee5dc;
  --clrBe2: #ebe2d3;
  --clrBr: #866d59;
  --clrOr: #f78822;
  --clrGrn: #3a4302;
  --clrWh1: #f5eee4;
}
body {
  color: #3a4302;
}
.clrWh {
  color: var(--clrWh);
}
.clrBe1 {
  color: var(--clrBe1);
}
.clrBe2 {
  color: var(--clrBe2);
}
.clrBr {
  color: var(--clrBr);
}
.clrOr {
  color: var(--clrOr);
}
.clrGrn {
  color: var(--clrGrn);
}
.clrWh1 {
  color: var(--clrWh1);
}
/* ==================================================
kadoR
 ================================================== */
:root {
  --kadoR80: 80px;
  --kadoR16: 16px;
  --kadoR8: 8px;
  --kadoR36: 36px;
}
@media (width <= 900px) {
  :root {
    --kadoR80: 40px;
    --kadoR16: 16px;
    --kadoR8: 6px;
    --kadoR36: 22px;
  }
}

/*-------------------------------------------------
	++ HEADER
-------------------------------------------------*/
#header {
}
#header #headerLogo {
  width: 100px;
}
#header #headerLogo img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 759px) {
  /*SP*/
  #header {
  }
  #header #headerLogo {
    width: 20%;
  }
}
/*-------------------------------------------------
	++ MENU
-------------------------------------------------*/
#menuBtn {
  position: absolute;
  top: 20px;
  right: 35px;
  width: 64px;
  height: 64px;
  z-index: 9998;
  border: 2px solid #3a4302;
  border-radius: 100px;
  cursor: pointer;
}
#menuBtn::before {
  content: "";
  background: #ebe2d3;
  position: absolute;
  width: 52px;
  height: 52px;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  border-radius: 100px;
  bottom: 0;
}
#menuBtn span {
  display: inline-block;
  position: absolute;
  left: 0;
  width: 30px;
  height: 4px;
  border-radius: 2px;
  right: 0;
  background-color: #3a4302;
  margin: auto;
}
#menuBtn span:nth-of-type(1) {
  top: calc(50% - 6px);
}
#menuBtn span:nth-of-type(2) {
  top: calc(50% + 4px);
  width: 22px;
}
#menuBtn span:nth-of-type(3) {
  bottom: 0;
}
#menuBtn.current span:nth-of-type(1) {
  transform: rotate(45deg);
  top: calc(50% - 2px);
}
#menuBtn.current span:nth-of-type(2) {
  /* display: none; */
  transform: rotate(-45deg);
  top: calc(50% - 2px);
  width: 30px;
}
#menuBtn.current span:nth-of-type(3) {
  transform: rotate(-45deg);
  top: 20px;
}

#menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  margin: 0;
  z-index: 9998;
}
#menu .menuBox {
  width: 100%;
  height: 100vh;
  background-color: rgba(25, 46, 15, 0.95);
  display: none;
  padding: 0 0 0 0;
  text-align: center;
}
#menu .menuBox .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding: 30px;
  overflow-y: scroll;
  flex-flow: column;
}
#menu .menuBox ul.indexLists {
  display: flex;
  flex-flow: wrap;
  justify-content: center;
}
#menu .menuBox ul.indexLists .indexList {
}
#menu .menuBox ul.indexLists .indexList a {
}
#menu .menuBox ul.indexLists .indexList + .indexList {
  margin: 0 0 0 3em;
}

#menu .menuBox ul.menuLists {
  margin: 50px auto 0;
  max-width: 580px;
  width: 65%;
}
#menu .menuBox ul.menuLists .menuList {
  border-bottom: 2px solid var(--clrWh1);
  padding: 0 0 8px;
}
#menu .menuBox ul.menuLists .menuList a {
  letter-spacing: 0.05em;
  line-height: 1;
}
#menu .menuBox ul.menuLists .menuList + .menuList {
  margin: 3em 0 0;
}

#menu .menuBox .btnObj {
  position: relative;
  margin: 50px auto 0;
  text-align: center;
  width: 280px;
  background: var(--clrOr);
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--kadoR16);
  transition: 0.2s;
}
#menu .menuBox .btnObj a {
  text-decoration: none;
  color: var(--clrWh);
  letter-spacing: 0.05em;
  display: flex;
  flex-flow: row;
  justify-content: center;
  align-items: center;
}
#menu .menuBox .btnObj a .icon {
  width: 1em;
  display: flex;
  margin: 0 10px 0 0;
}

#menu .menuBox ul li {
}
#menu .menuBox ul li a {
}
#menu .menuBox ul li.menuMessage {
}
#menu .menuBox ul li.menuJme {
}
#menu .menuBox ul li.menuJme a {
}

@media screen and (max-width: 900px) {
  /*SP*/
  #menu .menuBox .inner {
    padding: 30px 0;
  }
  #menuBtn {
    top: 3vw;
    right: 3vw;
    width: 50px;
    height: 50px;
  }
  #menuBtn::before {
    width: 40px;
    height: 40px;
  }
  #menuBtn span {
    height: 3px;
    width: 23px;
  }
  #menuBtn span:nth-of-type(1) {
    top: calc(50% - 6px);
  }
  #menuBtn span:nth-of-type(2) {
    top: calc(50% + 2px);
    width: 18px;
  }
  #menuBtn span:nth-of-type(3) {
    bottom: 1vw;
  }
  #menuBtn.current span:nth-of-type(1) {
    top: calc(50% - 2px);
  }
  #menuBtn.current span:nth-of-type(2) {
    top: calc(50% - 2px);
    width: 22px;
  }
  #menu .menuBox ul.indexLists {
  }
  #menu .menuBox ul.indexLists .indexList {
    width: 50%;
  }
  #menu .menuBox ul.indexLists .indexList a {
  }
  #menu .menuBox ul.indexLists .indexList + .indexList {
    margin: 0 0 1em;
  }

  #menu .menuBox ul.menuLists {
    width: 90%;
    margin: 30px 0 0;
  }
  #menu .menuBox ul.menuLists .menuList {
  }
  #menu .menuBox ul.menuLists .menuList a {
  }
  #menu .menuBox ul.menuLists .menuList + .menuList {
  }

  #menu .menuBox .btnObj {
  }
  #menu .menuBox .btnObj a {
  }
  #menu .menuBox .btnObj a .icon {
  }
}

#gigyaShare {
  margin: 80px auto;
}
@media screen and (max-width: 759px) {
  #gigyaShare {
  }
}
