/* System notifications & header dropdowns (RTL/LTR safe) */

/* --------------------------------------------------------------------------
   Header <details> dropdowns (user menu, quick actions)
   -------------------------------------------------------------------------- */

.exp-header-bar .tw-dw-dropdown {
    position: relative !important;
}

.exp-header-bar .exp-header-dropdown-menu {
    display: none;
    position: absolute !important;
    top: calc(100% + 10px) !important;
    width: 12rem;
    min-width: 192px;
    max-width: min(12rem, calc(100vw - 24px));
    margin: 0 !important;
    padding: 0.5rem !important;
    list-style: none;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #fff !important;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.18), 0 4px 12px rgba(15, 23, 42, 0.08);
    z-index: 1060 !important;
    float: none !important;
    transform: none !important;
}

.exp-header-bar .tw-dw-dropdown[open] > .exp-header-dropdown-menu {
    display: block;
}

/* User menu — trigger sits on the visual start edge in RTL (left side) */
[dir="rtl"] .exp-header-bar .exp-header-user-menu > .exp-header-dropdown-menu {
    left: 0 !important;
    right: auto !important;
    inset-inline-start: auto !important;
    inset-inline-end: 0 !important;
}

[dir="ltr"] .exp-header-bar .exp-header-user-menu > .exp-header-dropdown-menu {
    right: 0 !important;
    left: auto !important;
    inset-inline-end: 0 !important;
    inset-inline-start: auto !important;
}

/* Quick actions (+) menu */
[dir="rtl"] .exp-header-bar .exp-header-actions-menu > .exp-header-dropdown-menu {
    right: 0 !important;
    left: auto !important;
}

[dir="ltr"] .exp-header-bar .exp-header-actions-menu > .exp-header-dropdown-menu {
    left: 0 !important;
    right: auto !important;
}

.exp-header-user-dropdown__head {
    margin: -0.5rem -0.5rem 0.5rem;
    border-radius: 12px 12px 0 0;
}

.exp-header-bar .exp-header-dropdown-menu li {
    list-style: none;
}

.exp-header-bar .exp-header-dropdown-menu a {
    text-decoration: none;
}

/* --------------------------------------------------------------------------
   Header notifications dropdown (RTL/LTR safe)
   -------------------------------------------------------------------------- */

.notifications-menu {
    position: relative !important;
}

.notifications-menu > .exp-notifications-dropdown.dropdown-menu {
    display: none;
    position: absolute !important;
    top: calc(100% + 10px) !important;
    left: auto !important;
    right: 0 !important;
    inset-inline-end: 0 !important;
    inset-inline-start: auto !important;
    float: none !important;
    width: 22rem;
    min-width: 280px;
    max-width: min(22rem, calc(100vw - 24px));
    max-height: min(28rem, 72vh) !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.18), 0 4px 12px rgba(15, 23, 42, 0.08);
    z-index: 1060 !important;
    transform: none !important;
}

[dir="rtl"] .notifications-menu > .exp-notifications-dropdown.dropdown-menu {
    left: 0 !important;
    right: auto !important;
    inset-inline-end: 0 !important;
    inset-inline-start: auto !important;
}

.notifications-menu.open > .exp-notifications-dropdown.dropdown-menu,
.notifications-menu > .exp-notifications-dropdown.dropdown-menu.open {
    display: block;
}

.exp-notifications-dropdown__header {
    padding: 12px 16px;
    border-bottom: 1px solid #e2e8f0;
    background: linear-gradient(135deg, #f8fafc 0%, #fff 100%);
    font-weight: 700;
    font-size: 14px;
    color: #1e293b;
    list-style: none;
}

.exp-notifications-dropdown__header i {
    color: #4f46e5;
    margin-inline-end: 8px;
}

.exp-notifications-dropdown__body {
    list-style: none;
    max-height: min(22rem, 60vh);
    overflow-y: auto;
    overflow-x: hidden;
    padding: 6px;
}

.exp-notifications-dropdown__body > .menu {
    margin: 0;
    padding: 0;
    list-style: none;
    max-height: none;
}

.exp-notifications-dropdown__footer {
    list-style: none;
    border-top: 1px solid #e2e8f0;
    text-align: center;
    padding: 10px;
    background: #f8fafc;
}

.exp-notifications-dropdown__footer a {
    font-weight: 600;
    color: #4f46e5;
}

.exp-notifications-dropdown .notification-li {
    width: 100%;
}

.exp-notifications-dropdown .exp-sys-notif-empty {
    padding: 28px 16px;
}

.exp-notifications-dropdown .exp-sys-notif-empty span {
    display: block;
    font-size: 13px;
}

/* Override legacy AdminLTE / RTL rules that pin menu to viewport edge */
.navbar-custom-menu > .navbar-nav > li.notifications-menu > .dropdown-menu,
.main-header .notifications-menu > .dropdown-menu {
    left: auto !important;
}

[dir="rtl"] .navbar-custom-menu > .navbar-nav > li.notifications-menu > .dropdown-menu,
[dir="rtl"] .main-header .notifications-menu > .dropdown-menu {
    left: 0 !important;
    right: auto !important;
}

/* Badge on bell */
.notifications-menu .notifications_count {
    position: absolute;
    top: -4px;
    inset-inline-end: -4px;
    font-size: 10px;
    padding: 2px 5px;
    border-radius: 10px;
    min-width: 16px;
    text-align: center;
}

.exp-sys-notif__link {
    align-items: flex-start;
    text-decoration: none;
    color: inherit;
}

.exp-sys-notif__link:hover,
.exp-sys-notif__link:focus {
    text-decoration: none;
    color: inherit;
}

.exp-sys-notif__icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}

