/* Advanced Responsive Enhancements for Project Grid */

/* Base grid layout improvements */
.projects-page {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, auto);
    grid-template-areas: 
        "project1 project2"
        "project3 project4";
    grid-auto-flow: row;
    gap: 30px;
    justify-content: space-between;
    will-change: transform; /* Performance optimization */
}

/* Explicit grid positions for each project card */
.projects-page > .project-card:nth-child(1) { grid-area: project1 !important; }
.projects-page > .project-card:nth-child(2) { grid-area: project2 !important; }
.projects-page > .project-card:nth-child(3) { grid-area: project3 !important; }
.projects-page > .project-card:nth-child(4) { grid-area: project4 !important; }

/* Enhanced desktop experience */
@media (min-width: 1201px) {
    .projects-container {
        padding: 40px 0;
    }
    
    .projects-page {
        max-width: 1400px;
        margin: 0 auto;
        gap: 35px;
    }
    
    /* Elegant hover animations exclusive to desktop */
    .project-card:hover .project-screenshot img {
        transform: scale(1.05);
    }
    
    .project-card:hover::after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        border-radius: 12px;
        box-shadow: 0 0 0 3px var(--primary-color, #4169E1);
        opacity: 0.5;
        pointer-events: none;
        animation: pulse 1.5s infinite;
    }
    
    @keyframes pulse {
        0% { opacity: 0.5; }
        50% { opacity: 0.3; }
        100% { opacity: 0.5; }
    }
}

/* Tablet-specific improvements */
@media (min-width: 769px) and (max-width: 1200px) {
    .projects-page {
        gap: 25px;
    }
    
    /* Slightly different hover effect for tablets */
    .project-card:hover,
    .project-card:active {
        transform: translateY(-5px);
    }
}

/* Optimized mobile experience (portrait) */
@media (max-width: 768px) and (orientation: portrait) {
    .projects-page {
        grid-template-columns: 1fr;
        grid-template-areas: 
            "project1"
            "project2"
            "project3"
            "project4";
        gap: 25px;
    }
    
    /* Enhanced touch feedback */
    .project-card:active {
        transform: scale(0.98);
        transition: transform 0.2s ease-out;
    }
    
    /* Larger clickable areas */
    .view-project-btn {
        padding: 12px 20px;
    }
    
    /* Carousel navigation optimization */
    .carousel-button {
        width: 42px;
        height: 42px;
    }
    
    .carousel-dots {
        margin-top: 35px;
    }
}

/* Mobile landscape optimization */
@media (max-width: 900px) and (orientation: landscape) {
    .projects-page {
        grid-template-columns: repeat(2, 1fr);
        grid-template-areas: 
            "project1 project2"
            "project3 project4";
        gap: 15px;
        padding: 0 15px;
    }
    
    /* Compact layout for landscape */
    .project-screenshot {
        height: 140px;
    }
    
    .project-content {
        padding: 10px;
    }
    
    .project-card-footer {
        padding: 10px;
    }
    
    /* Hide non-essential elements in landscape */
    .project-tech-tag {
        display: none;
    }
}

/* Foldable device-specific optimizations */
@media (min-width: 600px) and (max-width: 800px) and (min-height: 720px) {
    .projects-page {
        gap: 18px;
    }
}

/* Ensure our grid layout is maintained regardless of JS failures */
@supports not (display: grid) {
    .projects-page {
        display: flex;
        flex-wrap: wrap;
    }
    
    .project-card {
        width: calc(50% - 15px);
        margin-bottom: 30px;
    }
    
    @media (max-width: 768px) {
        .project-card {
            width: 100%;
        }
    }
}

/* High-DPI screen optimizations */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .project-screenshot img {
        image-rendering: -webkit-optimize-contrast;
    }
}

/* Force correct project ordering */
.projects-page {
    /* Ensure placement works in all browsers */
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 30px 1fr;
    grid-template-columns: 1fr 1fr;
    -ms-grid-rows: auto 30px auto;
    grid-template-rows: auto auto;
}

/* Fix for Safari's grid implementation */
@supports (-webkit-touch-callout: none) {
    .projects-page {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-auto-flow: row;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
    }
}
