/* Analytics Cards Responsive Fix - Ensure proper alignment and content fitting */

/* Fix the main analytics section grid */
.visitor-analytics-section {
    margin: 1rem !important; /* Reduce margin for better fit */
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important; /* Smaller min width */
    gap: 1rem !important; /* Consistent gap */
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Ensure analytics cards fit content properly */
.analytics-card {
    min-height: 0 !important; /* Remove any minimum height */
    height: auto !important; /* Let height adjust to content */
    display: flex !important;
    flex-direction: column !important;
    overflow: visible !important; /* Show all content */
}

/* Fix card body to expand properly */
.analytics-card-body {
    flex: 1 !important;
    padding: 1rem !important; /* Consistent padding */
    display: flex !important;
    flex-direction: column !important;
}

/* Fix Visit Statistics grid layout */
.quick-stats-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.75rem !important;
    width: 100% !important;
}

/* Make stat items more compact and aligned */
.stat-item {
    padding: 0.75rem !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 90px !important;
}

.stat-icon {
    width: 32px !important;
    height: 32px !important;
    margin-bottom: 0.5rem !important;
    flex-shrink: 0 !important;
}

.stat-value {
    font-size: 1.125rem !important;
    margin: 0 0 0.25rem 0 !important;
    word-break: break-word !important;
}

.stat-label {
    font-size: 0.75rem !important;
    color: #6b7280 !important;
    margin: 0 !important;
    line-height: 1.2 !important;
}

/* Fix charts to be responsive */
.frequency-chart,
#visitFrequencyChart,
#visitTimesChart {
    max-width: 100% !important;
    height: auto !important;
    max-height: 200px !important;
}

/* Fix weekly pattern grid */
.weekday-grid {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 0.5rem !important;
    width: 100% !important;
}

.weekday-item {
    aspect-ratio: 1 !important; /* Keep squares */
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.5rem !important;
    font-size: 0.75rem !important;
}

/* Fix time distribution grid */
.time-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.5rem !important;
    width: 100% !important;
}

.time-item {
    padding: 0.75rem !important;
    text-align: center !important;
    border-radius: 0.375rem !important;
}

/* Fix Top Locations list */
#topLocations,
.recent-activity-list {
    max-height: 300px !important; /* Limit height */
    overflow-y: auto !important; /* Add scroll if needed */
    padding: 0 !important;
}

.activity-item {
    padding: 0.75rem !important;
    margin-bottom: 0.5rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0.5rem !important;
}

.activity-item:last-child {
    margin-bottom: 0 !important;
}

.activity-icon {
    width: 32px !important;
    height: 32px !important;
    flex-shrink: 0 !important;
}

.activity-details {
    flex: 1 !important;
    min-width: 0 !important; /* Allow text truncation */
}

.activity-title {
    font-size: 0.875rem !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.activity-meta {
    font-size: 0.75rem !important;
    color: #6b7280 !important;
}

/* Responsive adjustments */
@media (max-width: 1200px) {
    .visitor-analytics-section {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 768px) {
    .visitor-analytics-section {
        grid-template-columns: 1fr !important;
        gap: 0.75rem !important;
        margin: 0.5rem !important;
    }
    
    /* Stack stats in a single column on mobile */
    .quick-stats-grid {
        grid-template-columns: 1fr !important;
        gap: 0.5rem !important;
    }
    
    .stat-item {
        flex-direction: row !important;
        justify-content: flex-start !important;
        text-align: left !important;
        min-height: auto !important;
        padding: 0.75rem !important;
    }
    
    .stat-icon {
        margin-right: 0.75rem !important;
        margin-bottom: 0 !important;
    }
    
    .stat-value {
        font-size: 1rem !important;
    }
    
    /* Make weekday grid smaller on mobile */
    .weekday-item {
        font-size: 0.625rem !important;
        padding: 0.25rem !important;
    }
    
    /* Stack time items vertically */
    .time-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Ensure all analytics cards have equal height in each row */
@supports (display: grid) {
    .visitor-analytics-section {
        grid-auto-rows: 1fr !important;
    }
    
    .analytics-card {
        display: grid !important;
        grid-template-rows: auto 1fr !important;
    }
}

/* Fix any overflow issues */
.analytics-card * {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Improve scrollbar styling for top locations */
#topLocations::-webkit-scrollbar {
    width: 6px;
}

#topLocations::-webkit-scrollbar-track {
    background: #f3f4f6;
    border-radius: 3px;
}

#topLocations::-webkit-scrollbar-thumb {
    background: #d1d5db;
    border-radius: 3px;
}

#topLocations::-webkit-scrollbar-thumb:hover {
    background: #9ca3af;
}