@charset "UTF-8";
/*
Theme Name: Theme name
Author: Author
Author URI:
*/
html {
  font-size: calc(100vw / 1300 * 14);
}
@media (1200px < width) {
  html {
    font-size: 14px;
  }
}
@media (width <= 768px) {
  html {
    font-size: calc(100vw / 375 * 14);
  }
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

pre {
  white-space: pre;
}

ul {
  list-style: none;
}

/********************************************
* Layout
********************************************/
/* Header */
.l-header {
  background-color: #eee;
  padding: 0 30px;
  position: relative;
}
.l-header__inner {
  margin: 0 auto;
  min-height: 250px;
}
.l-menu_trigger {
  position: absolute;
  top: 15px;
  right: 20px;
  width: 40px;
  margin: 0 auto;
  height: 30px;
}
.l-menu_trigger__bar {
  display: inline-block;
  transition: all 0.4s;
  box-sizing: border-box;
  width: 100%;
  position: absolute;
  left: 0;
  height: 2px;
  display: inline-block;
  background-color: #333;
  border-radius: 4px;
}
.l-menu_trigger__bar:nth-of-type(1) {
  top: 0px;
}
.l-menu_trigger__bar:nth-of-type(2) {
  top: 50%;
}
.l-menu_trigger__bar:nth-of-type(3) {
  top: 100%;
}
.l-menu_trigger__bar:nth-of-type(4) {
  background: none;
  bottom: 0;
}
body.is-menu_open .l-menu_trigger span:nth-of-type(1) {
  -webkit-transform: translateY(15px) rotate(-45deg);
  transform: translateY(15px) rotate(-45deg);
}
body.is-menu_open .l-menu_trigger span:nth-of-type(2) {
  opacity: 0;
}
body.is-menu_open .l-menu_trigger span:nth-of-type(3) {
  -webkit-transform: translateY(-15px) rotate(45deg);
  transform: translateY(-15px) rotate(45deg);
}

/* Footer */
.l-footer {
  background-color: #eee;
  padding: 0 30px;
}
.l-footer__inner {
  margin: 0 auto;
  min-height: 250px;
}
/* Sidebar */
/********************************************
* Form
********************************************/
input[type=email],
input[type=text] {
  width: 500px;
  max-width: 100%;
  padding: 5px;
  height: 35px;
}

textarea {
  width: 500px;
  max-width: 100%;
  height: 250px;
}

input[type=submit] {
  width: 300px;
  height: 35px;
  max-width: 100%;
  border: 1px solid #ccc;
}

/********************************************
* Wordpress
********************************************/
/* Media */
.size-auto,
.size-full,
.size-large,
.size-medium,
.size-thumbnail {
  max-width: 100%;
  height: auto;
}

.aligncenter {
  display: block;
  margin: 0 auto;
}

.alignright {
  float: right;
}

.alignleft {
  float: left;
}

/* Contact Form */
.wpcf7 .wpcf7-not-valid-tip {
  display: none;
}
.wpcf7 .wpcf7-not-valid {
  background: pink;
}
.wpcf7 .wpcf7-response-output {
  margin: 10px 0 0;
  padding: 8px 35px 8px 14px;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
}
.wpcf7 .wpcf7-validation-errors {
  color: #b94a48;
  background-color: #f2dede;
  border: 1px solid #eed3d7;
}
.wpcf7 .wpcf7-mail-sent-ok {
  color: #3a87ad;
  background-color: #d9edf7;
  border: 1px solid #bce8f1;
}

/********************************************
* Component
********************************************/
.c-inner {
  max-width: 85.7142857143rem;
  padding: 4.2857142857rem 0 8.5714285714rem;
  margin: 0 auto;
}
@media (width <= 768px) {
  .c-inner {
    width: 100%;
    padding: 2.8571428571rem 1.4285714286rem;
  }
}

.c-item-list:not(:last-of-type){
    margin-bottom: 7rem;
}
@media (width <= 768px) {
  .c-item-list:not(:last-of-type){
      margin-bottom: 5rem;
  }
}
.c-item-list__item {
  display: flex;
  justify-content: space-between;
}
@media (width <= 768px) {
  .c-item-list__item {
    flex-wrap: wrap;
  }
}
.c-item-list__item:not(:last-of-type) {
  margin-bottom: 10.7142857143rem;
}
@media (width <= 768px) {
  .c-item-list__item:not(:last-of-type) {
    margin-bottom: 4.2857142857rem;
  }
}
.c-item-list__item:nth-of-type(2n) .c-item-list__thumb {
  order: 2;
}
@media (width <= 768px) {
  .c-item-list__item:nth-of-type(2n) .c-item-list__thumb {
    order: 1;
  }
}
.c-item-list__item:nth-of-type(2n) .c-item-list__text {
  order: 1;
}
@media (width <= 768px) {
  .c-item-list__item:nth-of-type(2n) .c-item-list__text {
    order: 2;
  }
}
.c-item-list__thumb {
  width: 51.4285714286rem;
}
@media (width <= 768px) {
  .c-item-list__thumb {
    width: 100%;
    margin-bottom: 1.4285714286rem;
  }
}
.c-item-list__text {
  width: 29.2857142857rem;
  position: relative;
}
@media (width <= 768px) {
  .c-item-list__text {
    width: 100%;
  }
}
.c-item-list__title {
  font-weight: 700;
  font-size: 1.8571428571rem;
  margin-bottom: 3.2142857143rem;
}
@media (width <= 768px) {
  .c-item-list__title {
    font-size: 1.4285714286rem;
    margin-bottom: 0.7142857143rem;
    text-align: center;
  }
}
.c-item-list__p {
  font-size: 1.7142857143rem;
  margin-bottom: 1em;
}
@media (width <= 768px) {
  .c-item-list__p {
    font-size: 1rem;
  }
}

.c-btn {
  background: #fff;
  text-align: center;
  border-radius: 1.4285714286rem;
}
@media (width <= 768px) {
  .c-btn {
    border-radius: 0.7142857143rem;
  }
}
.c-btn__link {
  display: block;
  font-size: 2.2857142857rem;
  font-weight: 700;
  line-height: 2;
}
@media (width <= 768px) {
  .c-btn__link {
    font-size: 1.4285714286rem;
  }
}

.c-menu-list {
  display: flex;
  gap: 2.1428571429rem;
  justify-content: center;
}
@media (width <= 768px) {
  .c-menu-list {
    gap: 2.1428571429rem;
    flex-wrap: wrap;
  }
}
@media (width <= 768px) {
  .c-menu-list__item {
    width: calc(50% - 1.0714285714rem);
  }
}

.c-title {
  font-size: 6.2142857143rem;
  text-align: center;
  font-weight: 700;
}
@media (width <= 768px) {
  .c-title {
    font-size: 2rem;
  }
}

.c-catch {
  font-size: 3rem;
  text-align: center;
  margin-bottom: 9.2857142857rem;
}
@media (width <= 768px) {
  .c-catch {
    font-size: 1.1428571429rem;
    margin-bottom: 2.8571428571rem;
  }
}

/********************************************
* Project
********************************************/
section {
  position: relative;
}

a {
  text-decoration: none;
  transition: 0.3s;
}
a:hover {
  opacity: 0.8;
}

.c-btn {
  width: 100%;
  max-width: 29.2857142857rem;
  position: absolute;
  bottom: 0;
  margin: 0 auto;
}
@media (width <= 768px) {
  .c-btn {
    max-width: inherit;
    position: static;
  }
}

.p-mv {
  max-height: 71.4285714286rem;
}
.p-mv__text {
  background: rgba(255, 255, 255, 0.8);
  padding: 4.2857142857rem 2.8571428571rem;
  position: absolute;
  width: 37.1428571429rem;
  left: 4.2857142857rem;
  top: 7.1428571429rem;
  z-index: 1;
}
@media (width <= 768px) {
  .p-mv__text {
    position: static;
    padding: 2.8571428571rem 1.4285714286rem;
    width: 100%;
    left: 1.4285714286rem;
    bottom: 7.1428571429rem;
  }
}
.p-mv__title {
  font-size: 4.1428571429rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 2.1428571429rem;
}
@media (width <= 768px) {
  .p-mv__title {
    font-size: 2.5714285714rem;
  }
}
.p-mv__p {
  font-size: 1.8571428571rem;
  line-height: 1.8;
}
@media (width <= 768px) {
  .p-mv__p {
    font-size: 1rem;
  }
}
.p-mv__list {
  overflow: hidden;
  position: relative;
}
.p-mv__list-item {
  height: 71.4285714286rem;
}
@media (width <= 768px) {
  .p-mv__list-item {
    height: auto;
  }
}
.p-mv .slick-dotted.slick-slider {
  margin-bottom: 0;
}
.p-mv .slick-dots {
  position: absolute;
  bottom: 2.8571428571rem;
}
@media (width <= 768px) {
  .p-mv .slick-dots {
    bottom: 1.4285714286rem;
  }
}
.p-mv .slick-dots li button:before {
  font-size: 1.4285714286rem;
}
@media (width <= 768px) {
  .p-mv .slick-dots li button:before {
    font-size: 1.4285714286rem;
  }
}
.p-mv .slick-dots li {
  margin: 0 0.7142857143rem;
}
@media (width <= 768px) {
  .p-mv .slick-dots li {
    margin: 0 0.7142857143rem;
  }
}
.p-mv .slick-dots li button:before {
  opacity: 0.4;
  color: #fff;
}
.p-mv .slick-dots li.slick-active button:before {
  opacity: 1;
}
@media (width <= 768px) {
  .p-mv .slick-dotted.slick-slider {
    margin-bottom: 0;
  }
}

.p-menu {
  background: #b96372;
  color: #fff;
  padding-bottom: 5.7142857143rem;
  z-index: 1;
}
@media (width <= 768px) {
  .p-menu {
    padding-bottom: 5.7142857143rem;
  }
}
.p-menu__ghost {
  animation: swing 6s infinite;
  width: 8.0714285714rem;
  position: absolute;
  bottom: -0.2142857143rem;
  left: 3.5714285714rem;
  bottom: -0.2142857143rem;
  left: 3.5714285714rem;
}
@media (width <= 768px) {
  .p-menu__ghost {
    width: 5.7142857143rem;
  }
}

.p-halloween {
  background-size: auto auto;
  background-color: #af87bb;
  background-image: repeating-linear-gradient(-60deg, transparent, transparent 4.2857142857rem, #b28fc0 4.2857142857rem, #b28fc0 6.4285714286rem);
  color: #fff;
  overflow: hidden;
}
@media (width <= 768px) {
  .p-halloween {
    background-image: repeating-linear-gradient(-60deg, transparent, transparent 2.8571428571rem, #b28fc0 2.8571428571rem, #b28fc0 4.2857142857rem);
  }
}
.p-halloween .c-btn__link {
  color: #af87bb;
}
.p-halloween__spider {
  width: 16.3571428571rem;
  animation: swing-tate 4s infinite;
  position: absolute;
  top: -17.8571428571rem;
  right: 10.3571428571rem;
}
@media (width <= 768px) {
  .p-halloween__spider {
    width: 10rem;
    right: -0.7142857143rem;
    top: -17.1428571429rem;
  }
}
.p-halloween__deer {
  animation: swing 6s infinite;
  width: 8.1428571429rem;
  position: absolute;
  bottom: -0.2142857143rem;
  left: 3.5714285714rem;
}
@media (width <= 768px) {
  .p-halloween__deer {
    width: 7.1428571429rem;
    left: 2.8571428571rem;
  }
}

.p-christmas {
  background: url(../images/event-wear/c-bg.png);
  color: #fff;
  padding-bottom: 5.7142857143rem;
}
.p-christmas .c-btn__link {
  color: #317e4e;
}
.p-christmas__snake {
  animation: swing 6s 2s infinite;
  width: 8.3571428571rem;
  position: absolute;
  bottom: 0;
  left: 3.5714285714rem;
}
@media (width <= 768px) {
  .p-christmas__snake {
    width: 5.7142857143rem;
    left: 2.8571428571rem;
  }
}

.p-newyear {
  background: url(../images/event-wear/n-bg.png);
  color: #fff;
  padding-bottom: 5.7142857143rem;
}
.p-newyear .c-btn__link {
  color: #c7930b;
}

.p-back {
  background: #b96372;
  color: #fff;
}
.p-back .c-inner {
  padding-bottom: 4.2857142857rem;
}
@media (width <= 768px) {
  .p-back .c-inner {
    padding-bottom: 2.8571428571rem;
  }
}
.p-back .c-btn {
  position: static;
}
.p-back .c-btn__link {
  color: #b96372;
}

@keyframes swing {
  0% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(21.4285714286rem);
  }
  100% {
    transform: translateX(0);
  }
}
@media (width <= 768px) {
  @keyframes swing {
    0% {
      transform: translateX(0);
    }
    50% {
      transform: translateX(14.2857142857rem);
    }
    100% {
      transform: translateX(0);
    }
  }
}
@keyframes swing-tate {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(5.7142857143rem);
  }
  100% {
    transform: translateY(0);
  }
}
@media (width <= 768px) {
  @keyframes swing-tate {
    0% {
      transform: translateY(0);
    }
    50% {
      transform: translateY(4.2857142857rem);
    }
    100% {
      transform: translateY(0);
    }
  }
}
/* Utilities */
.u-mt0 {
  margin-top: 0px;
}

.u-mb0 {
  margin-bottom: 0px;
}

.u-mt10 {
  margin-top: 10px;
}

.u-mb10 {
  margin-bottom: 10px;
}

.u-mt20 {
  margin-top: 20px;
}

.u-mb20 {
  margin-bottom: 20px;
}

.u-mt30 {
  margin-top: 30px;
}

.u-mb30 {
  margin-bottom: 30px;
}

.u-mt40 {
  margin-top: 40px;
}

.u-mb40 {
  margin-bottom: 40px;
}

.u-mt50 {
  margin-top: 50px;
}

.u-mb50 {
  margin-bottom: 50px;
}

.u-mt60 {
  margin-top: 60px;
}

.u-mb60 {
  margin-bottom: 60px;
}

.u-mt70 {
  margin-top: 70px;
}

.u-mb70 {
  margin-bottom: 70px;
}

.u-mt80 {
  margin-top: 80px;
}

.u-mb80 {
  margin-bottom: 80px;
}

.u-mt90 {
  margin-top: 90px;
}

.u-mb90 {
  margin-bottom: 90px;
}

.u-mt100 {
  margin-top: 100px;
}

.u-mb100 {
  margin-bottom: 100px;
}

.u-pc {
  display: block;
}
.u-pc--inline {
  display: inline;
}
.u-pc--iblock {
  display: inline-block;
}
.u-pc--table {
  display: table;
}

.u-sp {
  display: none;
}
.u-sp--inline {
  display: none;
}
.u-sp--iblock {
  display: none;
}
.u-sp--table {
  display: none;
}

.u-ofit {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.u-pos--absolute {
  position: absolute;
}
.u-pos--fixed {
  position: fixed;
}
.u-pos--relative {
  position: relative;
}

.u-text--default {
  font-family: "メイリオ", Meiryo, Verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;
}
.u-text--mincho {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.u-text--center {
  text-align: center;
}
.u-text--left {
  text-align: left;
}
.u-text--right {
  text-align: right;
}
.u-text--thin {
  font-weight: 100;
}
.u-text--extra-light {
  font-weight: 200;
}
.u-text--light {
  font-weight: 300;
}
.u-text--regular {
  font-weight: 400;
}
.u-text--medium {
  font-weight: 500;
}
.u-text--semi-bold {
  font-weight: 600;
}
.u-text--bold {
  font-weight: 700;
}
.u-text--extra-bold {
  font-weight: 800;
}
.u-text--black {
  font-weight: 900;
}
.u-text--big {
  font-size: 1.4em;
}
.u-text--regular {
  font-size: 1em;
}
.u-text--small {
  font-size: 0.8em;
}

.u-text_ellipsis {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  background-color: #ccc;
  line-height: 1.5;
}
.u-text_ellipsis--multiline {
  white-space: normal;
  max-height: 3em;
  position: relative;
}
.u-text_ellipsis--multiline::after {
  content: "…";
  position: absolute;
  display: block;
  bottom: 0;
  right: 0;
  background-color: #ccc;
}
.u-text_ellipsis--line2 {
  max-height: 3em;
}
.u-text_ellipsis--line3 {
  max-height: 4.5em;
}
.u-text_ellipsis--line4 {
  max-height: 6em;
}
.u-text_ellipsis--line5 {
  max-height: 7.5em;
}

.u-color__yellow {
  color: yellow;
}

.u-fade-in {
  opacity: 0;
  transform: translateY(2.1428571429rem);
  transition: 0.8s;
}
@media (width <= 768px) {
  .u-fade-in {
    transform: translateY(2.1428571429rem);
  }
}
.u-fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (width <= 768px) {
  .u-pc {
    display: none;
  }
  .u-pc--inline {
    display: none;
  }
  .u-pc--iblock {
    display: none;
  }
  .u-pc--table {
    display: none;
  }

  .u-sp {
    display: block;
  }
  .u-sp--inline {
    display: inline;
  }
  .u-sp--iblock {
    display: inline-block;
  }
  .u-sp--table {
    display: table;
  }
}