:root {
  --base-color: #4b2316;
  --base-fontset: "indivisible", "momochidori", sans-serif;
  --sans-serif: "indivisible", sans-serif;
  --serif: "dnp-shuei-nmincho-std", serif;
  --nav-bg: #4b2316;
  --nav-color: #e4cea1;
}
body {
  font-family: var(--base-fontset);
  font-feature-settings: "palt";
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 2;
  background-color: var(--nav-bg);
  /* background-color: #fad3d2; */
  color: var(--base-color);
  /* -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; */
}
@media (max-width: 959px) {
  body {
    font-size: min(4vw, 14.5px);
  }
}
@media (min-width: 960px) {
  body {
    font-size: min(1.35vw, 16px);
  }
}
@media (min-width: 740px) {
  .sp {
    display: none;
  }
}
@media (min-width: 960px) {
  .tb {
    display: none;
  }
  .sptb {
    display: none;
  }
}
@media (max-width: 739px) {
  .tb {
    display: none;
  }
  .tbpc {
    display: none;
  }
}
@media (max-width: 959px) {
  .pc {
    display: none;
  }
}
h1,
h2,
h3,
h4 {
  font-weight: normal;
  text-wrap: wrap;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
a {
  color: inherit;
}
address {
  font-style: normal;
}
.contents_wrapper {
  position: relative;
  z-index: 2;
}
main {
  display: block;
}
@media (max-width: 739px) {
  aside {
    display: none;
  }
}
@media (min-width: 740px) {
  aside.right {
    position: relative;
    z-index: 4;
  }
  main {
    position: relative;
    z-index: 5;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
    background-color: #fff;
  }
}
@media (min-width: 740px) and (max-width: 959px) {
  .contents_wrapper {
    display: flex;
    overflow-y: scroll;
    & aside.left_nav {
      flex: 1;
    }
    & main {
      width: min(64%, 460px);
    }
    & aside.right {
      flex: 1;
    }
  }
}
@media (min-width: 960px) {
  .contents_wrapper {
    display: flex;
    & aside.left_nav {
      width: min(46%, 640px);
    }
    & main {
      width: min(46%, 540px);
    }
    & aside.right {
      flex: 1;
    }
  }
}
.container {
  width: 82%;
  margin: auto;
}
h2 img {
  width: min(90%, 380px);
  margin: auto;
}
.asterisk {
  position: relative;
  padding: 0 0 0 1.2em;
  font-size: 0.9em;
}
.asterisk::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}

