/* ========================================
   DJ Travel Dashboard - B2B Agency Styles
   ======================================== */


/* Modal Styles */

.modal-content {
    border: none;
    border-radius: var(--dj-border-radius-lg);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

.modal-header {
    background: linear-gradient(135deg, var(--dj-primary), #0056b3);
    color: var(--dj-white);
    border-bottom: none;
    border-radius: var(--dj-border-radius-lg) var(--dj-border-radius-lg) 0 0;
    padding: 20px 25px;
}

.modal-header .modal-title {
    font-size: 18px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 10px;
}

.modal-header .btn-close {
    background: transparent;
    border: none;
    color: var(--dj-white);
    opacity: 0.8;
    font-size: 20px;
}

.modal-header .btn-close:hover {
    opacity: 1;
}

.modal-body {
    padding: 25px;
}

.modal-footer {
    border-top: 1px solid var(--dj-gray-200);
    padding: 20px 25px;
    background: var(--dj-gray-100);
    border-radius: 0 0 var(--dj-border-radius-lg) var(--dj-border-radius-lg);
}


/* Tour Details Modal */

.dj-reservation-details-card {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius);
    padding: 25px;
    margin-bottom: 20px;
    border: 1px solid var(--dj-gray-200);
}

.dj-tour-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 2px solid var(--dj-gray-200);
}

.dj-tour-header h4 {
    color: var(--dj-dark);
    font-weight: 700;
    margin: 0;
    flex: 1;
}

.dj-tour-category {
    background: var(--dj-primary);
    color: var(--dj-white);
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 5px;
}

.dj-detail-item {
    margin-bottom: 15px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.dj-detail-item strong {
    color: var(--dj-dark);
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.dj-detail-item span {
    color: var(--dj-gray-600);
    font-size: 14px;
    margin-left: 22px;
}

.dj-program-days {
    background: var(--dj-gray-100);
    border-radius: var(--dj-border-radius);
    padding: 20px;
}

.dj-day-item {
    margin-bottom: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--dj-gray-300);
    font-size: 14px;
    line-height: 1.5;
}

.dj-day-item:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

.dj-day-item strong {
    color: var(--dj-primary);
    margin-right: 8px;
}


/* Customer Summary */

.dj-customer-summary,
.dj-payment-summary,
.dj-booking-timeline {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius);
    padding: 20px;
    border: 1px solid var(--dj-gray-200);
}

.dj-customer-card {
    background: var(--dj-gray-100);
    border-radius: var(--dj-border-radius-sm);
    padding: 15px;
}

.dj-customer-card h5 {
    color: var(--dj-dark);
    margin-bottom: 10px;
    font-weight: 700;
}

.dj-customer-card p {
    margin-bottom: 8px;
    font-size: 14px;
    color: var(--dj-gray-600);
    display: flex;
    align-items: center;
    gap: 8px;
}

.dj-customer-card p:last-child {
    margin-bottom: 0;
}


/* Payment Breakdown */

.dj-payment-breakdown {
    background: var(--dj-gray-100);
    border-radius: var(--dj-border-radius-sm);
    padding: 15px;
}

.dj-payment-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    font-size: 14px;
}

.dj-payment-line:last-child {
    margin-bottom: 0;
}

.dj-payment-line.total {
    font-size: 16px;
    font-weight: 700;
    color: var(--dj-dark);
    padding-top: 10px;
}

.dj-payment-status {
    text-align: center;
    margin-top: 15px;
}


/* Timeline */

.dj-timeline {
    position: relative;
    padding-left: 20px;
}

.dj-timeline::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--dj-primary);
}

.dj-timeline-item {
    position: relative;
    margin-bottom: 20px;
}

.dj-timeline-item::before {
    content: '';
    position: absolute;
    left: -16px;
    top: 5px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--dj-primary);
    border: 3px solid var(--dj-white);
    box-shadow: 0 0 0 2px var(--dj-primary);
}

.dj-timeline-date {
    font-size: 12px;
    color: var(--dj-gray-500);
    font-weight: 600;
}

.dj-timeline-content {
    font-size: 14px;
    color: var(--dj-gray-700);
    margin-top: 2px;
}


/* Group Requests & Visa Applications */

.dj-group-requests-section,
.dj-visa-section {
    padding: 20px 0;
}

.dj-group-stats,
.dj-visa-stats {
    margin-bottom: 30px;
}

.dj-request-id,
.dj-visa-id {
    font-weight: 600;
    color: var(--dj-primary);
}

.dj-destination,
.dj-visa-country,
.dj-visa-type {
    font-weight: 500;
    color: var(--dj-gray-700);
}

.dj-person-count {
    font-weight: 600;
    color: var(--dj-dark);
    text-align: center;
}

.dj-request-actions,
.dj-visa-actions {
    display: flex;
    gap: 5px;
    justify-content: center;
}


/* Critical Navigation Visibility Fix */

.dj-nav-list,
.dj-nav-item,
.dj-nav-link,
.dj-nav-text,
.dj-nav-icon,
.dj-nav-badge,
.dj-nav-arrow {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.dj-nav-link {
    display: flex !important;
}

.dj-nav-icon,
.dj-nav-text,
.dj-nav-badge,
.dj-nav-arrow {
    display: inline-block !important;
}


/* Dashboard Main Container */

.dj-dashboard-main {
    background: var(--dj-light);
    min-height: calc(100vh - var(--header-height));
    padding: var(--dj-spacing-lg);
    position: relative;
    z-index: 1;
}

.dj-dashboard-container {
    max-width: 100%;
    margin: 0;
    padding: 0;
}

.dj-dashboard-main .container-fluid {
    padding: 0;
    max-width: 100%;
}

.dj-dashboard-main .row {
    margin: 0;
    display: flex;
    flex-wrap: nowrap;
    --bs-gutter-x: 0;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 30px;
}

.dj-dashboard-main .col-lg-3,
.dj-dashboard-main .col-xl-2,
.dj-dashboard-main .col-lg-9,
.dj-dashboard-main .col-xl-10 {
    padding-left: 0;
    padding-right: 0;
}


/* ========================================
   Sidebar Styles
   ======================================== */

.dj-dashboard-sidebar {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius-lg);
    border: none;
    box-shadow: none;
    padding: var(--dj-spacing-xl);
    height: 100%;
    position: static;
    width: 100%;
    transition: var(--dj-transition);
    overflow: visible;
    margin: 0;
}


/* Company Profile Section */

.dj-company-profile {
    margin-bottom: var(--dj-spacing-md);
    padding: var(--dj-spacing-md);
    background: linear-gradient(135deg, var(--dj-primary) 0%, #0056b3 100%);
    border-radius: var(--dj-border-radius);
    color: var(--dj-white);
    position: relative;
    overflow: hidden;
}

.dj-company-header {
    display: flex;
    align-items: center;
    gap: 12px;
}

.dj-company-profile::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="1"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');
    opacity: 0.5;
}

.dj-company-avatar {
    position: relative;
    width: 50px;
    height: 50px;
    flex-shrink: 0;
    z-index: 1;
}

.dj-company-logo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    border: 3px solid rgba(255, 255, 255, 0.3);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.dj-company-status-indicator {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 24px;
    height: 24px;
    background: #28a745;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 14px;
    border: 2px solid white;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.dj-company-info {
    position: relative;
    z-index: 1;
}

.dj-company-name {
    font-size: 16px;
    font-weight: 700;
    color: white;
    margin-bottom: 4px;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.dj-company-email {
    color: rgba(255, 255, 255, 0.9);
    font-size: 14px;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 4px;
}

.dj-company-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 600;
    padding: 6px 12px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.2);
    color: white;
    backdrop-filter: blur(10px);
}

.dj-status-verified {
    background: rgba(40, 167, 69, 0.2);
    color: #d4edda;
}


/* Navigation Menu */

.dj-dashboard-nav {
    margin-bottom: 24px;
    background: transparent;
    padding: 0;
}

.dj-nav-title {
    font-size: 14px;
    font-weight: 700;
    color: #2c3e50;
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 0 12px;
}

.dj-nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.dj-nav-item {
    margin-bottom: 2px;
}

.dj-nav-link {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 10px 15px !important;
    border: none;
    background: none;
    color: #2c3e50 !important;
    text-decoration: none;
    border-radius: 8px;
    transition: all 0.3s ease;
    width: 100% !important;
    text-align: left;
    font-size: 14px;
    font-weight: 500;
    min-height: 44px;
    box-sizing: border-box;
    position: relative;
}

.dj-nav-link:hover {
    background: #f8f9fa;
    color: #007bff;
    transform: translateX(2px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.dj-nav-link.active {
    background: linear-gradient(135deg, #007bff, #0056b3);
    color: white;
    box-shadow: 0 4px 16px rgba(0, 123, 255, 0.3);
    transform: translateX(4px);
}

.dj-nav-link.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: #ffd700;
    border-radius: 0 3px 3px 0;
}

.dj-nav-icon {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    flex-shrink: 0;
}

.dj-nav-text {
    flex: 1;
    text-align: left;
    font-size: 16px;
    font-weight: 600;
    white-space: nowrap;
    overflow: visible;
    text-overflow: ellipsis;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    line-height: 1.4;
    transition: all 0.3s ease;
    color: #2c3e50 !important;
    margin-top: 0px;
    margin-bottom: 5px;
}

.dj-nav-badge {
    background: #dc3545;
    color: white;
    font-size: 14px;
    padding: 2px 6px;
    border-radius: 10px;
    font-weight: 600;
    min-width: 18px;
    text-align: center;
}


/* Quick Actions */

.dj-quick-actions {
    background: transparent;
    border-radius: 0;
    padding: 20px 0;
    margin-bottom: 24px;
    border: none;
    box-shadow: none;
}

.dj-action-buttons {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.dj-action-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    min-height: 44px;
    color: white;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.dj-action-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.dj-action-btn i {
    font-size: 16px;
}

.dj-action-btn span {
    font-weight: 500;
}


/* Recent Activity */

.dj-recent-activity {
    background: transparent;
    border-radius: 0;
    padding: 20px 0;
    border: none;
    box-shadow: none;
}

.dj-activity-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.dj-activity-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: white;
    border-radius: 8px;
    transition: all 0.3s ease;
    border: 1px solid #f1f3f4;
}

.dj-activity-item:hover {
    transform: translateX(2px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.dj-activity-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 14px;
    flex-shrink: 0;
}

.dj-icon-booking {
    background: linear-gradient(135deg, #007bff, #0056b3);
}

.dj-icon-payment {
    background: linear-gradient(135deg, #28a745, #1e7e34);
}

.dj-icon-customer {
    background: linear-gradient(135deg, #fd7e14, #e8590c);
}

.dj-icon-flight {
    background: linear-gradient(135deg, #007bff, #0056b3);
}

.dj-activity-content {
    flex: 1;
}

.dj-activity-text {
    font-size: 13px;
    color: #2c3e50;
    margin-bottom: 4px;
    font-weight: 500;
}

.dj-activity-time {
    font-size: 14px;
    color: #6c757d;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}


/* ========================================
   Main Content Area
   ======================================== */

.dj-dashboard-content {
    background-color: white;
    border-radius: 15px;
    box-shadow: 0 1px 0px 0px rgba(0, 0, 0, 0.08);
    border: none;
    overflow: hidden;
    flex: 1;
    height: auto;
    transition: all 0.3s ease;
    margin-left: 30px;
}


/* Dashboard Header */

.dj-dashboard-header {
    background: transparent;
    color: #2c3e50;
    padding: 0 0 24px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0;
    border-bottom: 1px solid #e9ecef;
}

.dj-header-left {
    flex: 1;
}

.dj-page-title {
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 8px;
}

.dj-page-subtitle {
    font-size: 16px;
    opacity: 0.9;
    margin: 0;
}

.dj-header-right {
    display: flex;
    align-items: center;
    gap: 24px;
}

.dj-header-stats {
    display: flex;
    align-items: center;
    gap: 24px;
    background: rgba(255, 255, 255, 0.1);
    padding: 16px 24px;
    border-radius: 12px;
    backdrop-filter: blur(10px);
}

.dj-stat-item {
    text-align: center;
}

.dj-stat-value {
    display: block;
    font-size: 20px;
    font-weight: 700;
}

.dj-stat-label {
    font-size: 14px;
    opacity: 0.8;
}

.dj-stat-divider {
    width: 1px;
    height: 40px;
    background: rgba(255, 255, 255, 0.2);
}

.dj-mobile-menu-toggle {
    display: none;
    background: rgba(255, 255, 255, 0.1);
    border: none;
    color: white;
    padding: 12px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.dj-mobile-menu-toggle:hover {
    background: rgba(255, 255, 255, 0.2);
}


/* ========================================
   Tab Content
   ======================================== */

.dj-tab-content {
    padding: 0 0 0 0;
}

.dj-tab-content .tab-pane {
    padding: 0;
}


/* Enhanced Section Spacing */

.dj-flights-section,
.dj-hotels-section,
.dj-customers-section,
.dj-packages-section,
.dj-reservations-section,
.dj-invoices-section,
.dj-reports-section,
.dj-settings-section {
    padding-top: 0px !important;
    padding-left: 0px !important;
    padding-right: 0px !important;
    margin: 20px;
}


/* ========================================
   Overview Section
   ======================================== */

.dj-overview-section {
    padding: 20px;
    padding-top: 0px !important;
    margin-bottom: 32px;
    margin-top: 25px;
    margin-left: 10px;
}


/* Stats Cards */

.dj-stats-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    margin-bottom: 40px;
}

.dj-stats-row .col-lg-3,
.dj-stats-row .col-md-6 {
    margin-bottom: 0;
    padding: 0;
}

.dj-stat-card {
    background: white;
    border-radius: 12px;
    padding: 16px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border: 1px solid #e9ecef;
    overflow: visible;
    height: auto;
    max-height: 140px;
    border-left: 4px solid transparent;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 15px;
    margin-right: 15px;
    position: relative;
    transition: all 0.3s ease;
}

.dj-stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.dj-card-blue {
    border-left-color: #007bff;
}

.dj-card-green {
    border-left-color: #28a745;
}

.dj-card-orange {
    border-left-color: #fd7e14;
}

.dj-card-purple {
    border-left-color: #6f42c1;
}

.dj-stat-card .dj-stat-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    color: white;
    margin-bottom: 0;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.dj-stat-card .dj-stat-icon i {
    position: relative;
    z-index: 3;
    text-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.dj-stat-card:hover .dj-stat-icon {
    transform: translateY(-2px) scale(1.03);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}

.dj-stat-card:hover .dj-stat-icon i {
    transform: scale(1.08);
}

.dj-card-blue .dj-stat-icon {
    background: linear-gradient(135deg, #007bff, #0056b3);
}

.dj-card-blue .dj-stat-icon::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05));
    border-radius: inherit;
    z-index: 1;
}

.dj-card-blue .dj-stat-icon::after {
    content: '';
    position: absolute;
    top: -20%;
    left: -20%;
    width: 140%;
    height: 140%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.15) 0%, transparent 60%);
    animation: shimmer 4s ease-in-out infinite;
    z-index: 2;
}

.dj-card-green .dj-stat-icon {
    background: linear-gradient(135deg, #28a745, #1e7e34);
}

.dj-card-green .dj-stat-icon::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05));
    border-radius: inherit;
    z-index: 1;
}

.dj-card-green .dj-stat-icon::after {
    content: '';
    position: absolute;
    top: -20%;
    left: -20%;
    width: 140%;
    height: 140%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.15) 0%, transparent 60%);
    animation: shimmer 4s ease-in-out infinite 1s;
    z-index: 2;
}

.dj-card-orange .dj-stat-icon {
    background: linear-gradient(135deg, #fd7e14, #e8590c);
}

.dj-card-orange .dj-stat-icon::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05));
    border-radius: inherit;
    z-index: 1;
}

