.vertical-text {
  writing-mode: vertical-rl;
}

.hero-bg-shape {
  position: absolute;
  top: 10%;
  left: 5%;
  width: 80%;
  z-index: -1;
  opacity: 0.15;
}

.text-border {
  text-shadow: -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff, 1px 1px 0 #fff;
}

html {
  scroll-behavior: smooth;
}

.naruto-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  /* ← 横幅を少し締める */

  padding: 14px;
  /* ← 一番効く（高さが小さくなる） */
  background: #ffffff;

  border-radius: 9999px;
  border: 2px solid #2aa7d8;

  color: #2aa7d8;
  font-size: 18px;
  /* ← 22 → 18 */
  font-weight: 700;
  letter-spacing: .05em;
  text-decoration: none;

  /* 影も縮小（←これが最重要） */
  box-shadow:
    0px 1.5px 0px #2aa7d8,
    0px 4px 0px #2aa7d8,
    0px 8px 14px rgba(0, 0, 0, 0.18);

  transition: all .18s ease;

  /* 上面ハイライト（立体感） */
  background:
    linear-gradient(to bottom,
      #ffffff 0%,
      #ffffff 70%,
      #f5fbff 100%);
}

/* ホバーで浮く */
.naruto-btn:hover {
  transform: translateY(2px);
  box-shadow:
    0px 1px 0px #2aa7d8,
    0px 2px 0px #2aa7d8,
    0px 5px 10px rgba(0, 0, 0, 0.15);
}

/* 押した時に沈む（超重要） */
.naruto-btn:active {
  transform: translateY(5px);
  box-shadow:
    0px 0px 0px #2aa7d8,
    0px 1px 0px #2aa7d8,
    0px 3px 6px rgba(0, 0, 0, 0.15);
}

.naruto-btn .label {
  margin: 0 auto;
}

.naruto-btn .arrow {
  font-size: 22px;
  opacity: .8;
  transition: transform .2s;
}

.naruto-btn:hover .arrow {
  transform: translateX(6px);
}

/* ===== FAQ（#faq）だけに効かせる：滑らか開閉 ===== */
#faq details .faq-panel {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-6px);
  transition:
    max-height 0.45s cubic-bezier(.25, .8, .25, 1),
    opacity 0.25s ease,
    transform 0.35s ease;
}

/* 開いた時 */
#faq details[open] .faq-panel {
  opacity: 1;
  transform: translateY(0);
}

/* summaryの三角を消す */
#faq summary::-webkit-details-marker {
  display: none;
}