/* TaxiMK Responsive CSS - Mobile-First Design */

/* Base Mobile Styles */
.mobile-nav-hidden {
    display: none;
}

/* Responsive Grid Layouts */
.responsive-grid-1 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.responsive-grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.responsive-grid-3 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

/* Tablet Styles */
@media (min-width: 640px) {
    .responsive-grid-2 {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
    
    .responsive-grid-3 {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
}

/* Desktop Styles */
@media (min-width: 1024px) {
    .responsive-grid-3 {
        grid-template-columns: repeat(3, 1fr);
        gap: 2rem;
    }
}

/* Responsive Text Sizes */
.responsive-text-xl {
    font-size: 1.125rem; /* 18px */
}

.responsive-text-2xl {
    font-size: 1.25rem; /* 20px */
}

@media (min-width: 640px) {
    .responsive-text-xl {
        font-size: 1.25rem; /* 20px */
    }
    
    .responsive-text-2xl {
        font-size: 1.5rem; /* 24px */
    }
}

@media (min-width: 1024px) {
    .responsive-text-xl {
        font-size: 1.5rem; /* 24px */
    }
    
    .responsive-text-2xl {
        font-size: 1.875rem; /* 30px */
    }
}

/* Responsive Padding */
.responsive-padding {
    padding: 1rem;
}

@media (min-width: 640px) {
    .responsive-padding {
        padding: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .responsive-padding {
        padding: 2rem;
    }
}

/* Mobile Form Improvements */
@media (max-width: 639px) {
    .form-input {
        font-size: 16px; /* Prevent zoom on iOS */
        padding: 0.75rem;
    }
    
    .form-button {
        padding: 0.75rem 1rem;
        font-size: 0.875rem;
    }
    
    .card-padding {
        padding: 1rem;
    }
    
    .nav-height {
        height: 3.5rem;
    }
}

/* Touch-friendly buttons on mobile */
@media (max-width: 639px) {
    .btn-touch {
        min-height: 44px;
        min-width: 44px;
    }
}

/* Dashboard responsive adjustments */
.dashboard-card {
    padding: 1rem;
    border-radius: 1rem;
}

@media (min-width: 640px) {
    .dashboard-card {
        padding: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .dashboard-card {
        padding: 2rem;
    }
}

/* Notification panel responsive */
.notification-panel {
    position: fixed;
    top: 0;
    right: -100%;
    width: 100%;
    height: 100vh;
    background: white;
    transition: right 0.3s ease;
    z-index: 1000;
}

.notification-panel.open {
    right: 0;
}

@media (min-width: 768px) {
    .notification-panel {
        width: 400px;
        right: -400px;
    }
    
    .notification-panel.open {
        right: 0;
    }
}

/* Mobile table improvements */
@media (max-width: 639px) {
    .table-responsive {
        overflow-x: auto;
    }
    
    .table-responsive table {
        min-width: 600px;
    }
}