/* カートに入れるボタン（base / hover / active） */
.cart-button{
  /* サイズ指定 */
  width: 365px;
  height: 52px;

  /* 見た目 */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 12px; /* 角丸は好みで調整可 */
  color: #fff;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  user-select: none;

  /* 色（base） */
  --base: #011461;
  background: linear-gradient(to bottom,
    color-mix(in srgb, var(--base) 88%, #ffffff 12%) 0%,
    var(--base) 55%,
    color-mix(in srgb, var(--base) 88%, #000000 12%) 100%
  );

  /* 立体感 */
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 -2px 0 rgba(0,0,0,0.22),
    0 6px 12px rgba(0,0,0,0.20);

  transition: transform .08s ease, box-shadow .12s ease, filter .12s ease;
}

/* hover：明るく（明度 +8〜+12 相当） */
.cart-button:hover{
  filter: brightness(1.5); /* 1.08〜1.12で調整 */
}

/* active：暗く（明度 -8〜-12 相当）＋影弱め＋押し込み */
.cart-button:active{
  filter: brightness(0.90); /* 0.88〜0.92で調整 */
  transform: translateY(1px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.14),
    inset 0 -1px 0 rgba(0,0,0,0.18),
    0 3px 8px rgba(0,0,0,0.16); /* 影を弱め＋距離短め */
}

/* キーボード操作時の視認性（任意だが推奨） */
.cart-button:focus-visible{
  outline: 2px solid color-mix(in srgb, #ffffff 60%, var(--base) 40%);
  outline-offset: 3px;
}

/* 無効状態（任意） */
.cart-button:disabled,
.cart-button[aria-disabled="true"]{
  opacity: .55;
  cursor: not-allowed;
  filter: none;
  transform: none;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.14),
    inset 0 -2px 0 rgba(0,0,0,0.18),
    0 4px 10px rgba(0,0,0,0.14);
}