/* Reset Dasar */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    text-decoration: none;
}

/* ---- TEMA PERSONA 5: WARNA & FONT ---- */
:root {
    /* Merah Persona 5 yang ikonik */
    --primary-color: #e60012; 
    /* Versi lebih gelap untuk efek hover */
    --primary-dark: #b3000e;  
}

body {
    background-color: #0a0a0a; /* Hitam pekat */
    color: #ffffff; /* Teks Putih */
    overflow-x: hidden;
    /* Gunakan Inter untuk teks paragraf agar tetap mudah dibaca */
    font-family: 'Inter', sans-serif; 
}

/* GUNAKAN SPACE GROTESK UNTUK SEMUA JUDUL AGAR GAYA P5 */
h1, h2, h3, .btn, .btn-home, .btn-submit {
    font-family: 'Space Grotesk', sans-serif;
    letter-spacing: -0.5px;
    text-transform: uppercase; /* Gaya P5 sering pakai huruf kapital */
}

/* Canvas Background */
canvas {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    cursor: none; /* Sembunyikan kursor asli */
}

.container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 20px;
    position: relative;
    z-index: 1;
    cursor: default; 
}

/* Hero Section */
.hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 90vh;
    padding: 40px 0;
}

.hero-content {
    flex: 1;
    max-width: 600px;
}

.hero-content h3 {
    font-size: 1.5rem;
    color: var(--primary-color); /* Merah P5 */
    margin-bottom: 10px;
    font-weight: 700;
    background: #000; /* Sedikit latar belakang hitam biar teks menonjol */
    display: inline-block;
    padding: 2px 5px;
    transform: skew(-5deg); /* Miringkan sedikit ala P5 */
}

.hero-content h1 {
    font-size: 4rem;
    font-weight: 800;
    margin-bottom: 10px;
    line-height: 1.1;
}

.hero-content h2 {
    font-size: 1.8rem;
    margin-bottom: 20px;
    font-weight: 400;
}

/* Highlight text jadi Merah */
.hero-content .highlight {
    color: var(--primary-color);
    font-weight: 700;
}

.hero-content p {
    font-size: 1.1rem;
    color: #b0b0b0;
    margin-bottom: 30px;
    line-height: 1.6;
    /* Kembalikan font paragraf ke Inter agar tidak terlalu ramai */
    font-family: 'Inter', sans-serif; 
    text-transform: none;
}

/* BUTTONS SOSMED */
.social-icons {
    display: flex;
    gap: 15px;
    margin-bottom: 40px;
}

.social-icons a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border: 2px solid var(--primary-color); /* Border Merah */
    border-radius: 50%;
    background: #000;
    transition: all 0.3s ease;
}

.social-icons a img {
    width: 30px;
    height: 30px;
    object-fit: contain;
    filter: brightness(0) invert(1); 
    transition: 0.3s;
}

.social-icons a:hover {
    background-color: var(--primary-color); /* Tetap berubah merah */
    
    /* UBAH DI SINI: Hapus 'rotate(...)' */
    transform: translateY(-5px); /* Hanya gerak ke atas 5 pixel */
    
    /* Shadow tetap ada (opsional, bisa dihapus jika ingin lebih flat) */
    box-shadow: 5px 5px 0px rgba(230, 0, 18, 0.5); 
}

/* Tombol Utama */
.btn {
    display: inline-block;
    padding: 15px 40px;
    background-color: var(--primary-color);
    color: white;
    font-weight: 800;
    letter-spacing: 1px;
    transition: all 0.3s ease;
    border: 2px solid var(--primary-color);
    /* Bentuk jajar genjang ala P5 */
    transform: skew(-10deg); 
    box-shadow: 5px 5px 0px #000; /* Shadow hitam kasar */
}

/* Agar teks di dalam tombol tidak ikut miring */
.btn span {
    display: inline-block;
    transform: skew(10deg);
}

.btn:hover {
    background-color: #000;
    color: var(--primary-color);
    box-shadow: 5px 5px 0px var(--primary-color);
    transform: skew(-10deg) translate(-2px, -2px);
}

/* ---- FOTO PROFIL GAYA PERSONA 5 ---- */

/* ---- FOTO PROFIL GAYA PERSONA 5 (NATURAL CHAOS V2) ---- */
/* ---- FOTO PROFIL GAYA PERSONA 5 (ULTIMATE CHAOS) ---- */

/* ---- FOTO PROFIL GAYA PERSONA 5 (ASIK & RAPI) ---- */

.hero-image {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    z-index: 2;
    padding: 20px;
}

/* Wrapper utama: Gerakan dasar mengambang yang santai */
.image-wrapper {
    position: relative;
    width: 320px;
    height: 320px;
    display: flex;
    justify-content: center;
    align-items: center;
    /* Durasi agak panjang agar tidak memusingkan */
    animation: masterFloat 6s ease-in-out infinite alternate;
}

