/* Custom Styles for MenuMax Tableau de Bord 3 */

/* Override Tailwind defaults */
:root {
    --primary-color: rgb(255, 152, 0);
    --primary-dark: rgb(230, 137, 0);
    --primary-light: rgb(255, 183, 77);
}

/* Custom animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in-up {
    animation: fadeInUp 0.5s ease-out;
}

/* Date Range Picker Styling */
.daterangepicker {
    border-radius: 0.5rem;
    border: none;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

.daterangepicker .ranges li {
    color: #374151;
}

.daterangepicker .ranges li:hover {
    background-color: var(--primary-light);
    color: white;
}

.daterangepicker .ranges li.active {
    background-color: var(--primary-color);
    color: white;
}

.daterangepicker td.active,
.daterangepicker td.active:hover {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.daterangepicker .calendar-table .next span,
.daterangepicker .calendar-table .prev span {
    color: var(--primary-color);
    border-color: var(--primary-color);
}

.daterangepicker .calendar-table .next:hover span,
.daterangepicker .calendar-table .prev:hover span {
    background-color: var(--primary-color);
    color: white;
}

/* ApexCharts overrides */
.apexcharts-menu {
    border-radius: 0.375rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.apexcharts-tooltip {
    border-radius: 0.375rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

/* Custom scrollbar */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: #f1f5f9;
    border-radius: 3px;
}

::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

/* Mobile optimizations */
@media (max-width: 768px) {
    .grid-cols-1 {
        gap: 1rem;
    }
    
    .text-4xl {
        font-size: 2rem;
    }
    
    .text-2xl {
        font-size: 1.25rem;
    }
    
    table {
        font-size: 0.875rem;
    }
    
    .px-4 {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }
    
    /* Chart containers for mobile */
    #salesChart,
    #restaurantChart {
        min-height: 250px;
        width: 100%;
    }
    
    /* Chart responsive containers */
    .chart-container {
        width: 100%;
        overflow: hidden;
    }
    
    /* Reduce padding on mobile */
    .p-6 {
        padding: 1rem;
    }
    
    /* Mobile chart legend adjustments */
    .apexcharts-legend {
        padding: 0 !important;
        margin: 10px 0 !important;
    }
    
    .apexcharts-legend-series {
        margin: 2px 5px !important;
    }
}

@media (max-width: 480px) {
    #salesChart,
    #restaurantChart {
        min-height: 200px;
    }
    
    /* Hide chart legends on very small screens */
    .apexcharts-legend {
        display: none !important;
    }
    
    /* Smaller chart labels */
    .apexcharts-xaxis-label,
    .apexcharts-yaxis-label {
        font-size: 9px !important;
    }
    
    /* Compact grid layout */
    .lg\:grid-cols-3 {
        grid-template-columns: 1fr;
    }
    
    .lg\:col-span-2 {
        grid-column: span 1;
    }
}

/* Hover effects for cards */
.hover\:scale-105:hover {
    transform: scale(1.05);
}

/* Custom table styling */
.table-auto tbody tr:hover {
    background-color: #f9fafb;
}

/* Loading animation */
@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

.animate-spin {
    animation: spin 1s linear infinite;
}

/* Focus states */
input:focus,
select:focus {
    outline: none;
    box-shadow: 0 0 0 2px var(--primary-color);
    border-color: transparent;
}

/* Button states */
button:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.12);
}

button:active {
    transform: translateY(0);
}

/* Modal backdrop */
.modal-backdrop {
    backdrop-filter: blur(4px);
}

/* Error states */
.border-red-400:focus {
    box-shadow: 0 0 0 2px #f87171;
    border-color: #f87171;
}

/* Success states */
.border-green-400:focus {
    box-shadow: 0 0 0 2px #4ade80;
    border-color: #4ade80;
}
