/* ================================
   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;
    }
}