/* ================================
   PAGE TOP: white circle + chevron
   ================================ */

/* 調整しやすい変数 */
:root{
  --to-top-size: 44px;              /* 40〜56px 推奨 */
  --to-top-right: 2%;
  --to-top-bottom: 3%;
  --to-top-z: 99999;

  --to-top-bg: #ffffff;             /* ボタンの塗り（白） */
  --to-top-border: rgba(0,0,0,.06); /* 薄い外枠 */
  --to-top-arrow: #0181a7;          /* 矢印色（画像に近い青緑） */

  /* ふわっとした拡散影（複数レイヤーでやさしく） */
  --to-top-shadow:
      0 18px 38px rgba(10, 20, 30, .10),
      0 6px 16px rgba(10, 20, 30, .06),
      0 1px 2px rgba(10, 20, 30, .04);
}

.to-top {
  position: fixed;
  right: var(--to-top-right);
  bottom: var(--to-top-bottom);
  z-index: var(--to-top-z);
  width: var(--to-top-size);
  height: var(--to-top-size);
  border-radius: 999px;
  background: var(--to-top-bg);
  border: 1px solid var(--to-top-border);
  box-shadow: var(--to-top-shadow);
  cursor: pointer;

  /* フェードイン */
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition:
    opacity .25s ease,
    transform .25s ease,
    visibility .25s step-end,
    box-shadow .25s ease,
    border-color .25s ease,
    background-color .25s ease;

  /* 念のため既存背景を無効化 */
  background-image: none !important;
}

/* 表示時（JSで付与） */
.to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition:
    opacity .25s ease,
    transform .25s ease,
    visibility 0s step-start;
}

/* ホバー時は影をほんの少し強めるだけ（色は変えない） */
.to-top:hover,
.to-top:focus-visible {
  outline: none;
  box-shadow:
      0 22px 48px rgba(10, 20, 30, .12),
      0 8px 20px rgba(10, 20, 30, .08),
      0 1px 2px rgba(10, 20, 30, .04);
}

/* ▼ 中央の「細い上向きシェブロン矢印」を mask で描画 */
.to-top::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;

  /* 矢印色（マスクで切り抜いた領域に塗る） */
  background: var(--to-top-arrow);

  /* ストロークのシェブロン（塗りなし）をSVGで描く：
     M6 14 L12 8 L18 14（角は丸・線幅は環境により微調整） */
  --chevron-svg: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'>\
  <path d='M6 14 L12 8 L18 14' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' />\
</svg>");

  -webkit-mask-image: var(--chevron-svg);
          mask-image: var(--chevron-svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: 36%; /* 矢印サイズ（30〜40%でお好み） */
          mask-size: 36%;
}

/* 動きに弱い設定の方へ配慮 */
@media (prefers-reduced-motion: reduce) {
  .to-top { transition: none; }
}
