/* Grab Style Admin UI Overrides */

:root {
    /* Brand Colors (Keep originals as utilities if needed) */
    --grab-green: #00B14F;
    --grab-light-green: #E6F7ED;
    --grab-orange: #FF8A00;
    --grab-light-orange: #FFF3E5;
    --grab-blue: #0085FF;
    --grab-light-blue: #E5F3FF;
    
    /* Primary (Rebranded to Teal) */
    --grab-primary: #1ABC9C;
    --grab-primary-hover: #16A085;
    --grab-primary-dark: #117A65;
    --grab-soft-bg: rgba(26, 188, 156, 0.2);
    
    /* Layout Variables */
    --grab-dark: #1C1C1C;
    --grab-gray: #757575;
    --grab-surface: #F8F9FA;
    --grab-text-main: #1C1C1C;
    --grab-text-muted: #757575;
    --grab-border: rgba(0,0,0,0.05);

    /* Override legacy variables */
    --primary-color: #1ABC9C !important;
    --primary-clr: #1ABC9C !important;
    
    /* Shape & Depth */
    --grab-shadow: 0 4px 20px rgba(0,0,0,0.03);
    --grab-radius: 12px;
}

/* Global Base Overrides */
.content.container-fluid {
    background-color: var(--grab-surface);
    padding-top: 1.5rem;
}

/* Page Header */
.page-header-title {
    color: var(--grab-text-main);
    font-weight: 700;
}

/* Global Cards */
.card, .grab-card {
    background-color: #fff;
    border-radius: var(--grab-radius);
    border: none !important;
    box-shadow: var(--grab-shadow);
    transition: all 0.2s ease;
}

.card:hover, .grab-card:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

.card-header, .grab-card .card-header {
    background-color: transparent;
    border-bottom: 1px solid var(--grab-border);
    padding: 1.25rem 1.5rem;
}

/* Base Bootstrap Overrides */
.text-primary {
    color: var(--grab-primary) !important;
}

.bg-primary {
    background-color: var(--grab-primary) !important;
}

.border-primary {
    border-color: var(--grab-primary) !important;
}

/* Buttons */
.btn-primary {
    background-color: var(--grab-primary);
    border-color: var(--grab-primary);
    border-radius: 8px;
    font-weight: 600;
}
.btn-primary:hover {
    background-color: var(--grab-primary-hover);
    border-color: var(--grab-primary-hover);
}

/* Form Controls */
.form-control, .custom-select {
    border-radius: 8px;
    border-color: var(--grab-border);
}
.form-control:focus, .custom-select:focus {
    box-shadow: 0 0 0 0.2rem var(--grab-soft-bg);
    border-color: var(--grab-primary);
}
.badge-grab {
    padding: 0.4rem 0.8rem;
    font-weight: 600;
    border-radius: 50px;
    font-size: 0.75rem;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.badge-grab-delivery {
    background-color: var(--grab-light-orange);
    color: var(--grab-orange);
    border: 1px solid rgba(255, 138, 0, 0.2);
}

.badge-grab-ride {
    background-color: var(--grab-light-green);
    color: var(--grab-green);
    border: 1px solid rgba(0, 177, 79, 0.2);
}

/* Status Indicators */
.status-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    margin-right: 6px;
}

.status-online {
    background-color: var(--grab-green);
    box-shadow: 0 0 0 0 rgba(0, 177, 79, 0.7);
    animation: pulse-green 2s infinite;
}

.status-offline {
    background-color: var(--grab-gray);
}

@keyframes pulse-green {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(0, 177, 79, 0.7);
    }
    70% {
        transform: scale(1);
        box-shadow: 0 0 0 10px rgba(0, 177, 79, 0);
    }
    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(0, 177, 79, 0);
    }
}

/* Table Enhancements */
.table-thead-bordered th {
    background-color: #F8F9FA;
    font-weight: 700;
    color: var(--grab-dark);
}

.card-table tr:hover {
    background-color: #F9FFF7 !important;
    transition: background-color 0.2s ease;
}

.table-rest-info img {
    border: 2px solid #fff;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.info .rating {
    color: #FFC107;
    font-weight: bold;
    cursor: pointer;
}

/* KPI Cards */
.grab-kpi-card {
    transition: all 0.3s ease;
    border-radius: 12px !important;
}

.grab-kpi-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1) !important;
}

