/**
 * Bluhorizon HRM Premium Theme - FINAL STABLE RTL
 * Overrides OrangeHRM 5.8 Layout & Styles
 * Color: Royal Navy (#001529)
 * Full RTL support with Grid/Flex Balance
 */

@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;600;700&family=Inter:wght@300;400;600&display=swap');

:root {
    --blh-navy: #001529;
    --blh-navy-light: #002140;
    --blh-accent: #00aaff;
    --blh-white: #ffffff;
    --blh-gray: #f7f9fa;
    --sidepanel-width: 290px;

    /* System Override */
    --oxd-primary-one-color: var(--blh-navy) !important;
    --oxd-primary-font-family: 'Cairo', 'Inter', sans-serif !important;
    --oxd-primary-gradient-start-color: var(--blh-navy) !important;
    --oxd-primary-gradient-end-color: var(--blh-navy-light) !important;
}

/* --- Global Typography --- */
body, .oxd-text, .oxd-main-menu-item, .oxd-input, .oxd-select-text, .oxd-button, .oxd-label, .oxd-table-cell {
    font-family: 'Cairo', 'Inter', sans-serif !important;
}

* {
    box-sizing: border-box;
}

html,
body,
#app {
    min-width: 0 !important;
    overflow-x: hidden;
}

/* --- Core Layout Fix (Removing Gaps & Overlaps) --- */
html[dir="rtl"] .oxd-sidepanel {
    right: 0 !important;
    left: auto !important;
    width: var(--sidepanel-width) !important;
    position: fixed !important;
    height: 100vh !important;
    z-index: 1000 !important;
}

/* Content Container Balance */
html[dir="rtl"] .oxd-layout-container {
    /* margin-right: var(--sidepanel-width) !important; */
    margin-left: 0 !important;
    transition: all 0.3s ease !important;
    min-height: 100vh !important;
    background-color: var(--blh-gray);
}

/* Navigation Ordering */
html[dir="rtl"] .oxd-layout-navigation {
    flex-direction: row-reverse !important;
}

/* --- Topbar Alignment (Flipping Profile to Left & Fixing Overlap) --- */
html[dir="rtl"] .oxd-topbar-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding-left: 30px !important;
    padding-right: 0 !important;
    /* margin-right: var(--sidepanel-width) !important; */
    /* width: calc(100% - var(--sidepanel-width)) !important; */
}

/* Secondary Top Navigation (Configuration, Qualifications, etc.) */
html[dir="rtl"] .oxd-topbar-body-nav {
    display: flex !important;
    flex-direction: row-reverse !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
    margin: 0 auto !important;
    gap: 16px !important;
    overflow: visible !important;
}

html[dir="rtl"] .oxd-topbar-body-nav-tab {
    flex-direction: row-reverse !important;
    text-align: right !important;
}

html[dir="rtl"] .oxd-topbar-body-nav-tab-item {
    min-width: 120px !important;
    justify-content: center !important;
    padding: 10px 18px !important;
    text-align: center !important;
}

html[dir="rtl"] .oxd-topbar-body-nav-tab i {
    margin-right: 8px !important;
    margin-left: 0 !important;
}

html[dir="rtl"] .oxd-topbar-header-title {
    text-align: right !important;
    flex: 1 !important;
}

html[dir="rtl"] .oxd-topbar-header-breadcrumb {
    margin-left: auto !important;
    margin-right: 20px !important;
}

html[dir="rtl"] .oxd-userdropdown-tab {
    flex-direction: row-reverse !important;
}

/* --- Sidebar Menu RTL Styling --- */
html[dir="rtl"] .oxd-main-menu-item {
    flex-direction: row-reverse !important;
    justify-content: flex-start !important;
    text-align: right !important;
    min-height: 38px !important;
    padding: 8px 15px !important;
}

html[dir="rtl"] .oxd-main-menu-item i {
    margin-left: 15px !important;
    margin-right: 0 !important;
    font-size: 1.2rem !important;
}

html[dir="rtl"] .oxd-main-menu-search {
    padding: 15px !important;
    text-align: right !important;
}

html[dir="rtl"] .oxd-main-menu-search input {
    text-align: right !important;
    padding-right: 35px !important;
}

/* --- Visual Styling (Premium Navy) --- */
.oxd-sidepanel {
    background: linear-gradient(180deg, var(--blh-navy) 0%, var(--blh-navy-light) 100%) !important;
}

.oxd-main-menu-item {
    border-radius: 10px !important;
    margin: 3px 15px !important;
    color: rgba(255,255,255,0.8) !important;
}

.oxd-sidepanel,
.oxd-sidepanel-body,
.oxd-main-menu {
    overflow: visible !important;
}

.oxd-sidepanel-body::-webkit-scrollbar,
.oxd-main-menu::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
    display: none !important;
}

.oxd-sidepanel-body,
.oxd-main-menu {
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
}

.oxd-main-menu {
    height: auto !important;
    max-height: none !important;
    padding-bottom: 10px !important;
}

.oxd-main-menu-item-wrapper {
    margin-bottom: 2px !important;
}

.oxd-main-menu-item--name {
    font-size: 14px !important;
    line-height: 1.25 !important;
}

html[dir="rtl"] .oxd-main-menu-search {
    padding: 8px 15px !important;
}

