/* Mobile Responsive Optimizations for PolyQuant Dashboard */

/* Base mobile-first approach */
@media (max-width: 640px) {
    /* Header adjustments */
    .header-flex {
        flex-direction: column;
        gap: 1rem;
        align-items: flex-start;
    }

    .header-buttons {
        width: 100%;
        display: flex;
        gap: 0.5rem;
        flex-wrap: wrap;
    }

    .header-buttons a,
    .header-buttons button {
        flex: 1;
        min-width: 120px;
        text-align: center;
        font-size: 0.875rem;
        padding: 0.5rem 1rem;
    }

    /* Grid optimizations */
    .stats-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.75rem;
    }

    .controls-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem;
    }

    .filters-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem;
    }

    /* Cards and content */
    .card-padding {
        padding: 1rem;
    }

    .card-title {
        font-size: 1.25rem;
    }

    /* Tables - horizontal scroll */
    .table-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .table-container table {
        min-width: 600px;
    }

    /* Forms and inputs */
    .form-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem;
    }

    .input-group {
        flex-direction: column;
        align-items: stretch;
    }

    .input-group label {
        margin-bottom: 0.5rem;
    }

    /* Navigation */
    .nav-tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
        padding-bottom: 0.5rem;
    }

    .nav-tab {
        display: inline-block;
        margin-right: 0.5rem;
        white-space: nowrap;
    }

    /* Modal adjustments */
    .modal-container {
        margin: 0.5rem;
        max-height: calc(100vh - 1rem);
        overflow-y: auto;
    }

    .modal-content {
        padding: 1rem;
    }

    /* Touch targets */
    button,
    .toggle-switch,
    .clickable {
        min-height: 44px;
        min-width: 44px;
    }

    /* Text adjustments */
    .text-3xl {
        font-size: 1.875rem;
    }

    .text-2xl {
        font-size: 1.5rem;
    }

    .text-xl {
        font-size: 1.25rem;
    }

    /* Spacing adjustments */
    .page-padding {
        padding: 1rem;
    }

    .section-spacing {
        margin-bottom: 1.5rem;
    }
}

/* Tablet adjustments */
@media (min-width: 641px) and (max-width: 1024px) {
    .stats-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    .filters-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .controls-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* Landscape phone adjustments */
@media (max-width: 896px) and (orientation: landscape) {
    .page-padding {
        padding: 0.5rem;
    }

    .header-flex {
        flex-direction: row;
        align-items: center;
    }

    .stats-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* Touch improvements */
@media (pointer: coarse) {
    .hover\\:bg-gray-700:hover {
        background-color: rgb(55 65 81);
    }

    .hover\\:bg-blue-700:hover {
        background-color: rgb(29 78 216);
    }

    /* Larger touch targets */
    .toggle-switch {
        width: 3rem;
        height: 1.75rem;
    }

    .toggle-slider:before {
        height: 1.25rem;
        width: 1.25rem;
    }

    input:checked + .toggle-slider:before {
        transform: translateX(1.25rem);
    }
}

/* Dark mode adjustments for mobile */
@media (prefers-color-scheme: dark) {
    .mobile-safe-area {
        background-color: rgb(17 24 39);
    }
}

/* iOS specific adjustments */
@supports (-webkit-touch-callout: none) {
    .page-container {
        padding-bottom: env(safe-area-inset-bottom);
        padding-top: env(safe-area-inset-top);
    }

    .modal-container {
        padding-bottom: env(safe-area-inset-bottom);
    }
}

/* Android specific adjustments */
@supports not (-webkit-touch-callout: none) {
    .android-nav-height {
        padding-bottom: 0.5rem;
    }
}

/* High DPI displays */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .crisp-edges {
        image-rendering: -webkit-optimize-contrast;
        image-rendering: crisp-edges;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .transition-all {
        transition: none !important;
    }

    .animate-spin {
        animation: none !important;
    }
}

/* Print styles */
@media print {
    .no-print {
        display: none !important;
    }

    .page-container {
        padding: 0;
        background: white;
        color: black;
    }
}