.dj-card-orange .dj-stat-icon::after {
    content: '';
    position: absolute;
    top: -20%;
    left: -20%;
    width: 140%;
    height: 140%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.15) 0%, transparent 60%);
    animation: shimmer 4s ease-in-out infinite 2s;
    z-index: 2;
}

.dj-card-purple .dj-stat-icon {
    background: linear-gradient(135deg, #6f42c1, #59359a);
}

.dj-card-purple .dj-stat-icon::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05));
    border-radius: inherit;
    z-index: 1;
}

.dj-card-purple .dj-stat-icon::after {
    content: '';
    position: absolute;
    top: -20%;
    left: -20%;
    width: 140%;
    height: 140%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.15) 0%, transparent 60%);
    animation: shimmer 4s ease-in-out infinite 3s;
    z-index: 2;
}

.dj-stat-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

.dj-stat-number {
    font-size: 22px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 4px;
    line-height: 1.2;
}

.dj-stat-title {
    font-size: 15px;
    color: #6c757d;
    margin-bottom: 6px;
    font-weight: 500;
    line-height: 1.3;
}

.dj-stat-change {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 14px;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 6px;
}

.dj-positive {
    background: #d4edda;
    color: #155724;
}

.dj-negative {
    background: #f8d7da;
    color: #721c24;
}


/* Activity Section */

.dj-activity-row {
    margin-bottom: 40px;
    gap: 24px;
}

.dj-activity-row {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 24px;
    margin-bottom: 40px;
}

.dj-activity-row .col-lg-8,
.dj-activity-row .col-lg-4 {
    padding: 0;
    margin-bottom: 0;
}

.dj-activity-card,
.dj-quick-stats-card {
    background: white;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: none;
    overflow: hidden;
    height: 100%;
    transition: all 0.3s ease;
}

.dj-activity-card:hover,
.dj-quick-stats-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.dj-card-header {
    padding: 12px 15px;
    border-bottom: 1px solid #f1f3f4;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #fafbfc;
}

.dj-card-title i {
    font-size: 16px;
    color: var(--dj-primary);
    flex-shrink: 0;
}

.dj-btn-link {
    background: linear-gradient(135deg, #007bff, #0056b3);
    border: none;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    padding: 8px 16px;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 2px 8px rgba(0, 123, 255, 0.2);
    display: inline-block;
}

.dj-btn-link:hover {
    background: linear-gradient(135deg, #0056b3, #004085);
    color: #ffffff;
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
}


/* Reservation List - Compact */

.dj-reservation-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    background: #f8f9fa;
    border-radius: 6px;
    transition: all 0.3s ease;
    border: 1px solid #f1f3f4;
}

.dj-reservation-item:hover {
    background: #e9ecef;
    transform: translateX(2px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    border-color: #e9ecef;
}

.dj-reservation-details {
    flex: 1;
}

.dj-reservation-title {
    font-size: 15px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 2px;
    line-height: 1.3;
}

.dj-reservation-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    color: #6c757d;
}

.dj-reservation-date {
    font-size: 12px;
    color: #adb5bd;
}


/* Status Badges */


/* Common Status System */

.dj-status,
.dj-status-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    min-height: 32px;
    white-space: nowrap;
}

.dj-status-confirmed {
    background: #d4edda;
    color: #155724;
}

.dj-status-pending {
    background: #fff3cd;
    color: #856404;
}

.dj-status-cancelled {
    background: #f8d7da;
    color: #721c24;
}

.dj-status-paid {
    background: #d1ecf1;
    color: #0c5460;
}

.dj-status-verified {
    background: rgba(40, 167, 69, 0.2);
    color: #d4edda;
}

.dj-status-connected {
    background: #d4edda;
    color: #155724;
}


/* Quick Stats */

.dj-quick-stat-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid #e9ecef;
}

.dj-quick-stat-item:last-child {
    border-bottom: none;
}

.dj-quick-stat-icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: white;
}


/* Common Icon System */

.dj-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--dj-border-radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: var(--dj-white);
    flex-shrink: 0;
}

.dj-icon-blue {
    background: linear-gradient(135deg, var(--dj-primary), #0056b3);
}

.dj-icon-green {
    background: linear-gradient(135deg, var(--dj-success), #1e7e34);
}

.dj-icon-orange {
    background: linear-gradient(135deg, #fd7e14, #e8590c);
}

.dj-icon-purple {
    background: linear-gradient(135deg, #6f42c1, #5a32a3);
}

.dj-icon-info {
    background: linear-gradient(135deg, var(--dj-info), #138496);
}

.dj-icon-warning {
    background: linear-gradient(135deg, var(--dj-warning), #e0a800);
}

.dj-icon-success {
    background: linear-gradient(135deg, var(--dj-success), #1e7e34);
}

.dj-quick-stat-info {
    flex: 1;
}

.dj-quick-stat-number {
    font-size: 18px;
    font-weight: 700;
    color: #2c3e50;
    display: block;
}

.dj-quick-stat-label {
    font-size: 14px;
    color: #6c757d;
}


/* ========================================
   Section Headers
   ======================================== */

.dj-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid #e9ecef;
    margin-bottom: 20px;
    padding-bottom: 15px;
}

.dj-section-title {
    font-size: 24px;
    font-weight: 700;
    color: #2c3e50;
    margin: 0;
}

.dj-section-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}


/* Search Box */

.dj-search-box {
    position: relative;
}

.dj-search-box i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #6c757d;
    font-size: 14px;
}


/* Common Form System */

.dj-form-control,
.dj-search-input {
    padding: 10px 12px;
    border: 1px solid var(--dj-gray-400);
    border-radius: var(--dj-border-radius-sm);
    font-size: 14px;
    transition: var(--dj-transition);
}

.dj-search-input {
    padding-left: 36px;
    width: 240px;
}

.dj-form-control:focus,
.dj-search-input:focus {
    outline: none;
    border-color: var(--dj-primary);
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}


/* Filter Dropdown */

.dj-filter-dropdown {
    position: relative;
}

.dj-filter-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: #f8f9fa;
    border: 1px solid #ced4da;
    border-radius: 8px;
    font-size: 14px;
    color: #495057;
    cursor: pointer;
    transition: all 0.3s ease;
}

.dj-filter-btn:hover {
    background: #e9ecef;
    border-color: #adb5bd;
}


/* ========================================
   Tables
   ======================================== */

.dj-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 24px;
}

.dj-table-header th {
    background: #f8f9fa;
    padding: 16px 12px;
    text-align: left;
    font-weight: 600;
    color: #495057;
    border-bottom: 2px solid #e9ecef;
    font-size: 14px;
}

.dj-table-body td {
    padding: 16px 12px;
    border-bottom: 1px solid #e9ecef;
    font-size: 14px;
    vertical-align: middle;
}

.dj-table-row:hover {
    background: #f8f9fa;
}

.dj-booking-id {
    font-family: 'Courier New', monospace;
    font-weight: 600;
    color: #007bff;
}

.dj-customer-details {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dj-customer-name {
    font-weight: 500;
    color: #2c3e50;
}

.dj-customer-email,
.dj-customer-company {
    font-size: 14px;
    color: #6c757d;
}


/* Service Badges */

.dj-service-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dj-service-flight {
    background: #e3f2fd;
    color: #1565c0;
}

.dj-service-hotel {
    background: #e8f5e8;
    color: #2e7d32;
}

.dj-service-tour {
    background: #fff3e0;
    color: #ef6c00;
}


/* Action Dropdown */

.dj-action-dropdown {
    position: relative;
}

.dj-action-toggle {
    background: none;
    border: none;
    padding: 8px 12px;
    border-radius: 6px;
    cursor: pointer;
    color: #6c757d;
    transition: all 0.3s ease;
    min-height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dj-action-toggle:hover {
    background: #f8f9fa;
    color: #495057;
}


/* Pagination */

.dj-table-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 32px;
    margin-bottom: 24px;
}

.dj-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.dj-pagination .page-item {
    margin: 0;
}

.dj-pagination .page-link {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    min-width: 44px;
    height: 44px;
    border: 1px solid #e9ecef;
    border-radius: 8px;
    color: #495057;
    text-decoration: none;
    font-weight: 500;
    font-size: 14px;
    transition: all 0.3s ease;
    background: white;
    box-sizing: border-box;
}

.dj-pagination .page-link:hover {
    background: #f8f9fa;
    border-color: #007bff;
    color: #007bff;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 123, 255, 0.15);
}

.dj-pagination .page-item.active .page-link {
    background: #007bff;
    border-color: #007bff;
    color: white;
    font-weight: 600;
    box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
}

.dj-pagination .page-item.disabled .page-link {
    background: #f8f9fa;
    border-color: #e9ecef;
    color: #adb5bd;
    cursor: not-allowed;
    opacity: 0.6;
}

.dj-pagination .page-item.disabled .page-link:hover {
    background: #f8f9fa;
    border-color: #e9ecef;
    color: #adb5bd;
    transform: none;
    box-shadow: none;
}


/* Navigation arrows */

.dj-pagination .page-link i {
    font-size: 14px;
}


/* ========================================
   Forms
   ======================================== */

.dj-form-group {
    margin-bottom: 20px;
}

.dj-form-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    color: #495057;
    margin-bottom: 8px;
    font-size: 14px;
}

.dj-form-label i {
    color: #6c757d;
}

.dj-form-control {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--dj-gray-400);
    border-radius: var(--dj-border-radius-sm);
    font-size: 14px;
    transition: var(--dj-transition);
    background: var(--dj-white);
    color: var(--dj-gray-700);
}

.dj-form-control:focus {
    outline: none;
    border-color: var(--dj-primary);
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}

.dj-form-control:disabled {
    background: var(--dj-gray-100);
    color: var(--dj-gray-600);
    cursor: not-allowed;
}


/* Password Input */

.dj-password-input {
    position: relative;
}

.dj-password-toggle {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: #6c757d;
    cursor: pointer;
    padding: 4px;
}

.dj-password-toggle:hover {
    color: #495057;
}


/* Toggle Switch */

.dj-toggle-switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 24px;
}

