@charset "utf-8";
/* *************************************
hamburger
************************************* */
.hamburger {
  width: fit-content;
  text-align: center;
}

@media (any-hover: hover) {
  .hamburger:hover {
    cursor: pointer;
  }
}

.hamburger__btn {
  padding: calc(8 * var(--rem));
}

.hamburger__btn span {
  display: block;
  width: calc(32 * var(--rem));
  height: calc(2 * var(--rem));
  background-color: var(--black);
  transition: 0.3s ease;
}

.hamburger__btn span:nth-child(2) {
  margin: calc(8 * var(--rem)) 0;
}

/* is-open */
.hamburger.is-open .hamburger__btn span:nth-child(1) {
  transform: translateY(calc(10 * var(--rem))) rotate(45deg);
}
.hamburger.is-open .hamburger__btn span:nth-child(2) {
  opacity: 0;
}
.hamburger.is-open .hamburger__btn span:nth-child(3) {
  transform: translateY(calc(-10 * var(--rem))) rotate(-45deg);
}

.hamburger__menu,
.hamburger__close {
  text-transform: uppercase;
  font-size: calc(12 * var(--rem));
  font-weight: bold;
  font-family: var(--jp);
  line-height: 1;
}

.hamburger.is-open .hamburger__menu {
  display: none;
}

.hamburger__close {
  display: none;
}

.hamburger.is-open .hamburger__close {
  display: block;
}

/* *************************************
page-hed
************************************* */
.page-head {
  position: relative;
  height: calc(250 * var(--rem));
  margin-block-start: calc(80 * var(--rem));
}

.page-head::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background-color: #00000030;
  position: absolute;
  inset: 0;
}

.page-head__img {
  height: inherit;
}

.page-head__img img {
  aspect-ratio: 1440/250;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-head__title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  display: grid;
  row-gap: calc(8 * var(--rem));
  width: 100%;
  padding: calc(16 * var(--rem));
}

.page-head__title-jp {
  font-size: calc(40 * var(--rem));
  line-height: 1.5;
  letter-spacing: 0.05em;
  text-align: center;
  color: var(--white);
  @media (width < 768px) {
    font-size: calc(30 * var(--rem));
  }
}

.page-head__title-en {
  font-size: calc(20 * var(--rem));
  font-weight: bold;
  line-height: 1;
  text-align: center;
  text-wrap: balance;
  color: var(--white);
  text-transform: uppercase;
  @media (width < 768px) {
    font-size: calc(16 * var(--rem));
  }
}

/* *************************************
btn1
************************************* */
.btn1 {
  display: inline-block;
  background-color: var(--sub);
  min-width: calc(160 * var(--rem));
  padding: calc(10 * var(--rem));
  text-align: center;
  border-radius: 100vmax;
  color: var(--white);
}

/* *************************************
btn2
************************************* */
.btn2 {
  display: inline-grid;
  grid-template-columns: 1fr auto 1fr;
  column-gap: calc(8 * var(--rem));
  align-items: center;
  background-color: var(--sub);
  min-width: calc(160 * var(--rem));
  padding: calc(10 * var(--rem)) calc(16 * var(--rem));
  border-radius: 100vmax;
  color: var(--white);
}

.btn2::before {
  content: '';
}

.btn2::after {
  content: '';
  display: block;
  width: calc(16 * var(--rem));
  aspect-ratio: 1;
  background: url(../images/common/btn-arrow-w.svg) no-repeat center / contain;
  justify-self: end;
  transition: transform 0.3s ease;
}

@media (any-hover: hover) {
  .btn2:hover::after {
    transform: translateX(4px);
  }
}
