/*==========================================================
                    PROJECT HEADER
==========================================================*/

.projects-section{

    padding-top:60px;

}

.projects-header{

    display:flex;

    justify-content:space-between;

    align-items:flex-end;

    gap:30px;

    margin-bottom:60px;

}

.section-subtitle{

    display:inline-block;

    color:var(--secondary);

    font-size:14px;

    font-weight:700;

    letter-spacing:2px;

    text-transform:uppercase;

    margin-bottom:12px;

}

.projects-header h2{

    font-size:46px;

    margin-bottom:15px;

    color:var(--primary);

}

.projects-header p{

    max-width:620px;

    color:var(--gray);

}

.projects-tools{

    display:flex;

    align-items:center;

    gap:20px;

}

.projects-count{

    color:var(--gray);

    font-weight:600;

}

.projects-tools select{

    border:none;

    background:#fff;

    border-radius:50px;

    padding:12px 22px;

    box-shadow:var(--shadow-sm);

    outline:none;

}


/*==========================================================
                    PROJECTS GRID
==========================================================*/

.projects-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(380px,1fr));

    gap:35px;

}


/*==========================================================
                    PROJECT CARD
==========================================================*/

.project-card{

    position:relative;

    overflow:hidden;

    background:#fff;

    border-radius:28px;

    box-shadow:var(--shadow);

    transition:all .45s ease;

}

.project-card:hover{

    transform:translateY(-12px);

    box-shadow:var(--shadow-lg);

}


/*==========================================================
                    PROJECT IMAGE
==========================================================*/

.project-image{

    position:relative;

    overflow:hidden;

    height:280px;

}

.project-image img{

    width:100%;

    height:100%;

    object-fit:cover;

    transition:transform .7s ease;

}

.project-card:hover .project-image img{

    transform:scale(1.08);

}

.project-image::after{

    content:"";

    position:absolute;

    inset:0;

    background:linear-gradient(

        to top,

        rgba(0,0,0,.55),

        rgba(0,0,0,.05)

    );

}


/*==========================================================
                    CATEGORY BADGE
==========================================================*/

.project-category{

    position:absolute;

    top:22px;

    left:22px;

    z-index:20;

    padding:8px 18px;

    border-radius:30px;

    background:#9c5e44;

    color:#fff;

    font-size:13px;

    font-weight:700;

    letter-spacing:.5px;

}

.project-category.healthcare{

    background:#27ae60;

}

.project-category.infrastructure{

    background:#2980b9;

}

.project-category.hospitality{

    background:#8e44ad;

}

.project-category.sports{

    background:#d35400;

}

.project-category.mixed{

    background:#34495e;

}


/*==========================================================
                    PROJECT OVERLAY
==========================================================*/

.project-overlay{

    position:absolute;

    inset:0;

    display:flex;

    justify-content:center;

    align-items:center;

    flex-direction:column;

    gap:18px;

    background:rgba(183, 127, 101, 0.6);

    opacity:0;

    visibility:hidden;

    transition:.4s;

    z-index:10;

}

.project-card:hover .project-overlay{

    opacity:1;

    visibility:visible;

}

.project-overlay h4{

    color:#fff;

    font-size:30px;

    font-weight:700;

}

.project-overlay p{

    color:rgba(255,255,255,.8);

    margin-bottom:10px;

}


/*==========================================================
                    PROJECT BODY
==========================================================*/

.project-body{

    padding:32px;

}

.project-location{

    display:flex;

    align-items:center;

    gap:8px;

    color:#888;

    font-size:15px;

    margin-bottom:14px;

}

.project-location i{

    color:var(--secondary);

}

.project-body h3{

    font-size:30px;

    margin-bottom:15px;

    transition:.35s;

}

.project-card:hover .project-body h3{

    color:var(--secondary);

}

.project-body p{

    color:#666;

    line-height:1.9;

    margin-bottom:30px;

}


/*==========================================================
                    PROJECT INFO
==========================================================*/

.project-info{

    display:grid;

    grid-template-columns:repeat(2,1fr);

    gap:15px;

    padding-top:22px;

    border-top:1px solid #ececec;

}

.project-info-item{

    text-align:center;

}

.project-info-item span{

    display:block;

    font-size:13px;

    color:#999;

    margin-bottom:5px;

}