/* --- 1. Gambar Depan (Foto Anda) --- */
.image-wrapper img {
    width: 95%;
    height: auto;
    object-fit: contain;
    position: relative;
    z-index: 10;
    
    /* Bayangan tajam yang solid (tidak blur) agar sesuai gaya komik */
    filter: drop-shadow(5px 5px 0px rgba(0,0,0,0.85));
    
    /* Foto bergerak sedikit berlawanan arah dengan background untuk efek kedalaman */
    animation: imageCounterMove 5s ease-in-out infinite alternate;
}

/* --- 2. Shape UTAMA (Warna Tema / Merah) --- */
.image-wrapper::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    /* Menggunakan variabel warna tema agar konsisten */
    background: var(--primary-color); 
    z-index: 1;
    
    /* Border hitam tebal */
    border: 3px solid #000;
    
    /* Bentuk awal: Jajar Genjang */
    clip-path: polygon(10% 0%, 100% 0%, 90% 100%, 0% 100%);
    
    /* Animasi Morphing yang 'Asik' (Smooth tapi bervariasi) */
    animation: personaShapeMorph 4s cubic-bezier(0.45, 0, 0.55, 1) infinite alternate;
}

/* --- 3. Shape BAYANGAN (Hitam) --- */
.image-wrapper::after {
    content: '';
    position: absolute;
    /* Sedikit offset agar terlihat seperti bayangan di belakang */
    top: 15px; left: -15px;
    width: 100%; height: 100%;
    background: #000; /* Hitam pekat */
    z-index: 0;
    opacity: 0.8; /* Sedikit transparan */
    
    /* Bentuk sedikit berbeda */
    clip-path: polygon(5% 0%, 100% 5%, 95% 100%, 0% 95%);
    
    /* Animasi mengikuti shape utama tapi lebih lambat (lagging effect) */
    animation: personaShadowMorph 5s cubic-bezier(0.45, 0, 0.55, 1) infinite alternate-reverse;
}


/* ---- KEYFRAMES ANIMASI (ASIK & TIDAK LEBAY) ---- */

/* 1. Mengambang Santai (Wadah) */
@keyframes masterFloat {
    0% { transform: translateY(0px) rotate(0deg); }
    100% { transform: translateY(-12px) rotate(-1deg); }
}

/* 2. Foto bergerak berlawanan (Parallax) */
@keyframes imageCounterMove {
    0% { transform: translate(0,0) scale(1); }
    100% { transform: translate(5px, -5px) scale(1.02); }
}

/* 3. Shape UTAMA: Berubah bentuk dengan luwes */
@keyframes personaShapeMorph {
    0% {
        /* Pose 1: Standar */
        transform: skew(-10deg) scale(1);
        clip-path: polygon(10% 0%, 100% 0%, 90% 100%, 0% 100%);
    }
    50% {
        /* Pose 2: Miring sedikit lebih tajam & melebar */
        transform: skew(-20deg) scale(1.05) translate(-10px, -5px);
        /* Perubahan sudut yang tidak ekstrem */
        clip-path: polygon(5% 5%, 95% 0%, 95% 95%, 5% 100%);
    }
    100% {
        /* Pose 3: Miring arah sebaliknya (sedikit) & menyempit */
        transform: skew(-5deg) scale(0.98) translate(5px, 5px);
        clip-path: polygon(15% 0%, 100% 5%, 85% 100%, 0% 95%);
    }
}

/* 4. Shape BAYANGAN: Gerakan penyeimbang */
@keyframes personaShadowMorph {
    0% {
        transform: skew(-5deg) scale(1);
        clip-path: polygon(5% 0%, 100% 5%, 95% 100%, 0% 95%);
    }
    100% {
        transform: skew(-15deg) scale(1.02) translate(-15px, 10px);
        clip-path: polygon(0% 0%, 95% 10%, 100% 100%, 5% 90%);
    }
}

/* Responsif HP */
@media (max-width: 768px) {
    .image-wrapper {
        width: 260px; height: 260px; margin-bottom: 50px;
    }
    /* Di HP gerakan dikurangi intensitasnya agar tetap rapi */
    @keyframes personaShapeMorph {
        0%, 100% { transform: skew(-10deg) scale(1); }
        50% { transform: skew(-15deg) scale(1.02); }
    }
}

/* Form Kontak */
.contact-section {
    padding: 80px 0;
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
    border-top: 2px solid #333;
    margin-top: 50px;
}

.contact-section h2 {
    font-size: 2.5rem;
    margin-bottom: 30px;
    color: var(--primary-color);
    text-transform: uppercase;
    font-weight: 800;
}

