/* ====================================
   ULTRA PROFESSIONAL NEON CSS
   PORTFOLIO MUHAMMAD FAIS
==================================== */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Poppins',sans-serif;
    scroll-behavior:smooth;
}

:root{
    --bg:#050816;
    --card:#0f172a;
    --text:#ffffff;
    --cyan:#00ffff;
    --purple:#7c3aed;
    --pink:#ff00ff;
    --blue:#3b82f6;
}

/* ===============================
   BODY
================================ */
body{
    background:
    radial-gradient(circle at top left,#00ffff22,transparent 20%),
    radial-gradient(circle at bottom right,#7c3aed33,transparent 25%),
    linear-gradient(135deg,#020617,#050816,#0f172a);

    color:var(--text);
    overflow-x:hidden;
    min-height:100vh;
    transition:0.5s;
}

/* Animated Background */

body::before{
    content:'';
    position:fixed;
    width:100%;
    height:100%;
    background:
    linear-gradient(90deg,transparent,#00ffff08,transparent);

    animation:bgMove 8s linear infinite;
    z-index:-1;
}

/* ===============================
   SCROLLBAR
================================ */
::-webkit-scrollbar{
    width:10px;
}

::-webkit-scrollbar-track{
    background:#020617;
}

::-webkit-scrollbar-thumb{
    background:linear-gradient(var(--cyan),var(--purple));
    border-radius:50px;
}

/* ===============================
   HEADER
================================ */
header{
    position:sticky;
    top:0;
    z-index:999;

    width:100%;
    padding:20px 8%;

    display:flex;
    justify-content:space-between;
    align-items:center;

    background:rgba(255,255,255,0.05);
    backdrop-filter:blur(18px);

    border-bottom:1px solid rgba(255,255,255,0.1);

    box-shadow:
    0 5px 20px rgba(0,255,255,0.08);
}

/* ===============================
   LOGO
================================ */
.logo{
    font-size:32px;
    font-weight:800;
    color:var(--cyan);

    text-shadow:
    0 0 10px var(--cyan),
    0 0 20px var(--cyan),
    0 0 40px var(--cyan);

    cursor:pointer;
    transition:0.4s;
}

.logo:hover{
    transform:scale(1.08);
}

/* ===============================
   NAVBAR
================================ */
nav{
    display:flex;
    gap:30px;
}

nav a{
    position:relative;
    text-decoration:none;
    color:white;
    font-size:17px;
    font-weight:500;
    transition:0.4s;
    padding:10px 5px;
}

nav a::before{
    content:'';
    position:absolute;
    bottom:0;
    left:0;

    width:0%;
    height:3px;

    border-radius:20px;

    background:linear-gradient(to right,var(--cyan),var(--purple));

    transition:0.5s;
}

nav a:hover::before,
.active::before{
    width:100%;
}

nav a:hover{
    color:var(--cyan);

    text-shadow:
    0 0 10px var(--cyan),
    0 0 25px var(--cyan);
}

/* ===============================
   DARK MODE BUTTON
================================ */
#darkModeBtn{
    width:55px;
    height:55px;

    border:none;
    border-radius:50%;

    background:linear-gradient(135deg,var(--cyan),var(--purple));

    color:white;
    font-size:22px;

    cursor:pointer;
    transition:0.5s;

    box-shadow:
    0 0 15px var(--cyan),
    0 0 35px var(--purple);
}

#darkModeBtn:hover{
    transform:rotate(360deg) scale(1.1);

    box-shadow:
    0 0 25px var(--cyan),
    0 0 50px var(--purple);
}

#darkModeBtn:active{
    transform:scale(0.85);
}

/* ===============================
   HERO SECTION
================================ */
.hero{
    min-height:100vh;

    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:80px 8%;
    gap:60px;
}

.hero-text{
    flex:1;
    animation:slideLeft 1s ease;
}

.hero-text h2{
    font-size:75px;
    line-height:1.1;
    margin-bottom:20px;

    background:linear-gradient(
    to right,
    var(--cyan),
    var(--purple),
    var(--pink));

    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;

    animation:glowText 3s infinite alternate;
}

.hero-text p{
    font-size:18px;
    color:#cbd5e1;
    line-height:2;
    margin-bottom:35px;
}

/* ===============================
   BUTTON GLOW
================================ */
.btn-glow{
    position:relative;

    padding:16px 42px;
    border:none;
    border-radius:60px;

    background:linear-gradient(
    135deg,
    var(--cyan),
    var(--purple));

    color:white;
    font-size:17px;
    font-weight:600;

    cursor:pointer;
    overflow:hidden;

    transition:0.5s;

    box-shadow:
    0 0 15px var(--cyan),
    0 0 40px var(--purple);
}

/* Shine Effect */

.btn-glow::before{
    content:'';
    position:absolute;

    top:0;
    left:-120%;

    width:100%;
    height:100%;

    background:rgba(255,255,255,0.3);

    transform:skewX(30deg);

    transition:0.7s;
}

.btn-glow:hover::before{
    left:120%;
}

.btn-glow:hover{
    transform:translateY(-8px) scale(1.05);

    box-shadow:
    0 0 25px var(--cyan),
    0 0 60px var(--purple);
}

/* Click Animation */

.btn-glow:active{
    transform:scale(0.9);
}

/* ===============================
   HERO IMAGE
================================ */
.hero-image img{
    width:420px;
    height:420px;              /* ✔ bikin proporsi kotak agar bisa bulat */
    object-fit:cover;         /* ✔ supaya gambar tidak gepeng */
    border-radius:50%;        /* ✔ jadi lingkaran sempurna */

    border:5px solid rgba(0,255,255,0.8);

    filter:
    drop-shadow(0 0 20px var(--cyan))
    drop-shadow(0 0 40px var(--purple));

    animation:float 4s ease-in-out infinite;
}


.hero-image img{
    width:420px;

    filter:
    drop-shadow(0 0 20px var(--cyan))
    drop-shadow(0 0 40px var(--purple));

    animation:float 4s ease-in-out infinite;
}

/* ===============================
   CARD SECTION
================================ */
.card-container{
    padding:80px 8%;

    display:flex;
    justify-content:center;
    gap:35px;
    flex-wrap:wrap;
}

.card{
    position:relative;

    width:320px;
    padding:40px;

    border-radius:30px;

    background:rgba(255,255,255,0.05);

    backdrop-filter:blur(18px);

    border:1px solid rgba(255,255,255,0.08);

    overflow:hidden;
    cursor:pointer;

    transition:0.5s;
}

/* Animated Border */

.card::before{
    content:'';
    position:absolute;
    inset:-2px;

    background:linear-gradient(
    45deg,
    var(--cyan),
    transparent,
    var(--purple),
    transparent,
    var(--pink));

    z-index:-1;
    border-radius:30px;

    animation:rotateBorder 5s linear infinite;
}

/* Card Glow */

.card::after{
    content:'';
    position:absolute;
    width:100%;
    height:100%;
    top:0;
    left:0;

    background:linear-gradient(
    135deg,
    rgba(0,255,255,0.08),
    transparent);

    opacity:0;
    transition:0.5s;
}

.card:hover::after{
    opacity:1;
}

.card:hover{
    transform:
    translateY(-15px)
    scale(1.05);

    box-shadow:
    0 0 30px var(--cyan),
    0 0 60px var(--purple);
}

/* CLICK EFFECT */

.card:active{
    transform:scale(0.92);
}

.card h3{
    font-size:30px;
    margin-bottom:15px;

    color:var(--cyan);

    text-shadow:
    0 0 10px var(--cyan);
}

.card p{
    color:#d1d5db;
    line-height:1.9;
}

/* ===============================
   ABOUT
================================ */
.about,
.contact{
    min-height:100vh;

    display:flex;
    justify-content:center;
    align-items:center;

    padding:80px 8%;
}

.about-box,
.contact-form{
    width:800px;

    padding:50px;

    border-radius:35px;

    background:rgba(255,255,255,0.05);

    backdrop-filter:blur(18px);

    border:1px solid rgba(255,255,255,0.08);

    transition:0.5s;

    box-shadow:
    0 0 30px rgba(0,255,255,0.1);
}

.about-box:hover,
.contact-form:hover{
    transform:translateY(-10px);

    box-shadow:
    0 0 30px var(--cyan),
    0 0 60px var(--purple);
}

.about-box h2,
.contact-form h2{
    font-size:45px;
    margin-bottom:25px;

    color:var(--cyan);

    text-shadow:
    0 0 15px var(--cyan);
}

.about-box p{
    line-height:2;
    color:#d1d5db;
}

.about-box ul{
    margin-top:20px;
}

.about-box ul li{
    margin:15px 0;
    color:white;
}

/* ===============================
   FORM
================================ */
.contact-form input,
.contact-form textarea{
    width:100%;

    padding:16px;
    margin:15px 0;

    border:none;
    outline:none;

    border-radius:15px;

    background:#111827;
    color:white;

    font-size:16px;

    transition:0.4s;
}

.contact-form input:focus,
.contact-form textarea:focus{
    transform:scale(1.02);

    box-shadow:
    0 0 15px var(--cyan),
    0 0 35px var(--purple);
}

.contact-form textarea{
    resize:none;
    height:150px;
}

/* ===============================
   DARK MODE
================================ */
.dark-mode{
    background:
    linear-gradient(
    135deg,
    #ffffff,
    #dbeafe,
    #f8fafc);

    color:#111827;
}

.dark-mode header,
.dark-mode .card,
.dark-mode .about-box,
.dark-mode .contact-form{
    background:rgba(255,255,255,0.7);
}

.dark-mode nav a{
    color:#111827;
}

.dark-mode .card p,
.dark-mode .about-box p{
    color:#374151;
}

/* ===============================
   ANIMATION
================================ */

@keyframes glowText{
    from{
        filter:drop-shadow(0 0 10px var(--cyan));
    }

    to{
        filter:drop-shadow(0 0 25px var(--purple));
    }
}

@keyframes float{
    0%{
        transform:translateY(0);
    }

    50%{
        transform:translateY(-20px);
    }

    100%{
        transform:translateY(0);
    }
}

@keyframes slideLeft{
    from{
        opacity:0;
        transform:translateX(-80px);
    }

    to{
        opacity:1;
        transform:translateX(0);
    }
}

@keyframes slideRight{
    from{
        opacity:0;
        transform:translateX(80px);
    }

    to{
        opacity:1;
        transform:translateX(0);
    }
}

@keyframes rotateBorder{
    0%{
        transform:rotate(0deg);
    }

    100%{
        transform:rotate(360deg);
    }
}

@keyframes bgMove{
    0%{
        transform:translateX(-100%);
    }

    100%{
        transform:translateX(100%);
    }
}

/* ===============================
   RESPONSIVE
================================ */

@media(max-width:992px){

    .hero{
        flex-direction:column-reverse;
        text-align:center;
    }

    .hero-text h2{
        font-size:50px;
    }

    .hero-image img{
        width:300px;
    }

}

@media(max-width:768px){

    header{
        flex-direction:column;
        gap:20px;
    }

    nav{
        flex-wrap:wrap;
        justify-content:center;
    }

    .hero-text h2{
        font-size:42px;
    }

    .about-box,
    .contact-form{
        width:100%;
    }

}

@media(max-width:500px){

    .hero-text h2{
        font-size:34px;
    }

    .hero-text p{
        font-size:15px;
    }

    .btn-glow{
        width:100%;
    }

    .card{
        width:100%;
    }

}
/* ====================================
   PROFILE SECTION
==================================== */

.profile-section{
  
  .profile-section{
    min-height:100vh;

    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;

    width:100%;              /* ✔ penting */
    text-align:center;

    padding:80px 0;         /* ✔ hapus efek geser kiri kanan */
    box-sizing:border-box;
}
}


/* PROFILE CARD + SOCIAL WRAPPER RAPI */

  .profile-card{
    width:850px;
    max-width:90%;       /* ✔ biar responsif */
    margin:0 auto;       /* ✔ pusatkan total */
    display:block;       /* ✔ anti geser flex bug */
}

/* SOCIAL WRAPPER FIX */
.social-wrapper{
    margin-top:10px;
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
}

/* SOCIAL MEDIA */
.social-media{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:20px;
    flex-wrap:wrap;
    max-width:600px;
}


.profile-card{
    width:850px;

    padding:50px;

    border-radius:35px;

    background:rgba(255,255,255,0.05);

    backdrop-filter:blur(18px);

    border:1px solid rgba(255,255,255,0.08);

    text-align:center;

    transition:0.5s;

    box-shadow:
    0 0 25px rgba(0,255,255,0.1);
}

.profile-card:hover{
    transform:translateY(-10px);

    box-shadow:
    0 0 35px #00ffff,
    0 0 70px #7c3aed;
}

.profile-card img{
    width:180px;

    border-radius:50%;

    margin-bottom:25px;

    border:5px solid #00ffff;

    box-shadow:
    0 0 25px #00ffff,
    0 0 50px #7c3aed;

    animation:float 4s ease-in-out infinite;
}

.profile-card h2{
    font-size:45px;

    margin-bottom:10px;

    color:#00ffff;

    text-shadow:
    0 0 15px #00ffff;
}

.profile-role{
    font-size:20px;

    margin-bottom:20px;

    color:#d1d5db;
}

.profile-card p{
    line-height:2;
}

.profile-info{
    margin-top:40px;

    display:flex;
    justify-content:center;
    gap:25px;

    flex-wrap:wrap;
}

.info-box{
    width:180px;

    padding:25px;

    border-radius:25px;

    background:rgba(255,255,255,0.06);

    transition:0.5s;

    cursor:pointer;
}

.info-box:hover{
    transform:scale(1.08);

    box-shadow:
    0 0 20px #00ffff,
    0 0 45px #7c3aed;
}

.info-box:active{
    transform:scale(0.9);
}

.info-box h3{
    color:#00ffff;

    margin-bottom:10px;
}

.info-box span{
    font-size:18px;
}

/* ====================================
   CAREER SECTION
==================================== */

.career-section{
    min-height:100vh;

    padding:100px 8%;
}

.career-title{
    text-align:center;

    font-size:55px;

    margin-bottom:60px;

    color:#00ffff;

    text-shadow:
    0 0 20px #00ffff;
}

.career-container{
    display:flex;
    justify-content:center;
    gap:35px;

    flex-wrap:wrap;
}

.career-card{
    width:320px;

    padding:40px;

    border-radius:30px;

    background:rgba(255,255,255,0.05);

    backdrop-filter:blur(18px);

    border:1px solid rgba(255,255,255,0.08);

    transition:0.5s;

    position:relative;

    overflow:hidden;

    cursor:pointer;
}

.career-card::before{
    content:'';
    position:absolute;

    inset:0;

    background:linear-gradient(
    135deg,
    rgba(0,255,255,0.15),
    transparent);

    opacity:0;

    transition:0.5s;
}

.career-card:hover::before{
    opacity:1;
}

.career-card:hover{
    transform:
    translateY(-15px)
    scale(1.05);

    box-shadow:
    0 0 30px #00ffff,
    0 0 60px #7c3aed;
}

.career-card:active{
    transform:scale(0.9);
}

.career-card h3{
    font-size:40px;

    margin-bottom:20px;

    color:#00ffff;

    text-shadow:
    0 0 10px #00ffff;
}

.career-card p{
    line-height:2;

    color:#d1d5db;
}
/* SOCIAL WRAPPER */

.social-wrapper{
    margin-top:50px;
    text-align:center;
}

.social-title{
    margin-bottom:25px;
    font-size:24px;
    color:#818cf8;
    letter-spacing:1px;
}

/* SOCIAL MEDIA */

.social-media{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:20px;
    flex-wrap:wrap;
}

.social{
    display:flex;
    align-items:center;
    gap:10px;
    padding:15px 28px;
    border-radius:50px;
    text-decoration:none;
    color:white;
    font-weight:600;
    transition:0.4s;
    font-size:16px;
    box-shadow:0 10px 25px rgba(0,0,0,0.25);
}

.social i{
    font-size:22px;
}

/* WHATSAPP */

.wa{
    background:#25D366;
}

/* INSTAGRAM */

.ig{
    background:linear-gradient(
        45deg,
        #f9ce34,
        #ee2a7b,
        #6228d7
    );
}

/* TIKTOK */

.tt{
    background:#000;
    border:1px solid rgba(255,255,255,0.2);
}

/* HOVER */

.social:hover{
    transform:translateY(-8px) scale(1.05);
    box-shadow:0 15px 35px rgba(0,0,0,0.35);
}