/* ===============================
   SP Menu Popup（表示制御：そのまま）
================================ */

.sp-menu-popup{
  position:fixed;
  top:0;
  right:0;
  width:50vw;            /* PC：右半分 */
  height:100vh;
  z-index:9999;
  opacity:0;
  pointer-events:none;
  transition:opacity .4s;
}

.sp-menu-popup.is-open{
  opacity:1;
  pointer-events:auto;
}

/* ※ズレ対策は「overflowを触らない方式」にしたので、body固定はしない */
body.is-sp-menu-open{
  overflow:visible;
}

/* ===============================
   SP Menu Popup（layout + base）
================================ */

/* backdrop は使わない（左側を覆わない） */
.sp-menu-popup__backdrop{
  display:none;
}

/* パネル本体（親が50vwなので100%でOK） */
.sp-menu-popup__panel{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  background:#FCFBF8;
  display:flex;
  flex-direction:column;
  padding:28px 40px 28px;
  box-sizing:border-box;
}

/* ==========================
   Header
========================== */
.sp-menu-popup__head{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  padding-top:52px;
}

/* 閉じるボタン（右上：白丸 / 線2本クロス赤） */
.sp-menu-popup__close{
  position:absolute;
  top:20px;
  right:0;
  width:70px;
  height:70px;
  border-radius:999px;

  /* 通常状態 */
  background:#FCFBF8;
  border:2px solid #1EA896;

  padding:0;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;

  transition:
    background-color 220ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.sp-menu-popup__close-icon{
  font-size:0;
  position:relative;
  width:24px;
  height:24px;
  line-height:0;
}

.sp-menu-popup__close-icon::before,
.sp-menu-popup__close-icon::after{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  width:30px;
  height:2px;

  /* 通常：×は緑 */
  background:#1EA896;

  transform-origin:center;
  transition:background-color 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.sp-menu-popup__close-icon::before{
  transform:translate(-50%, -50%) rotate(45deg);
}

.sp-menu-popup__close-icon::after{
  transform:translate(-50%, -50%) rotate(-45deg);
}

/* ===============================
   SP Menu Close Button : Astra 無効化 & 色固定
================================ */

/* すべての状態で色を固定 */
.sp-menu-popup__close,
.sp-menu-popup__close:hover,
.sp-menu-popup__close:focus,
.sp-menu-popup__close:active,
.sp-menu-popup__close:focus-visible {
  background: #FCFBF8;
  border-color: #1EA896;
  outline: none;
  box-shadow: none;
}

/* × の色も全状態で固定 */
.sp-menu-popup__close-icon::before,
.sp-menu-popup__close-icon::after,
.sp-menu-popup__close:hover .sp-menu-popup__close-icon::before,
.sp-menu-popup__close:hover .sp-menu-popup__close-icon::after,
.sp-menu-popup__close:focus .sp-menu-popup__close-icon::before,
.sp-menu-popup__close:focus .sp-menu-popup__close-icon::after,
.sp-menu-popup__close:active .sp-menu-popup__close-icon::before,
.sp-menu-popup__close:active .sp-menu-popup__close-icon::after {
  background: #1EA896;
}

/* hover のときだけ反転 */
.sp-menu-popup__close:hover {
  background: #1EA896;
}

.sp-menu-popup__close:hover .sp-menu-popup__close-icon::before,
.sp-menu-popup__close:hover .sp-menu-popup__close-icon::after {
  background: #FCFBF8;
}

/* ==========================
   Nav（縦リスト）
========================== */
.sp-menu-popup__nav{
  padding-top:60px;
  display:flex;
  flex-direction:column;
  row-gap:14px;
  width:100%;
  max-width:520px;
  margin:0 auto;
}

/* お問い合わせは一覧に不要 → CSSで非表示（HTMLは触らない） */
.sp-menu-popup__item[href$="contact/"],
.sp-menu-popup__item[href$="/contact/"]{
  display:none;
}

.sp-menu-popup__item{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  padding:14px 6px;
  text-decoration:none;
  color:#111;
  border-bottom:1px solid rgba(0,0,0,.12);
  transform: translate3d(0,0,0);
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

.sp-menu-popup__item:hover,
.sp-menu-popup__item:focus,
.sp-menu-popup__item:active{
  color:#111;
  transform: translate3d(0,-3px,0);
}

.sp-menu-popup__text{
  font-family:var(--font-ja);
  font-size:15px;
  font-weight:500;
  letter-spacing:0.02em;
}

/* ==========================
   Actions
========================== */
.sp-menu-popup__actions {
  margin: 40px auto 0;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 16px;
  width: 100%;
  max-width: 520px;
  padding: 40px 20px;
  background: #f7f0b1;
  border-radius: 20px;
}

/* CTA */
.sp-menu-popup__cta-image{
  display:inline-block;
  width:100%;
  max-width:400px;
  line-height:0;
  transition: transform .25s cubic-bezier(.22,1,.36,1);
}

.sp-menu-popup__cta-image:hover{
  transform: translateY(-3px);
}

.sp-menu-popup__cta-image img{
  width:100%;
  height:auto;
  display:block;
}

/* SNS */
.sp-menu-popup__sns{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding: 30px 12px 0;
  border-radius:999px;
  background:none;
  border:none;
  text-decoration:none;
  transition: transform .25s cubic-bezier(.22,1,.36,1);
}

.sp-menu-popup__sns:hover{
  transform: translateY(-3px);
}

/* ラベル文字 */
.sp-menu-popup__sns-label{
  font-family: var(--font-ja);
  font-size:12px;
  font-weight:600;
  letter-spacing:0.08em;
  color:#2E2E2A;
  line-height:1;
  white-space:nowrap;
}

/* アイコン */
.sp-menu-popup__sns img{
  width:35px;
  height:35px;
  display:block;
}

@media(max-width:500px){
  .sp-menu-popup__actions {
    flex-direction: column;
    margin-top: 0;
  }
}

/* ===============================
   SP Menu Popup（SP調整：ユーザー指定を組み込み）
================================ */

@media (max-width:1000px){
  #spMenuPopup.sp-menu-popup{
    width:100%;
    z-index:2147483647 !important;
  }

  .sp-menu-popup__close{
    top:0;
  }

  .sp-menu-popup__panel{
    justify-content:space-around;
  }

  .sp-menu-popup__nav{
    margin-top:0;
    padding-top: 0;
  }

  body.is-sp-menu-open .site-header--top{
    z-index:1 !important;
  }

  body.is-sp-menu-open .site-header--top .site-header-logo,
  body.is-sp-menu-open .site-header--top .sp-menu-button{
    pointer-events:none;
  }
}

@media(max-width:500px){
  .sp-menu-popup__panel{
    height: auto;
    
    overflow-y: auto;
    padding: 24px 20px;
    box-sizing: border-box;
  }

  .sp-menu-popup__head{
    margin-bottom: 18px;
  }

  .sp-menu-popup__nav{
    margin-bottom: 18px;
  }

  .sp-menu-popup__actions{
    margin-top: 18px;
    padding: 20px;
  }
  .sp-menu-popup__item{
    padding: 10px 6px;
  }
}

/* タップで残る白枠を消す（アクセシビリティは focus-visible で担保） */
.header-nav-item:focus,
.site-header-cta:focus,
.sp-menu-button:focus,
.sp-menu-popup__item:focus,
.sp-menu-popup__close:focus {
  outline: none;
}

/* キーボード操作時だけフォーカス可視化 */
.header-nav-item:focus-visible,
.site-header-cta:focus-visible,
.sp-menu-button:focus-visible,
.sp-menu-popup__item:focus-visible,
.sp-menu-popup__close:focus-visible {
  outline: 2px solid rgba(0,0,0,.5);
  outline-offset: 3px;
}

body.is-modal-open{
  position: fixed;
  width: 100%;
  overflow: hidden;
}

#spMenuPopup{
  height: 100dvh;
}