.oxd-main-menu-item:hover, .oxd-main-menu-item.active {
    background: rgba(255,255,255,0.1) !important;
    color: var(--blh-white) !important;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

/* --- Branding (Whitelabeling) --- */
img[src*="orangehrm-logo.png"], 
.orangehrm-logo, 
img[src*="ohrm_logo.png"],
.oxd-brand-banner img,
.orangehrm-login-logo,
.orangehrm-upgrade-button,
.oxd-footer-copyright {
    display: none !important;
}

/* Custom Bluhorizon Sidebar Text */
.oxd-brand-banner::after {
    content: "BLUHORIZON";
    color: white;
    font-weight: 800;
    font-size: 1.6rem;
    letter-spacing: 3px;
    padding: 12px 10px;
    display: block;
    text-align: center;
}

@media (max-height: 820px) {
    html[dir="rtl"] .oxd-main-menu-item {
        min-height: 34px !important;
        padding-top: 6px !important;
        padding-bottom: 6px !important;
    }

    .oxd-main-menu-item {
        margin-top: 1px !important;
        margin-bottom: 1px !important;
    }

    .oxd-main-menu-item--name {
        font-size: 13px !important;
    }

    .oxd-brand-banner::after {
        padding: 8px 10px !important;
        font-size: 1.25rem !important;
    }
}

/* --- Card & Table Polish --- */
.oxd-sheet {
    border-radius: 16px !important;
    box-shadow: 0 8px 30px rgba(0,0,0,0.04) !important;
    border: 1px solid #f0f3f7 !important;
}

.oxd-table-header {
    background-color: #f7f9fa !important;
}

.oxd-table,
.oxd-table-body,
.oxd-table-header,
.oxd-table-card,
.orangehrm-container {
    min-width: 0 !important;
}

.orangehrm-container,
.oxd-table-container {
    width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
}

.oxd-table {
    min-width: 720px !important;
}

.oxd-table-card {
    border-radius: 8px !important;
}

/* Responsive Handling */
@media (max-width: 1024px) {
    html[dir="rtl"] .oxd-layout-container {
        margin-right: 0 !important;
    }

    html[dir="rtl"] .oxd-layout-context {
        margin-right: 0 !important;
        padding: 16px !important;
        width: 100% !important;
    }

    html[dir="rtl"] .oxd-topbar {
        right: 0 !important;
        width: 100% !important;
    }

    html[dir="rtl"] .oxd-topbar-body-nav {
        justify-content: flex-start !important;
        overflow-x: auto !important;
        flex-wrap: nowrap !important;
        gap: 8px !important;
        padding: 0 12px !important;
        -webkit-overflow-scrolling: touch;
    }

    html[dir="rtl"] .oxd-topbar-body-nav-tab-item {
        min-width: max-content !important;
        padding: 10px 14px !important;
        white-space: nowrap !important;
    }
}

@media (max-width: 768px) {
    body {
        font-size: 14px !important;
    }

    html[dir="rtl"] .oxd-sidepanel {
        width: 82vw !important;
        max-width: 290px !important;
        height: 100dvh !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-overflow-scrolling: touch;
    }

    .oxd-sidepanel-body,
    .oxd-main-menu {
        overflow-y: auto !important;
        max-height: calc(100dvh - 76px) !important;
    }

    .oxd-brand-banner::after {
        font-size: 1.1rem !important;
        padding: 8px 10px !important;
        letter-spacing: 2px !important;
    }

    .oxd-layout-context {
        padding: 12px !important;
    }

    .oxd-topbar-header {
        min-height: 56px !important;
        padding: 10px 14px !important;
    }

    .oxd-topbar-header-title,
    .oxd-topbar-header-breadcrumb {
        max-width: calc(100vw - 112px) !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    .oxd-topbar-header-userarea {
        left: 10px !important;
        max-width: 42vw !important;
    }

    .oxd-userdropdown-name {
        max-width: 34vw !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    .oxd-sheet,
    .orangehrm-card-container {
        border-radius: 8px !important;
        padding: 14px !important;
    }

    .oxd-grid-2,
    .oxd-grid-3,
    .oxd-grid-4,
    .orangehrm-dashboard-widget-grid,
    .orangehrm-dashboard-widget-container {
        grid-template-columns: 1fr !important;
    }

    .oxd-form-row,
    .oxd-form-actions {
        flex-wrap: wrap !important;
        gap: 10px !important;
    }

    .oxd-button,
    .oxd-button--secondary,
    .oxd-button--main,
    .oxd-button--ghost {
        min-height: 42px !important;
        margin: 4px !important;
        white-space: normal !important;
    }

    .oxd-table {
        min-width: 680px !important;
    }
}

@media (max-width: 480px) {
    html[dir="rtl"] .oxd-layout-context {
        padding: 10px !important;
    }

    .oxd-table {
        min-width: 620px !important;
    }

    .oxd-text--h6,
    .oxd-topbar-header-title {
        font-size: 18px !important;
        line-height: 1.3 !important;
    }
}

/* Modern mobile app shell */
@media (max-width: 768px) {
    :root {
        --blh-mobile-bg: #f4f7fb;
        --blh-mobile-panel: #071b2f;
        --blh-mobile-panel-soft: #0b2842;
        --blh-mobile-accent: #2f80ed;
        --blh-mobile-menu-text: #eaf2fb;
    }

    body {
        background: var(--blh-mobile-bg) !important;
    }

    html[dir="rtl"] .oxd-sidepanel {
        inset: 0 0 auto auto !important;
        width: 100vw !important;
        max-width: 100vw !important;
        min-width: 100vw !important;
        height: 100dvh !important;
        padding: 10px 14px 18px !important;
        background: radial-gradient(circle at 22% 8%, rgba(47, 128, 237, 0.28), transparent 28%),
            linear-gradient(180deg, var(--blh-mobile-panel) 0%, #03111f 100%) !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    .oxd-sidepanel-header {
        min-height: 76px !important;
        padding: 8px 0 12px !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    }

    .oxd-brand-banner {
        width: 100% !important;
        min-height: 48px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .oxd-brand-banner::after {
        content: "BLUHORIZON";
        padding: 0 !important;
        font-size: 17px !important;
        line-height: 1 !important;
        color: #ffffff !important;
        letter-spacing: 4px !important;
    }

    .oxd-sidepanel-toggle {
        top: 22px !important;
        left: 14px !important;
        right: auto !important;
        width: 40px !important;
        height: 40px !important;
        border-radius: 14px !important;
        background: rgba(255, 255, 255, 0.12) !important;
        border: 1px solid rgba(255, 255, 255, 0.12) !important;
        color: #ffffff !important;
    }

    html[dir="rtl"] .oxd-main-menu-search {
        margin: 12px 0 18px !important;
        padding: 0 !important;
    }

    html[dir="rtl"] .oxd-main-menu-search input {
        width: 100% !important;
        min-height: 44px !important;
        padding: 0 44px 0 16px !important;
        border: 1px solid rgba(255, 255, 255, 0.16) !important;
        border-radius: 16px !important;
        background: rgba(255, 255, 255, 0.96) !important;
        color: #0f172a !important;
        text-align: right !important;
        font-size: 14px !important;
        box-shadow: 0 10px 26px rgba(0, 0, 0, 0.12) !important;
    }

    .oxd-main-menu {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        height: calc(100dvh - 152px) !important;
        max-height: calc(100dvh - 152px) !important;
        overflow-y: auto !important;
        padding: 0 0 20px !important;
    }

    .oxd-main-menu-item-wrapper {
        margin: 0 !important;
    }

    html[dir="rtl"] .oxd-main-menu-item {
        min-height: 54px !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 16px !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 14px !important;
        border-radius: 16px !important;
        color: var(--blh-mobile-menu-text) !important;
        background: rgba(255, 255, 255, 0.045) !important;
        border: 1px solid rgba(255, 255, 255, 0.06) !important;
        box-shadow: none !important;
    }

    html[dir="rtl"] .oxd-main-menu-item:hover,
    html[dir="rtl"] .oxd-main-menu-item.active,
    html[dir="rtl"] .oxd-main-menu-item--active {
        background: linear-gradient(135deg, var(--blh-mobile-accent), #1261c7) !important;
        color: #ffffff !important;
        border-color: rgba(255, 255, 255, 0.16) !important;
        box-shadow: 0 10px 22px rgba(47, 128, 237, 0.28) !important;
    }

    .oxd-main-menu-item--icon {
        width: 26px !important;
        min-width: 26px !important;
        height: 26px !important;
        margin: 0 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: inherit !important;
        font-size: 20px !important;
    }

    .oxd-main-menu-item--name {
        flex: 1 !important;
        min-width: 0 !important;
        text-align: right !important;
        color: inherit !important;
        font-size: 15px !important;
        font-weight: 700 !important;
        line-height: 1.25 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .oxd-layout-context,
    .orangehrm-background-container {
        background: var(--blh-mobile-bg) !important;
    }

    .oxd-topbar-header {
        background: #ffffff !important;
        color: #0f172a !important;
        border-radius: 0 0 18px 18px !important;
        box-shadow: 0 8px 24px rgba(15, 23, 42, 0.08) !important;
    }

    .oxd-topbar-header-title,
    .oxd-userdropdown-name {
        color: #0f172a !important;
    }
}

/* ==========================================================================
   Bluhorizon Mobile App Shell Redesign (UI/UX Pro Max Specification)
   ========================================================================== */
@media (max-width: 768px) {
    :root {
        --blh-mobile-bg: #f3f7fb;
        --blh-mobile-card: #ffffff;
        --blh-mobile-text: #1e293b;
        --blh-mobile-muted: #64748b;
        --blh-mobile-primary: #00509e;
        --blh-mobile-navy: #001529;
        --blh-mobile-cyan: #20c7c9;
        --blh-mobile-accent: #00aaff;
        --blh-mobile-shadow: 0 10px 30px rgba(15, 23, 42, 0.05), 0 1px 3px rgba(15, 23, 42, 0.03);
        --blh-mobile-glass: rgba(255, 255, 255, 0.82);
        --blh-mobile-border: rgba(255, 255, 255, 0.35);
        --blh-mobile-easing: cubic-bezier(0.16, 1, 0.3, 1);
        --blh-mobile-top-safe: env(safe-area-inset-top, 0px);
        --blh-mobile-header-height: calc(72px + var(--blh-mobile-top-safe));
        --blh-mobile-content-top: calc(96px + var(--blh-mobile-top-safe));
    }

    /* Strict Boundary Lock & Reset */
    *, *::before, *::after {
        box-sizing: border-box !important;
    }

    body, #app, .oxd-layout, .orangehrm-background-container, .oxd-layout-context {
        background: var(--blh-mobile-bg) !important;
        max-width: 100vw !important;
        overflow-x: hidden !important;
    }

    /* Hide standard desktop elements with absolute certainty */
    .oxd-sidepanel, 
    .oxd-topbar-header, 
    .oxd-topbar-body,
    .oxd-topbar {
        display: none !important;
    }

    /* Ensure content context expands and doesn't get squished */
    .oxd-layout-container {
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
    }

    .oxd-layout-context {
        margin: 0 !important;
        width: 100% !important;
        padding: var(--blh-mobile-content-top) 16px calc(92px + env(safe-area-inset-bottom, 0px)) !important;
    }

    /* Global Typography Enhancement */
    body, .oxd-text, .oxd-label, .oxd-input, .oxd-select-text, .oxd-table-cell, .oxd-button, h1, h2, h3, h4, h5, h6 {
        font-family: 'Cairo', 'Inter', sans-serif !important;
        color: var(--blh-mobile-text) !important;
    }

    /* ==========================================
       [1] Premium Glassmorphic Top Header Bar
       ========================================== */
    .blh-mobile-app-header {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        height: var(--blh-mobile-header-height) !important;
        background: var(--blh-mobile-glass) !important;
        backdrop-filter: blur(18px) !important;
        -webkit-backdrop-filter: blur(18px) !important;
        border-bottom: 1px solid var(--blh-mobile-border) !important;
        box-shadow: var(--blh-mobile-shadow) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: var(--blh-mobile-top-safe) 16px 0 !important;
        z-index: 1500 !important;
        direction: rtl !important;
    }

    .blh-header-left, .blh-header-right {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
    }

    .blh-header-btn {
        background: transparent !important;
        border: none !important;
        color: var(--blh-mobile-navy) !important;
        font-size: 22px !important;
        cursor: pointer !important;
        position: relative !important;
        padding: 4px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: transform 0.2s !important;
        touch-action: manipulation !important;
    }
    
    .blh-header-btn:active {
        transform: scale(0.9) !important;
    }

    .blh-header-title {
        font-size: 18px !important;
        font-weight: 800 !important;
        color: var(--blh-mobile-navy) !important;
        letter-spacing: 1px !important;
        font-family: 'Inter', 'Cairo', sans-serif !important;
        text-align: center !important;
        flex: 1 !important;
    }

    .blh-notification-badge {
        position: absolute !important;
        top: 2px !important;
        left: 2px !important;
        width: 10px !important;
        height: 10px !important;
        background: #ef4444 !important;
        border-radius: 50% !important;
        border: 1.5px solid #ffffff !important;
        box-shadow: 0 0 8px rgba(239, 68, 68, 0.8) !important;
        display: none;
    }

    /* ==========================================
       [2] Glassmorphic Bottom Navigation Bar
       ========================================== */
    .blh-mobile-bottom-nav {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        height: calc(68px + env(safe-area-inset-bottom, 0px)) !important;
        padding-bottom: env(safe-area-inset-bottom, 0px) !important;
        background: var(--blh-mobile-glass) !important;
        backdrop-filter: blur(18px) !important;
        -webkit-backdrop-filter: blur(18px) !important;
        border-top: 1px solid var(--blh-mobile-border) !important;
        box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.04) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-around !important;
        z-index: 1500 !important;
        direction: rtl !important;
    }

    .blh-bottom-nav-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        flex: 1 !important;
        height: 100% !important;
        color: var(--blh-mobile-muted) !important;
        text-decoration: none !important;
        font-family: 'Cairo', sans-serif !important;
        cursor: pointer !important;
        gap: 3px !important;
        transition: color 0.3s var(--blh-mobile-easing) !important;
    }

    .blh-bottom-nav-item i {
        font-size: 20px !important;
        transition: transform 0.3s var(--blh-mobile-easing) !important;
    }

    .blh-bottom-nav-item span {
        font-size: 10px !important;
        font-weight: 800 !important;
    }

    .blh-bottom-nav-item.active {
        color: var(--blh-mobile-primary) !important;
    }

    .blh-bottom-nav-item.active i {
        transform: scale(1.12) translateY(-2px) !important;
    }

    /* Pulsing Center "+" Button */
    .blh-bottom-nav-center-wrapper {
        position: relative !important;
        width: 60px !important;
        height: 60px !important;
        margin-top: -24px !important;
        z-index: 1510 !important;
        pointer-events: auto !important;
    }

    .blh-bottom-nav-center-btn {
        width: 54px !important;
        height: 54px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, var(--blh-mobile-primary) 0%, var(--blh-mobile-navy) 100%) !important;
        border: 4px solid #ffffff !important;
        box-shadow: 0 8px 24px rgba(0, 80, 158, 0.4) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: #ffffff !important;
        font-size: 24px !important;
        cursor: pointer !important;
        transition: transform 0.3s var(--blh-mobile-easing) !important;
        pointer-events: auto !important;
        touch-action: manipulation !important;
    }

    .blh-bottom-nav-center-btn:active {
        transform: scale(0.9) !important;
    }

    .blh-bottom-nav-center-btn::before {
        content: '' !important;
        position: absolute !important;
        top: -4px !important;
        left: -4px !important;
        right: -4px !important;
        bottom: -4px !important;
        border-radius: 50% !important;
        border: 1.5px solid var(--blh-mobile-primary) !important;
        animation: blhGlowPulse 2s infinite !important;
        opacity: 0 !important;
    }

    @keyframes blhGlowPulse {
        0% { transform: scale(1); opacity: 0.8; }
        100% { transform: scale(1.22); opacity: 0; }
    }

    /* ==========================================
       [3] Dynamic Custom App Views Overlay
       ========================================== */
    .blh-mobile-app-view {
        display: none;
        width: 100% !important;
        animation: blhFadeIn 0.35s var(--blh-mobile-easing) !important;
    }

    .blh-mobile-app-view.active {
        display: block !important;
    }

    @keyframes blhFadeIn {
        from { opacity: 0; transform: translateY(12px); }
        to { opacity: 1; transform: translateY(0); }
    }

    /* ==========================================
       [4] Mobile Dashboard Elements (Employee)
       ========================================== */
    .blh-greeting-banner {
        min-height: 154px !important;
        padding: 24px 20px !important;
        border-radius: 24px !important;
        background: radial-gradient(circle at 18% 18%, rgba(32, 199, 201, 0.15), transparent 30%),
                    linear-gradient(135deg, var(--blh-mobile-navy) 0%, #031122 100%) !important;
        box-shadow: 0 12px 30px rgba(0, 21, 41, 0.12) !important;
        margin-bottom: 20px !important;
        color: #ffffff !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        text-align: right !important;
    }

    .blh-greeting-title {
        font-size: 26px !important;
        font-weight: 800 !important;
        color: #ffffff !important;
        line-height: 1.4 !important;
        margin-bottom: 6px !important;
    }

    .blh-greeting-subtitle {
        font-size: 12px !important;
        font-weight: 600 !important;
        color: rgba(255, 255, 255, 0.6) !important;
    }

    .blh-section-title {
        font-size: 17px !important;
        font-weight: 800 !important;
        color: var(--blh-mobile-navy) !important;
        margin: 20px 4px 12px !important;
        text-align: right !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
    }

    /* Symmetry Grid Layouts (UI/UX Pro Max) */
    .blh-symmetric-grid {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
        width: 100% !important;
        direction: rtl !important;
        margin-bottom: 16px !important;
    }

    .blh-app-card {
        background: var(--blh-mobile-card) !important;
        border-radius: 20px !important;
        border: 1px solid rgba(226, 232, 240, 0.8) !important;
        padding: 16px !important;
        box-shadow: var(--blh-mobile-shadow) !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        cursor: pointer !important;
        transition: transform 0.2s var(--blh-mobile-easing), box-shadow 0.2s var(--blh-mobile-easing) !important;
        min-height: 108px !important;
    }

    .blh-app-card:active {
        transform: scale(0.96) !important;
        box-shadow: 0 4px 12px rgba(15, 23, 42, 0.03) !important;
    }

    .blh-card-icon-wrapper {
        width: 44px !important;
        height: 44px !important;
        border-radius: 14px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 22px !important;
        margin-bottom: 10px !important;
        color: #ffffff !important;
    }

    .blh-card-title {
        font-size: 13px !important;
        font-weight: 700 !important;
        color: var(--blh-mobile-navy) !important;
        line-height: 1.3 !important;
    }

    /* ==========================================
       [5] Prioritized Manager Dashboard
       ========================================== */
    .blh-manager-dashboard {
        width: 100% !important;
    }

    .blh-pending-requests-stack {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        width: 100% !important;
        direction: rtl !important;
    }

    .blh-pending-request-card {
        background: #ffffff !important;
        border-radius: 20px !important;
        border: 1px solid rgba(226, 232, 240, 0.8) !important;
        padding: 18px !important;
        box-shadow: var(--blh-mobile-shadow) !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        position: relative !important;
        overflow: hidden !important;
    }

    .blh-pending-card-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
    }

    .blh-pending-user-info {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
    }

    .blh-pending-user-avatar {
        width: 38px !important;
        height: 38px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, var(--blh-mobile-primary), var(--blh-mobile-navy)) !important;
        color: #ffffff !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-weight: 800 !important;
        font-size: 15px !important;
    }

    .blh-pending-user-name {
        font-size: 14px !important;
        font-weight: 800 !important;
        color: var(--blh-mobile-navy) !important;
    }

    .blh-pending-badge {
        font-size: 10px !important;
        font-weight: 800 !important;
        padding: 3px 9px !important;
        border-radius: 999px !important;
    }

    .blh-pending-badge.leave {
        background: rgba(0, 80, 158, 0.08) !important;
        color: var(--blh-mobile-primary) !important;
    }

    .blh-pending-badge.loan {
        background: rgba(32, 199, 201, 0.1) !important;
        color: #0d9488 !important;
    }

    .blh-pending-details {
        font-size: 13px !important;
        font-weight: 600 !important;
        color: var(--blh-mobile-muted) !important;
        line-height: 1.5 !important;
        background: #f8fafc !important;
        padding: 10px 14px !important;
        border-radius: 12px !important;
    }

    .blh-pending-actions {
        display: flex !important;
        gap: 10px !important;
        margin-top: 4px !important;
    }

    .blh-btn-action {
        flex: 1 !important;
        height: 40px !important;
        border-radius: 12px !important;
        font-size: 13px !important;
        font-weight: 800 !important;
        border: none !important;
        cursor: pointer !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 6px !important;
        transition: transform 0.15s !important;
    }

    .blh-btn-action:active {
        transform: scale(0.97) !important;
    }

    .blh-btn-action.approve {
        background: #10b981 !important;
        color: #ffffff !important;
        box-shadow: 0 4px 12px rgba(16, 185, 129, 0.2) !important;
    }

    .blh-btn-action.reject {
        background: #ef4444 !important;
        color: #ffffff !important;
        box-shadow: 0 4px 12px rgba(239, 68, 68, 0.2) !important;
    }

    /* ==========================================
       [6] Live Geofencing GPS Punch Card & UI
       ========================================== */
    .blh-gps-card {
        background: #ffffff !important;
        border-radius: 24px !important;
        border: 1px solid rgba(226, 232, 240, 0.8) !important;
        padding: 24px 20px !important;
        box-shadow: var(--blh-mobile-shadow) !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 16px !important;
        margin-bottom: 20px !important;
        text-align: center !important;
        direction: rtl !important;
    }

    .blh-gps-status-badge {
        font-size: 12px !important;
        font-weight: 800 !important;
        padding: 5px 14px !important;
        border-radius: 999px !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 6px !important;
    }

    .blh-gps-status-badge.checking {
        background: #f1f5f9 !important;
        color: var(--blh-mobile-muted) !important;
    }

    .blh-gps-status-badge.in-range {
        background: #d1fae5 !important;
        color: #065f46 !important;
    }

    .blh-gps-status-badge.out-range {
        background: #fee2e2 !important;
        color: #991b1b !important;
    }

    /* Giant Punch Pulsing Circle Button */
    .blh-giant-punch-btn {
        width: 130px !important;
        height: 130px !important;
        min-width: 130px !important;
        min-height: 130px !important;
        border-radius: 50% !important;
        border: 8px solid #f1f5f9 !important;
        background: linear-gradient(135deg, var(--blh-mobile-muted) 0%, #475569 100%) !important;
        box-shadow: 0 10px 25px rgba(71, 85, 105, 0.15) !important;
        color: #ffffff !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 4px !important;
        cursor: not-allowed !important;
        opacity: 0.6 !important;
        transition: all 0.4s var(--blh-mobile-easing) !important;
        position: relative !important;
        box-sizing: border-box !important;
        padding: 0 10px !important;
        text-align: center !important;
        line-height: 1 !important;
    }

    .blh-giant-punch-btn.unlocked {
        background: linear-gradient(135deg, var(--blh-mobile-primary) 0%, var(--blh-mobile-navy) 100%) !important;
        border-color: rgba(0, 80, 158, 0.1) !important;
        box-shadow: 0 12px 30px rgba(0, 80, 158, 0.35) !important;
        cursor: pointer !important;
        opacity: 1 !important;
    }

    .blh-giant-punch-btn.is-loading {
        pointer-events: none !important;
        filter: saturate(0.85) !important;
    }

    .blh-giant-punch-btn.unlocked:active {
        transform: scale(0.94) !important;
    }

    .blh-giant-punch-btn i {
        font-size: 32px !important;
    }

    .blh-punch-icon {
        width: 46px !important;
        height: 46px !important;
        min-width: 46px !important;
        min-height: 46px !important;
        border-radius: 50% !important;
        display: block !important;
        flex: 0 0 46px !important;
        position: relative !important;
        margin: 0 auto 2px !important;
        overflow: visible !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }

    .blh-punch-icon::before {
        content: '' !important;
        position: absolute !important;
        inset: 0 !important;
        width: 46px !important;
        height: 46px !important;
        border: 0 !important;
        border-radius: 50% !important;
        transform: none !important;
        background: url("data:image/svg+xml,%3Csvg width='46' height='46' viewBox='0 0 46 46' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 21.5C12 15.7 16.9 11 23 11C29.1 11 34 15.7 34 21.5' stroke='white' stroke-width='2.4' stroke-linecap='round'/%3E%3Cpath d='M16 23C16 19.1 19.1 16 23 16C26.9 16 30 19.1 30 23C30 26.7 28.8 29.5 27.1 32.5' stroke='white' stroke-width='2.4' stroke-linecap='round'/%3E%3Cpath d='M20.2 23.3C20.2 21.6 21.5 20.2 23.2 20.2C24.9 20.2 26.2 21.6 26.2 23.3C26.2 27.8 24.3 31.5 21.2 34.9' stroke='white' stroke-width='2.4' stroke-linecap='round'/%3E%3Cpath d='M12.8 28.2C13.6 31.2 15.4 33.8 18 35.8' stroke='white' stroke-width='2.4' stroke-linecap='round' opacity='.82'/%3E%3Cpath d='M33.3 27.8C32.8 31 31.6 34.1 29.7 36.8' stroke='white' stroke-width='2.4' stroke-linecap='round' opacity='.82'/%3E%3Ccircle cx='23' cy='23' r='21' stroke='white' stroke-opacity='.28' stroke-width='1.4'/%3E%3C/svg%3E") center / contain no-repeat !important;
    }

    .blh-punch-icon::after {
        content: '' !important;
        position: absolute !important;
        left: 7px !important;
        right: 7px !important;
        top: 9px !important;
        height: 2px !important;
        border-radius: 999px !important;
        background: rgba(255,255,255,0.92) !important;
        box-shadow: 0 0 10px rgba(255,255,255,0.75) !important;
        opacity: 0 !important;
    }

    .blh-giant-punch-btn.is-loading .blh-punch-icon::after {
        animation: blhFingerprintScan 1.05s ease-in-out infinite !important;
        opacity: 1 !important;
    }

    .blh-giant-punch-btn span:not(.blh-punch-icon) {
        font-size: 14px !important;
        font-weight: 800 !important;
        display: block !important;
        width: 100% !important;
        text-align: center !important;
        line-height: 1.25 !important;
    }

    /* Glowing Ripple around giant punch button when unlocked */
    .blh-giant-punch-btn.unlocked::after {
        content: '' !important;
        position: absolute !important;
        inset: -8px !important;
        border-radius: 50% !important;
        border: 2px solid var(--blh-mobile-primary) !important;
        animation: blhGiantPulse 2.5s infinite !important;
    }

    @keyframes blhGiantPulse {
        0% { transform: scale(1); opacity: 0.6; }
        100% { transform: scale(1.18); opacity: 0; }
    }

    @keyframes blhFingerprintScan {
        0%, 100% { transform: translateY(0); opacity: 0.25; }
        50% { transform: translateY(23px); opacity: 1; }
    }

    /* ==========================================
       [7] Slide-up Quick Actions Bottom Sheet
       ========================================== */
    .blh-sheet-overlay {
        position: fixed !important;
        inset: 0 !important;
        background: rgba(15, 23, 42, 0.4) !important;
        backdrop-filter: blur(4px) !important;
        z-index: 2400 !important;
        opacity: 0 !important;
        pointer-events: none !important;
        transition: opacity 0.3s ease !important;
    }

    .blh-sheet-overlay.active {
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    .blh-bottom-sheet {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        background: #ffffff !important;
        border-radius: 28px 28px 0 0 !important;
        box-shadow: 0 -10px 40px rgba(15, 23, 42, 0.15) !important;
        z-index: 2410 !important;
        transform: translateY(100%) !important;
        transition: transform 0.4s var(--blh-mobile-easing) !important;
        padding: 24px 20px calc(24px + env(safe-area-inset-bottom, 0px)) !important;
        direction: rtl !important;
        max-height: min(76dvh, 560px) !important;
        overflow-y: auto !important;
    }

    .blh-bottom-sheet.active {
        transform: translateY(0) !important;
    }

    .blh-sheet-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        margin-bottom: 20px !important;
    }

    .blh-sheet-title {
        font-size: 17px !important;
        font-weight: 800 !important;
        color: var(--blh-mobile-navy) !important;
    }

    .blh-sheet-close {
        font-size: 24px !important;
        color: var(--blh-mobile-muted) !important;
        cursor: pointer !important;
        width: 44px !important;
        height: 44px !important;
        border: 0 !important;
        border-radius: 50% !important;
        background: #f1f5f9 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        line-height: 1 !important;
        padding: 0 !important;
    }

    /* ==========================================
       [8] Sliding Right Drawer Menu
       ========================================== */
    .blh-drawer-overlay {
        position: fixed !important;
        inset: 0 !important;
        background: rgba(15, 23, 42, 0.4) !important;
        backdrop-filter: blur(4px) !important;
        z-index: 1900 !important;
        opacity: 0 !important;
        pointer-events: none !important;
        transition: opacity 0.3s ease !important;
    }

    .blh-drawer-overlay.active {
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    .blh-mobile-drawer {
        position: fixed !important;
        top: 0 !important;
        right: 0 !important;
        width: 85vw !important;
        max-width: 320px !important;
        height: 100vh !important;
        background: #ffffff !important;
        z-index: 1910 !important;
        box-shadow: -10px 0 40px rgba(15, 23, 42, 0.15) !important;
        transform: translateX(100%) !important;
        transition: transform 0.4s var(--blh-mobile-easing) !important;
        padding: calc(24px + env(safe-area-inset-top, 0px)) 18px 24px !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 16px !important;
        direction: rtl !important;
    }

    .blh-mobile-drawer.active {
        transform: translateX(0) !important;
    }

    /* Drawer Header & Greeting */
    .blh-drawer-header {
        padding: 10px 0 20px !important;
        border-bottom: 1px solid rgba(226, 232, 240, 0.8) !important;
        text-align: right !important;
    }

    .blh-drawer-user-card {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        margin-bottom: 12px !important;
    }

    .blh-drawer-avatar {
        width: 48px !important;
        height: 48px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, var(--blh-mobile-primary), var(--blh-mobile-navy)) !important;
        color: #ffffff !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 18px !important;
        font-weight: 800 !important;
        border: 2px solid #e2e8f0 !important;
    }

    .blh-drawer-welcome {
        font-size: 17px !important;
        font-weight: 800 !important;
        color: var(--blh-mobile-navy) !important;
    }

    .blh-drawer-login-meta {
        font-size: 11px !important;
        font-weight: 600 !important;
        color: var(--blh-mobile-muted) !important;
    }

    /* Toggle Switches (Manager / Employee) */
    .blh-drawer-role-toggle {
        display: flex !important;
        background: #f1f5f9 !important;
        border-radius: 12px !important;
        padding: 4px !important;
        margin: 12px 0 4px !important;
        gap: 4px !important;
    }

    .blh-role-btn {
        flex: 1 !important;
        height: 36px !important;
        border-radius: 8px !important;
        border: none !important;
        font-size: 12px !important;
        font-weight: 800 !important;
        background: transparent !important;
        color: var(--blh-mobile-muted) !important;
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: all 0.2s ease !important;
    }

    .blh-role-btn.active {
        background: #ffffff !important;
        color: var(--blh-mobile-navy) !important;
        box-shadow: var(--blh-mobile-shadow) !important;
    }

    /* Drawer Menu items list */
    .blh-drawer-menu {
        flex: 1 !important;
        overflow-y: auto !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 4px !important;
        padding: 10px 0 !important;
    }

    .blh-drawer-item {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        min-height: 48px !important;
        padding: 0 14px !important;
        border-radius: 12px !important;
        color: var(--blh-mobile-text) !important;
        text-decoration: none !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        cursor: pointer !important;
        transition: background 0.2s !important;
    }

    .blh-drawer-item:active {
        background: #f1f5f9 !important;
    }

    .blh-drawer-item-left {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
    }

    .blh-drawer-item-left i {
        font-size: 18px !important;
        color: var(--blh-mobile-primary) !important;
    }

    .blh-header-title {
        cursor: pointer !important;
    }

    .blh-badge-new {
        background: #fef08a !important;
        color: #854d0e !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        padding: 2px 7px !important;
        border-radius: 6px !important;
    }

    /* ==========================================
       [9] Glassmorphic Profile Card & Tab Bar
       ========================================== */
    .blh-profile-header-card {
        background: #ffffff !important;
        border-radius: 24px !important;
        border: 1px solid rgba(226, 232, 240, 0.8) !important;
        padding: 20px 16px 14px !important;
        box-shadow: var(--blh-mobile-shadow) !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        margin-bottom: 20px !important;
        position: relative !important;
    }

    .blh-profile-avatar-giant {
        width: 76px !important;
        height: 76px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, var(--blh-mobile-primary) 0%, var(--blh-mobile-navy) 100%) !important;
        color: #ffffff !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 32px !important;
        font-weight: 800 !important;
        border: 4px solid #f1f5f9 !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06) !important;
        margin-bottom: 12px !important;
        margin-top: -50px !important; /* Elegant overlap style */
    }

    .blh-profile-name {
        font-size: 17px !important;
        font-weight: 800 !important;
        color: var(--blh-mobile-navy) !important;
        margin-bottom: 14px !important;
    }

    .blh-profile-caption {
        color: #64748b !important;
        font-size: 12px !important;
        font-weight: 800 !important;
        line-height: 1.5 !important;
        margin-top: -8px !important;
        margin-bottom: 8px !important;
        text-align: center !important;
    }

    /* Inner sub-tabs inside profile */
    .blh-profile-tabs {
        display: flex !important;
        background: #f1f5f9 !important;
        border-radius: 999px !important;
        padding: 4px !important;
        width: 100% !important;
        gap: 2px !important;
    }

    .blh-profile-tab-btn {
        flex: 1 !important;
        height: 32px !important;
        border-radius: 999px !important;
        border: none !important;
        font-size: 11px !important;
        font-weight: 800 !important;
        background: transparent !important;
        color: var(--blh-mobile-muted) !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
    }

    .blh-profile-tab-btn.active {
        background: #ffffff !important;
        color: var(--blh-mobile-navy) !important;
        box-shadow: 0 4px 10px rgba(15, 23, 42, 0.04) !important;
    }

    /* ==========================================
       [10] In-App Notifications Panel Overlay
       ========================================== */
    .blh-notifications-panel {
        position: fixed !important;
        top: 64px !important;
        left: 16px !important;
        right: 16px !important;
        background: var(--blh-mobile-glass) !important;
        backdrop-filter: blur(18px) !important;
        -webkit-backdrop-filter: blur(18px) !important;
        border: 1px solid var(--blh-mobile-border) !important;
        border-radius: 20px !important;
        box-shadow: 0 20px 40px rgba(15, 23, 42, 0.15) !important;
        z-index: 1490 !important;
        transform: translateY(-120%) !important;
        transition: transform 0.4s var(--blh-mobile-easing) !important;
        padding: 16px !important;
        direction: rtl !important;
        max-height: 320px !important;
        overflow-y: auto !important;
    }

    .blh-notifications-panel.active {
        transform: translateY(0) !important;
    }

    .blh-notification-item {
        padding: 10px 8px !important;
        border-bottom: 1px solid rgba(226, 232, 240, 0.6) !important;
        font-size: 12px !important;
        font-weight: 600 !important;
        line-height: 1.5 !important;
        color: var(--blh-mobile-text) !important;
        text-align: right !important;
    }

    .blh-notification-item:last-child {
        border-bottom: none !important;
    }

    /* ==========================================
       [11] Dynamic Forms Styling (OrangeHRM Overrides)
       ========================================== */
    .oxd-sheet, .orangehrm-card-container {
        border-radius: 24px !important;
        border: 1px solid rgba(226, 232, 240, 0.8) !important;
        box-shadow: var(--blh-mobile-shadow) !important;
        padding: 16px !important;
        background: #ffffff !important;
        margin-bottom: 16px !important;
    }

    .oxd-form-row {
        margin-bottom: 12px !important;
    }

    .oxd-input, .oxd-select-text, .oxd-textarea {
        border-radius: 14px !important;
        border: 1.5px solid #cbd5e1 !important;
        font-size: 14px !important;
        padding: 8px 14px !important;
        background: #ffffff !important;
    }

    .oxd-input:focus, .oxd-select-text:focus, .oxd-textarea:focus {
        border-color: var(--blh-mobile-primary) !important;
        box-shadow: 0 0 0 3px rgba(0, 80, 158, 0.12) !important;
    }

    .oxd-button {
        border-radius: 14px !important;
        min-height: 44px !important;
        font-weight: 800 !important;
        font-size: 14px !important;
        width: 100% !important;
        margin: 6px 0 !important;
    }

    /* ==========================================
       [12] Absolute Sanctuary for N8N Chatbot Widget
       ========================================== */
    #blh-ai-widget {
        position: fixed !important;
        bottom: 92px !important; /* Gracefully float above bottom nav */
        left: 20px !important;   /* Safe margins in bottom-left corner */
        right: auto !important;
        width: 56px !important;
        height: 56px !important;
        background: linear-gradient(135deg, #20c7c9 0%, #00aaff 100%) !important;
        border-radius: 50% !important;
        box-shadow: 0 8px 24px rgba(32, 199, 201, 0.4) !important;
        z-index: 999999 !important; /* Guarantee absolute priority */
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: transform 0.3s var(--blh-mobile-easing) !important;
        touch-action: manipulation !important;
    }

    #blh-ai-widget:active {
        transform: scale(0.9) !important;
    }

    #blh-ai-widget-label {
        position: fixed !important;
        bottom: 154px !important;
        left: 20px !important;
        right: auto !important;
        background: var(--blh-mobile-navy) !important;
        color: #ffffff !important;
        border-radius: 12px !important;
        z-index: 999998 !important;
    }

    #blh-tasks-launcher {
        left: auto !important;
        right: 16px !important;
        bottom: calc(92px + env(safe-area-inset-bottom, 0px)) !important;
        min-width: 56px !important;
        min-height: 56px !important;
        z-index: 999997 !important;
    }

    body.blh-ai-chat-open #blh-tasks-launcher {
        opacity: 0.45 !important;
        pointer-events: none !important;
        transform: scale(0.94) !important;
    }

    #blh-ai-container {
        position: fixed !important;
        top: calc(74px + env(safe-area-inset-top, 0px)) !important;
        bottom: calc(84px + env(safe-area-inset-bottom, 0px)) !important;
        left: 10px !important;
        right: 10px !important;
        width: auto !important;
        height: auto !important;
        max-width: none !important;
        max-height: none !important;
        border-radius: 20px !important;
        box-shadow: 0 15px 45px rgba(15, 23, 42, 0.25) !important;
        z-index: 1000000 !important;
    }

    body.blh-ai-chat-open #blh-ai-widget {
        transform: scale(0.88) !important;
        opacity: 0.86 !important;
    }

    #blh-ai-container .blh-ai-header {
        min-height: 50px !important;
        padding: 10px 12px !important;
        flex-shrink: 0 !important;
    }

    #blh-ai-container .blh-ai-messages {
        padding: 12px !important;
        gap: 8px !important;
        min-height: 0 !important;
    }

    #blh-ai-container .blh-msg {
        max-width: 88% !important;
        font-size: 13px !important;
        line-height: 1.55 !important;
        padding: 9px 12px !important;
    }

    #blh-ai-container .blh-ai-input-area {
        padding: 10px 10px calc(10px + env(safe-area-inset-bottom, 0px)) !important;
        gap: 8px !important;
        flex-shrink: 0 !important;
    }

    #blh-ai-container .blh-ai-input {
        min-width: 0 !important;
        min-height: 40px !important;
        font-size: 13px !important;
    }

    #blh-ai-container .blh-ai-send {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        flex: 0 0 40px !important;
    }

    body.blh-password-page.blh-legacy-mode .oxd-layout-context {
        padding: var(--blh-mobile-content-top) 14px calc(92px + env(safe-area-inset-bottom, 0px)) !important;
        background: var(--blh-mobile-bg) !important;
    }

    body.blh-password-page.blh-legacy-mode .orangehrm-card-container,
    body.blh-password-page.blh-legacy-mode .oxd-sheet {
        margin: 0 !important;
        padding: 16px !important;
        border-radius: 20px !important;
        box-shadow: var(--blh-mobile-shadow) !important;
        border: 1px solid rgba(226, 232, 240, 0.9) !important;
    }

    body.blh-password-page.blh-legacy-mode .oxd-form-row,
    body.blh-password-page.blh-legacy-mode .oxd-grid-item,
    body.blh-password-page.blh-legacy-mode .oxd-input-group {
        margin: 0 0 10px !important;
        padding: 0 !important;
    }

    body.blh-password-page.blh-legacy-mode .oxd-grid-2,
    body.blh-password-page.blh-legacy-mode .oxd-grid-3,
    body.blh-password-page.blh-legacy-mode .oxd-grid-4 {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    body.blh-password-page.blh-legacy-mode .oxd-input {
        min-height: 44px !important;
        border-radius: 12px !important;
    }

    body.blh-password-page.blh-legacy-mode .oxd-form-actions {
        margin-top: 8px !important;
        padding: 0 !important;
        gap: 10px !important;
    }

    /* ==========================================
       [13] Primary Button & Card Text Contrast Hotfix
       ========================================== */
    /* Force extremely high contrast for primary/success/danger buttons */
    .oxd-button--main,
    .oxd-button--success,
    .oxd-button--danger,
    .oxd-button--primary,
    .orangehrm-login-button,
    button.oxd-button {
        color: #ffffff !important;
    }
    
    /* Ensure secondary/cancel buttons are readable dark slate */
    .oxd-button--secondary {
        color: #1e293b !important;
        background: #e2e8f0 !important;
        border: 1px solid #cbd5e1 !important;
    }

    /* Force dark slate color for text elements on light card backgrounds */
    .oxd-sheet .oxd-text,
    .orangehrm-card-container .oxd-text,
    .blh-mobile-views .oxd-text,
    .orangehrm-attendance-card-state,
    .orangehrm-attendance-card-details,
    .oxd-text--span,
    .oxd-label,
    span.oxd-text,
    p.oxd-text {
        color: #1e293b !important; /* Force highly readable slate-gray on white cards! */
    }

    /* Bulletproof Mobile view native elements hiding & sanctuary view container overlay */
    .blh-mobile-views {
        position: fixed !important;
        top: var(--blh-mobile-header-height) !important;
        bottom: calc(68px + env(safe-area-inset-bottom, 0px)) !important; /* height of bottom nav */
        left: 0 !important;
        right: 0 !important;
        overflow-y: auto !important;
        background: var(--blh-mobile-bg) !important;
        z-index: 1400 !important; /* below Header/Nav but above everything else */
        padding: 16px !important;
        direction: rtl !important;
        display: block !important;
    }

    .blh-mobile-panel {
        min-height: 100% !important;
        direction: rtl !important;
        text-align: right !important;
        padding-bottom: 18px !important;
    }

    .blh-inline-back {
        border: none !important;
        background: #ffffff !important;
        color: var(--blh-mobile-navy) !important;
        min-height: 36px !important;
        width: auto !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 6px !important;
        border-radius: 999px !important;
        padding: 0 12px !important;
        box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06) !important;
        font-size: 12px !important;
        font-weight: 800 !important;
        margin: 0 0 12px !important;
    }

    .blh-mobile-panel-head {
        background: linear-gradient(135deg, #001529 0%, #05233d 100%) !important;
        color: #ffffff !important;
        border-radius: 22px !important;
        padding: 20px !important;
        margin-bottom: 16px !important;
        box-shadow: 0 12px 30px rgba(0, 21, 41, 0.12) !important;
    }

    .blh-mobile-panel-title {
        color: #ffffff !important;
        font-size: 22px !important;
        font-weight: 900 !important;
        line-height: 1.35 !important;
    }

    .blh-mobile-panel-subtitle {
        color: rgba(255,255,255,0.72) !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        line-height: 1.6 !important;
        margin-top: 6px !important;
    }

    .blh-mobile-form,
    .blh-mobile-info-card,
    .blh-mobile-empty,
    .blh-mobile-list-row,
    .blh-metric-card {
        background: #ffffff !important;
        border: 1px solid rgba(226, 232, 240, 0.9) !important;
        box-shadow: var(--blh-mobile-shadow) !important;
    }

    .blh-mobile-form {
        border-radius: 20px !important;
        padding: 16px !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        margin-bottom: 16px !important;
    }

    .blh-mobile-form.compact {
        gap: 10px !important;
    }

    .blh-mobile-form label {
        display: flex !important;
        flex-direction: column !important;
        gap: 6px !important;
        color: var(--blh-mobile-navy) !important;
        font-size: 12px !important;
        font-weight: 800 !important;
    }

    .blh-mobile-form input,
    .blh-mobile-form select,
    .blh-mobile-form textarea {
        width: 100% !important;
        min-height: 44px !important;
        border-radius: 12px !important;
        border: 1px solid #cbd5e1 !important;
        background: #f8fafc !important;
        color: #0f172a !important;
        padding: 10px 12px !important;
        font-family: 'Cairo', sans-serif !important;
        font-size: 14px !important;
        outline: none !important;
        box-sizing: border-box !important;
    }

    .blh-mobile-form textarea {
        min-height: 86px !important;
        resize: vertical !important;
    }

    .blh-mobile-form-row {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
    }

    .blh-mobile-primary-btn,
    .blh-mobile-secondary-btn {
        width: 100% !important;
        min-height: 46px !important;
        border-radius: 14px !important;
        border: none !important;
        font-family: 'Cairo', sans-serif !important;
        font-size: 14px !important;
        font-weight: 900 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        margin: 0 !important;
        cursor: pointer !important;
    }

    .blh-mobile-primary-btn {
        background: linear-gradient(135deg, var(--blh-mobile-primary), var(--blh-mobile-navy)) !important;
        color: #ffffff !important;
    }

    .blh-mobile-secondary-btn {
        background: #e2e8f0 !important;
        color: #0f172a !important;
        margin-top: 12px !important;
    }

    .blh-mobile-primary-btn:disabled {
        opacity: 0.55 !important;
    }

    .blh-mobile-split-title {
        font-size: 16px !important;
        font-weight: 900 !important;
        color: var(--blh-mobile-navy) !important;
        margin: 18px 4px 10px !important;
    }

    .blh-mobile-split-title.compact {
        font-size: 14px !important;
        margin-top: 14px !important;
    }

    .blh-mobile-metrics {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 10px !important;
        margin-bottom: 12px !important;
    }

    .blh-mobile-metrics.payroll {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .blh-mobile-metrics .blh-mobile-empty {
        grid-column: 1 / -1 !important;
    }

    .blh-metric-card {
        border-radius: 18px !important;
        padding: 14px !important;
        min-height: 92px !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        gap: 4px !important;
    }

    .blh-metric-card span,
    .blh-mobile-info-grid span {
        color: #64748b !important;
        font-size: 11px !important;
        font-weight: 800 !important;
    }

    .blh-metric-card strong {
        color: var(--blh-mobile-navy) !important;
        font-size: 21px !important;
        font-weight: 900 !important;
        line-height: 1.2 !important;
    }

    .blh-metric-card small {
        color: #94a3b8 !important;
        font-size: 10px !important;
        font-weight: 700 !important;
    }

    .blh-mobile-list {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
    }

    .blh-mobile-list-row {
        border-radius: 16px !important;
        padding: 13px 14px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 12px !important;
    }

    .blh-mobile-list-row > div {
        display: flex !important;
        flex-direction: column !important;
        gap: 4px !important;
        min-width: 0 !important;
    }

    .blh-mobile-list-row strong {
        color: #0f172a !important;
        font-size: 13px !important;
        font-weight: 900 !important;
        line-height: 1.35 !important;
    }

    .blh-mobile-list-row span {
        color: #64748b !important;
        font-size: 11px !important;
        font-weight: 700 !important;
        line-height: 1.35 !important;
        word-break: break-word !important;
    }

    .blh-mobile-list-row em {
        color: var(--blh-mobile-primary) !important;
        font-size: 11px !important;
        font-weight: 900 !important;
        font-style: normal !important;
        white-space: nowrap !important;
    }

    .blh-mobile-list-row.muted em {
        color: #64748b !important;
    }

    .blh-mobile-empty {
        border-radius: 18px !important;
        min-height: 96px !important;
        padding: 20px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        gap: 6px !important;
    }

    .blh-mobile-empty strong {
        color: #0f172a !important;
        font-size: 14px !important;
        font-weight: 900 !important;
    }

    .blh-mobile-empty span,
    .blh-mobile-note,
    .blh-mobile-info-card p {
        color: #64748b !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        line-height: 1.7 !important;
    }

    .blh-mobile-note {
        margin-top: 12px !important;
        background: #f8fafc !important;
        border-radius: 14px !important;
        padding: 12px !important;
    }

    .blh-mobile-note.warn {
        background: #fff7ed !important;
        color: #9a3412 !important;
        border: 1px solid #fed7aa !important;
    }

    .blh-mobile-info-card {
        border-radius: 20px !important;
        padding: 16px !important;
    }

    .blh-mobile-payroll-id {
        margin-bottom: 12px !important;
    }

    .blh-mobile-info-grid {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 8px !important;
        margin-bottom: 14px !important;
    }

    .blh-mobile-info-grid div {
        background: #f8fafc !important;
        border-radius: 14px !important;
        padding: 10px !important;
        min-height: 76px !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        gap: 5px !important;
    }

    .blh-mobile-info-grid strong {
        color: #0f172a !important;
        font-size: 12px !important;
        font-weight: 900 !important;
    }

    /* In legacy mode, hide our custom views container completely */
    body.blh-legacy-mode .blh-mobile-views {
        display: none !important;
    }

}

/* Mobile white-screen safety net.
   Keep the native OrangeHRM Vue app visible even if the optional mobile shell fails. */
@media (max-width: 768px) {
    body.blh-mobile-mode #app,
    body.blh-legacy-mode #app,
    #app {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    body:not(:has(.blh-mobile-views)) .oxd-topbar,
    body:not(:has(.blh-mobile-views)) .oxd-topbar-header,
    body:not(:has(.blh-mobile-views)) .oxd-topbar-body,
    body:not(:has(.blh-mobile-views)) .oxd-sidepanel {
        display: revert !important;
    }

    .blh-mobile-views:not(:has(.blh-mobile-app-view.active:not(:empty))) {
        display: none !important;
        pointer-events: none !important;
    }
}