.grab-icon-circle {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.grab-kpi-card:hover .grab-icon-circle {
    transform: scale(1.1);
}

/* Sidebar & Navigation Overrides (Grab Style) */
.navbar-vertical-aside,
.navbar-vertical-container,
.navbar-brand-wrapper {
    border-right: none !important;
    background-color: #fff !important;
}
.navbar-vertical-aside {
    box-shadow: var(--grab-shadow);
}
.navbar-vertical-aside .nav-link,
.navbar-vertical-container .nav-link,
.navbar-vertical-content .nav-link,
.navbar-vertical-aside .nav-subtitle {
    transition: all 0.2s ease;
    border-radius: 8px;
    margin: 2px 10px;
    padding: 0.65rem 1rem;
    color: var(--grab-text-main) !important;
}
.navbar-vertical-aside .nav-link .nav-icon {
    color: var(--grab-text-muted) !important;
}
.navbar-vertical-aside .navbar-vertical-aside-has-menu.show.active > .nav-link,
.navbar-vertical-aside .navbar-vertical-aside-has-menu.active > .nav-link,
.navbar-vertical-aside .nav-item.active > .nav-link {
    background-color: var(--grab-soft-bg) !important;
    color: var(--grab-primary-dark) !important;
}
.navbar-vertical-aside .navbar-vertical-aside-has-menu.show.active > .nav-link .nav-icon,
.navbar-vertical-aside .navbar-vertical-aside-has-menu.active > .nav-link .nav-icon,
.navbar-vertical-aside .nav-item.active > .nav-link .nav-icon {
    color: var(--grab-primary-dark) !important;
}
.navbar-vertical .nav-link:hover {
    background-color: rgba(26, 188, 156, 0.05) !important;
    color: var(--grab-primary) !important;
}
.navbar-vertical .nav-link:hover .nav-icon {
    color: var(--grab-primary) !important;
}

/* Sidebar Search Form Overrides */
.sidebar--search-form {
    background-color: #fff !important;
}
.sidebar--search-form .form--control {
    background-color: var(--grab-bg-light, #F7F7F7) !important;
    border: 1px solid #E5E5E5 !important;
    color: var(--grab-text-main) !important;
    box-shadow: none !important;
}
.sidebar--search-form .form--control::placeholder {
    color: var(--grab-text-muted) !important;
}
.sidebar--search-form .form--control:focus {
    background-color: #fff !important;
    border-color: var(--grab-primary) !important;
    box-shadow: 0 0 0 1px var(--grab-primary) inset !important;
}
.sidebar--search-form .search--form-group .btn {
    color: var(--grab-text-muted) !important;
}
/* Submenu indicators */
.navbar-vertical .nav-indicator-icon,
.navbar-vertical .tio-circle {
    font-size: 0.6rem;
}
.navbar-vertical .active > .nav-link .tio-circle {
    color: var(--grab-primary) !important;
}

/* Header Overrides (Grab Style) */
#header {
    border-bottom: none !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.02);
    background-color: #fff;
    padding: 0.5rem 1rem;
}
.__navbar-nav > .__nav-item > .__nav-link.active {
    color: var(--grab-primary) !important;
    background-color: var(--grab-soft-bg) !important;
    border-radius: 8px;
}
.__navbar-nav > .__nav-item > .__nav-link:hover {
    color: var(--grab-primary) !important;
    background-color: rgba(26, 188, 156, 0.05) !important;
    border-radius: 8px;
}
.__navbar-nav .btn-status-danger {
    background-color: #FF5A5F; /* Grab red notification */
}

/* search box in header */
.global-search-container .search-input {
    border: 1px solid var(--grab-border) !important;
    border-radius: 12px !important;
    padding-left: 2.5rem !important;
    background-color: var(--grab-surface);
}
.global-search-container .search-input:focus {
    border-color: var(--grab-primary) !important;
    box-shadow: 0 0 0 3px var(--grab-soft-bg) !important;
    background-color: #fff;
}

/* Pagination Overrides */
.pagination .page-item.active .page-link {
    background-color: var(--grab-primary) !important;
    border-color: var(--grab-primary) !important;
    color: #fff !important;
    border-radius: 4px;
}
.pagination .page-link {
    color: var(--grab-text-main);
    border: none;
    margin: 0 2px;
    border-radius: 4px;
    transition: all 0.2s;
}
.pagination .page-link:hover {
    background-color: var(--grab-soft-bg);
    color: var(--grab-primary);
}
/* Dashboard Minimal Status Cards */
.order--card {
    background-color: #fff;
    border-radius: var(--grab-radius);
    border: 1px solid var(--grab-border);
    padding: 1rem 1.25rem;
    transition: all 0.2s;
}
.order--card:hover {
    border-color: var(--grab-primary);
    box-shadow: var(--grab-shadow);
}
.order--card .card-subtitle {
    font-size: 0.85rem;
    color: var(--grab-text-muted);
    font-weight: 500;
}
.order--card .card-title {
    font-size: 1.5rem;
    font-weight: 700;
}
.oder--card-icon {
    width: 24px;
    height: 24px;
    opacity: 0.7;
    filter: grayscale(100%);
    transition: filter 0.2s;
}
.order--card:hover .oder--card-icon {
    filter: grayscale(0%);
}

/* Dashboard Top Bar Stat Cards */
.__dashboard-card-2 {
    background-color: #fff;
    border: none;
    border-radius: var(--grab-radius);
    box-shadow: var(--grab-shadow);
    padding: 1.5rem;
    text-align: center;
}
.__dashboard-card-2 img {
    width: 48px;
    height: 48px;
    margin-bottom: 1rem;
    background: var(--grab-soft-bg);
    padding: 10px;
    border-radius: 50%;
}
.__dashboard-card-2 .name {
    color: var(--grab-text-muted);
    font-weight: 500;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.5px;
}
.__dashboard-card-2 .count {
    color: var(--grab-text-main);
    font-weight: 700;
    font-size: 1.75rem;
    margin: 0.5rem 0;
}
