body.slams-mobile-app {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}

.slams-navbar-app-shell,
.slams-navbar-app-actions {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.glass-navbar .navbar-brand {
    order: 1;
}

.glass-navbar .navbar-collapse {
    order: 2;
}

.slams-navbar-app-shell {
    order: 3;
    margin-left: 0.75rem;
}

.slams-navbar-app-btn {
    position: relative;
    display: inline-grid;
    width: 40px;
    height: 40px;
    min-height: 40px;
    place-items: center;
    padding: 0;
    border: 1px solid var(--slams-nav-border);
    border-radius: 8px;
    background: var(--slams-nav-control-bg);
    color: var(--slams-nav-text);
    box-shadow: none;
}

.slams-navbar-app-btn:hover,
.slams-navbar-app-btn:focus,
.slams-navbar-app-btn.is-active {
    color: var(--slams-primary);
    background: color-mix(in srgb, var(--slams-primary) 12%, var(--slams-nav-control-bg));
}

.slams-navbar-app-btn.is-enabled {
    color: var(--slams-primary);
    background: color-mix(in srgb, var(--slams-primary) 14%, var(--slams-nav-control-bg));
}

.slams-navbar-app-btn.is-blocked {
    color: #b91c1c;
    background: color-mix(in srgb, #fecaca 68%, var(--slams-nav-control-bg));
}

.slams-navbar-app-btn.theme-toggle-btn {
    border-color: var(--slams-nav-border);
    background: var(--slams-nav-control-bg);
    color: var(--slams-nav-text);
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.slams-navbar-notification-trigger {
    text-decoration: none;
}

.notification-menu-device {
    flex-shrink: 0;
    background: var(--slams-surface-soft);
}

.notification-device-toggle {
    width: auto;
    min-width: 104px;
    padding: 0 0.72rem;
    grid-auto-flow: column;
    gap: 0.42rem;
    font-size: 0.78rem;
    font-weight: 700;
}

.notification-device-toggle i {
    font-size: 0.92rem;
}

.slams-navbar-profile-btn {
    overflow: hidden;
    border-radius: 999px;
}

.slams-navbar-profile-avatar,
.slams-navbar-profile-fallback {
    display: grid;
    width: 100%;
    height: 100%;
    place-items: center;
}

.slams-navbar-profile-avatar {
    object-fit: cover;
}

.slams-navbar-profile-fallback {
    font-size: 1rem;
}

.slams-mobile-bottom-nav,
.slams-mobile-status-banner,
.slams-mobile-update-banner {
    display: none;
}

@media (max-width: 991.98px) {
    :root {
        --slams-mobile-nav-height: 72px;
    }

    body.slams-mobile-app {
        padding-bottom: env(safe-area-inset-bottom, 0px);
    }

    .glass-navbar .navbar-collapse {
        order: 3;
    }

    .slams-navbar-app-shell {
        order: 2;
        margin-left: auto;
    }

    .slams-mobile-app .slams-main,
    .slams-mobile-app .content-area {
        padding-bottom: 1.5rem !important;
    }

    .slams-mobile-app .glass-navbar {
        position: sticky;
        top: 0;
        z-index: 1000;
    }

    .slams-mobile-app .user-profile-glass {
        display: none;
    }

    .slams-mobile-app .chatbot-panel {
        position: fixed;
        right: calc(0.75rem + var(--floating-control-size) + var(--floating-panel-gap));
        left: auto;
        bottom: calc(0.85rem + env(safe-area-inset-bottom, 0px));
        width: min(340px, calc(100vw - 112px));
        max-width: calc(100vw - 112px);
        max-height: min(64vh, 520px);
        margin-inline: 0;
    }

    .slams-mobile-app .theme-toggle {
        right: auto;
        left: 0.75rem;
        bottom: calc(0.85rem + env(safe-area-inset-bottom, 0px));
        z-index: 1046;
    }

    .slams-mobile-app .slams-chatbot {
        left: auto;
        right: 0.75rem;
        bottom: calc(0.85rem + env(safe-area-inset-bottom, 0px));
        z-index: 1046;
    }

    .slams-mobile-status-banner,
    .slams-mobile-update-banner {
        position: fixed;
        left: 0.75rem;
        right: 0.75rem;
        z-index: 1052;
        border: 1px solid color-mix(in srgb, var(--slams-border) 70%, transparent);
        border-radius: 12px;
        box-shadow: 0 14px 38px rgba(15, 23, 42, 0.14);
        backdrop-filter: blur(18px);
        -webkit-backdrop-filter: blur(18px);
    }

    .slams-mobile-status-banner {
        top: calc(0.75rem + env(safe-area-inset-top, 0px));
        padding: 0.8rem 1rem;
        background: color-mix(in srgb, var(--slams-surface) 88%, rgba(255, 255, 255, 0.45));
        color: var(--slams-text);
        font-size: 0.88rem;
        font-weight: 600;
    }

    .slams-mobile-status-banner.is-offline {
        border-color: rgba(220, 38, 38, 0.18);
        background: color-mix(in srgb, #fecaca 72%, var(--slams-surface));
        color: #991b1b;
    }

    .slams-mobile-status-banner.is-online {
        border-color: rgba(15, 118, 110, 0.18);
        background: color-mix(in srgb, #ccfbf1 70%, var(--slams-surface));
        color: #115e59;
    }

    .slams-mobile-update-banner {
        top: calc(4.6rem + env(safe-area-inset-top, 0px));
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.85rem;
        padding: 0.8rem 0.95rem;
        background: color-mix(in srgb, var(--slams-primary) 16%, var(--slams-surface));
    }

    .slams-mobile-update-copy {
        display: flex;
        flex-direction: column;
        gap: 0.1rem;
        min-width: 0;
        color: var(--slams-text);
        font-size: 0.8rem;
    }

    .slams-mobile-update-copy strong {
        font-size: 0.84rem;
    }

    .slams-mobile-bottom-nav {
        position: fixed;
        right: 0;
        bottom: 0;
        left: 0;
        z-index: 1045;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        min-height: calc(var(--slams-mobile-nav-height) + env(safe-area-inset-bottom, 0px));
        padding: 0.42rem 0.35rem calc(0.42rem + env(safe-area-inset-bottom, 0px));
        border-top: 2px solid color-mix(in srgb, var(--slams-border) 80%, transparent);
        background: color-mix(in srgb, var(--slams-surface) 94%, transparent);
        box-shadow: 0 -12px 32px rgba(15, 23, 42, 0.14);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
    }

    .slams-mobile-nav-item {
        position: relative;
        display: flex;
        min-width: 0;
        min-height: 56px;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        gap: 0.2rem;
        border-radius: 8px;
        color: var(--slams-muted);
        font-size: 0.72rem;
        font-weight: 700;
        text-decoration: none;
    }

    .slams-mobile-nav-item i {
        font-size: 1.15rem;
        line-height: 1;
    }

    .slams-mobile-nav-item span {
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .slams-mobile-nav-item.active {
        color: var(--slams-primary);
        background: color-mix(in srgb, var(--slams-primary) 10%, transparent);
    }

    .slams-mobile-nav-item.active::before {
        content: '';
        position: absolute;
        top: -2px;
        left: 20%;
        right: 20%;
        height: 3px;
        border-radius: 0 0 3px 3px;
        background: var(--slams-primary);
    }

    .slams-mobile-nav-item:focus,
    .slams-mobile-nav-item:hover {
        color: var(--slams-primary);
        background: color-mix(in srgb, var(--slams-primary) 12%, transparent);
    }

    .slams-mobile-nav-badge {
        position: absolute;
        top: 0.3rem;
        right: 0.55rem;
        min-width: 18px;
        padding: 0 0.3rem;
        border-radius: 999px;
        background: #dc2626;
        color: #fff;
        font-size: 0.64rem;
        font-weight: 700;
        line-height: 18px;
        text-align: center;
    }

    .slams-mobile-nav-logout {
        padding: 0;
        background: none;
        border: none;
    }

    .slams-mobile-nav-logout button {
        display: flex;
        width: 100%;
        height: 100%;
        min-height: 56px;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        gap: 0.2rem;
        border-radius: 8px;
        padding: 0;
        background: none;
        border: none;
        color: var(--slams-muted);
        font-size: 0.72rem;
        font-weight: 700;
        cursor: pointer;
    }

    .slams-mobile-nav-logout button:hover,
    .slams-mobile-nav-logout button:focus {
        color: var(--slams-primary);
        background: color-mix(in srgb, var(--slams-primary) 12%, transparent);
    }

    .slams-mobile-nav-logout button i {
        font-size: 1.15rem;
        line-height: 1;
    }
}

@media (max-width: 767.98px) {
    .slams-navbar-app-actions {
        gap: 0.36rem;
    }

    .slams-navbar-app-btn {
        width: 38px;
        height: 38px;
        min-height: 38px;
    }

    .notification-device-toggle {
        width: auto;
        min-width: 96px;
        padding: 0 0.68rem;
    }

    .slams-mobile-app .admin-glass-navbar {
        min-height: 60px;
    }

    .slams-mobile-app .navbar-title h4 {
        max-width: 58vw;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .slams-mobile-app .navbar-actions {
        gap: 0.35rem;
    }

    .slams-mobile-app .user-profile-glass .user-info {
        display: none;
    }

    .slams-mobile-app .btn-logout-glass {
        min-height: 38px;
        padding-inline: 0.8rem;
    }

    .slams-mobile-app .card,
    .slams-mobile-app .quick-action-card,
    .slams-mobile-app .booking-card,
    .slams-mobile-app .asset-card,
    .slams-mobile-app .glass-card {
        border-radius: 8px !important;
    }

    .slams-mobile-app .table-responsive {
        border: 1px solid var(--slams-border);
        border-radius: 8px;
        background: var(--slams-surface);
    }

    .slams-mobile-app .modal-dialog {
        margin: 0.5rem;
    }

    .slams-mobile-app input,
    .slams-mobile-app select,
    .slams-mobile-app textarea,
    .slams-mobile-app .btn {
        min-height: 44px;
    }

}
