/* ==========================================================================
   デジタルガイド：最終安定版（PC右端吸着 / SPメニュー動的回避：見た目維持版）
   ========================================================================== */

/* ==========================
   ベース・共通ボタンデザイン
   ========================= */

.very-floating-container {
    will-change: transform;
    transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
                opacity 0.2s ease !important;
    pointer-events: auto !important;
    opacity: 1;
    /* ★重要：重なり安定化 */
    contain: layout paint;
    z-index: 9999 !important;
}

.btn-shuttle.very-fix-btn {
    display: flex !important;
    align-items: center !important;
    padding: 10px 20px !important;
    background-color: #30c2c2 !important;
    color: #fff !important;
    text-decoration: none !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15) !important;
    min-width: 220px !important;
    white-space: nowrap !important;
}

.very-icon { 
    font-size: 22px !important; 
    margin-right: 12px !important; 
}

.very-text { 
    font-family: sans-serif !important;
    font-size: 14px !important; 
    font-weight: bold !important; 
    line-height: 1.2 !important;
    color: #fff !important;
}

.very-text small { 
    font-size: 11px !important; 
    display: block !important;
    font-weight: normal !important;
}

/* ==========================
   PCレイアウト (769px以上)
   「ヘッダーナビ右端」に吸着
   ========================== */

@media (min-width: 769px) {
    .header-nav .nav-inner {
        position: relative !important;
    }

    .very-floating-container {
        /* 通常時はナビ右端を基準とした絶対配置 */
        position: absolute !important;
        top: 100% !important; 
        right: 0 !important;   
        left: auto !important;
        margin-top: 10px !important; 
        transform: none !important;
    }

    .very-floating-container.is-scrolled {
        margin-top: 5px !important;
        transform: none !important;
    }
}

/* ==========================
   SPレイアウト (768px以下)
   ========================== */

@media (max-width: 768px) {
    .very-floating-container {
        position: fixed !important;
        top: 0 !important;
        right: 15px !important;
        left: auto !important;
        /* 通常時はヘッダーを避ける位置(70px)を維持 */
        transform: translate3d(0, 70px, 0);
    }

    .very-floating-container.is-scrolled {
        transform: translate3d(0, 70px, 0);
    }
}

/* ============================================================
   ★最優先：メニュー表示時
   メニュー画面には「取り込まれず」、独立した浮遊状態を維持。
   JSによって計算された transform 数値がここに適用されます。
   ============================================================ */

body.is-menu-open .very-floating-container,
.site-header.is-menu-open ~ .very-floating-container,
.very-floating-container.is-menu-open {
    position: fixed !important; 
    z-index: 100001 !important;
    top: 0 !important;
    right: 15px !important; 
    opacity: 1 !important;
    visibility: visible !important;

    /* 
       JS側で動的にメニューの末尾を計算した transform を付与します。
       JSが読み込まれるまでの初期値として 430px をセット。
    */
    transform: translate3d(0, 430px, 0);

    pointer-events: auto !important;
}

/* ==========================
   追加安全策（メニュー本体）
   ========================== */

.sp-menu.is-open,
.sp-menu-container.is-open {
    z-index: 100000 !important;
}