/* Banner */

.banner{
    width:100%;
    height:310px;
    position:relative;
    overflow:hidden;
}

.banner-image{
    width:100%;
    height:100%;
    object-fit:cover;
    transform:scale(1.02);
}

.banner-overlay{
    position:absolute;
    inset:0;
    background:
    linear-gradient(to bottom,
    rgba(0,0,0,.15),
    rgba(9,9,18,.82));
}

/* Hero */

.hero{
    width:85%;
    margin:auto;
    display:flex;
    align-items:center;
    gap:35px;
    margin-top:-80px;
    position:relative;
    z-index:5;
}

.profile-image{
    width:170px;
    height:170px;
    object-fit:cover;
    border-radius:50%;
    border:2px solid #2a1f5a;
    box-shadow:var(--shadow);
}

.hero-text h1{
    font-size:46px;
    margin-bottom:10px;
}

.hero-text p{
    color:var(--text2);
    font-size:18px;
}

/* About section */

.about{
    border:2px solid rgba(255, 255, 255, 0.799);
    width:85%;
    margin:45px auto;
    background:linear-gradient(180deg,var(--card),var(--card2));
    border-radius:var(--radius);
    padding:28px;
    box-shadow:var(--shadow);
}

.about p{
    color:#d6d6e9;
    line-height:1.9;
    font-size:17px;
}

/* Working On */

.working-container{
    width:85%;
    margin:35px auto;
}

.working-card{
    display:flex;
    align-items:center;
    gap:16px;

    position:relative;
    padding:18px 24px;
    border-radius:20px;
    overflow:hidden;
    border:3px solid transparent;

    background:
        linear-gradient(#17172a,#17172a) padding-box,
        linear-gradient(
            45deg,
            #ff2d55,
            #ff8c2d,
            #ffe82d,
            #56ff67,
            #39d5ff,
            #5475ff,
            #a84dff,
            #ff2db2,
            #ff2d55
        ) border-box;

    background-size:100%,400%;
    animation:rainbowBorder 7s linear infinite;
    transition:.35s;
}

.working-card:hover{
    transform:translateY(-5px);
    box-shadow:0 15px 40px rgba(0,0,0,.45);
}

.working-title{
    display:inline-block;
    padding:8px 18px;
    border-radius:25px;
    background:rgba(255,255,255,.06);
    color:#d7d7ff;
    font-weight:600;
    margin-bottom:18px;
}

.working-card h2{
    font-size:35px;
    font-weight:700;
}

/* Projects */

.projects{
    width:85%;
    margin:70px auto;
}

.projects h2{
    display:inline-block;
    margin-bottom:35px;
    font-size:34px;
    position:relative;
}

.projects h2::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-8px;
    width:100%;
    height:4px;
    border-radius:20px;
    background:linear-gradient(90deg,#8b5cf6,#4f7cff);
}

.project-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
    gap:35px;
}

.project-card{
    position:relative;
    overflow:hidden;
    border-radius:22px;
    background:#17172a;
    box-shadow:var(--shadow);
    transition:.4s;
}

.project-card:hover{
    transform:translateY(-8px) scale(1.02);
}

.project-card img{
    width:100%;
    height:240px;
    object-fit:cover;
    transition:.45s;
}

.project-card:hover img{
    transform:scale(1.1);
}

.project-info{
    position:absolute;
    left:0;
    right:0;
    bottom:0;
    padding:18px;
    background:linear-gradient(
        transparent,
        rgba(9,9,18,.97)
    );
}

.project-info h3{
    font-size:24px;
}

.project-hover{
    position:absolute;
    inset:0;
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
    padding:35px;
    background:rgba(9,9,18,0);
    opacity:0;
    transition:.35s;
}

.project-hover p{
    color:#dadaf8;
    line-height:1.8;
    transform:translateY(20px);
    transition:.35s;
}

.project-card:hover .project-hover{
    opacity:1;
    background:rgba(9,9,18,.5);
}

.project-card:hover .project-hover p{
    transform:translateY(0);
}

/* Rainbow featured project */

.rainbow{
    position:relative;
    border:3px solid transparent;
    background:
        linear-gradient(#17172a,#17172a) padding-box,
        linear-gradient(
            45deg,
            #ff2d55,
            #ff8c2d,
            #ffe82d,
            #56ff67,
            #39d5ff,
            #5475ff,
            #a84dff,
            #ff2db2,
            #ff2d55
        ) border-box;
    background-size:100%,400%;
    animation:rainbowBorder 7s linear infinite;
}

.rainbow::before{
    content:"";
    position:absolute;
    inset:-3px;
    border-radius:24px;
    background:linear-gradient(
        45deg,
        #ff2d55,
        #ff8c2d,
        #ffe82d,
        #56ff67,
        #39d5ff,
        #5475ff,
        #a84dff,
        #ff2db2,
        #ff2d55
    );
    background-size:400%;
    animation:rainbowBorder 7s linear infinite;
    z-index:-2;
}

.rainbow::after{
    content:"";
    position:absolute;
    inset:3px;
    background:#17172a;
    border-radius:20px;
    z-index:-1;
}

/* Rainbow animation */

@keyframes rainbowBorder{

0%{
background-position:0% 50%;
}

50%{
background-position:100% 50%;
}

100%{
background-position:0% 50%;
}

}

/* Nice fade when hovering */

.project-card,
.working-card,
.about,

.about:hover,
.working-card:hover{
    transform:translateY(-5px);
}