.contact-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.input-group input, 
.input-group textarea {
    width: 100%;
    padding: 15px;
    background: #000;
    border: 2px solid #333;
    /* Bentuk input sedikit miring */
    transform: skew(-2deg);
    color: white;
    outline: none;
    transition: 0.3s;
    font-size: 1rem;
    font-family: 'Inter', sans-serif;
}

.input-group input:focus, 
.input-group textarea:focus {
    border-color: var(--primary-color);
    box-shadow: 3px 3px 0px var(--primary-color);
}

/* Tombol di Form */
.form-actions {
    display: flex;
    gap: 15px;
    margin-top: 10px;
}

.btn-submit, .btn-home {
    flex: 1;
    padding: 15px;
    font-weight: 800;
    transition: 0.3s;
    cursor: pointer;
    text-align: center;
    transform: skew(-10deg);
    display: flex;
    justify-content: center;
    align-items: center;
}

.btn-submit {
    background: var(--primary-color);
    color: white;
    border: none;
    box-shadow: 5px 5px 0px #000;
}

.btn-submit:hover {
    background: #000;
    color: var(--primary-color);
    border: 2px solid var(--primary-color);
    box-shadow: 5px 5px 0px var(--primary-color);
}

.btn-home {
    background: transparent;
    border: 2px solid var(--primary-color);
    color: white;
    box-shadow: 5px 5px 0px #000;
}

.btn-home:hover {
    background: var(--primary-color);
    color: #000;
    box-shadow: 5px 5px 0px var(--primary-color);
}

/* Responsif */
@media (max-width: 768px) {
    .hero {
        flex-direction: column-reverse;
        text-align: center;
        padding-top: 20px;
    }
    
    .hero-content h1 {
        font-size: 2.8rem;
    }
    
    .social-icons {
        justify-content: center;
    }

    .image-wrapper img {
        width: 250px;
        height: 250px;
        margin-bottom: 40px;
    }
    
    .form-actions {
        flex-direction: column;
    }

    .btn, .btn-submit, .btn-home, .input-group input, .input-group textarea {
        transform: skew(0deg); /* Di HP jangan terlalu miring biar rapi */
    }
    .btn span {
        transform: skew(0deg);
    }
}

/* ---- Status Message Persona Style ---- */
.status-message {
    margin-top: 20px;
    padding: 15px;
    border-radius: 4px;
    display: none; /* Sembunyi dulu */
    font-family: 'Space Grotesk', sans-serif;
    font-weight: bold;
    text-align: center;
    transform: skew(-10deg); /* Miring ala Persona */
    border: 2px solid transparent;
}

/* Jika Sukses */
.status-message.success {
    display: block;
    background-color: #000;
    color: var(--primary-color); /* Merah */
    border-color: var(--primary-color);
    box-shadow: 5px 5px 0px var(--primary-color);
}

/* Jika Error / Spam */
.status-message.error {
    display: block;
    background-color: #000;
    color: #fff;
    border-color: #fff;
    box-shadow: 5px 5px 0px #fff;
}

/* Wadah Navbar di paling atas */
.navbar {
    position: absolute; /* Agar menempel di atas canvas */
    top: 0;
    left: 0;
    width: 100%;
    padding: 25px 10%; /* Padding agar sejajar dengan konten utama */
    display: flex;
    justify-content: flex-start; /* Logo di kiri */
    z-index: 100; /* Pastikan di atas elemen lain */
}

/* Link pembungkus logo (agar bisa diklik kembali ke atas) */
.logo-container {
    display: inline-block;
    transition: transform 0.3s ease;
}

/* Gaya Gambar Logo ala Persona 5 */
.persona-logo {
    /* Atur tinggi logo agar tidak terlalu besar */
    height: 50px; 
    width: auto; /* Lebar menyesuaikan otomatis */
    
    /* --- EFEK PERSONA 5 --- */
    transform: skew(-10deg) rotate(-2deg); /* Dimiringkan */
    border: 3px solid #000; /* Garis tepi hitam tebal */
    /* Bayangan merah kasar */
    box-shadow: 5px 5px 0px var(--primary-color); 
    background-color: #000; /* Latar belakang hitam (opsional, bagus jika logo transparan) */
    padding: 5px; /* Jarak antara logo dan border */
    
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Efek Hover saat mouse diarahkan ke logo */
.logo-container:hover .persona-logo {
    transform: skew(-10deg) rotate(0deg) translate(-3px, -3px);
    box-shadow: 8px 8px 0px var(--primary-color);
    background-color: var(--primary-color); /* Berubah jadi merah saat hover (opsional) */
}

/* Responsif untuk HP */
@media (max-width: 768px) {
    .navbar {
        padding: 20px 5%; /* Padding lebih kecil di HP */

    }
    .persona-logo {
        height: 40px; /* Logo sedikit lebih kecil di HP */
    }
}