.copyright {
  background-color: #fff;
  text-align: center;
  font-family: var(--font-serif);
  font-size: 0.8125em;
  padding: 4em 0;
  text-transform: uppercase;
}
/* 左サイド */
@media (max-width: 959px) {
  .left_nav_contents {
    display: none;
  }
}
@media (min-width: 960px) {
  .left_nav .container {
    position: sticky;
    top: 0;
    padding: 2.5em 0;
    height: 100vh;
  }
  .left_nav_contents {
    display: flex;
    flex-direction: column;
    /* gap: 3em; */
    height: 100%;
    .left_logo {
      margin: 0 0 0 -1em;
      & img {
        width: max(50%, 240px);
      }
    }
    .left_nav {
      flex: 1;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 2em 0;
    }
    & a {
      color: #fff;
    }
    .nav_label {
      display: flex;
      gap: 0.75em;
      align-items: center;
    }
    .nav_label::before {
      content: "";
      display: block;
      width: 0.6em;
      height: 0.6em;
      border-radius: 50%;
      border: 3px solid #ea596d;
    }
    .c_nav {
      display: inline-flex;
      gap: 0.5em;
      align-items: center;
      margin: 0.25em 0;
      .en {
        font-size: 1.125em;
        text-transform: uppercase;
        letter-spacing: 0.1em;
        padding-left: 0.25em;
      }
      .jp {
        font-size: 0.875em;
      }
    }
    .nav_onlineshop {
      padding: 0.5em 0 0.75em 2em;
    }
  }
}
@media (min-width: 1240px) {
  .left_nav_contents {
    .c_nav {
      .en {
        font-size: 1.25em;
      }
    }
  }
}
/* 右サイド */
.side_tab {
  position: fixed;
  top: 20px;
  left: calc((100% - 460px) / 2 + 460px);
  width: 4em;
  .side_onlineshop {
    color: #fff;
    font-weight: 700;
    & a {
      background-color: #773d2c;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 0.75em;
      width: 4em;
      text-align: center;
      padding: 1em 0 1.5em;
    }
    & p {
      writing-mode: vertical-rl;
      letter-spacing: 0;
      font-size: 0.875em;
      font-feature-settings: normal;
    }
    .side_onlineshop_image {
      width: 3em;
    }
    .side_onlineshop_icon {
      width: 1.75em;
      border: 1px solid;
      border-radius: 50%;
    }
  }
  .side_sns {
    background-color: #fff;
    padding: 0.75em 0;
    & li {
      width: 4em;
      & a {
        display: block;
        padding: 0.75em 0;
        text-align: center;
      }
      & a::before {
        content: "";
        display: block;
        width: 2em;
        height: 2em;
        background-size: cover;
        margin: auto;
      }
      & a p {
        font-family: var(--font-serif);
        font-size: 0.7em;
        letter-spacing: 0;
      }
    }
    .side_sns_insta a::before {
      background-image: url(../images/icon_insta.svg);
    }
    .side_sns_fb a::before {
      background-image: url(../images/icon_fb.svg);
    }
  }
}
@media (min-width: 960px) {
  .side_tab {
    position: sticky;
    top: 20px;
  }
}
/* スマホ・タブレット用ドロワーメニュー */
.page_nav_wrapper {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 50;
  overflow: hidden;
  pointer-events: none;
}
.home_link a {
  display: inline-flex;
  align-items: center;
  gap: 1em;
  letter-spacing: 0.15em;
  margin: 0 0 3em 0;
  & svg {
    width: 1.2em;
    height: 1.2em;
    fill: var(--nav-color);
  }
}
.drawer_nav {
  padding: 1.75em 0 5em;
  width: 100%;
  height: 100vh;
  overflow-y: auto;
  background: var(--nav-bg);
  transform: translateY(-100vh);
  transition: 1s;
  pointer-events: all;
  & a {
    color: var(--nav-color);
  }
  .c_nav {
    display: flex;
    align-items: center;
    column-gap: 0.5em;
    .en {
      font-size: 1.25em;
      font-weight: 500;
      letter-spacing: 0.1em;
      text-transform: uppercase;
    }
    .jp {
      font-size: 0.9375em;
    }
  }
  & li {
    margin: 0.5em 0;
  }
}
@media (min-width: 740px) {
  .drawer_nav {
    width: min(64%, 460px);
    margin: 0 auto;
    padding: 3em 0 5em;
  }
}
.drawer_nav.is-open {
  transform: translateY(0);
}
.nav_onlineshop {
  padding: 0.5em 0 0.75em 1em;
  & > div a {
    font-weight: 500;
    font-size: 1.125em;
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
  }
  & > div a svg {
    width: 1em;
    transform: translateY(-0.1em);
  }
  & ul {
    display: flex;
    column-gap: 1.5em;
    flex-wrap: wrap;
    padding: 0 0 0 1em;
    font-size: 0.9375em;
    & li {
      margin: 0.25em 0;
    }
    & a {
      text-decoration: underline;
      text-underline-offset: 3px;
    }
  }
}
.menu_sns {
  display: flex;
  align-items: center;
  gap: 1.5em;
  margin: 1em 0 0 0;
  & a {
    display: block;
  }
  & img {
    width: 2.2em;
  }
}
.nav_button {
  position: fixed;
  right: 20px;
  top: 5px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  z-index: 10;
  pointer-events: all;
  & button {
    width: 3.125em;
    height: 4em;
    position: relative;
    z-index: 101;
    color: #fff;
    & span:not(.text) {
      position: absolute;
      left: 0;
      width: 100%;
      height: 1px;
      background: #fff;
      transform-origin: center center;
      transition-duration: 1s;
      transition-property: -webkit-transform;
      transition-property: transform;
      transition-property: transform, -webkit-transform;
      transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
    }
    & span:not(.text):first-child {
      transform: translateY(-7px);
    }
    & span:not(.text):nth-of-type(3) {
      transform: translateY(7px);
    }
    & span.text {
      position: absolute;
      top: 80%;
      left: calc(50% - 1.6em);
      font-size: 0.625em;
      letter-spacing: 0.1em;
      font-weight: 600;
    }
  }
}

.nav_button.is-open button {
  & span:not(.text):first-child {
    transform: translateY(0px) rotate(-30deg);
  }
  & span:not(.text):nth-of-type(2) {
    transform: scale(0);
  }
  & span:not(.text):nth-of-type(3) {
    transform: translateY(0px) rotate(30deg);
  }
}
@media (max-width: 739px) {
  .nav_button button {
    color: var(--base-color);
    transition: 0.5s;
    & span:not(.text) {
      background: var(--base-color);
    }
  }
  .nav_button.light button {
    color: #fff;
    transition: 0.5s;
    & span:not(.text) {
      background: #fff;
    }
  }
  .nav_button.is-open button {
    color: var(--nav-color);
    & span:not(.text) {
      background: var(--nav-color);
    }
  }
}
.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 49;
  pointer-events: none;
}
.overlay.is-open {
  pointer-events: all;
}
@media (min-width: 960px) {
  .page_nav_wrapper,
  .overlay {
    display: none;
  }
}
.loader {
  width: 100%;
  height: 100vh;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none;
  position: fixed;
  transition: 0.5s;
  z-index: 51;
  .loading_anime {
    animation: roast 6s ease infinite;
  }
  .move_beans {
    animation: bounce 2s ease infinite;
    width: 2em;
    & svg {
      width: 2em;
    }
  }
}
.loader.loaded {
  opacity: 0;
}
@keyframes roast {
  0% {
    color: #cec084;
  }
  33% {
    color: #bf8755;
  }
  66% {
    color: #884d1e;
  }
  100% {
    color: #3a1a04;
  }
}
@keyframes bounce {
  0%,
  20%,
  50%,
  80%,
  100% {
    transform: translateY(0) rotate(0);
  }
  40% {
    transform: translateY(20px) rotate(360deg);
  }
  60% {
    transform: translateY(15px);
  }
}