.dj-toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.dj-toggle-label {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #ccc;
    border-radius: 24px;
    transition: 0.3s;
}

.dj-toggle-label:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 3px;
    background: white;
    border-radius: 50%;
    transition: 0.3s;
}

input:checked+.dj-toggle-label {
    background: #007bff;
}

input:checked+.dj-toggle-label:before {
    transform: translateX(26px);
}


/* ========================================
   Cards
   ======================================== */

.dj-security-card,
.dj-settings-card {
    background: white;
    border-radius: 16px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    border: 1px solid #e9ecef;
    margin-bottom: 24px;
    overflow: hidden;
    margin-right: 15px;
}

.dj-card-subtitle {
    font-size: 14px;
    color: #6c757d;
    margin-top: 4px;
    margin-bottom: 0;
}


/* Billing Cards */

.dj-billing-overview {
    margin-bottom: 32px;
}

.dj-billing-card {
    background: white;
    border-radius: 16px;
    margin-right: 15px;
    padding: 30px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    border: 1px solid #e9ecef;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 16px;
}

.dj-billing-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.dj-billing-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    color: white;
    flex-shrink: 0;
}

.dj-card-revenue .dj-billing-icon {
    background: linear-gradient(135deg, #28a745, #1e7e34);
}

.dj-card-pending .dj-billing-icon {
    background: linear-gradient(135deg, #ffc107, #e0a800);
}

.dj-card-overdue .dj-billing-icon {
    background: linear-gradient(135deg, #dc3545, #c82333);
}

.dj-billing-amount {
    font-size: 24px;
    font-weight: 700;
    color: #2c3e50;
    margin-bottom: 4px;
}

.dj-billing-label {
    font-size: 14px;
    color: #6c757d;
    margin-bottom: 4px;
}

.dj-billing-period {
    font-size: 14px;
    color: #adb5bd;
}


/* Payment Cards */

.dj-payment-methods {
    margin-bottom: 32px;
}

.dj-payment-card {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 16px;
    padding: 24px;
    color: white;
    margin-bottom: 16px;
}

.dj-payment-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.dj-card-primary {
    background: linear-gradient(135deg, #007bff 0%, #0056b3 100%);
    border: 2px solid #ffd700;
}

.dj-payment-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}

.dj-payment-type {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
}

.dj-payment-type i {
    font-size: 20px;
}

.dj-payment-status {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dj-status-primary {
    color: #ffd700;
}

.dj-status-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: currentColor;
}

.dj-payment-details {
    margin-bottom: 16px;
}

.dj-card-number {
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 2px;
    margin-bottom: 8px;
}

.dj-card-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dj-card-holder,
.dj-card-expiry {
    font-size: 14px;
    opacity: 0.9;
}

.dj-payment-actions {
    display: flex;
    gap: 8px;
}


/* Transaction List */

.dj-transaction-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.dj-transaction-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: #f8f9fa;
    border-radius: 12px;
    transition: all 0.3s ease;
}

.dj-transaction-item:hover {
    background: #e9ecef;
}

.dj-transaction-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: white;
    flex-shrink: 0;
}

.dj-transaction-details {
    flex: 1;
}

.dj-transaction-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 4px;
}

.dj-transaction-info {
    font-size: 14px;
    color: #6c757d;
    margin-bottom: 4px;
}

.dj-transaction-date {
    font-size: 14px;
    color: #adb5bd;
}

.dj-transaction-amount {
    font-size: 16px;
    font-weight: 700;
}

.dj-amount-positive {
    color: #28a745;
}

.dj-amount-negative {
    color: #dc3545;
}


/* ========================================
   Privacy & Settings
   ======================================== */

.dj-privacy-options,
.dj-notification-options {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.dj-privacy-item,
.dj-notification-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: #f8f9fa;
    border-radius: 12px;
}

.dj-privacy-title,
.dj-notification-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 4px;
}

.dj-privacy-desc,
.dj-notification-desc {
    font-size: 14px;
    color: #6c757d;
    margin: 0;
}


/* 2FA Status */

.dj-2fa-status {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: #f8f9fa;
    border-radius: 12px;
}

.dj-2fa-info {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dj-2fa-label {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
}


/* Danger Zone */

.dj-danger-zone {
    border: 2px solid #dc3545;
    border-radius: 16px;
}

.dj-danger-zone .dj-card-header {
    background: #f8d7da;
    border-bottom-color: #dc3545;
}

.dj-danger-actions {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.dj-danger-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: #f8f9fa;
    border-radius: 12px;
}

.dj-danger-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 4px;
}

.dj-danger-desc {
    font-size: 14px;
    color: #6c757d;
    margin: 0;
}


/* Button Icons */

.dj-btn-icon {
    background: none;
    border: none;
    padding: 8px;
    border-radius: 6px;
    cursor: pointer;
    color: #6c757d;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
}

.dj-btn-icon:hover {
    background: #f8f9fa;
    color: #495057;
}


/* Subsection Titles */

.dj-subsection-title {
    font-size: 18px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid #e9ecef;
}


/* ========================================
   Responsive Design
   ======================================== */

@media (max-width: 991.98px) {
    .dj-dashboard-main {
        padding: 16px;
    }
    .dj-dashboard-main .row {
        flex-wrap: wrap;
        border-radius: 12px;
        min-height: calc(100vh - var(--header-height) - 32px);
    }
    .dj-dashboard-sidebar {
        position: fixed;
        left: -280px;
        z-index: 1050;
        top: var(--header-height);
        height: calc(100vh - var(--header-height));
        width: 280px;
        background: #f8f9fa;
        border-radius: 0;
    }
    .dj-dashboard-sidebar.active {
        left: 0;
    }
    .dj-dashboard-content {
        flex: 1;
        width: 100%;
        padding: 24px;
    }
    .dj-sidebar-toggle {
        display: none;
    }
    .dj-mobile-menu-toggle {
        display: block;
    }
    .dj-dashboard-header {
        padding: 24px 20px;
    }
    .dj-header-stats {
        display: none;
    }
    .dj-section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }
    .dj-section-actions {
        width: 100%;
        justify-content: flex-start;
    }
    .dj-search-box {
        width: 100%;
    }
    .dj-stats-row .col-lg-3 {
        margin-bottom: 16px;
    }
    .dj-billing-card {
        flex-direction: column;
        text-align: center;
    }
    .dj-payment-actions {
        justify-content: center;
    }
    .dj-danger-item {
        flex-direction: column;
        gap: 12px;
        text-align: center;
    }
    /* Ensure navigation text is visible on mobile */
    .dj-nav-text {
        display: block !important;
        font-size: 14px !important;
        color: inherit !important;
        opacity: 1 !important;
        visibility: visible !important;
    }
    .dj-nav-link {
        padding: 12px 16px !important;
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
    }
    .dj-dashboard-sidebar {
        background: white !important;
        box-shadow: 2px 0 10px rgba(0, 0, 0, 0.1);
    }
}

@media (max-width: 767.98px) {
    .dj-dashboard-content {
        border-radius: 0;
        margin: 0;
    }
    .dj-page-title {
        font-size: 24px;
    }
    .dj-stat-card {
        padding: 16px;
    }
    .dj-stat-number {
        font-size: 24px;
    }
    .dj-reservation-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .dj-reservation-status {
        align-self: flex-end;
    }
    .dj-table-responsive {
        overflow-x: auto;
    }
    .dj-form-group {
        margin-bottom: 16px;
    }
    .dj-privacy-item,
    .dj-notification-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
}

@media (max-width: 575.98px) {
    .dj-dashboard-content {
        padding: 16px;
    }
    .dj-quick-actions {
        padding-top: 16px;
    }
    .dj-action-buttons {
        gap: 6px;
    }
    .dj-card-header {
        padding: 16px;
    }
    .dj-card-body {
        padding: 16px;
    }
    .dj-billing-card {
        padding: 16px;
    }
    .dj-payment-card {
        padding: 16px;
    }
}


/* ========================================
   Animations
   ======================================== */

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

