@charset "UTF-8";
@import url(/css/root.css);

.sp-menu-btn {
  width: 5rem;
  aspect-ratio: 1;
}
.sp-menu-btn-wrp {
  top: 2rem;
  right: 2rem;
  bottom: auto;
  left: auto;
  background: var(--color-main);
  border-radius: 50%;
  cursor: pointer;
}
.sp-menu-btn-wrp:has(.sp-menu-btn[aria-expanded="true"]) {
  background: none;
  top: 2.25rem;
  right: 1.25rem;
}
.sp-menu-btn-line {
  width: 2.7rem;
  height: clamp(1px, 0.1rem, 2px);
  background: #fff;
}
.sp-menu-btn-line--top {
  top: 32%;
}
.sp-menu-btn-line--bottom {
  top: 67%;
}
.sp-menu-btn__text {
  color: #fff;
  font-size: 1rem;
}
.sp-menu-btn[aria-expanded="true"] {
  width: 4.5rem;
}
.sp-menu-btn[aria-expanded="true"] .sp-menu-btn-line {
  width: 100%;
  background: var(--color-text);
}

/* Drawer
------------------------------------ */
#drawer-nav {
  padding: 2rem 2.5rem;
  background-color: var(--color-bg);
}
#drawer-nav .drawer-logo {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: auto;
  margin-bottom: 2.5rem;
}
#drawer-nav .drawer-logo img {
  height: 5rem;
  aspect-ratio: 11/10;
  -o-object-fit: cover;
  object-fit: cover;
}
#drawer-nav #nav .drawer-item {
  font-size: var(--font-size-base);
  font-family: var(--font-family-kaku);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-base);
  margin-bottom: 3.2rem;
}
#drawer-nav #nav .drawer-item:last-of-type {
  margin-bottom: 0;
}
#drawer-nav #nav .drawer-link {
  margin-block: calc((1em - 1lh) / 2);
  letter-spacing: 0.1em;
  transition: all 0.15s ease-out;
}
#drawer-nav #nav .drawer-link:hover,
#drawer-nav #nav .drawer-link[aria-current="page"] {
  color: var(--color-main);
}
#drawer-nav #nav .drawer-link--dropdown {
  padding: 15px 12% 15px 0;
}
@media screen and (max-width: 450px) {
  #drawer-nav #nav .drawer-link--dropdown {
    padding: 3.33334vw 12% 3.33334vw 0;
  }
}
@media screen and (max-width: 360px) {
  #drawer-nav #nav .drawer-link--dropdown {
    font-size: 1.6rem;
    padding: 12px 12% 12px 0;
  }
}
#drawer-nav #nav .drawer-link--dropdown span {
  display: block;
}
#drawer-nav #nav .drawer-link--dropdown span:before {
  background: #000;
}
#drawer-nav #nav .drawer-link--dropdown span:after {
  background: #000;
}
#drawer-nav #nav .drawer-link[aria-current="page"] .drawer-text::after {
  opacity: 0 !important;
}
#drawer-nav #nav .drawer-dropdown {
  margin: 3% 0;
  padding-left: 4%;
  box-sizing: border-box;
}
> #drawer-nav #nav .drawer-dropdown > li__link:before {
  border-left: 1px solid #000;
  border-bottom: 1px solid #000;
}
> #drawer-nav #nav .drawer-dropdown > li__link span {
  padding: 0 0 0 5%;
}
.drawer-info {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: clamp(20px, 2rem, 40px) 1.6rem;
  padding-block: 2.5rem;
}

/*SNS 
---------------------------*/
.drawer-sns {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: clamp(20px, 2rem, 40px);
}
.drawer-sns-item {
  width: clamp(40px, 4rem, 80px);
}
.drawer-sns-item--mail a {
  position: relative;
}
.drawer-sns-item--mail a::before {
  content: "";
  -webkit-mask: url(../images/common/ic_mail.png) no-repeat center/contain;
  mask: url(../images/common/ic_mail.png) no-repeat center/contain;
  background-color: var(--color-main);
  position: absolute;
  inset: 0;
  z-index: 0;
}
.drawer-sns-item--mail a img {
  opacity: 0;
}
.drawer-sns-item a {
  display: block;
  aspect-ratio: 1;
  transition: all 0.3s ease-out;
}
.drawer-sns-item a:hover {
  opacity: 0.54;
}

/*電話番号
---------------------------*/
.drawer-tel {
  font-size: 2.4rem;
}

/*mail
---------------------------*/
