@charset "utf-8";

/*========================================================================*\

$body

\*========================================================================*/

body,
html {
  height: 100%;
}

html {
  /*scroll-padding-top: 100px;*/
}

body {
  font-family: var(font-family);
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0;
}

#wrapper {
  display: grid;
  z-index: 1;
  position: relative;
  grid-template-areas: "left main right";
  grid-template-columns: 1fr 34.375rem 1fr;
  grid-template-rows: 1fr;
  margin: 0 auto;
  background: #9cc930;
}

#wrapper::before,
#wrapper::after {
  content: "";
  display: block;
  z-index: -1;
  position: sticky;
  top: 0;
  width: 100%;
  height: 100%;
  max-height: 100vh;
}

#wrapper::before {
  grid-area: left;
  background-image: url(../images/bg_left_02.png), url(../images/bg_left.png);
  background-repeat: no-repeat;
  background-position:
    left top,
    left bottom;
  background-size: 50%, contain;
}

#wrapper::after {
  grid-area: right;
  background-image: url(../images/bg_right_02.png), url(../images/bg_right.png);
  background-repeat: no-repeat;
  background-position:
    right top,
    right bottom;
  background-size: clamp(100px, 50%, 300px), contain;
}

#wrapper::after {
  grid-area: right;
  background-image: url(../images/bg_right_02.png), url(../images/bg_right.png);
  background-repeat: no-repeat;
  background-position:
    right top,
    right bottom;
  background-size: clamp(100px, 50%, 300px), contain;
}

/*========================================================================*\

$Co

\*========================================================================*/

#Co {
  background: #ffffff;
}

/*========================================================================*\

$header

\*========================================================================*/

header h1 {
  width: 240px;
  text-align: center;
  margin: 0 auto;
  padding: 15px 0;
}

header p {
  background: #008d92;
  color: #ffffff;
  text-align: center;
  font-weight: 600;
}

/*========================================================================*\

$topmain

\*========================================================================*/

#topmain {
  margin-bottom: 30px;
}

#topmain h2 {
  padding: 30px 70px 20px 70px;
}

/*========================================================================*\

$Co

\*========================================================================*/

#Co .ankerBox {
  padding: 0 20px;
  margin-bottom: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#Co .ankerBox li {
  width: 48.5%;
}

#Co .ankerBox li a:hover {
  opacity: 0.7;
}

#Co .catch {
  text-align: center;
  color: #008d92;
  line-height: 1.4;
  font-weight: 700;
  margin-bottom: 50px !important;
  font-size: 20px;
}

#Co .storeBox h3 {
  text-align: center;
  margin-bottom: 20px;
}

#Co .storeBox h4 {
  font-weight: 700;
  color: #45bdcf;
  font-size: 20px;
}

#Co .storeBox a:hover {
  opacity: 0.7;
}

#Co .storeBox:last-child h4 {
  color: #f1979a;
}

#Co .storeBox .innerBox {
  background: url(../images/bg_18.png) repeat 0 0;
  padding: 20px;
  margin-bottom: 50px;
  background-size: contain;
}

#Co .storeBox:last-child .innerBox {
  background: url(../images/bg_19.png) repeat 0 0;
  padding: 20px;
  margin-bottom: 0;
  background-size: contain;
}

#Co .box02 li:nth-child(n + 3) {
  margin: 0.625rem 0 0 0;
}

/*========================================================================*\

$footer

\*========================================================================*/

footer {
  background: #009d58;
}

#footerInner {
  padding: 1.25rem 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

#footerInner p {
  line-height: 1;
  font-size: 0.75rem;
  color: #ffffff;
}

/*========================================================================*\

$btnTop

\*========================================================================*/

/* ページトップボタン */
#btnTop {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 60px;
  height: 60px;
  background: #000000;
  border-radius: 50%;
  z-index: 20000;
}

/* アクティブ状態 */
#btnTop.active {
  opacity: 1;
  visibility: visible;
}

/* 内部リンク */
#btnTop a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  text-decoration: none;
}

/* 上矢印 */
#btnTop a::before {
  content: "";
  position: absolute;
  top: 45%;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 10px;
  height: 10px;
  border-left: 4px solid #ffffff;
  border-top: 4px solid #ffffff;
}

/* レスポンシブ */
@media screen and (max-width: 767px) {
  #btnTop {
    bottom: 10px;
    width: 50px;
    height: 50px;
  }

  #btnTop a::before {
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
  }
}
