.text-purple-muted {
    color: #6B7280;
}

.bg-purple-gradient {
    background-image: linear-gradient(to bottom right, #B93C9F, #8E24AA);
}

.bg-purple-soft {
    background-color: #F8EEF6;
}

/* 買家登入／忘記密碼等 auth 頁：Firefox 在 body 為 flex 欄、main 為 flex-grow 時，預設 min-height:auto 偶發把可捲動高度算錯 */
body.buyer-signin-page > main,
body.buyer-forgot-password-page > main,
body.buyer-reset-password-page > main {
    min-height: 0;
}
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background-color: #D1D5DB;
    border-radius: 20px;
}

.dark ::-webkit-scrollbar-thumb {
    background-color: #4A148C;
}

/*登入驗證碼文字大寫*/
#Captcha {
    text-transform: uppercase;
}

/* register-04：配銷國家「已選」標籤由 JS 產生；Tailwind content 未掃 .js 時任意色不會出現在 bundle，故用固定 CSS */
.distribution-country-tag {
    background-color: #B93C9F;
}

.distribution-country-tag-remove:hover {
    background-color: #8E24AA;
}

/* Privacy Modal */
.modal-overlay {
    transition: opacity 0.3s ease-out;
}

.modal-content {
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}

.modal-hidden {
    opacity: 0;
    pointer-events: none;
}

.modal-hidden .modal-content {
    transform: scale(0.95);
}

/* Loading 動畫 */
.loader {
    border: 3px solid #f3f3f3;
    border-top: 3px solid #3498db;
    border-radius: 50%;
    width: 24px;
    height: 24px;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0);
    }

    100% {
        transform: rotate(360deg);
    }
}