@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: #9ccc7b;
}

#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: #d1edfb;
}

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

$topmain

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

#topmain {
  background: url(../images/main_bg.png) no-repeat center bottom #d1edfb;
  padding: 30px 0 0;
  background-size: contain;
}

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

#topmain .btn {
  width: 100%;
  margin: 2.5rem auto 0 auto;
  padding: 0 0 300px 0;
}

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

$btnBox

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

#Co .enqueteBox {
  background: #ffffff;
  padding: 30px 70px;
  margin-bottom: 30px;
}

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

$Co

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

#Co .sectionInner {
  padding: 40px 30px;
}

#Co .shopBox {
  margin-bottom: 50px;
  padding: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}

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

$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);
  }
}

#Co .btn {
  margin: 3.125rem auto 0 auto;
  width: 80%;
}

#Co .btn a {
  background: #0081c5;
  font-size: 1.625rem;
  padding: 12px;
  color: #ffffff;
  font-weight: 700;
}

#Co .btn a:after {
  border-right: solid 2px #ffffff;
  border-top: solid 2px #ffffff;
  height: 12px;
  right: 20px;
  width: 12px;
}
