/* ===========================
 * BL Swipe Match - Landing Page Styles
 * PCSP統合スタイル
 * ブレークポイント: 950px
 *
 * NOTE: Vueコンポーネントのスタイルはwebpackバンドル内のSCSSで管理。
 * このファイルはSmartyテンプレート要素とグローバルレイアウトの
 * オーバーライドのみを担当する。
 * =========================== */

/* 共通スタイル（PC/SP両対応） */
.bl-face-match-wrapper {
    max-width: 540px;
    margin: 0 auto;
    padding: 0;
}

/* ローディング表示（Vue マウント前に表示） */
.bl-face-match-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 400px;
}

.bl-face-match-loading__spinner {
    width: 48px;
    height: 48px;
    border: 4px solid #F3F4F6;
    border-top-color: #FF4B8A;
    border-radius: 50%;
    animation: bl-face-match-spin 1s linear infinite;
}

@keyframes bl-face-match-spin {
    to {
        transform: rotate(360deg);
    }
}

.bl-face-match-loading__text {
    margin-top: 16px;
    font-size: 14px;
    color: #6B7280;
}

.bl-face-match-noscript {
    text-align: center;
    padding: 40px;
    background: #FFF5F8;
    border-radius: 12px;
    color: #FF4B8A;
}

/* Vueが読み込まれたらローディングを非表示 */
#bl_face_match_vue:not(.p-vue-error) .bl-face-match-loading {
    display: none;
}

.p-vue-error .bl-face-match-loading {
    display: flex;
}

/* ===========================
 * PC専用スタイル (950px以上)
 * =========================== */
@media screen and (min-width: 950px) {
    #container #container_inner {
        width: 100%;
        min-width: 0;
    }

    #main.bl-face-match-page {
        width: 100%;
        float: none;
        min-height: 600px;
    }
}

/* ===========================
 * SP専用スタイル (949px以下)
 * =========================== */
@media screen and (max-width: 949px) {
    #main.bl-face-match-page {
        min-height: 100vh;
        padding-bottom: env(safe-area-inset-bottom);
        width: 100%;
        overflow-x: hidden;
    }

    #container #container_inner {
        width: 100%;
        min-width: 0;
        padding: 0;
        margin: 0;
        max-width: 100%;
    }

    .bl-face-match-wrapper {
        width: 100%;
        max-width: 100%;
    }

    .bl-face-match-loading {
        min-height: 60vh;
    }

    .bl-face-match-noscript {
        padding: 40px 20px;
        margin: 20px;
    }
}

/* ===========================
 * 小画面専用スタイル (540px以下)
 * =========================== */
@media screen and (max-width: 540px) {
    .bl-face-match-wrapper {
        padding: 0;
    }
}