@keyframes slideInLeft {
    from {
        opacity: 0;
        transform: translateX(-20px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes shimmer {
    0% {
        transform: rotate(0deg) scale(0.8);
        opacity: 0;
    }
    50% {
        transform: rotate(180deg) scale(1.2);
        opacity: 0.3;
    }
    100% {
        transform: rotate(360deg) scale(0.8);
        opacity: 0;
    }
}

@keyframes iconPulse {
    0%,
    100% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
}

.dj-stat-card,
.dj-activity-card {
    animation: fadeInUp 0.6s ease;
}

.dj-nav-item {
    animation: slideInLeft 0.4s ease;
    animation-delay: 0s;
}


/* ========================================
   B2B Travel Agency Enhancements
   ======================================== */


/* Professional Data Tables */

.dj-table {
    border-collapse: separate;
    border-spacing: 0;
}

.dj-table thead th {
    background: #f8f9fa;
    border-bottom: 2px solid #e9ecef;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-size: 14px;
    color: #6c757d;
}

.dj-table tbody tr:hover {
    background: #f8f9fa;
}


/* Enhanced Status Badges */

.dj-status-badge {
    font-weight: 600;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 6px 12px;
    border-radius: 20px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}


/* Professional Form Styling */

.dj-form-control {
    border: 2px solid #f1f3f4;
    border-radius: 8px;
    padding: 12px 16px;
    font-size: 15px;
    transition: all 0.3s ease;
}

.dj-form-control:focus {
    border-color: #007bff;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}


/* Travel Agency Specific Icons */

.dj-travel-icon {
    background: linear-gradient(135deg, #007bff, #0056b3);
    color: white;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    margin-right: 12px;
}


/* Revenue Highlighting */

.dj-revenue-highlight {
    background: linear-gradient(135deg, #28a745, #20c997);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-weight: 800;
}


/* Quick Actions Enhancement */

.dj-quick-action-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin-top: 24px;
}

.dj-quick-action-card {
    background: white;
    border-radius: 12px;
    padding: 20px;
    text-align: center;
    border: 1px solid #f1f3f4;
    transition: all 0.3s ease;
    cursor: pointer;
}

.dj-quick-action-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
    border-color: #007bff;
}

.dj-quick-action-icon {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, #007bff, #0056b3);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    margin: 0 auto 12px;
}

.dj-quick-action-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 4px;
}

.dj-quick-action-desc {
    font-size: 14px;
    color: #6c757d;
}


/* Professional Spacing System */

.dj-section-spacing {
    margin-bottom: 40px;
}

.dj-card-spacing {
    margin-bottom: 24px;
}

.dj-element-spacing {
    margin-bottom: 16px;
}


/* Enhanced Shadows */

.dj-shadow-soft {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.dj-shadow-medium {
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.dj-shadow-strong {
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}


/* Professional Color Palette */

.dj-text-primary {
    color: #007bff !important;
}

.dj-text-success {
    color: #28a745 !important;
}

.dj-text-warning {
    color: #fd7e14 !important;
}

.dj-text-danger {
    color: #dc3545 !important;
}

.dj-text-info {
    color: #17a2b8 !important;
}

.dj-text-dark {
    color: #2c3e50 !important;
}

.dj-text-muted {
    color: #6c757d !important;
}


/* Background Utilities */

.dj-bg-light {
    background-color: #f8f9fa !important;
}

.dj-bg-white {
    background-color: #ffffff !important;
}

.dj-bg-primary-light {
    background-color: rgba(0, 123, 255, 0.1) !important;
}

.dj-bg-success-light {
    background-color: rgba(40, 167, 69, 0.1) !important;
}


/* Border Utilities */

.dj-border-soft {
    border: 1px solid #f1f3f4 !important;
}

.dj-border-light {
    border: 1px solid #e9ecef !important;
}

.dj-border-primary {
    border: 1px solid #007bff !important;
}


/* ========================================
   Travel Packages Styling
   ======================================== */

.dj-packages-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-top: 24px;
    padding: 0;
}

.dj-package-card {
    background: white;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    transition: all 0.3s ease;
}

.dj-package-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}

.dj-package-image {
    position: relative;
    height: 200px;
    overflow: hidden;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.dj-package-image::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(108,117,125,0.1)" stroke-width="1"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');
    opacity: 0.5;
}

.dj-package-image i {
    font-size: 48px;
    color: #6c757d;
    z-index: 1;
    position: relative;
}

.dj-package-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.dj-package-image img[src]:not([src=""]) {
    opacity: 1;
}

.dj-package-image img[src="/CDN/Images/blank.png"],
.dj-package-image img[src*="blank.png"] {
    opacity: 0;
}

.dj-package-badge {
    position: absolute;
    top: 16px;
    right: 16px;
}

.dj-badge-popular {
    background: #007bff;
    color: white;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dj-badge-new {
    background: #28a745;
    color: white;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dj-package-rating {
    position: absolute;
    top: 16px;
    right: 16px;
    background: rgba(0, 0, 0, 0.8);
    color: white;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 4px;
}

.dj-package-rating i {
    color: #ffc107;
}

.dj-package-content {
    padding: 24px;
}

.dj-package-title {
    font-size: 18px;
    font-weight: 700;
    color: #2c3e50;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    line-height: 1.3;
}

.dj-package-location {
    color: #6c757d;
    font-size: 14px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 6px;
    min-height: 20px;
}

.dj-package-description {
    color: #6c757d;
    font-size: 14px;
    margin-bottom: 16px;
    line-height: 1.5;
}

.dj-package-features {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
    min-height: 32px;
    align-items: flex-start;
}

.dj-package-feature {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 8px;
    background: #f8f9fa;
    border-radius: 12px;
    font-size: 14px;
    color: #6c757d;
    font-weight: 500;
}

.dj-package-feature i {
    color: #007bff;
    font-size: 10px;
}

.dj-package-details {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    padding: 12px 0;
    border-top: 1px solid #f1f3f4;
    border-bottom: 1px solid #f1f3f4;
}

.dj-package-duration {
    display: flex;
    align-items: center;
    gap: 6px;
    color: #6c757d;
    font-size: 14px;
}

.dj-package-price {
    text-align: right;
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-bottom: 16px;
    min-height: 32px;
}

.dj-price-amount {
    font-size: 24px;
    font-weight: 700;
    color: #007bff;
}

.dj-price-per {
    font-size: 14px;
    color: #6c757d;
}

.dj-package-stats {
    display: flex;
    justify-content: space-between;
    margin-bottom: 16px;
    font-size: 14px;
    color: #6c757d;
}

.dj-package-bookings,
.dj-package-rating {
    display: flex;
    align-items: center;
    gap: 4px;
}

.dj-package-actions {
    display: flex;
    gap: 8px;
    min-height: 36px;
    align-items: center;
}


/* ========================================
   Reports & Analytics Styling
   ======================================== */

.dj-report-cards {
    margin-bottom: 32px;
}

.dj-report-card {
    background: white;
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    margin-bottom: 25px;
    margin-right: 30px;
}

.dj-report-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

.dj-report-icon {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, #007bff, #0056b3);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    margin-bottom: 16px;
}

.dj-report-title {
    font-size: 16px;
    font-weight: 700;
    color: #2c3e50;
    margin-bottom: 8px;
}

.dj-report-description {
    color: #6c757d;
    font-size: 14px;
    margin-bottom: 16px;
}

.dj-report-stats {
    margin-bottom: 16px;
}

.dj-report-value {
    font-size: 24px;
    font-weight: 700;
    color: #007bff;
    display: block;
}

.dj-report-period {
    font-size: 14px;
    color: #6c757d;
}

.dj-chart-card {
    background: white;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    margin-bottom: 24px;
}

.dj-chart-controls {
    display: flex;
    align-items: center;
    gap: 12px;
}

.dj-form-control-sm {
    padding: 6px 12px;
    font-size: 14px;
    border-radius: 6px;
    border: 1px solid #ced4da;
}

.dj-chart-placeholder {
    text-align: center;
    padding: 60px 20px;
    color: #6c757d;
}

.dj-chart-placeholder i {
    font-size: 48px;
    margin-bottom: 16px;
    color: #dee2e6;
}

.dj-chart-placeholder p {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 8px;
}

.dj-chart-placeholder small {
    font-size: 14px;
    color: #adb5bd;
}

.dj-destination-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.dj-destination-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.dj-destination-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dj-destination-name {
    font-weight: 600;
    color: #2c3e50;
}

.dj-destination-bookings {
    font-size: 14px;
    color: #6c757d;
}

.dj-destination-bar {
    height: 6px;
    background: #f1f3f4;
    border-radius: 3px;
    overflow: hidden;
}

.dj-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, #007bff, #0056b3);
    border-radius: 3px;
    transition: width 0.3s ease;
}


/* ========================================
   Customer Contact Styling
   ======================================== */

.dj-contact-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dj-contact-email {
    font-size: 14px;
    color: #2c3e50;
}

.dj-contact-phone {
    font-size: 14px;
    color: #6c757d;
}

.dj-booking-count {
    font-weight: 600;
    color: #007bff;
}

.dj-customer-spent {
    font-weight: 700;
    color: #28a745;
}

.dj-last-activity {
    color: #6c757d;
    font-size: 14px;
}


/* Responsive Improvements */

@media (max-width: 991.98px) {
    .dj-stats-row {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }
}

.dj-activity-row {
    grid-template-columns: 1fr;
    gap: 16px;
}


/* ========================================
   Settings & Security Enhancements
   ======================================== */

.dj-security-options {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.dj-security-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    background: #f8f9fa;
    border-radius: 8px;
    border: 1px solid #e9ecef;
}

.dj-security-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 4px;
}

.dj-security-desc {
    font-size: 14px;
    color: #6c757d;
    margin: 0;
}

.dj-integration-item {
    text-align: center;
    padding: 20px;
    background: #f8f9fa;
    border-radius: 12px;
    border: 1px solid #e9ecef;
    transition: all 0.3s ease;
    margin-bottom: 16px;
    margin-right: 15px;
}

.dj-integration-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.dj-integration-icon {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, #007bff, #0056b3);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    margin: 0 auto 12px;
}

.dj-integration-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 8px;
}

.dj-integration-status {
    font-size: 14px;
    margin-bottom: 12px;
    font-weight: 500;
}

.dj-status-connected {
    color: #28a745;
}

.dj-status-pending {
    color: #fd7e14;
}


/* ========================================
   Flight Management Styling
   ======================================== */

.dj-flight-stats,
.dj-hotel-stats {
    margin-bottom: 32px;
}

.dj-flight-details,
.dj-hotel-details {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dj-flight-number {
    font-weight: 600;
    color: #007bff;
    font-size: 14px;
}

.dj-airline {
    font-size: 14px;
    color: #6c757d;
}

.dj-route-details {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
}

.dj-departure,
.dj-arrival {
    font-size: 14px;
    color: #2c3e50;
}

.dj-route-details i {
    color: #007bff;
    font-size: 14px;
}

.dj-flight-price,
.dj-hotel-price {
    font-weight: 700;
    color: #28a745;
    font-size: 16px;
}


/* ========================================
   Hotel Management Styling
   ======================================== */

.dj-hotels-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin-top: 24px;
}

.dj-hotel-card {
    background: white;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    transition: all 0.3s ease;
}

.dj-hotel-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}

.dj-hotel-image {
    position: relative;
    height: 200px;
    overflow: hidden;
}

.dj-hotel-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dj-hotel-rating {
    position: absolute;
    top: 16px;
    right: 16px;
    background: rgba(0, 0, 0, 0.8);
    color: white;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 4px;
}

.dj-hotel-rating i {
    color: #ffc107;
}

.dj-hotel-content {
    padding: 24px;
}

.dj-hotel-name {
    font-size: 18px;
    font-weight: 700;
    color: #2c3e50;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 48px;
    line-height: 1.3;
}

.dj-hotel-location {
    color: #6c757d;
    font-size: 14px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 6px;
    min-height: 20px;
}

.dj-hotel-amenities {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
    min-height: 32px;
    align-items: flex-start;
}

.dj-amenity {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 8px;
    background: #f8f9fa;
    border-radius: 12px;
    font-size: 14px;
    color: #6c757d;
    font-weight: 500;
}

.dj-amenity i {
    color: #007bff;
    font-size: 10px;
}

.dj-hotel-price {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-bottom: 16px;
    min-height: 32px;
}

.dj-price-amount {
    font-size: 24px;
    font-weight: 700;
    color: #007bff;
}

.dj-price-per {
    font-size: 14px;
    color: #6c757d;
}

.dj-hotel-actions {
    display: flex;
    gap: 8px;
    min-height: 36px;
    align-items: center;
}


/* Enhanced Mobile Responsiveness */

@media (max-width: 1200px) {
    .dj-packages-grid,
    .dj-hotels-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }
}

@media (max-width: 991.98px) {
    .dj-dashboard-main .row {
        flex-wrap: wrap;
    }
    .dj-dashboard-main .col-lg-3,
    .dj-dashboard-main .col-lg-9 {
        width: 100%;
        max-width: 100%;
        flex: 0 0 100%;
    }
    .dj-dashboard-sidebar {
        margin-bottom: 24px;
    }
    .dj-quick-stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }
    .dj-nav-list {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
        gap: 8px;
    }
    .dj-nav-link {
        justify-content: center;
        text-align: center;
        flex-direction: column;
        gap: 6px;
        padding: 12px 8px;
        min-height: 60px;
    }
    .dj-nav-text {
        font-size: 14px;
        text-align: center;
    }
    .dj-nav-badge {
        position: absolute;
        top: 8px;
        right: 8px;
    }
    .dj-packages-grid,
    .dj-hotels-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }
}

@media (max-width: 767.98px) {
    .dj-stats-row {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .dj-stat-card {
        padding: 20px;
        min-height: 120px;
        max-height: 150px;
    }
    .dj-stat-number {
        font-size: 28px;
    }
    .dj-stat-card .dj-stat-icon {
        width: 40px;
        height: 40px;
        font-size: 18px;
        margin-bottom: 12px;
    }
    .dj-card-header {
        padding: 16px 20px;
    }
    .dj-card-body {
        padding: 20px;
    }
    .dj-quick-stats-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .dj-nav-list {
        grid-template-columns: repeat(2, 1fr);
    }
    .dj-activity-list {
        gap: 8px;
    }
    .dj-activity-item {
        padding: 12px;
    }
    .dj-activity-icon {
        width: 32px;
        height: 32px;
        font-size: 14px;
    }
    .dj-packages-grid,
    .dj-hotels-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .dj-package-card,
    .dj-hotel-card {
        margin-bottom: 16px;
    }
}


/* ========================================
   Today's Performance & Quick Actions
   ======================================== */

.dj-performance-row {
    margin-bottom: 32px;
}

.dj-performance-card,
.dj-quick-actions-card {
    background: white;
    border-radius: 16px;
    padding: 12px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    border: 1px solid #e9ecef;
    height: 100%;
}

.dj-performance-item {
    display: flex;
    align-items: center;
    padding: 12px;
    margin-bottom: 8px;
    border-radius: 8px;
    background: #f8f9fa;
    transition: all 0.3s ease;
}

.dj-performance-item:hover {
    background: #e9ecef;
    transform: translateY(-2px);
}

.dj-performance-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 12px;
    color: white;
}

