:root {
    --latar-gelap: #050604;
    --aksen-hijau: #a3e635;
    --aksen-pijar: rgba(163, 230, 53, 0.4);
    --teks-utama: #ffffff;
    --teks-pudar: #9ca3af;
    --kristal-batas: rgba(163, 230, 53, 0.2);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    background-color: var(--latar-gelap);
    color: var(--teks-utama);
    font-family: 'Inter', sans-serif;
    overflow-x: hidden;
    line-height: 1.6;
}

canvas { position: fixed; top: 0; left: 0; z-index: -1; pointer-events: none; will-change: transform; }

.wadah { max-width: 1200px; margin: 0 auto; padding: 0 2rem; width: 100%; }

/* --- ANIMASI --- */
@keyframes munulKeAtas {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}
.fade-enter { animation: munulKeAtas 0.8s ease forwards; }

/* --- NAVIGASI --- */
nav {
    position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;
    background: rgba(5, 6, 4, 0.9); backdrop-filter: blur(25px);
    border-bottom: 1px solid var(--kristal-batas);
}
.wadah-navigasi { height: 90px; display: flex; justify-content: space-between; align-items: center; max-width: 1240px; margin: 0 auto; padding: 0 3rem; }
.merek-nav { font-family: 'Outfit', sans-serif; font-size: 2.2rem; font-weight: 900; color: var(--aksen-hijau); text-decoration: none; letter-spacing: -1px; }
.tautan-nav { display: flex; gap: 2.5rem; }
.tautan-nav a { text-decoration: none; color: #999; font-weight: 600; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 1.5px; transition: 0.4s; position: relative; padding: 0.5rem 0; }
.tautan-nav a:hover, .tautan-nav a.active { color: var(--aksen-hijau); }
.tautan-nav a.active::after { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 3px; background: var(--aksen-hijau); box-shadow: 0 0 15px var(--aksen-hijau); border-radius: 10px; }
.pemicu-nav { display: none; font-size: 1.8rem; color: var(--aksen-hijau); cursor: pointer; }

/* --- HERO --- */
.tata-letak-hero { min-height: 100vh; display: flex; align-items: center; gap: 5rem; padding: 180px 0 120px 0; }
.area-gambar-hero { flex: 0.8; display: flex; justify-content: center; position: relative; }

/* --- WADAH FOTO PIJAR --- */
.wadah-foto-pijar { position: relative; display: inline-block; padding: 15px; }
.bingkai-pijar { 
    position: absolute; top: 0; left: 0; width: 100%; height: 100%; 
    border: 1px solid var(--aksen-hijau); border-radius: 30px; 
    opacity: 0.2; z-index: -1; animation: denyut 3s infinite; 
}
@keyframes denyut { 0%, 100% { transform: scale(1); opacity: 0.2; } 50% { transform: scale(1.03); opacity: 0.4; } }

.foto-profil-hero { width: 100%; max-width: 380px; aspect-ratio: 1/1; border-radius: 20px; object-fit: cover; border: 2px solid var(--kristal-batas); box-shadow: 0 0 40px rgba(0,0,0,0.5); }

.area-teks-hero { flex: 1.2; }
.area-teks-hero h1 { font-family: 'Outfit', sans-serif; font-size: 4.2rem; font-weight: 900; line-height: 1.1; margin-bottom: 2rem; letter-spacing: -2px; }
.area-teks-hero h2 { color: var(--aksen-hijau); font-size: 1rem; text-transform: uppercase; letter-spacing: 4px; margin-bottom: 1.5rem; font-weight: 800; }
.area-teks-hero p { font-size: 1.2rem; color: var(--teks-pudar); margin-bottom: 3rem; line-height: 1.8; }

.hero-btns { display: flex; gap: 1.5rem; align-items: center; }

.bar-statistik {
    display: flex; gap: 5rem; padding: 3rem; background: #0d0e0c;
    border: 1px solid var(--kristal-batas); border-radius: 24px; margin-top: -40px;
    position: relative; z-index: 10; justify-content: center;
    box-shadow: 0 40px 80px rgba(0,0,0,0.9);
}
.item-statistik { text-align: center; }
.item-statistik h3 { font-size: 3.5rem; color: white; font-family: 'Outfit'; margin-bottom: 0.5rem; line-height: 1; }
.item-statistik p { color: var(--aksen-hijau); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; }

/* --- KARTU KRISTAL --- */
.kartu-kristal {
    background: #0d0e0c; border: 1px solid var(--kristal-batas);
    padding: 5rem; border-radius: 30px; position: relative;
    margin-top: 140px; margin-bottom: 80px;
    box-shadow: 0 50px 100px rgba(0,0,0,0.7);
}
.judul-halaman { font-family: 'Outfit'; font-size: 3.5rem; margin-bottom: 4rem; color: var(--aksen-hijau); }

/* --- BIODATA --- */
.grid-tentang { display: grid; grid-template-columns: 350px 1fr; gap: 5rem; align-items: start; }
.area-foto-biodata { display: flex; justify-content: center; }
.foto-biodata { width: 100%; max-width: 350px; aspect-ratio: 1/1; border-radius: 20px; object-fit: cover; border: 2px solid var(--kristal-batas); }

.sub-judul { font-family: 'Outfit'; font-size: 1.8rem; margin: 2.5rem 0 1.5rem 0; color: var(--aksen-hijau); }
.sub-judul:first-child { margin-top: 0; }
.deskripsi-bio { font-size: 1.15rem; color: var(--teks-pudar); line-height: 1.8; margin-bottom: 2rem; }

.grid-biodata { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; }
.kartu-info { background: #131410; padding: 1.5rem; border-radius: 12px; border: 1px solid var(--kristal-batas); overflow-wrap: break-word; word-break: break-word; }
.kartu-info strong { display: block; color: var(--aksen-hijau); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 0.5rem; }
.kartu-info p { font-size: 1.1rem; color: white; line-height: 1.4; }

/* --- GRID UMUM --- */
.grid { display: grid; gap: 3rem; width: 100%; }
.grid-2 { grid-template-columns: 1fr 1fr; }
.grid-3 { grid-template-columns: 1fr 1fr 1fr; }

/* --- LINIMASA --- */
.wadah-linimasa { border-left: 2px solid var(--kristal-batas); margin-left: 10px; padding-left: 50px; position: relative; margin-top: 4rem; }
.item-linimasa { margin-bottom: 6rem; position: relative; }
.titik-linimasa { 
    position: absolute; left: -61px; top: 0; width: 22px; height: 22px; 
    background: var(--latar-gelap); border: 4px solid var(--aksen-hijau); 
    border-radius: 50%; box-shadow: 0 0 20px var(--aksen-pijar);
}
.tgl-linimasa { color: var(--aksen-hijau); font-size: 0.9rem; font-weight: 800; margin-bottom: 1.2rem; text-transform: uppercase; letter-spacing: 2px; }
.jabatan-linimasa { font-family: 'Outfit'; font-size: 2.2rem; margin-bottom: 0.5rem; line-height: 1.2; }
.pt-linimasa { color: var(--teks-pudar); font-size: 1.3rem; margin-bottom: 2rem; font-weight: 500; }
.ket-linimasa { color: var(--teks-pudar); line-height: 1.8; font-size: 1.15rem; }

/* --- KEAHLIAN --- */
.kartu-keahlian { background: #121410; border: 1px solid var(--kristal-batas); padding: 3.5rem; border-radius: 24px; transition: 0.4s; }
.kartu-keahlian:hover { border-color: var(--aksen-hijau); transform: translateY(-12px); box-shadow: 0 20px 40px rgba(163,230,53,0.1); }
.ikon-keahlian { font-size: 2.5rem; color: var(--aksen-hijau); margin-bottom: 2.5rem; }
.grup-tag { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.tag-hijau { background: rgba(163, 230, 53, 0.1); color: var(--aksen-hijau); padding: 0.6rem 1.4rem; border-radius: 10px; font-size: 0.85rem; font-weight: 700; border: 1px solid rgba(163, 230, 53, 0.2); }

/* --- PROYEK --- */
.kartu-proyek { background: #121410; border: 1px solid var(--kristal-batas); border-radius: 28px; overflow: hidden; transition: 0.5s; display: flex; flex-direction: column; }
.kartu-proyek:hover { transform: translateY(-15px); border-color: var(--aksen-hijau); box-shadow: 0 30px 60px rgba(0,0,0,0.5); }
.wadah-gambar-proyek { width: 100%; height: 350px; overflow: hidden; border-bottom: 1px solid var(--kristal-batas); }
.wadah-gambar-proyek img { width: 100%; height: 100%; object-fit: cover; transition: 0.6s; }
.kartu-proyek:hover img { transform: scale(1.1); }
.konten-proyek { padding: 3rem; flex-grow: 1; display: flex; flex-direction: column; }
.konten-proyek h3 { font-family: 'Outfit'; font-size: 2rem; margin-bottom: 1.5rem; }
.konten-proyek p { color: var(--teks-pudar); margin-bottom: 2.5rem; font-size: 1.1rem; line-height: 1.7; flex-grow: 1; }
.kolaborasi-tag { color: var(--aksen-hijau); font-weight: 800; margin-bottom: 2.5rem; font-size: 1rem; letter-spacing: 1px; }

/* --- ARTIKEL --- */
.kartu-artikel { background: #121410; border: 1px solid var(--kristal-batas); border-radius: 24px; overflow: hidden; transition: 0.4s; }
.gambar-artikel { width: 100%; height: 250px; object-fit: cover; }
.konten-artikel { padding: 2.5rem; }
.tautan-artikel { color: var(--aksen-hijau); text-decoration: none; font-weight: 800; font-size: 0.9rem; letter-spacing: 1.5px; display: inline-block; margin-top: 2rem; }

/* --- TOMBOL --- */
.tombol { padding: 1.3rem 3rem; border-radius: 14px; font-weight: 800; text-transform: uppercase; font-size: 0.9rem; text-decoration: none; transition: 0.4s; display: inline-block; cursor: pointer; border: none; letter-spacing: 2px; text-align: center; }
.tombol-utama { background: var(--aksen-hijau); color: black; box-shadow: 0 8px 20px rgba(163,230,53,0.3); }
.tombol-utama:hover { transform: translateY(-5px); box-shadow: 0 15px 35px var(--aksen-pijar); }
.tombol-garis { border: 2px solid var(--aksen-hijau); color: var(--aksen-hijau); background: transparent; }

/* --- FOOTER (CENTERED) --- */
.footer-kristal { padding: 6rem 0; border-top: 1px solid var(--kristal-batas); margin-top: 10rem; background: #050604; width: 100%; }
.wadah-footer { display: flex; justify-content: center; align-items: center; max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.tautan-sosial { display: flex !important; flex-direction: row !important; gap: 2rem; align-items: center; }
.ikon-sosial { width: 60px; height: 60px; background: #131410; border: 1px solid var(--kristal-batas); border-radius: 18px; color: white !important; display: flex; align-items: center; justify-content: center; text-decoration: none; transition: 0.4s; font-size: 1.6rem; }
.ikon-sosial:hover { background: var(--aksen-hijau); color: black !important; transform: translateY(-10px) rotate(12deg); box-shadow: 0 15px 30px var(--aksen-pijar); }

/* --- ADMIN PANEL --- */
.panel-admin { padding-top: 130px; max-width: 1200px; margin: 0 auto; padding-left: 2rem; padding-right: 2rem; padding-bottom: 100px; }
.header-admin { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4rem; }
.tata-letak-admin { display: grid; grid-template-columns: 280px 1fr; gap: 4rem; align-items: start; }
.sidebar-admin { background: #0d0e0c; border: 1px solid var(--kristal-batas); border-radius: 24px; padding: 1.5rem; position: sticky; top: 130px; }
.item-nav-admin { padding: 1.2rem 1.5rem; border-radius: 12px; cursor: pointer; color: var(--teks-pudar); font-weight: 700; margin-bottom: 0.5rem; transition: 0.3s; }
.item-nav-admin.active { background: rgba(163, 230, 53, 0.1); color: var(--aksen-hijau); border: 1px solid var(--aksen-hijau); }

.grup-formulir { margin-bottom: 2rem; width: 100%; }
.grup-formulir label { display: block; margin-bottom: 1rem; color: var(--aksen-hijau); font-weight: 800; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 2px; }
.kontrol-formulir { width: 100%; padding: 1.2rem; background: #1a1c16; border: 1px solid var(--kristal-batas); border-radius: 12px; color: white; font-size: 1.1rem; }
.kontrol-formulir:focus { outline: none; border-color: var(--aksen-hijau); box-shadow: 0 0 20px var(--aksen-pijar); }

.item-kelola { display: flex; justify-content: space-between; align-items: center; padding: 2rem; background: #131410; border: 1px solid var(--kristal-batas); border-radius: 20px; margin-top: 1.5rem; }

/* --- RESPONSIVE --- */
@media (max-width: 1100px) {
    .grid-tentang { grid-template-columns: 1fr; text-align: center; gap: 3rem; }
    .area-foto-biodata { margin-bottom: 2rem; display: flex; justify-content: center; }
    .info-tentang { text-align: left; }
    .tata-letak-admin { grid-template-columns: 1fr; }
    .sidebar-admin { position: relative; top: 0; margin-bottom: 3rem; }
}

@media (max-width: 1024px) {
    .wadah-navigasi { padding: 0 1.5rem; }
    .tata-letak-hero { flex-direction: column; text-align: center; gap: 3rem; padding-top: 120px; }
    .hero-btns { justify-content: center; flex-direction: column; width: 100%; }
    .hero-btns .tombol { width: 100%; }
    .area-teks-hero h1 { font-size: 3rem; }
    .bar-statistik { flex-wrap: wrap; gap: 2rem; margin-top: 2rem; padding: 2rem 1rem; }
    .wadah-footer { flex-direction: column; gap: 4rem; text-align: center; }
    .grid-2, .grid-3 { grid-template-columns: 1fr; }
    .pemicu-nav { display: block; padding-right: 0.5rem; }
    .tautan-nav { position: fixed; top: 90px; right: -100%; width: 280px; height: calc(100vh - 90px); background: rgba(5, 6, 4, 0.98); backdrop-filter: blur(25px); flex-direction: column; padding: 3rem; border-left: 1px solid var(--kristal-batas); transition: 0.4s; }
    .tautan-nav.aktif { right: 0; }
}

@media (max-width: 768px) {
    .wadah { padding: 0 1rem; }
    .area-teks-hero h1 { font-size: 2.5rem; }
    .kartu-kristal { padding: 3rem 1rem; border-radius: 20px; margin-top: 80px; width: 100%; overflow: hidden; }
    .judul-halaman { font-size: 2.2rem; margin-bottom: 3rem; }
    .wadah-linimasa { padding-left: 20px; }
    .titik-linimasa { left: -31px; }
    .foto-profil-hero { max-width: 280px; }
    .foto-biodata { max-width: 280px; }
    .grid-biodata { grid-template-columns: 1fr; }
    .kartu-info p { font-size: 1rem; word-break: break-word; }
}
