/*
Theme Name: Divi Child
Template: Divi
Version: 1.0
Description: Custom Portfolio Theme
Author: WallPie
*/

/* ==================================
   HERO SECTION
================================== */

.wallpie-hero{
    background: linear-gradient(
        90deg,
        #1b2b82 0%,
        /*#163a8c 50%,*/
        #111630 100%
    );

    color:#fff;

    text-align:center;

    padding:90px 20px;

    border-radius:12px;

    margin-bottom:50px;

    box-shadow:0 10px 30px rgba(0,0,0,.12);
}

.wallpie-hero h1{
    font-size:58px;
    font-weight:700;
    margin-bottom:15px;
    color:#fff;
}

.wallpie-hero p{
    font-size:22px;
    opacity:.95;
    margin:0;
    color:#fff;
}

/* ==================================
   MAIN CONTAINER
================================== */

.wallpie-portfolio-container{
    width:100%;
    max-width:1700px;
    margin:40px auto;
    padding:0 40px;
    box-sizing: border-box;
}

/* ==================================
   SEARCH
================================== */

.wallpie-search{
    margin-bottom:20px;
}

.wallpie-search input{
    width:100%;
    height:40px;

    border:1px solid #d8dce8;
    border-radius:12px;

    padding:0 22px;

    font-size:16px;

    background:#fff;

    box-shadow:0 3px 12px rgba(0,0,0,.04);

    transition:.25s ease;
}

.wallpie-search input:focus{
    border-color:#224fc8;

    box-shadow:
        0 0 0 4px rgba(34,79,200,.12);

    outline:none;
}

/* ==================================
   FILTERS
================================== */

.wallpie-filters{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-bottom:25px;
}

.wallpie-filters button{
    border:1px solid #d8d8d8;
    background:#fff;
    padding:8px 16px;
    border-radius:25px;
    cursor:pointer;
    font-size:13px;
    transition:.25s ease;
}

.wallpie-filters button:hover{
    background:#f5f5f5;
}

.wallpie-filters button.active{
    background:#111;
    color:#fff;
    border-color:#111;
}

/* ==================================
   GRID
================================== */

.wallpie-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:20px;
}

/* ==================================
   CARD
================================== */

.portfolio-card{
    background:#fff;
    border:1px solid #ececec;
    padding:12px;
    transition:.25s ease;
}

.portfolio-card:hover{
    transform:translateY(-2px);
    box-shadow:0 2px 10px rgba(0,0,0,.05);
}

/* ==================================
   IMAGE BOX
================================== */

.image-box{
    height:165px;
    background:#f1f1f1;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:2px;
    overflow:hidden;
}

/* ==================================
   IMAGE
================================== */

.image-box img{
    max-width:100%;
    max-height:100%;
    width:auto;
    height:auto;
    object-fit:contain;
    display:block;
    cursor:pointer;
}

/* ==================================
   TITLE
================================== */

.portfolio-card h3{
    margin:10px 0 6px;
    font-size:14px;
    font-weight:600;
    line-height:1.4;
    color:#222;
}

/* ==================================
   CATEGORY CHIPS
================================== */

.portfolio-categories{
    display:flex;
    flex-wrap:wrap;
    gap:5px;
    margin-top:8px;
}

.portfolio-chip{
    display:inline-block;
    border:1px solid #d8d8d8;
    border-radius:20px;
    padding:2px 8px;
    font-size:10px;
    background:#fff;
    color:#666;
}

/* ==================================
   LIGHTBOX
================================== */

#wallpie-lightbox{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.94);

    display:none;
    flex-direction:column;
    align-items:center;
    justify-content:center;

    z-index:99999;
}

#wallpie-lightbox.active{
    display:flex;
}

/* CLOSE BUTTON */

.wallpie-close{
    position:absolute;
    top:20px;
    right:20px;

    width:50px;
    height:50px;

    border:none;
    background:transparent;

    color:#fff;
    font-size:42px;

    cursor:pointer;
    z-index:100000;
}

/* COUNTER */

.wallpie-counter{
    position:absolute;
    top:25px;
    left:25px;

    background:#111;
    color:#fff;

    padding:6px 14px;
    border-radius:25px;

    font-size:14px;
    z-index:100000;
}

/* ARROWS */

.wallpie-arrow{
    position:absolute;
    top:45%;

    width:60px;
    height:60px;

    border:none;
    border-radius:50%;

    background:#111;
    color:#fff;

    font-size:28px;

    cursor:pointer;
    z-index:100000;

    transition:.2s;
}

.wallpie-arrow:hover{
    background:#222;
}

.wallpie-prev{
    left:30px;
}

.wallpie-next{
    right:30px;
}

/* LIGHTBOX IMAGE */

#wallpie-lightbox-image{
    max-width:80vw;
    max-height:65vh;

    width:auto;
    height:auto;

    object-fit:contain;
}

/* INFO PANEL */

.wallpie-info{
    width:80%;
    max-width:800px;

    background:#fff;

    padding:20px;
    margin-top:20px;
}

.wallpie-info h2{
    margin:0 0 10px;
    font-size:24px;
    color:#222;
}

#wallpie-id{
    margin-bottom:15px;
    color:#666;
    font-size:14px;
}

#wallpie-tags{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

#wallpie-tags span{
    border:1px solid #ddd;
    border-radius:20px;
    padding:4px 10px;
    font-size:12px;
    background:#fff;
}

/* ==================================
   RESPONSIVE
================================== */

@media(max-width:1024px){

    .wallpie-grid{
        grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
    }

}

@media(max-width:768px){

    .wallpie-grid{
        grid-template-columns:1fr;
    }

    .image-box{
        height:220px;
    }

    .wallpie-info{
        width:95%;
    }

    .wallpie-arrow{
        width:50px;
        height:50px;
        font-size:24px;
    }

}

@media(max-width:480px){

    .image-box{
        height:200px;
    }

    .wallpie-info h2{
        font-size:20px;
    }

    .wallpie-arrow{
        width:45px;
        height:45px;
        font-size:20px;
    }
}

@media(max-width:768px){

    .wallpie-hero{
        padding:70px 20px;
    }

    .wallpie-hero h1{
        font-size:40px;
    }

    .wallpie-hero p{
        font-size:18px;
    }

}
```