.dj-performance-icon.dj-icon-bookings {
    background: linear-gradient(135deg, #007bff, #0056b3);
}

.dj-performance-icon.dj-icon-revenue {
    background: linear-gradient(135deg, #28a745, #1e7e34);
}

.dj-performance-icon.dj-icon-customers {
    background: linear-gradient(135deg, #fd7e14, #dc6505);
}

.dj-performance-icon.dj-icon-rating {
    background: linear-gradient(135deg, #ffc107, #e0a800);
}

.dj-performance-info {
    flex: 1;
}

.dj-performance-number {
    display: block;
    font-size: 18px;
    font-weight: 700;
    color: #2c3e50;
    line-height: 1.2;
}

.dj-performance-label {
    display: block;
    font-size: 14px;
    color: #6c757d;
    font-weight: 500;
}

.dj-quick-action-btn {
    width: 100%;
    padding: 12px;
    margin-bottom: 8px;
    border: none;
    border-radius: 8px;
    background: #f8f9fa;
    color: #2c3e50;
    font-weight: 600;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    cursor: pointer;
}

.dj-quick-action-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.dj-quick-action-btn.dj-btn-primary {
    background: linear-gradient(135deg, #007bff, #0056b3);
    color: white;
}

.dj-quick-action-btn.dj-btn-info {
    background: linear-gradient(135deg, #17a2b8, #117a8b);
    color: white;
}

.dj-quick-action-btn.dj-btn-success {
    background: linear-gradient(135deg, #28a745, #1e7e34);
    color: white;
}

.dj-quick-action-btn.dj-btn-warning {
    background: linear-gradient(135deg, #ffc107, #e0a800);
    color: white;
}

.dj-quick-action-btn i {
    margin-right: 8px;
    font-size: 16px;
}


/* Recent Activity Timeline */

.dj-recent-activity-card {
    background: white;
    border-radius: 16px;
    padding: 12px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    border: 1px solid #e9ecef;
    margin-top: 16px;
}

.dj-activity-timeline {
    position: relative;
}

.dj-activity-timeline-item {
    display: flex;
    align-items: flex-start;
    margin-bottom: 16px;
    position: relative;
}

.dj-activity-timeline-item:last-child {
    margin-bottom: 0;
}

.dj-activity-timeline-item::after {
    content: '';
    position: absolute;
    left: 18px;
    top: 36px;
    bottom: -16px;
    width: 2px;
    background: #e9ecef;
}

.dj-activity-timeline-item:last-child::after {
    display: none;
}

.dj-activity-timeline-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 12px;
    color: white;
    font-size: 14px;
    flex-shrink: 0;
    z-index: 1;
    position: relative;
}

.dj-activity-timeline-icon.dj-icon-booking {
    background: linear-gradient(135deg, #007bff, #0056b3);
}

.dj-activity-timeline-icon.dj-icon-payment {
    background: linear-gradient(135deg, #28a745, #1e7e34);
}

.dj-activity-timeline-icon.dj-icon-customer {
    background: linear-gradient(135deg, #fd7e14, #dc6505);
}

.dj-activity-timeline-icon.dj-icon-flight {
    background: linear-gradient(135deg, #6f42c1, #5a2d91);
}

.dj-activity-timeline-content {
    flex: 1;
    padding-top: 2px;
}

.dj-activity-timeline-text {
    font-size: 14px;
    color: #2c3e50;
    font-weight: 500;
    margin: 0 0 4px 0;
    line-height: 1.4;
}

.dj-activity-timeline-time {
    font-size: 14px;
    color: #6c757d;
    font-weight: 400;
}


/* ========================================
   API & Integrations Tab Styling
   ======================================== */

.dj-integrations-section {
    padding: 20px;
    padding-top: 0px !important;
    margin-bottom: 32px;
    margin-top: 25px;
    margin-left: 10px;
}

.dj-integration-stats {
    margin-bottom: 40px;
}


/* API Documentation Styling */

.dj-api-docs {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.dj-doc-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: #f8f9fa;
    border-radius: 12px;
    transition: all 0.3s ease;
    border: 1px solid #e9ecef;
}

.dj-doc-item:hover {
    background: #e9ecef;
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.dj-doc-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: white;
    flex-shrink: 0;
    background: linear-gradient(135deg, #007bff, #0056b3);
}

.dj-doc-info {
    flex: 1;
}

.dj-doc-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 4px;
}

.dj-doc-desc {
    font-size: 14px;
    color: #6c757d;
    margin: 0;
}


/* API Logs Styling */

.dj-api-logs {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.dj-log-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 8px;
    transition: all 0.3s ease;
}

.dj-log-item:hover {
    background: #e9ecef;
}

.dj-log-status {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    color: white;
    flex-shrink: 0;
}

.dj-log-status.dj-status-success {
    background: #28a745;
}

.dj-log-status.dj-status-warning {
    background: #ffc107;
}

.dj-log-status.dj-status-error {
    background: #dc3545;
}

.dj-log-info {
    flex: 1;
}

.dj-log-text {
    font-size: 13px;
    color: #2c3e50;
    margin-bottom: 4px;
    font-weight: 500;
}

.dj-log-time {
    font-size: 14px;
    color: #6c757d;
}


/* Enhanced Integration Item Styling */

.dj-integration-item {
    text-align: center;
    padding: 24px;
    background: #f8f9fa;
    border-radius: 16px;
    border: 1px solid #e9ecef;
    transition: all 0.3s ease;
    margin-bottom: 16px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.dj-integration-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    border-color: #007bff;
}

.dj-integration-icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, #007bff, #0056b3);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 24px;
    margin: 0 auto 16px;
    box-shadow: 0 4px 16px rgba(0, 123, 255, 0.3);
}

.dj-integration-title {
    font-size: 16px;
    font-weight: 700;
    color: #2c3e50;
    margin-bottom: 8px;
}

.dj-integration-status {
    font-size: 13px;
    margin-bottom: 16px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dj-status-connected {
    color: #28a745;
}

.dj-status-pending {
    color: #fd7e14;
}

.dj-status-error {
    color: #dc3545;
}


/* ========================================
   Quick Actions Header Dropdown
   ======================================== */

.dj-quick-actions-header {
    position: absolute;
    top: 24px;
    right: 24px;
    z-index: 1000;
}

.dj-quick-actions-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0, 123, 255, 0.3);
    transition: all 0.3s ease;
    border: none;
}

.dj-quick-actions-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 24px rgba(0, 123, 255, 0.4);
}

.dj-quick-actions-menu {
    min-width: 280px;
    max-height: 600px;
    overflow-y: auto;
    border: none;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
    padding: 8px 0;
    margin-top: 8px;
}

.dj-quick-actions-menu .dropdown-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 500;
    color: #2c3e50;
    transition: all 0.3s ease;
    border: none;
    background: none;
}

.dj-quick-actions-menu .dropdown-item:hover {
    background: #f8f9fa;
    color: #007bff;
    transform: translateX(4px);
    padding-left: 24px;
}

.dj-quick-actions-menu .dropdown-item i {
    width: 16px;
    font-size: 14px;
    color: #6c757d;
    transition: all 0.3s ease;
}

.dj-quick-actions-menu .dropdown-item:hover i {
    color: #007bff;
    transform: scale(1.1);
}

.dj-dropdown-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px 8px 20px;
    margin-top: 8px;
    font-size: 14px;
    font-weight: 700;
    color: #007bff;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: #f8f9fa;
    border-bottom: 1px solid #e9ecef;
}

.dj-dropdown-header:first-child {
    margin-top: 0;
}

.dj-dropdown-header i {
    font-size: 14px;
    color: #007bff;
}

.dj-quick-actions-menu .dropdown-divider {
    margin: 8px 0;
    border-color: #e9ecef;
}


/* Section Actions Dropdown */

.dj-dropdown-menu {
    min-width: 200px;
    border: none;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    padding: 8px 0;
    margin-top: 8px;
}

.dj-dropdown-menu .dropdown-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 500;
    color: #2c3e50;
    transition: all 0.3s ease;
}

.dj-dropdown-menu .dropdown-item:hover {
    background: #f8f9fa;
    color: #007bff;
    transform: translateX(2px);
}

.dj-dropdown-menu .dropdown-item i {
    width: 14px;
    font-size: 13px;
    color: #6c757d;
    transition: all 0.3s ease;
}

.dj-dropdown-menu .dropdown-item:hover i {
    color: #007bff;
}


/* Utility class for margin */

.dj-ml-5 {
    margin-left: 5px;
}


/* Mobile Responsiveness for Quick Actions */

@media (max-width: 991.98px) {
    .dj-quick-actions-header {
        position: relative;
        top: 0;
        right: 0;
        margin-bottom: 20px;
        text-align: center;
    }
    .dj-quick-actions-btn {
        width: 100%;
        justify-content: center;
    }
    .dj-quick-actions-menu {
        min-width: 100%;
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
    }
}

@media (max-width: 767.98px) {
    .dj-quick-actions-menu {
        max-height: 400px;
    }
    .dj-quick-actions-menu .dropdown-item {
        padding: 10px 16px;
        font-size: 13px;
    }
    .dj-dropdown-header {
        padding: 10px 16px 6px 16px;
        font-size: 14px;
    }
}


/* Mobile Responsiveness for Integrations */

@media (max-width: 991.98px) {
    .dj-integrations-section {
        padding: 16px;
        margin-left: 0;
    }
    .dj-integration-stats {
        margin-bottom: 24px;
    }
    .dj-doc-item {
        flex-direction: column;
        text-align: center;
        gap: 12px;
    }
    .dj-doc-info {
        text-align: center;
    }
    .dj-log-item {
        padding: 12px;
    }
}


/* ===== MISSING STYLES FOR DASHBOARD ELEMENTS ===== */


/* Top Statistics Row */

.dj-top-stats-row {
    margin-bottom: 20px;
}

.dj-top-stats-row .col-lg-3,
.dj-top-stats-row .col-md-6 {
    margin-bottom: 15px;
}


/* Main Analytics Row */

.dj-main-analytics-row {
    margin-bottom: 20px;
}

.dj-main-analytics-row .col-lg-8,
.dj-main-analytics-row .col-lg-4 {
    margin-bottom: 15px;
    padding-left: 10px;
    padding-right: 10px;
}

.dj-main-analytics-row .col-lg-8 {
    padding-right: 15px;
}

.dj-main-analytics-row .col-lg-4 {
    padding-left: 15px;
}


/* Stat Footer */

.dj-stat-footer {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dj-stat-footer .dj-stat-label {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.8);
    font-weight: 500;
}

.dj-stat-footer .dj-stat-value {
    font-size: 14px;
    color: #ffffff;
    font-weight: 600;
}


/* Chart Components */

.dj-chart-container {
    position: relative;
    width: 100%;
    height: 300px;
    padding: 20px;
}

.dj-chart-container canvas {
    width: 100% !important;
    height: 100% !important;
}

.dj-chart-legend {
    display: flex;
    gap: 20px;
    align-items: center;
    flex-wrap: wrap;
}

.dj-legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: #6c757d;
}

.dj-legend-color {
    width: 12px;
    height: 12px;
    border-radius: 2px;
    display: inline-block;
}


/* Secondary Stats */

.dj-secondary-stats {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.dj-stat-card.dj-card-compact {
    padding: 20px;
    min-height: auto;
    display: flex;
    align-items: center;
    gap: 15px;
}

.dj-stat-card.dj-card-compact .dj-stat-icon {
    width: 50px;
    height: 50px;
    min-width: 50px;
    border-radius: 12px;
}

.dj-stat-card.dj-card-compact .dj-stat-content {
    flex: 1;
}

.dj-stat-card.dj-card-compact .dj-stat-number {
    font-size: 18px;
    margin-bottom: 5px;
}

.dj-stat-card.dj-card-compact .dj-stat-title {
    font-size: 14px;
    margin-bottom: 0;
}


/* Popular Destinations */

.dj-popular-destinations-row {
    margin-bottom: 30px;
}

.dj-destinations-card {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid #f1f3f4;
    overflow: hidden;
}

.dj-destinations-card .dj-card-header {
    padding: 20px 25px;
    border-bottom: 1px solid #f1f3f4;
}

.dj-destinations-carousel {
    display: flex;
    gap: 20px;
    padding: 25px;
    overflow: hidden;
    position: relative;
    animation: autoSlide 25s infinite linear;
}

.dj-destinations-carousel:hover {
    animation-play-state: paused;
}

@keyframes autoSlide {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}


/* Hide scrollbars completely */

.dj-destinations-carousel::-webkit-scrollbar {
    display: none;
}

.dj-destinations-carousel {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.dj-destinations-carousel .dj-destination-item {
    min-width: 280px;
    background: #f8f9fa;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e9ecef;
    transition: all 0.3s ease;
}

.dj-destinations-carousel .dj-destination-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

.dj-destination-image {
    height: 120px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    position: relative;
    overflow: hidden;
}

.dj-destination-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dj-destination-content {
    padding: 20px;
}

.dj-destination-title {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    margin-bottom: 15px;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.dj-destination-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}

.dj-destination-stats .dj-stat-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: #6c757d;
    font-weight: 500;
}

.dj-destination-stats .dj-stat-item i {
    font-size: 14px;
    color: #007bff;
}


/* Activities Row */

.dj-activities-row {
    margin-bottom: 20px;
}

.dj-activities-row .col-lg-4 {
    padding-left: 10px;
    padding-right: 10px;
}

.dj-activities-row .col-lg-4:not(:last-child) {
    padding-right: 15px;
}

.dj-activities-row .col-lg-4:not(:first-child) {
    padding-left: 15px;
}


/* Empty State */

.dj-empty-state {
    text-align: center;
    padding: 40px 20px;
    color: #6c757d;
    background: #f8f9fa;
    border-radius: 12px;
    border: 2px dashed #dee2e6;
}

.dj-empty-state p {
    margin: 0;
    font-size: 14px;
    font-weight: 500;
}


/* Bottom Section */

.dj-bottom-section-row {
    margin-bottom: 20px;
}

.dj-bottom-section-row .col-lg-4 {
    margin-bottom: 15px;
    padding-left: 10px;
    padding-right: 10px;
}

.dj-bottom-section-row .col-lg-4:nth-child(1) {
    padding-right: 15px;
}

.dj-bottom-section-row .col-lg-4:nth-child(2) {
    padding-left: 8px;
    padding-right: 8px;
}

.dj-bottom-section-row .col-lg-4:nth-child(3) {
    padding-left: 15px;
}


/* Calendar Card */

.dj-calendar-card,
.dj-members-card {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid #f1f3f4;
    overflow: hidden;
}


/* Weekly Stats - Compact */

.dj-weekly-stats {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 10px;
}

.dj-weekly-stats .dj-week-day {
    margin-bottom: 0;
}

.dj-weekly-stats .dj-week-day:not(:last-child) {
    margin-bottom: 3px;
}

.dj-week-day {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: #f8f9fa;
    border-radius: 6px;
    transition: all 0.3s ease;
    border: 1px solid #e9ecef;
    font-size: 14px;
}

.dj-week-day:hover {
    background: #e9ecef;
}

.dj-day-name {
    font-size: 14px;
    font-weight: 700;
    color: #007bff;
    min-width: 22px;
    text-align: center;
}

.dj-day-label {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    min-width: 60px;
}

.dj-day-stats {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
    font-size: 10px;
}

.dj-day-stats .dj-stat-value {
    font-size: 14px;
    font-weight: 700;
    color: #2c3e50;
    min-width: 15px;
    text-align: center;
}

.dj-day-stats .dj-stat-label {
    font-size: 12px;
    color: #6c757d;
    font-weight: 500;
    white-space: nowrap;
}


/* Members Card - Compact */

.dj-members-list {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 12px;
}

.dj-member-item {
    padding: 6px 10px;
    background: #f8f9fa;
    border-radius: 6px;
    transition: all 0.3s ease;
    border: 1px solid #e9ecef;
}

.dj-member-item:hover {
    background: #e9ecef;
}

.dj-member-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dj-member-email {
    font-size: 14px;
    font-weight: 600;
    color: #2c3e50;
    line-height: 1.3;
}

.dj-member-date {
    font-size: 10px;
    color: #6c757d;
    font-weight: 500;
}


/* Events Section - Compact */

.dj-events-row {
    margin-bottom: 20px;
}

.dj-events-card {
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    border: 1px solid #f1f3f4;
    overflow: hidden;
}

.dj-events-list {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 12px;
}

.dj-event-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 6px 8px;
    background: #f8f9fa;
    border-radius: 6px;
    transition: all 0.3s ease;
}

.dj-event-item:hover {
    background: #e9ecef;
}

.dj-event-icon {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 10px;
}

.dj-event-icon.dj-icon-info {
    background: rgba(23, 162, 184, 0.1);
    color: #17a2b8;
}

.dj-event-icon.dj-icon-success {
    background: rgba(40, 167, 69, 0.1);
    color: #28a745;
}

.dj-event-icon.dj-icon-warning {
    background: rgba(255, 193, 7, 0.1);
    color: #ffc107;
}

.dj-event-content {
    flex: 1;
}

.dj-event-text {
    font-size: 14px;
    color: #2c3e50;
    margin-bottom: 2px;
    line-height: 1.4;
}

.dj-event-text strong {
    font-weight: 600;
    color: #007bff;
}

.dj-event-time {
    font-size: 9px;
    color: #6c757d;
    font-weight: 500;
}


/* Date Range Picker */

.dj-date-range-picker {
    margin-right: 15px;
}

.dj-date-range-picker select {
    padding: 8px 12px;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    background: #ffffff;
    font-size: 13px;
    font-weight: 500;
    color: #2c3e50;
    min-width: 180px;
    transition: all 0.3s ease;
}

.dj-date-range-picker select:focus {
    outline: none;
    border-color: #007bff;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}


/* Customer Stats */

.dj-customer-stats,
.dj-flight-stats,
.dj-hotel-stats {
    margin-bottom: 30px;
}


/* Dashboard Tables */

.dj-dashboard-table {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid #f1f3f4;
    overflow: hidden;
}

.dj-dashboard-table .dj-table-body tr {
    min-height: 64px;
}

.dj-dashboard-table .dj-table-body td {
    min-height: 64px;
    vertical-align: middle;
}

.dj-supplier-category,
.dj-supplier-status,
.dj-customer-status,
.dj-request-status {
    text-align: center;
    vertical-align: middle;
}

.dj-supplier-actions,
.dj-customer-actions,
.dj-request-actions {
    text-align: center;
    vertical-align: middle;
}

.dj-supplier-performance,
.dj-supplier-revenue,
.dj-supplier-commission,
.dj-last-transaction {
    text-align: center;
    vertical-align: middle;
}

.dj-supplier-location {
    text-align: center;
    vertical-align: middle;
    font-weight: 500;
}

.dj-customer-company {
    font-size: 14px;
    color: #6c757d;
    font-weight: 500;
}

.dj-customer-contact {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.dj-customer-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}


/* Invoice Specific */

.dj-invoice-number {
    font-family: 'Courier New', monospace;
    font-weight: 600;
    color: #007bff;
}

.dj-invoice-date,
.dj-due-date {
    font-size: 13px;
    color: #6c757d;
}

.dj-invoice-amount {
    font-weight: 600;
    color: #28a745;
}

.dj-invoice-status {
    text-align: center;
}

.dj-invoice-actions {
    display: flex;
    gap: 8px;
    justify-content: center;
}


/* Reports Section */

.dj-analytics-charts {
    margin-top: 30px;
}


/* Utility Classes */

.dj-mb-30 {
    margin-bottom: 30px !important;
}

.dj-mr-10 {
    margin-right: 10px !important;
}


/* Responsive Adjustments */

@media (max-width: 1200px) {
    .dj-destinations-carousel .dj-destination-item {
        min-width: 250px;
    }
}

@media (max-width: 991.98px) {
    .dj-chart-container {
        height: 250px;
        padding: 15px;
    }
    .dj-destinations-carousel .dj-destination-item {
        min-width: 220px;
    }
    .dj-destination-title {
        font-size: 13px;
    }
    .dj-week-day {
        flex-direction: column;
        gap: 10px;
        text-align: center;
    }
    .dj-day-name {
        font-size: 16px;
    }
    .dj-day-label {
        font-size: 13px;
        min-width: auto;
    }
}

@media (max-width: 767.98px) {
    .dj-chart-container {
        height: 200px;
        padding: 10px;
    }
    .dj-destinations-carousel .dj-destination-item {
        min-width: 200px;
    }
    .dj-destination-image {
        height: 100px;
    }
    .dj-destination-content {
        padding: 15px;
    }
    .dj-week-day {
        padding: 12px;
    }
    .dj-day-stats {
        min-width: 50px;
    }
    .dj-day-name {
        font-size: 14px;
    }
    .dj-day-label {
        font-size: 14px;
    }
}

@media (max-width: 575.98px) {
    .dj-chart-container {
        height: 180px;
        padding: 8px;
    }
    .dj-destinations-carousel .dj-destination-item {
        min-width: 180px;
    }
    .dj-destination-image {
        height: 80px;
    }
    .dj-destination-content {
        padding: 12px;
    }
    .dj-week-day {
        padding: 10px;
        gap: 8px;
    }
    .dj-day-name {
        font-size: 14px;
    }
    .dj-day-label {
        font-size: 14px;
    }
}


/* Enhanced Card Spacing */

.dj-activity-card,
.dj-calendar-card,
.dj-members-card,
.dj-events-card,
.dj-chart-card,
.dj-destinations-card {
    margin-bottom: 0;
    height: 100%;
}


/* Ensure equal heights for card containers */

.dj-bottom-section-row .col-lg-4,
.dj-activities-row .col-lg-4,
.dj-main-analytics-row .col-lg-8,
.dj-main-analytics-row .col-lg-4 {
    display: flex;
    flex-direction: column;
}

.dj-bottom-section-row .col-lg-4>*,
.dj-activities-row .col-lg-4>*,
.dj-main-analytics-row .col-lg-8>*,
.dj-main-analytics-row .col-lg-4>* {
    flex: 1;
}


/* Enhanced Reservation List Spacing */

.dj-reservation-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 14px;
}

.dj-reservation-item {
    margin-bottom: 0;
}


/* Enhanced Card Body Spacing */

.dj-card-body {
    padding: 10px;
}

.dj-card-header {
    padding: 10px 20px;
    border-bottom: 1px solid #e9ecef;
}


/* Perfect spacing for destination carousel */

.dj-destinations-carousel .dj-destination-item {
    margin-right: 20px;
}

.dj-destinations-carousel .dj-destination-item:last-child {
    margin-right: 0;
}


/* Enhanced responsive spacing */

@media (max-width: 991.98px) {
    .dj-dashboard-content .row .col-lg-6:first-child,
    .dj-dashboard-content .row .col-lg-6:last-child {
        padding-left: 15px;
        padding-right: 15px;
    }
    .dj-dashboard-content .row .col-lg-4:nth-child(1),
    .dj-dashboard-content .row .col-lg-4:nth-child(2),
    .dj-dashboard-content .row .col-lg-4:nth-child(3) {
        padding-left: 15px;
        padding-right: 15px;
    }
    .dj-bottom-section-row .col-lg-4:nth-child(1),
    .dj-bottom-section-row .col-lg-4:nth-child(2),
    .dj-bottom-section-row .col-lg-4:nth-child(3) {
        padding-left: 15px;
        padding-right: 15px;
        margin-bottom: 20px;
    }
    .dj-card-body {
        padding: 20px;
    }
    .dj-card-header {
        padding: 15px 20px;
    }
    .dj-reservation-list,
    .dj-members-list,
    .dj-events-list {
        padding: 20px;
        gap: 12px;
    }
}

@media (max-width: 767.98px) {
    .dj-card-body {
        padding: 16px;
    }
    .dj-card-header {
        padding: 12px 16px;
    }
    .dj-reservation-list,
    .dj-members-list,
    .dj-events-list {
        padding: 16px;
        gap: 10px;
    }
    .dj-section-header {
        margin-bottom: 20px;
        padding-bottom: 12px;
    }
}


/* ===== ADVANCED COMPONENTS ===== */


/* Customer Management */

.dj-customer-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    margin-right: 12px;
    flex-shrink: 0;
}

.dj-customer-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dj-customer-details {
    display: flex;
    align-items: center;
}

.dj-customer-details>div {
    display: flex;
    flex-direction: column;
}

.dj-customer-name {
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 2px;
}

.dj-customer-company {
    font-size: 12px;
    color: var(--dj-text-secondary);
}

.dj-segment-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
    gap: 4px;
}

.dj-segment-vip {
    background: linear-gradient(135deg, #ffd700, #ffed4a);
    color: #8b5a00;
}

.dj-segment-corporate {
    background: linear-gradient(135deg, #667eea, #764ba2);
    color: white;
}

.dj-segment-individual {
    background: linear-gradient(135deg, #74b9ff, #0984e3);
    color: white;
}

.dj-booking-number {
    font-weight: 600;
    color: var(--dj-text-primary);
    display: block;
}

.dj-booking-trend {
    font-size: 11px;
    color: var(--dj-success);
    margin-top: 2px;
}

.dj-loyalty-points {
    min-width: 80px;
}

.dj-points-display {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dj-points-number {
    font-weight: 600;
    color: var(--dj-text-primary);
    font-size: 14px;
}

.dj-points-bar {
    width: 100%;
    height: 4px;
    background: var(--dj-border-color);
    border-radius: 2px;
    overflow: hidden;
}

.dj-points-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--dj-warning), var(--dj-success));
    border-radius: 2px;
    transition: width 0.3s ease;
}

.dj-action-dropdown {
    position: relative;
}

.dj-action-toggle {
    background: none;
    border: none;
    padding: 8px;
    border-radius: var(--dj-border-radius-sm);
    color: var(--dj-text-secondary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.dj-action-toggle:hover {
    background: var(--dj-gray-100);
    color: var(--dj-text-primary);
}


/* Supplier Management */

.dj-supplier-logo {
    width: 40px;
    height: 40px;
    border-radius: var(--dj-border-radius-sm);
    overflow: hidden;
    margin-right: 12px;
    flex-shrink: 0;
    background: var(--dj-gray-100);
}

.dj-supplier-logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dj-supplier-details {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 48px;
}

.dj-supplier-name {
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 2px;
}

.dj-supplier-code {
    font-size: 12px;
    color: var(--dj-text-secondary);
    background: var(--dj-gray-100);
    padding: 2px 6px;
    border-radius: var(--dj-border-radius-sm);
}

.dj-category-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 600;
    gap: 6px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    min-height: 32px;
    white-space: nowrap;
}

.dj-category-airline {
    background: linear-gradient(135deg, #74b9ff, #0984e3);
    color: white;
}

.dj-category-hotel {
    background: linear-gradient(135deg, #fd79a8, #e84393);
    color: white;
}

.dj-category-transport {
    background: linear-gradient(135deg, #fdcb6e, #e17055);
    color: white;
}

.dj-performance-rating {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 32px;
}

.dj-rating-stars {
    display: flex;
    gap: 2px;
}

.dj-rating-stars i {
    color: #ffd700;
    font-size: 12px;
}

.dj-rating-score {
    font-weight: 600;
    color: var(--dj-text-primary);
    font-size: 14px;
}


/* Inventory Management */

.dj-inventory-category-card {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    padding: 20px;
    margin-bottom: 20px;
    transition: all 0.3s ease;
}

.dj-inventory-category-card:hover {
    box-shadow: var(--dj-shadow-lg);
    transform: translateY(-2px);
}

.dj-category-header {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.dj-category-icon {
    font-size: 24px;
    margin-right: 12px;
    color: var(--dj-primary);
}

.dj-category-stats {
    margin-bottom: 15px;
}

.dj-stat-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    font-size: 14px;
}

.dj-stat-row span:first-child {
    color: var(--dj-text-secondary);
}

.dj-stat-row span:last-child {
    font-weight: 600;
    color: var(--dj-text-primary);
}


/* Transfer Services */

.dj-service-card {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    padding: 20px;
    margin-bottom: 20px;
    transition: all 0.3s ease;
}

.dj-service-card:hover {
    box-shadow: var(--dj-shadow-lg);
    transform: translateY(-2px);
}

.dj-service-header {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.dj-service-icon {
    font-size: 24px;
    margin-right: 12px;
    color: var(--dj-primary);
}

.dj-service-stats {
    margin-bottom: 15px;
}

.dj-stat-item {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    font-size: 14px;
}

.dj-stat-label {
    color: var(--dj-text-secondary);
}

.dj-stat-value {
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-service-features {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.dj-feature-badge {
    background: var(--dj-primary);
    color: white;
    padding: 4px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}


/* Activities */

.dj-activity-card {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    overflow: hidden;
    margin-bottom: 20px;
    transition: all 0.3s ease;
}

.dj-activity-card:hover {
    box-shadow: var(--dj-shadow-lg);
    transform: translateY(-2px);
}

.dj-activity-image {
    position: relative;
    height: 200px;
    overflow: hidden;
}

.dj-activity-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dj-activity-badge {
    position: absolute;
    top: 10px;
    right: 10px;
}

.dj-badge-popular {
    background: linear-gradient(135deg, #ff6b6b, #ee5a24);
    color: white;
    padding: 4px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}

.dj-badge-new {
    background: linear-gradient(135deg, #00b894, #00a085);
    color: white;
    padding: 4px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}

.dj-activity-content {
    padding: 20px;
}

.dj-activity-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 8px;
}

.dj-activity-location {
    color: var(--dj-text-secondary);
    font-size: 14px;
    margin-bottom: 12px;
}

.dj-activity-features {
    display: flex;
    gap: 12px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}

.dj-feature {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--dj-text-secondary);
}

.dj-activity-rating {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}

.dj-stars {
    display: flex;
    gap: 2px;
}

.dj-stars i {
    color: #ffd700;
    font-size: 14px;
}

.dj-rating-text {
    font-size: 12px;
    color: var(--dj-text-secondary);
}

.dj-activity-price {
    display: flex;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 15px;
}

.dj-price {
    font-size: 24px;
    font-weight: 700;
    color: var(--dj-primary);
}

.dj-price-unit {
    font-size: 14px;
    color: var(--dj-text-secondary);
}

.dj-activity-actions {
    display: flex;
    gap: 8px;
}


/* Insurance Plans */

.dj-insurance-plan {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    padding: 20px;
    margin: 10px;
    position: relative;
    transition: all 0.3s ease;
}

.dj-insurance-plan:hover {
    box-shadow: var(--dj-shadow-lg);
    transform: translateY(-2px);
}

.dj-plan-popular {
    border-color: var(--dj-primary);
    box-shadow: 0 0 0 2px rgba(74, 144, 226, 0.1);
}

.dj-plan-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--dj-primary);
    color: white;
    padding: 4px 12px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}

.dj-plan-header {
    text-align: center;
    margin-bottom: 20px;
}

.dj-plan-name {
    font-size: 20px;
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 8px;
}

.dj-plan-price {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 4px;
}

.dj-plan-price .dj-price {
    font-size: 32px;
    font-weight: 700;
    color: var(--dj-primary);
}

.dj-price-period {
    font-size: 14px;
    color: var(--dj-text-secondary);
}

.dj-plan-features {
    margin-bottom: 20px;
}

.dj-feature-item {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    font-size: 14px;
}

.dj-feature-item i {
    color: var(--dj-success);
    font-size: 12px;
}


/* Marketing Components */

.dj-campaigns-list,
.dj-email-marketing {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    padding: 20px;
    margin-bottom: 20px;
}

.dj-campaign-item {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 15px;
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    margin-bottom: 15px;
    transition: all 0.3s ease;
}

.dj-campaign-item:hover {
    box-shadow: var(--dj-shadow-md);
}

.dj-campaign-info {
    flex: 1;
}

.dj-campaign-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 4px;
}

.dj-campaign-desc {
    color: var(--dj-text-secondary);
    font-size: 14px;
    margin-bottom: 8px;
}

.dj-campaign-meta {
    display: flex;
    gap: 15px;
}

.dj-campaign-type,
.dj-campaign-period {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    color: var(--dj-text-secondary);
}

.dj-campaign-stats {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 120px;
}

.dj-campaign-actions {
    display: flex;
    gap: 8px;
}

.dj-email-stats {
    margin-bottom: 20px;
}

.dj-email-stat-item {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    font-size: 14px;
}

.dj-email-stat-item .dj-stat-label {
    color: var(--dj-text-secondary);
}

.dj-email-stat-item .dj-stat-value {
    font-weight: 600;
    color: var(--dj-text-primary);
}


/* CRM Components */

.dj-sales-pipeline,
.dj-tasks-widget {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    padding: 20px;
    margin-bottom: 20px;
}

.dj-pipeline-stage {
    margin-bottom: 15px;
}

.dj-stage-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.dj-stage-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-stage-count {
    background: var(--dj-gray-100);
    color: var(--dj-text-secondary);
    padding: 2px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}

.dj-stage-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--dj-primary);
    margin-bottom: 8px;
}

.dj-stage-bar {
    width: 100%;
    height: 6px;
    background: var(--dj-gray-100);
    border-radius: 3px;
    overflow: hidden;
}

.dj-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--dj-primary), var(--dj-success));
    border-radius: 3px;
    transition: width 0.3s ease;
}

.dj-task-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    margin-bottom: 10px;
    transition: all 0.3s ease;
}

.dj-task-item:hover {
    box-shadow: var(--dj-shadow-sm);
}

.dj-task-completed {
    opacity: 0.7;
    background: var(--dj-gray-50);
}

.dj-task-checkbox {
    position: relative;
}

.dj-task-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
}

