/* ============================================
   MOBILE APP - COMPLETE FIX
   ============================================ */

@media (max-width: 991px) {

    /* ---- CRITICAL: Reset all sidebar margins on mobile ---- */
    .main-content {
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 0 0 85px 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        min-height: 100dvh !important;
        animation: appPageIn 0.35s ease both;
    }

    @keyframes appPageIn {
        from { opacity: 0; transform: translateY(16px); }
        to   { opacity: 1; transform: translateY(0); }
    }

    /* ---- RTL: also zero margins ---- */
    [dir="rtl"] .main-content {
        margin-right: 0 !important;
        margin-left: 0 !important;
    }

    /* ---- App Background ---- */
    html, body {
        background: #f0f4ff !important;
        font-size: 0.88rem !important;
        overflow-x: hidden;
    }

    body {
        padding-bottom: 80px !important;
    }

    /* ---- Inner content padding ---- */
    .main-content > .row,
    .main-content > .container,
    .main-content > div:not(.mobile-app-header):not(.mobile-bottom-nav):not(.mobile-fab) {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    /* ---- Hide desktop navbar ---- */
    .navbar.d-none.d-lg-flex,
    nav.navbar.d-none { display: none !important; }

    /* ---- App Top Bar ---- */
    .mobile-app-header {
        display: flex !important;
        justify-content: space-between !important;
        background: rgba(255,255,255,0.96) !important;
        backdrop-filter: saturate(180%) blur(20px) !important;
        -webkit-backdrop-filter: blur(20px) !important;
        padding: 10px 14px !important;
        margin: 0 !important;
        border-bottom: 1px solid rgba(0,0,0,0.05) !important;
        box-shadow: 0 2px 16px rgba(0,0,0,0.04) !important;
        position: sticky !important;
        top: 0 !important;
        z-index: 1100 !important;
        width: 100% !important;
    }

    [data-theme="dark"] .mobile-app-header {
        background: rgba(13,13,13,0.96) !important;
        border-bottom: 1px solid rgba(245,197,24,0.15) !important;
    }

    .mobile-app-header h5 {
        font-family: 'Alexandria', sans-serif !important;
        font-weight: 900 !important;
        font-size: 1rem !important;
        background: linear-gradient(135deg, var(--primary-color), #a855f7);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        white-space: nowrap;
        margin: 0 !important;
    }

    .mobile-app-header .btn {
        width: 36px !important;
        height: 36px !important;
        border-radius: 12px !important;
        background: rgba(67,97,238,0.08) !important;
        color: var(--primary-color) !important;
        border: none !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 1rem !important;
        padding: 0 !important;
    }

    .mobile-balance-pill {
        background: linear-gradient(135deg, #0f172a, #1e293b) !important;
        color: #ffd700 !important;
        font-weight: 900 !important;
        font-size: 0.75rem !important;
        padding: 5px 12px !important;
        border-radius: 50px !important;
        box-shadow: 0 4px 12px rgba(0,0,0,0.2) !important;
        white-space: nowrap !important;
    }

    /* ---- Sidebar as Drawer ---- */
    .sidebar {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 75% !important;
        max-width: 280px !important;
        height: 100dvh !important;
        border-radius: 0 24px 24px 0 !important;
        box-shadow: 6px 0 40px rgba(0,0,0,0.25) !important;
        transform: translateX(-105%) !important;
        transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
        z-index: 1200 !important;
        padding: 50px 16px 30px !important;
        overflow-y: auto !important;
    }
    .sidebar.active {
        transform: translateX(0) !important;
    }
    [dir="rtl"] .sidebar {
        left: auto !important;
        right: 0 !important;
        border-radius: 24px 0 0 24px !important;
        transform: translateX(105%) !important;
    }
    [dir="rtl"] .sidebar.active {
        transform: translateX(0) !important;
    }

    .sidebar .nav-link {
        border-radius: 14px !important;
        padding: 11px 14px !important;
        margin-bottom: 4px !important;
        font-family: 'Cairo', sans-serif !important;
        font-weight: 700 !important;
        font-size: 0.88rem !important;
        display: flex !important;
        align-items: center !important;
    }
    .sidebar .nav-link i {
        width: 24px !important;
        font-size: 0.95rem !important;
        margin-right: 10px !important;
    }
    [dir="rtl"] .sidebar .nav-link i { margin-right: 0 !important; margin-left: 10px !important; }
    .sidebar .nav-link.active {
        background: linear-gradient(135deg, var(--primary-color), var(--secondary-color)) !important;
        box-shadow: 0 6px 18px rgba(67,97,238,0.3) !important;
    }

    .sidebar-overlay {
        backdrop-filter: blur(5px) !important;
        background: rgba(0,0,0,0.55) !important;
    }

    /* ---- Cards: full width, consistent ---- */
    .card {
        border-radius: 20px !important;
        box-shadow: 0 2px 14px rgba(0,0,0,0.05) !important;
        border: none !important;
        padding: 16px !important;
        width: 100% !important;
    }

    /* ---- Dashboard Balance Card ---- */
    .balance-card-premium {
        border-radius: 20px !important;
        padding: 18px !important;
        min-height: auto !important;
    }
    .balance-card-premium h2 {
        font-size: 2rem !important;
        letter-spacing: -1px !important;
    }

    /* ---- Glass Stat Cards ---- */
    .glass-stat-card {
        border-radius: 18px !important;
        padding: 14px !important;
    }
    .glass-stat-card h3 { font-size: 1.3rem !important; }
    .magic-icon {
        width: 36px !important;
        height: 36px !important;
        font-size: 1rem !important;
        border-radius: 10px !important;
        margin-bottom: 8px !important;
    }

    /* ---- Row columns fix ---- */
    .row.g-4 { --bs-gutter-x: 12px; --bs-gutter-y: 12px; }
    .col-lg-4, .col-md-6, .col-md-12 {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* ---- Social Quick Icons ---- */
    .quick-social-wrapper {
        border-radius: 20px !important;
        padding: 14px !important;
    }
    .quick-social-scroll { gap: 10px !important; }
    .social-btn-magic {
        width: 44px !important;
        height: 44px !important;
        border-radius: 50% !important;
        font-size: 1.1rem !important;
        min-width: 44px !important;
    }

    /* ---- Activity Table → Cards ---- */
    .premium-table-card { border-radius: 20px !important; }
    .table-responsive { overflow-x: visible !important; }
    .table.table-borderless thead { display: none !important; }
    .table.table-borderless tbody tr.activity-row {
        display: block !important;
        background: #f8fafc !important;
        border-radius: 16px !important;
        margin-bottom: 10px !important;
        padding: 12px 14px !important;
        box-shadow: 0 2px 8px rgba(0,0,0,0.04) !important;
    }
    .table.table-borderless tbody td {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        border: none !important;
        padding: 5px 0 !important;
        font-size: 0.8rem !important;
    }
    .activity-row:hover { transform: none !important; }

    /* ---- Forms ---- */
    .form-control, .form-select {
        border-radius: 14px !important;
        padding: 12px 15px !important;
        font-size: 0.88rem !important;
        border: 1.5px solid #e2e8f0 !important;
        background: #fcfdff !important;
        width: 100% !important;
    }
    .form-control:focus, .form-select:focus {
        border-color: var(--primary-color) !important;
        box-shadow: 0 0 0 3px rgba(67,97,238,0.1) !important;
    }

    /* ---- Buttons ---- */
    .btn {
        border-radius: 14px !important;
        font-family: 'Cairo', sans-serif !important;
        font-weight: 700 !important;
        font-size: 0.85rem !important;
        -webkit-tap-highlight-color: transparent !important;
    }
    .btn:active { transform: scale(0.96) !important; }

    /* ---- Bottom Navigation ---- */
    .mobile-bottom-nav {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        height: 68px !important;
        background: rgba(255,255,255,0.97) !important;
        backdrop-filter: blur(24px) !important;
        -webkit-backdrop-filter: blur(24px) !important;
        border-top: 1px solid rgba(0,0,0,0.06) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-around !important;
        padding: 4px 0 10px !important;
        z-index: 2000 !important;
        box-shadow: 0 -4px 28px rgba(0,0,0,0.05) !important;
    }

    .mobile-nav-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 3px !important;
        text-decoration: none !important;
        color: #94a3b8 !important;
        flex: 1 !important;
        padding: 6px 2px !important;
        border-radius: 12px !important;
        transition: all 0.28s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
        -webkit-tap-highlight-color: transparent !important;
        position: relative !important;
    }
    .mobile-nav-item i {
        font-size: 1.25rem !important;
        transition: all 0.28s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
        display: block !important;
    }
    .mobile-nav-item span {
        font-size: 0.6rem !important;
        font-weight: 700 !important;
        font-family: 'Cairo', sans-serif !important;
        display: block !important;
    }
    .mobile-nav-item.active { color: var(--primary-color) !important; }
    .mobile-nav-item.active i { transform: translateY(-4px) scale(1.18) !important; }
    .mobile-nav-item.active::after {
        content: '';
        position: absolute;
        bottom: 0;
        width: 4px; height: 4px;
        background: var(--primary-color);
        border-radius: 50%;
        box-shadow: 0 0 8px var(--primary-color);
    }

    /* ---- FAB ---- */
    .mobile-fab {
        position: fixed !important;
        bottom: 80px !important;
        right: 18px !important;
        left: auto !important;
        width: 50px !important;
        height: 50px !important;
        border-radius: 18px !important;
        background: linear-gradient(135deg, var(--primary-color), var(--secondary-color)) !important;
        color: #fff !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 1.2rem !important;
        box-shadow: 0 8px 24px rgba(67,97,238,0.42) !important;
        border: 2px solid rgba(255,255,255,0.2) !important;
        z-index: 1500 !important;
        text-decoration: none !important;
        animation: fabPulse 2.5s ease-in-out infinite !important;
    }
    [dir="rtl"] .mobile-fab { right: auto !important; left: 18px !important; }
    @keyframes fabPulse {
        0%,100% { box-shadow: 0 8px 24px rgba(67,97,238,0.42); }
        50%      { box-shadow: 0 12px 32px rgba(67,97,238,0.65), 0 0 0 8px rgba(67,97,238,0.08); }
    }

    /* ---- Hide scrollbar ---- */
    ::-webkit-scrollbar { width: 0 !important; height: 0 !important; }

    /* ---- Order Wizard ---- */
    .order-wizard { padding: 0 !important; max-width: 100% !important; }
    .social-grid { grid-template-columns: repeat(5, 1fr) !important; gap: 10px !important; }
    .social-circle .icon-ring { width: 48px !important; height: 48px !important; font-size: 1.2rem !important; }
    .social-circle .soc-label { font-size: 0.6rem !important; }
    .service-types { gap: 8px !important; }
    .svc-type-btn { min-width: 64px !important; padding: 10px 10px !important; border-radius: 14px !important; }
    .price-summary-amount { font-size: 2rem !important; }

    /* ---- Badges ---- */
    .badge { font-size: 0.68rem !important; padding: 5px 10px !important; border-radius: 10px !important; }

    /* ---- Announcements ---- */
    .announcement-wrapper { display: none !important; }
}
