.header {
  position: fixed;
  width: 100%;
  padding: calc(15 * var(--u));
  top: 0;
  right: 0;
  left: 0;
  z-index: 99;
  transform: translateY(0);
  transition: opacity 0.3s ease, visibility 0.3s, transform 0.5s ease;
}

.header.header-sub {
  background: var(--white);
}

@media screen and (min-width: 48rem) {
  .header {
    padding: calc(30 * var(--u));
  }
}

.header.is-color {
  opacity: 1;
  visibility: visible;
  background: var(--white);
}

.header.is-hidden {
  opacity: 0;
  visibility: hidden;
  transform: translateY(-100%);
}

.header-container {
  z-index: 2
}

.header-content .header-content__pc {
  display: none
}

.header-content__sp {
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease, visibility 0.5s;
}

.header-content__sp.header-content__sp-sub {
  opacity: 1;
  visibility: visible;
}

@media screen and (min-width: 64rem) {
  .header-content__sp {
    opacity: 1;
    visibility: visible;
  }
}

.logo-wrap {
  display: contents;
}

.logo-link {
  width: calc(113 * var(--u));
  flex-shrink: 0;
}

@media screen and (min-width: 48rem) {
  .logo-link {
    width: calc(200 * var(--u));
  }
}

.sp-only {
  display: flex;
  align-items: center
}

.sp-only>div+div {
  margin-left: 1.875rem
}

.sp-btn {
  font-family: var(--font-inter);
  font-size: calc(12 * var(--u));
  font-weight: 700;
  display: inline-block;
  position: relative;
  width: calc(123 * var(--u));
  background: var(--black);
  color: var(--white);
  text-align: center;
  border-radius: 50vh;
  text-transform: capitalize;
  line-height: 1;
  letter-spacing: 0.08em;
  padding: calc(11 * var(--u)) calc(5 * var(--u));
}

.sp-btn::after {
  content: '';
  position: absolute;
  display: inline-block;
  width: calc(7 * var(--u));
  height: calc(7 * var(--u));
  top: 50%;
  left: 15px;
  transform: translateY(-50%);
  background: var(--oragne);
  border-radius: 50%;
}

@media screen and (min-width: 48rem) {
  .sp-btn {
    font-size: max(calc(16 * var(--u)), 12ppx);
    width: calc(200 * var(--u));
    padding: calc(13 * var(--u)) calc(5 * var(--u));
  }
}

.header-content__link {
  display: none;
}

@media screen and (min-width: 64rem) {
  .header-content__link {
    display: flex;
  }
}

.header .header-content__link ul li a {
  font-weight: 500;
  font-size: 1rem;
  display: inline-block;
  letter-spacing: 0.1em;
}

.header .header-content__link p {
  font-size: .75rem;
  margin-top: 4rem;
}

@media screen and (max-width:1023px) {
  .header-subttl{
    display: none;
  }
}

@media (min-width: 64rem) {
  .header {
    width: 100%;
    padding: calc(20 * var(--u)) ;
    margin: 0 auto;
    display: block;
  }

  .header_inner {
    max-width: 1538px;
    margin: 0 auto;
    width: 100%;
  }

  .header-content {
    display: flex;
    align-items: center;
    justify-content: space-between
  }

  .header-content__sp .sp-only {
    display: none
  }

  .header .header-content__link {
    position: relative;
    transform: translateX(0);
    width: auto;
    height: auto;
    padding: 0;
    background: transparent;
    overflow: visible;
    display: none;
  }

  .header .header-content__link::before {
    content: none
  }

  .logo-wrap {
    display: flex;
    align-items: center;
    gap: calc(5* var(--u));
    max-width: calc(461 * var(--u));
    width: 100%;
    flex-shrink: 0;
  }

  .logo-link {
    display: flex;
    align-items: center;
    width: calc(150 * var(--u));
    flex-shrink: 0;
  }

  .header-subttl {
    font-size: calc(11 * var(--u));
    letter-spacing: 0.04em;
    font-weight: 700;
    white-space: nowrap;
  }

  .nav-menu ul {
    display: flex;
    gap: 0;
  }

  .header .header-content__link ul li+li {
    margin-top: 0;
  }

  .header .header-content__link ul li a {
    font-size: calc(16 * var(--u));
    transition: all 0.3s ease;
    padding: calc(10 * var(--u)) calc(7 * var(--u));
    white-space: nowrap;
  }

  .header .header-content__link p {
    display: none;
    opacity: 0;
    visibility: hidden;
  }

  .header-content .header-content__pc {
    display: block;
  }

  .header-content .header-content__pc a {
    font-family: var(--font-inter);
    font-weight: 700;
    display: inline-block;
    position: relative;
    width: calc(123 * var(--u));
    background: var(--black);
    color: var(--white);
    text-align: center;
    border-radius: 50vh;
    text-transform: capitalize;
    line-height: 1;
    letter-spacing: 0.08em;
    padding: calc(11 * var(--u)) calc(5 * var(--u));
  }

  .header-content .header-content__pc a::after {
    content: '';
    position: absolute;
    display: inline-block;
    width: calc(7 * var(--u));
    height: calc(7 * var(--u));
    top: 50%;
    left: calc(15 * var(--u));
    transform: translateY(-50%);
    background: var(--oragne);
    border-radius: 50%;
  }
}


@media (any-hover: hover) {
  .header-content .header-content__pc a:hover {
    color: var(--white);
    background: var(--oragne);
  }
  .header-content .header-content__pc a:hover::after {
    background: var(--white);
  }

  .header .header-content__link ul li a:hover {
    color: var(--oragne);
  }
}

@media (min-width:64rem) {
  .header-content .header-content__pc a {
    width: calc(130 * var(--u));
  }
}

@media screen and (min-width: 64rem) {
  .header .header-content__link {
    display: flex;
    align-items: center;
    gap: calc(30 * var(--u));
  }
}
@media screen and (min-width: 74rem) {
  .logo-wrap {
    gap: calc(18* var(--u));
  }
}

@media (min-width:74rem) {
  .header-content .header-content__pc a {
    width: calc(154 * var(--u));
  }
}

@media (min-width:87.5rem) {
  .nav-menu ul {
    display: flex;
    gap: calc(18 * var(--u));
  }
}