.dj-task-content {
    flex: 1;
}

.dj-task-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 4px;
}

.dj-task-desc {
    font-size: 12px;
    color: var(--dj-text-secondary);
    margin-bottom: 4px;
}

.dj-task-time {
    font-size: 11px;
    color: var(--dj-text-secondary);
}

.dj-task-priority {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
}

.dj-priority-high {
    background: var(--dj-danger);
    color: white;
}

.dj-priority-medium {
    background: var(--dj-warning);
    color: white;
}

.dj-priority-low {
    background: var(--dj-success);
    color: white;
}


/* Loyalty Program */

.dj-loyalty-tiers,
.dj-rewards-catalog {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    padding: 20px;
    margin-bottom: 20px;
}

.dj-tier-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    margin-bottom: 10px;
    transition: all 0.3s ease;
}

.dj-tier-item:hover {
    box-shadow: var(--dj-shadow-md);
}

.dj-tier-bronze {
    border-left: 4px solid #cd7f32;
}

.dj-tier-silver {
    border-left: 4px solid #c0c0c0;
}

.dj-tier-gold {
    border-left: 4px solid #ffd700;
}

.dj-tier-platinum {
    border-left: 4px solid #e5e4e2;
}

.dj-tier-icon {
    font-size: 24px;
    color: var(--dj-primary);
}