.exp-sys-notif--budget.exp-sys-notif--danger .exp-sys-notif__icon,
.exp-sys-notif-icon--danger {
    background: #fef2f2;
    color: #dc2626;
}

.exp-sys-notif--budget.exp-sys-notif--warning .exp-sys-notif__icon,
.exp-sys-notif-icon--warning {
    background: #fffbeb;
    color: #d97706;
}

.exp-sys-notif__icon.notif-icon {
    position: static;
    margin: 0;
}

.exp-sys-notif__icon.notif-icon i {
    position: static;
}

.exp-sys-notif__body {
    flex: 1;
    min-width: 0;
}

.exp-sys-notif__title {
    font-weight: 600;
    color: #1e293b;
    margin-bottom: 2px;
}

.exp-sys-notif__msg .exp-budget-notif-msg-list {
    margin: 0;
    padding: 0 18px 0 0;
    list-style: disc;
}

[dir="ltr"] .exp-sys-notif__msg .exp-budget-notif-msg-list {
    padding: 0 0 0 18px;
}

.exp-sys-notif__msg .exp-budget-notif-msg-list li {
    margin-bottom: 2px;
    font-size: 12px;
    color: #475569;
}

.exp-budget-notif-ref {
    margin: 6px 0 0;
    font-size: 11px;
}

.exp-sys-notif__dot {
    flex-shrink: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #4f46e5;
    margin-top: 6px;
}

.exp-sys-notif.unread {
    background: rgba(79, 70, 229, 0.06);
}

.exp-sys-notif-empty {
    padding: 24px 12px;
}

/* Legacy notif-icon inside non-budget items */
.notification-li:not(.exp-sys-notif--budget) .notif-icon {
    margin-left: 0;
}

.notification-li .notif-info {
    display: block;
}

.notification-li .time {
    display: block;
    font-size: 11px;
    color: #94a3b8;
    margin-top: 4px;
}

/* Modal cards */
.exp-sys-notif-modal__body {
    max-height: 70vh;
    overflow-y: auto;
}

.exp-sys-notif-card {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 16px;
    background: #fff;
}

.exp-sys-notif-card--danger {
    border-color: #fecaca;
    background: linear-gradient(135deg, #fff5f5 0%, #fff 100%);
}

.exp-sys-notif-card--warning {
    border-color: #fde68a;
    background: linear-gradient(135deg, #fffbeb 0%, #fff 100%);
}

.exp-sys-notif-card__head {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 10px;
}

.exp-sys-notif-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}

.exp-sys-notif-card--danger .exp-sys-notif-card__icon {
    background: #fee2e2;
    color: #b91c1c;
}

.exp-sys-notif-card--warning .exp-sys-notif-card__icon {
    background: #fef3c7;
    color: #b45309;
}

.exp-sys-notif-card__subject {
    margin: 0 0 4px;
    font-size: 16px;
    font-weight: 700;
    color: #1e293b;
}

.exp-sys-notif-card__time {
    margin: 0;
    font-size: 12px;
}

.exp-sys-notif-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 10px;
    font-size: 12px;
    color: #64748b;
}

.exp-sys-notif-card__meta span i {
    margin-left: 4px;
}

[dir="ltr"] .exp-sys-notif-card__meta span i {
    margin-left: 0;
    margin-right: 4px;
}

.exp-sys-notif-card__msg {
    font-size: 13px;
    color: #334155;
    line-height: 1.6;
}

.exp-sys-notif-card__actions {
    margin-top: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.exp-sys-notif-card__divider {
    margin: 16px 0;
    border-color: #e2e8f0;
}

@media (max-width: 480px) {
    [dir="rtl"] .exp-header-bar .exp-header-user-menu > .exp-header-dropdown-menu {
        left: 0 !important;
        right: auto !important;
        max-width: calc(100vw - 16px);
    }

    .notifications-menu > .exp-notifications-dropdown.dropdown-menu {
        width: calc(100vw - 20px);
        min-width: 0;
        max-width: calc(100vw - 20px);
        inset-inline-end: 0 !important;
    }

    [dir="rtl"] .notifications-menu > .exp-notifications-dropdown.dropdown-menu {
        left: 0 !important;
        right: auto !important;
    }
}