.project-info-item strong{

    color:var(--primary);

    font-size:15px;

}


/*==========================================================
                    SHINE EFFECT
==========================================================*/

.project-card::before{

    content:"";

    position:absolute;

    top:-150%;

    left:-150%;

    width:70%;

    height:260%;

    background:rgba(255,255,255,.18);

    transform:rotate(25deg);

    transition:.8s;

    z-index:5;

    pointer-events:none;

}

.project-card:hover::before{

    left:180%;

}


/*==========================================================
                    PAGINATION
==========================================================*/

.projects-pagination{

    margin-top:80px;

}

.pagination .page-item{

    margin:0 5px;

}

.pagination .page-link{

    width:50px;

    height:50px;

    display:flex;

    align-items:center;

    justify-content:center;

    border:none;

    border-radius:50%;

    background:#fff;

    color:var(--primary);

    font-weight:700;

    box-shadow:var(--shadow-sm);

    transition:var(--transition);

}

.pagination .page-link:hover{

    background:var(--secondary);

    color:#9c5e44;

    transform:translateY(-4px);

}

.pagination .active .page-link{

    background:var(--primary);

    color:#fff;

}

/*==========================================================
                    RESPONSIVE
==========================================================*/

/* Large Tablets */
@media (max-width: 1200px){

    .projects-header{
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }

    .projects-tools{
        width: 100%;
        justify-content: space-between;
    }

    .projects-grid{
        grid-template-columns: repeat(2,1fr);
        gap: 25px;
    }

}

/* Tablets */
@media (max-width: 992px){

    .projects-section{
        padding-top:40px;
    }

    .projects-header{
        margin-bottom:40px;
    }

    .projects-header h2{
        font-size:36px;
    }

    .projects-grid{
        grid-template-columns: repeat(2,1fr);
        gap:20px;
    }

    .project-image{
        height:240px;
    }

    .project-body{
        padding:25px;
    }

    .project-body h3{
        font-size:24px;
    }

    .project-overlay h4{
        font-size:24px;
        text-align:center;
        padding:0 20px;
    }

    .project-info{
        grid-template-columns: repeat(3,1fr);
        gap:10px;
    }

}

/* Mobile */
@media (max-width: 768px){

    .projects-header{

        text-align:center;
        align-items:center;

    }

    .projects-header h2{

        font-size:30px;

    }

    .projects-header p{

        max-width:100%;

    }

    .projects-tools{

        flex-direction:column;
        width:100%;
        gap:15px;

    }

    .projects-tools select{

        width:100%;

    }

    .projects-count{

        text-align:center;

    }

    .projects-grid{

        grid-template-columns:1fr;

    }

    .project-image{

        height:250px;

    }

    .project-body{

        padding:22px;

    }

    .project-body h3{

        font-size:22px;

    }

    .project-overlay h4{

        font-size:22px;

    }

    .project-overlay p{

        text-align:center;
        padding:0 15px;

    }

    .project-info{

        grid-template-columns:1fr;
        gap:18px;

    }

    .project-info-item{

        padding-bottom:15px;
        border-bottom:1px solid #eee;

    }

    .project-info-item:last-child{

        border:none;
        padding-bottom:0;

    }

    .pagination .page-link{

        width:42px;
        height:42px;
        font-size:14px;

    }

}

/* Small Mobile */
@media (max-width: 576px){

    .projects-section{

        padding-top:25px;

    }

    .projects-header{

        margin-bottom:30px;

    }

    .projects-header h2{

        font-size:26px;

    }

    .projects-header p{

        font-size:15px;

    }

    .project-card{

        border-radius:20px;

    }

    .project-image{

        height:220px;

    }

    .project-category{

        top:15px;
        left:15px;
        padding:6px 14px;
        font-size:12px;

    }

    .project-body{

        padding:18px;

    }

    .project-body h3{

        font-size:20px;

    }

    .project-location{

        font-size:14px;

    }

    .project-overlay h4{

        font-size:20px;

    }

    .project-overlay a{

        font-size:14px;

    }

    .projects-pagination{

        margin-top:50px;

    }

    .pagination{

        flex-wrap:wrap;
        justify-content:center;

    }

    .pagination .page-item{

        margin:3px;

    }

    .pagination .page-link{

        width:38px;
        height:38px;
        font-size:13px;

    }

}