.dj-tier-info {
    flex: 1;
}

.dj-tier-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 4px;
}

.dj-tier-desc {
    font-size: 12px;
    color: var(--dj-text-secondary);
    margin-bottom: 8px;
}

.dj-tier-benefits {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.dj-benefit {
    background: var(--dj-gray-100);
    color: var(--dj-text-secondary);
    padding: 2px 6px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 11px;
}

.dj-tier-count {
    font-size: 18px;
    font-weight: 700;
    color: var(--dj-primary);
}

.dj-reward-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    border: 1px solid var(--dj-border-color);
    border-radius: var(--dj-border-radius);
    margin-bottom: 15px;
    transition: all 0.3s ease;
}

.dj-reward-item:hover {
    box-shadow: var(--dj-shadow-md);
}

.dj-reward-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--dj-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

.dj-reward-info {
    flex: 1;
}

.dj-reward-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 4px;
}

.dj-reward-desc {
    font-size: 12px;
    color: var(--dj-text-secondary);
    margin-bottom: 8px;
}

.dj-reward-cost {
    display: flex;
    align-items: center;
    gap: 8px;
}

.dj-points {
    background: var(--dj-warning);
    color: white;
    padding: 2px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}

.dj-reward-stock {
    text-align: center;
}

.dj-stock-count {
    font-size: 16px;
    font-weight: 700;
    color: var(--dj-text-primary);
}


/* Enhanced Statistics and Analytics Styling */

.dj-advanced-stats {
    margin-bottom: var(--dj-spacing-lg);
}

.dj-advanced-stats .col-lg-2 {
    margin-bottom: var(--dj-spacing-md);
}

.dj-analytics-dashboard {
    margin-bottom: var(--dj-spacing-lg);
}

.dj-performance-insights {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius);
    box-shadow: var(--dj-shadow-soft);
    border: 1px solid var(--dj-border-light);
}

.dj-insights-list {
    padding: 0;
}

.dj-insight-item {
    display: flex;
    align-items: flex-start;
    padding: var(--dj-spacing-md);
    border-bottom: 1px solid var(--dj-border-light);
    transition: var(--dj-transition);
}

.dj-insight-item:last-child {
    border-bottom: none;
}

.dj-insight-item:hover {
    background-color: var(--dj-bg-light);
}

.dj-insight-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: var(--dj-spacing-md);
    flex-shrink: 0;
}

.dj-insight-positive .dj-insight-icon {
    background: rgba(46, 204, 113, 0.1);
    color: var(--dj-success);
}

.dj-insight-warning .dj-insight-icon {
    background: rgba(241, 196, 15, 0.1);
    color: var(--dj-warning);
}

.dj-insight-info .dj-insight-icon {
    background: rgba(52, 152, 219, 0.1);
    color: var(--dj-info);
}

.dj-insight-content h6 {
    margin: 0 0 4px 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-insight-content p {
    margin: 0;
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-detailed-analytics {
    margin-bottom: var(--dj-spacing-lg);
}

.dj-customer-analytics {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius);
    box-shadow: var(--dj-shadow-soft);
    border: 1px solid var(--dj-border-light);
}

.dj-customer-segments {
    padding: 0;
}

.dj-segment-item {
    padding: var(--dj-spacing-md);
    border-bottom: 1px solid var(--dj-border-light);
}

.dj-segment-item:last-child {
    border-bottom: none;
}

.dj-segment-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--dj-spacing-sm);
}

.dj-segment-name {
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-segment-count {
    font-size: 14px;
    color: var(--dj-text-muted);
}

.dj-segment-bar {
    height: 8px;
    background: var(--dj-bg-light);
    border-radius: 4px;
    margin-bottom: var(--dj-spacing-sm);
    overflow: hidden;
}

.dj-bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.5s ease;
}

.dj-bar-gold {
    background: linear-gradient(90deg, #f39c12, #e67e22);
}

.dj-bar-blue {
    background: linear-gradient(90deg, #3498db, #2980b9);
}

.dj-bar-green {
    background: linear-gradient(90deg, #2ecc71, #27ae60);
}

.dj-segment-value {
    font-size: 13px;
    color: var(--dj-text-muted);
    font-weight: 500;
}

.dj-destination-flag {
    font-size: 18px;
    margin-right: var(--dj-spacing-sm);
}

.dj-realtime-analytics {
    margin-bottom: var(--dj-spacing-lg);
}

.dj-realtime-dashboard {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius);
    box-shadow: var(--dj-shadow-soft);
    border: 1px solid var(--dj-border-light);
}

.dj-live-indicator {
    display: inline-flex;
    align-items: center;
    margin-left: var(--dj-spacing-sm);
    color: var(--dj-danger);
    font-size: 12px;
    font-weight: 600;
}

.dj-live-indicator i {
    margin-right: 4px;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% {
        opacity: 1;
    }
    50% {
        opacity: 0.5;
    }
    100% {
        opacity: 1;
    }
}

.dj-realtime-stats {
    padding: var(--dj-spacing-md) 0;
}

.dj-realtime-stat {
    display: flex;
    align-items: center;
    padding: var(--dj-spacing-md);
    background: var(--dj-bg-light);
    border-radius: var(--dj-border-radius);
    border: 1px solid var(--dj-border-light);
}

.dj-realtime-stat .dj-stat-icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--dj-primary);
    color: white;
    margin-right: var(--dj-spacing-md);
    flex-shrink: 0;
}

.dj-realtime-stat .dj-stat-info h4 {
    margin: 0 0 4px 0;
    font-size: 24px;
    font-weight: 700;
    color: var(--dj-text-primary);
}

