﻿/* حاوية عامة — ضعها في الـ layout إن أردت ظهور التوست في كل الصفحة */
.toast-root {
    position: fixed;
    left: 24px; /* أسفل-يسار شائع بالعربية (dir=rtl) */
    top: 60px;
    z-index: 9999;
    pointer-events: none; /* يسمح بالنقر على عناصر خلفه ما لم تُعطَ عناصر داخلية pointer-events:auto */
}

/* البطاقة */
.booking-toast {
    pointer-events: auto;
    min-width: 300px;
    max-width: 420px;
    background: linear-gradient(180deg,#ffffff,#fcfdff);
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(12,20,40,0.12);
    border: 1px solid rgba(12,20,40,0.06);
    padding: 14px 14px;
    font-family: "Segoe UI", Tahoma, Arial, sans-serif;
    direction: rtl;
    color: #071124;
    overflow: hidden;
    transform-origin: right bottom;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: start;
    animation: toast-enter .28s cubic-bezier(.2,.9,.2,1);
}

/* عنوان + أيقونة */
.toast-head {
    display: flex;
    gap: 10px;
    align-items: center;
    grid-column: 1 / -1;
}

.toast-dot {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: white;
    background: linear-gradient(135deg, #ffc107, #aa8453);
    box-shadow: 0 8px 22px rgba(59,130,246,0.16);
    font-size: 18px;
}

/* نص */
.toast-title {
    font-weight: 700;
    font-size: 15px;
}

.toast-text {
    font-size: 14px;
    color: #344054;
    line-height: 1.45;
    margin-top: 6px;
}

/* زر إغلاق */
.toast-close {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 6px;
    font-size: 14px;
    color: #475569;
    border-radius: 8px;
}

    .toast-close:hover {
        background: rgba(7,17,36,0.04);
        color: #0b1220;
    }

/* شريط التقدّم الذي يظهر الأسفل */
.toast-progress {
    grid-column: 1 / -1;
    height: 5px;
    background: rgba(7,17,36,0.06);
    border-radius: 999px;
    overflow: hidden;
    margin-top: 10px;
}

    .toast-progress > span {
        display: block;
        height: 100%;
        width: 100%;
        transform-origin: left;
        background: linear-gradient(135deg, #ffc107, #aa8453);
        animation: progress-shrink 10s linear forwards;
    }

/* أنيميشن الدخول */
@keyframes toast-enter {
    from {
        transform: translateY(8px) scale(.98);
        opacity: 0;
    }

    to {
        transform: translateY(0) scale(1);
        opacity: 1;
    }
}

/* أنيميشن إنقاص شريط التقدم */
@keyframes progress-shrink {
    from {
        transform: scaleX(1);
    }

    to {
        transform: scaleX(0);
    }
}

/* أنيميشن الخروج (بعد 10s) — نستخدم animation-delay */
@keyframes toast-exit {
    from {
        opacity: 1;
        transform: translateY(0) scale(1);
    }

    to {
        opacity: 0;
        transform: translateY(8px) scale(.98);
    }
}

/* نجري تأثير الاختفاء بعد 10s (مطابقة مدة الشريط) */
.booking-toast {
    animation: toast-enter .28s cubic-bezier(.2,.9,.2,1), toast-exit .18s linear forwards;
    animation-delay: 0s, 10s;
    animation-fill-mode: none, forwards;
     ملاحظة: بعض المتصفحات لا تبدأ الـ second animation إلا بعد الأولى — هنا نستخدمها لإخفاء البطاقة بعد 10s 
}

    /* لو المستخدم نقر زر الإغلاق — نستخدم رابط #toastHidden ليقوم بـ :target لإخفاء العنصر */
    #toastHidden:target .booking-toast,
    .booking-toast.hidden {
        opacity: 0 !important;
        transform: translateY(8px) scale(.98) !important;
        pointer-events: none;
        transition: opacity .18s, transform .18s;
    }

/* استجابة */
@media (max-width:420px) {
    .booking-toast {
        min-width: 260px;
        max-width: calc(100% - 32px);
        left: 16px;
        right: 16px;
    }
}