.dj-realtime-stat .dj-stat-info p {
    margin: 0;
    font-size: 14px;
    color: var(--dj-text-muted);
}


/* Enhanced API Integrations Styling */

.dj-enterprise-integrations {
    margin-bottom: var(--dj-spacing-lg);
}

.dj-integration-item {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-light);
    border-radius: var(--dj-border-radius);
    padding: var(--dj-spacing-md);
    margin-bottom: var(--dj-spacing-md);
    transition: var(--dj-transition);
}

.dj-integration-item:hover {
    box-shadow: var(--dj-shadow-medium);
    transform: translateY(-2px);
}

.dj-integration-premium {
    border-left: 4px solid var(--dj-primary);
}

.dj-integration-pending {
    border-left: 4px solid var(--dj-warning);
    opacity: 0.8;
}

.dj-integration-header {
    display: flex;
    align-items: center;
    margin-bottom: var(--dj-spacing-md);
}

.dj-integration-header .dj-integration-icon {
    width: 50px;
    height: 50px;
    border-radius: var(--dj-border-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--dj-bg-light);
    color: var(--dj-primary);
    margin-right: var(--dj-spacing-md);
    flex-shrink: 0;
}

.dj-integration-info h6 {
    margin: 0 0 4px 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-integration-desc {
    margin: 0;
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-integration-metrics {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--dj-spacing-md);
    padding: var(--dj-spacing-sm);
    background: var(--dj-bg-light);
    border-radius: var(--dj-border-radius-sm);
}

.dj-metric {
    text-align: center;
    flex: 1;
}

.dj-metric-label {
    display: block;
    font-size: 11px;
    color: var(--dj-text-muted);
    margin-bottom: 2px;
}

.dj-metric-value {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-integration-status {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dj-status-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}

.dj-status-active {
    background: rgba(46, 204, 113, 0.1);
    color: var(--dj-success);
}

.dj-status-pending {
    background: rgba(241, 196, 15, 0.1);
    color: var(--dj-warning);
}

.dj-integration-actions {
    display: flex;
    gap: var(--dj-spacing-sm);
}

.dj-api-monitoring {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius);
    box-shadow: var(--dj-shadow-soft);
    border: 1px solid var(--dj-border-light);
    margin-bottom: var(--dj-spacing-md);
}

.dj-system-status {
    padding: var(--dj-spacing-md);
}

.dj-status-item {
    display: flex;
    align-items: center;
    margin-bottom: var(--dj-spacing-md);
}

.dj-status-indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-right: var(--dj-spacing-sm);
}

.dj-status-healthy {
    background: var(--dj-success);
}

.dj-status-label {
    font-weight: 500;
    color: var(--dj-text-primary);
}

.dj-status-metrics {
    display: flex;
    flex-direction: column;
    gap: var(--dj-spacing-sm);
}

.dj-metric-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--dj-spacing-sm);
    background: var(--dj-bg-light);
    border-radius: var(--dj-border-radius-sm);
}

.dj-metric-name {
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-metric-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-api-alerts {
    background: var(--dj-white);
    border-radius: var(--dj-border-radius);
    box-shadow: var(--dj-shadow-soft);
    border: 1px solid var(--dj-border-light);
}

.dj-alerts-list {
    padding: 0;
}

.dj-alert-item {
    display: flex;
    align-items: flex-start;
    padding: var(--dj-spacing-md);
    border-bottom: 1px solid var(--dj-border-light);
}

.dj-alert-item:last-child {
    border-bottom: none;
}

.dj-alert-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: var(--dj-spacing-md);
    flex-shrink: 0;
}

.dj-alert-info .dj-alert-icon {
    background: rgba(52, 152, 219, 0.1);
    color: var(--dj-info);
}

.dj-alert-success .dj-alert-icon {
    background: rgba(46, 204, 113, 0.1);
    color: var(--dj-success);
}

.dj-alert-warning .dj-alert-icon {
    background: rgba(241, 196, 15, 0.1);
    color: var(--dj-warning);
}

.dj-alert-content h6 {
    margin: 0 0 4px 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text-primary);
}

.dj-alert-content p {
    margin: 0 0 4px 0;
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-alert-content small {
    font-size: 12px;
    color: var(--dj-text-muted);
}


/* Enhanced Group Requests Styling */


/* Advanced Filtering System */

.dj-advanced-filters {
    background: var(--dj-white);
    border: 1px solid var(--dj-border-light);
    border-radius: var(--dj-border-radius);
    padding: var(--dj-spacing-lg);
    margin-bottom: var(--dj-spacing-lg);
    box-shadow: var(--dj-shadow-soft);
}

.dj-filter-row {
    margin-bottom: var(--dj-spacing-md);
}

.dj-search-container {
    margin-bottom: var(--dj-spacing-md);
}

.dj-search-container .dj-search-box {
    max-width: 400px;
    width: 100%;
}

.dj-filters-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--dj-spacing-md);
    margin-bottom: var(--dj-spacing-md);
}

.dj-filter-item {
    display: flex;
    flex-direction: column;
}

.dj-filter-label {
    display: flex;
    align-items: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: var(--dj-spacing-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dj-filter-label i {
    margin-right: var(--dj-spacing-sm);
    color: var(--dj-primary);
    font-size: 12px;
}

.dj-filter-select {
    padding: 8px 12px;
    border: 1px solid var(--dj-border-light);
    border-radius: var(--dj-border-radius-sm);
    background: var(--dj-white);
    color: var(--dj-text-primary);
    font-size: 14px;
    transition: var(--dj-transition);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 16px;
    padding-right: 32px;
}

.dj-filter-select:focus {
    outline: none;
    border-color: var(--dj-primary);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

.dj-filter-select:hover {
    border-color: var(--dj-primary);
}

.dj-filter-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--dj-spacing-md);
    border-top: 1px solid var(--dj-border-light);
}

.dj-filter-controls {
    display: flex;
    gap: var(--dj-spacing-sm);
}

.dj-action-buttons {
    display: flex;
    gap: var(--dj-spacing-sm);
}

.dj-filter-group {
    display: flex;
    gap: var(--dj-spacing-sm);
    flex-wrap: wrap;
    align-items: center;
}

.dj-action-group {
    display: flex;
    gap: var(--dj-spacing-sm);
    align-items: center;
}

.dj-table-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--dj-spacing-md);
    padding: var(--dj-spacing-md);
    background: var(--dj-bg-light);
    border-radius: var(--dj-border-radius);
    border: 1px solid var(--dj-border-light);
}

.dj-table-info {
    font-size: 14px;
    color: var(--dj-text-muted);
}

.dj-table-actions {
    display: flex;
    gap: var(--dj-spacing-sm);
    align-items: center;
}

.dj-table th {
    position: relative;
    cursor: pointer;
    user-select: none;
}

.dj-table th i[data-sort] {
    margin-left: var(--dj-spacing-sm);
    opacity: 0.5;
    transition: var(--dj-transition);
}

.dj-table th:hover i[data-sort] {
    opacity: 1;
}

.dj-checkbox-all,
.dj-row-checkbox {
    margin: 0;
    transform: scale(1.1);
}

.dj-customer-details {
    display: flex;
    align-items: flex-start;
}

.dj-customer-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    margin-right: var(--dj-spacing-md);
    flex-shrink: 0;
    background: var(--dj-bg-light);
    display: none;
    /* Hidden since avatars were removed */
}

.dj-customer-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dj-customer-data {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.dj-customer-name {
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 2px;
}

.dj-customer-email {
    font-size: 13px;
    color: var(--dj-text-muted);
    margin-bottom: 2px;
}

.dj-customer-company {
    font-size: 12px;
    color: var(--dj-primary);
    font-weight: 500;
}

.dj-destination-info {
    display: flex;
    align-items: center;
}

.dj-destination-flag {
    font-size: 20px;
    margin-right: var(--dj-spacing-sm);
}

.dj-destination-details {
    display: flex;
    flex-direction: column;
}

.dj-destination-country {
    font-weight: 600;
    color: var(--dj-text-primary);
    margin-bottom: 2px;
}

.dj-destination-city {
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-date-range {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.dj-date-start,
.dj-date-end {
    font-weight: 500;
    color: var(--dj-text-primary);
}

.dj-date-separator {
    margin: 0 4px;
    color: var(--dj-text-muted);
}

.dj-date-duration {
    font-size: 12px;
    color: var(--dj-text-muted);
    margin-top: 2px;
}

.dj-group-info {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.dj-group-size {
    font-size: 20px;
    font-weight: 700;
    color: var(--dj-text-primary);
}

.dj-group-type {
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-budget-info {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.dj-budget-amount {
    font-size: 16px;
    font-weight: 700;
    color: var(--dj-success);
}

.dj-budget-per-person {
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-priority-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    border-radius: var(--dj-border-radius-sm);
    font-size: 12px;
    font-weight: 500;
}

.dj-priority-high {
    background: rgba(231, 76, 60, 0.1);
    color: var(--dj-danger);
}

.dj-priority-medium {
    background: rgba(241, 196, 15, 0.1);
    color: var(--dj-warning);
}

.dj-priority-low {
    background: rgba(149, 165, 166, 0.1);
    color: var(--dj-text-muted);
}

.dj-request-date-created {
    display: block;
    font-size: 11px;
    color: var(--dj-text-muted);
    margin-top: 2px;
}

.dj-table-pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: var(--dj-spacing-md);
    padding: var(--dj-spacing-md);
    background: var(--dj-bg-light);
    border-radius: var(--dj-border-radius);
    border: 1px solid var(--dj-border-light);
}

.dj-pagination-info {
    font-size: 14px;
    color: var(--dj-text-muted);
}


/* Status Badge Enhancements */

.dj-status-processing {
    background: rgba(155, 89, 182, 0.1);
    color: #9b59b6;
}

.dj-status-processing i {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}


/* Responsive Enhancements */

@media (max-width: 1200px) {
    .dj-filters-grid {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }
    .dj-filter-actions {
        flex-direction: column;
        gap: var(--dj-spacing-md);
        align-items: stretch;
    }
    .dj-filter-controls,
    .dj-action-buttons {
        justify-content: center;
        flex-wrap: wrap;
    }
    .dj-filter-group {
        flex-direction: column;
        align-items: stretch;
    }
    .dj-filter-group>* {
        margin-bottom: var(--dj-spacing-sm);
    }
    .dj-integration-metrics {
        flex-direction: column;
        gap: var(--dj-spacing-sm);
    }
}

@media (max-width: 991.98px) {
    .dj-table-controls {
        flex-direction: column;
        gap: var(--dj-spacing-md);
    }
    .dj-table-pagination {
        flex-direction: column;
        gap: var(--dj-spacing-md);
    }
    .dj-customer-details {
        flex-direction: column;
        text-align: center;
    }
    .dj-customer-avatar {
        margin-right: 0;
        margin-bottom: var(--dj-spacing-sm);
    }
    .dj-advanced-stats .col-lg-2 {
        margin-bottom: var(--dj-spacing-md);
    }
}

@media (max-width: 767.98px) {
    .dj-advanced-filters {
        padding: var(--dj-spacing-md);
    }
    .dj-filters-grid {
        grid-template-columns: 1fr;
        gap: var(--dj-spacing-sm);
    }
    .dj-filter-actions {
        flex-direction: column;
        gap: var(--dj-spacing-md);
    }
    .dj-filter-controls,
    .dj-action-buttons {
        flex-direction: column;
        width: 100%;
    }
    .dj-filter-controls .dj-btn,
    .dj-action-buttons .dj-btn {
        width: 100%;
        margin-bottom: var(--dj-spacing-sm);
    }
    .dj-search-container .dj-search-box {
        max-width: 100%;
    }
    .dj-section-actions {
        flex-direction: column;
        gap: var(--dj-spacing-md);
    }
    .dj-filter-group,
    .dj-action-group {
        width: 100%;
        justify-content: stretch;
    }
    .dj-filter-group>*,
    .dj-action-group>* {
        flex: 1;
    }
    .dj-integration-item {
        margin-bottom: var(--dj-spacing-lg);
    }
    .dj-integration-header {
        flex-direction: column;
        text-align: center;
    }
    .dj-integration-header .dj-integration-icon {
        margin-right: 0;
        margin-bottom: var(--dj-spacing-sm);
    }
}


/* Additional Utility Classes */

.dj-text-truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dj-badge-small {
    font-size: 10px;
    padding: 2px 6px;
}

.dj-border-dashed {
    border-style: dashed !important;
}

.dj-opacity-50 {
    opacity: 0.5;
}

.dj-opacity-75 {
    opacity: 0.75;
}


/* Animation Utilities */

.dj-fade-in {
    animation: fadeIn 0.3s ease-in;
}

.dj-slide-up {
    animation: slideUp 0.3s ease-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

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