:root {
  /* Palet Warna */
  --warna-ungu-tua: #3E1E68;
  --warna-ungu-muda: #502F77;
  --warna-ungu-muda2: #e1c6ff;
  --warna-pink-tua: #E45A92;
  --warna-pink-muda: #FFACAC;
  --warna-pink-muda2: #facece;
  --warna-teks-hitam: #141414;
  --warna-teks-putih:#ffff;
  --warna-latar: #DCDCDC;
  --warna-button-kirim: #A2CB8B;
  --warna-button-danger:#D25353;
  --glow-pink: rgba(255, 153, 153, 0.3);

  /* Tipografi */
  --font-utama: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  --ukuran-font-dasar: 16px;

  /* Spasi (Spacing) */
  --padding-standar: 16px;
  --radius-sudut: 8px;

  /* 1. BREAKPOINT (Media Queries) */
  --breakpoint-sm: 576px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;
  --breakpoint-xxl: 1400px;

  /* 2. UKURAN BUTTON */
  --btn-border-radius: 0.375rem; /* 6px */
  
  /* Small */
  --btn-padding-y-sm: 0.25rem; /* 4px */
  --btn-padding-x-sm: 0.5rem;  /* 8px */
  --btn-font-size-sm: 0.875rem; /* 14px */

  /* Normal / Medium */
  --btn-padding-y: 0.375rem; /* 6px */
  --btn-padding-x: 0.75rem;  /* 12px */
  --btn-font-size: 1rem;     /* 16px */

  /* Large */
  --btn-padding-y-lg: 0.5rem; /* 8px */
  --btn-padding-x-lg: 1rem;   /* 16px */
  --btn-font-size-lg: 1.25rem;/* 20px */

  /* 3. CONTAINER (Max-Width) */
  --container-hp: 290px;
  --container-sm: 540px;
  --container-md: 720px;
  --container-lg: 960px;
  --container-xl: 1140px;
  --container-xxl: 1320px;

  /* 4. CARD */
  --card-border-radius: 0.375rem; /* 6px */
  --card-padding: 1.25rem;         /* 20px */
  --font-paragraf: 'Poppins', sans-serif;
  --font-tittle: 'Inter', sans-serif;
}

body{
    background-color: var(--warna-ungu-tua);
    margin: 0;
    padding: 0;
    place-items: center;
}

.container { 
        max-width: var(--container-hp); 
        height: fit-content; 
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        margin-bottom: 80px; 
    }
    
    .container-center { 
        max-width: var(--container-hp);
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        text-align: center;
        margin-bottom: 70px;
    } 

    .center{
        height: 50vh; 
        display: flex;
        justify-content: center; 
        align-items: center;
    }

    .layer-1{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda);
        font-size: 35px;
        font-weight: bolder;
        margin-bottom: 0;
    }

    .layer-2{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda2);
        font-size: 30px;
        font-weight: bolder;
        margin: 0;
    }

    .text-white{
        font-family: var(--font-paragraf);
        color: var(--warna-latar);
    }

    .button-1{
        font-size: var(--btn-font-size-sm);
        background-color: var(--warna-pink-tua);
        color: var(--warna-teks-putih);
        border-radius: var(--btn-border-radius);
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        box-shadow: 0 0px 5px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-1:hover{
        box-shadow: 0 0px 5px var(--warna-teks-putih);
        background-color: var(--warna-teks-putih);
        color: var(--warna-pink-tua);
        transition: transform 0.5s ease, box-shadow 0.3s ease;
        background-position: right bottom;
        transform: scale(1.05); 
    }

    .text-none {
        text-decoration: none;
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .text-none:hover{
        color: var(--warna-pink-muda);
        transform: scale(1.05); 
    }

    .nav-main {
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; /* Mengganti 99.3% agar penuh dan rapi */
        margin: 0;
        display: flex;          /* Membuat nav-main ikut mendukung flex */
        align-items: center;    /* Memastikan teks menu tepat di tengah secara VERTIKAL */
    }

    .nav-warp {
        display: flex;
        justify-content: center; /* Memusatkan menu secara HORIZONTAL */
        align-items: center;
        gap: 20px;
        width: 100%;            /* Memastikan pembungkus mengambil seluruh lebar */
    }

    /* Memperbaiki teks link yang hilang */
    .nav-warp a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
        line-height: 50px;
    }

    .logo{
        color: var(--warna-teks-putih);
    }

    .nav-links {
        display: flex; /* <-- Kunci utama agar berjejer ke samping */
        list-style: none; /* Menghilangkan titik/bullet point default */
        gap: 1.5rem; /* Jarak antar menu (bisa menggunakan variabel) */
        margin: 0;
        padding: 0;
    }

    .title{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-teks-putih);
        font-size: 35px;
        font-weight: bold;
        margin-top: 40px;
        word-wrap: break-word;
    }

    .layout-2{
        width: var(--container-hp);
        display: flex;
        flex-direction: column-reverse;
        justify-content: center;
        align-items: center;
        gap: 30px;
    }

    .desk{
        display: flex;
        justify-content: center;
        align-items: center;
        box-sizing: border-box;
        color: var(--warna-latar);
        padding: 0px 10px 0px 20px;
        text-align: left;
        font-family: var(--font-paragraf);
    }

    .desk p { 
        margin: 0;
    }

    .image-2{
        box-sizing: border-box;
        display: flex;
        justify-content: center;
    }

    .profil img {
        width: 100%;           /* Memastikan gambar memenuhi ruang div 50% */
        height: 100%;          /* Menjaga proporsi gambar */
        display: block;
        object-fit: cover;
        border-radius: var(--radius-sudut);
    }

    .profil{
        border: 8px solid transparent;
        border-radius: var(--radius-sudut);
        background-image: linear-gradient(to bottom , var(--warna-pink-muda), var(--warna-pink-muda2));
        background-origin: border-box;
        background-clip: border-box;
        width: 150px;
        height: 150px;
        overflow: hidden;
        box-shadow: 0 2px 5px var(--warna-pink-muda2), -2px -2px 5px var(--warna-pink-muda);
        
        
    }

    .skill{
        display: flex;
        flex-direction: row;
        gap: 0.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
    }

    .button-skill{
        background-color: var(--warna-pink-tua);
        border-radius: 25px;
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        color: var(--warna-latar);
        box-shadow: 0 2px 10px var(--glow-pink);
        font-family: var(--font-tittle);
        font-weight: bolder;
        font-size: small;
    }

    .exp{
        display: flex;
        flex-direction: column;
        gap: 1rem;
        margin-top: 0px;
        justify-content: center;
        align-items: center;
    }

    .card-exp{
        max-width: var(--container-hp);
        width: 320px;
        height: auto;
        background-color: var(--warna-ungu-muda);
        padding: 4px;
        border: 2px solid var(--warna-ungu-muda);
        border-radius: var(--radius-sudut);
        box-shadow: 0 2px 10px var(--warna-ungu-muda);
        font-family: var(--font-paragraf);
        word-wrap: break-word;
    }

    .card-exp p{
        color: var(--warna-ungu-muda2);
    }

    .card-exp a{
        background-color: var(--warna-ungu-tua);
        color: var(--warna-ungu-muda2);
        padding: 3px 8px;
        border-radius: var(--radius-sudut);
        text-decoration: none;
    }

    .label-exp{
        border-radius: 15px;
        background-color: var(--warna-pink-tua);
        padding: 4px 8px;
        width: fit-content;
        height: fit-content;
        text-align: center;
        font-size: small;
        color: var(--warna-pink-muda2);
    }

    .project{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: center;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 1rem;
        margin-top: 0px;
        font-family: var(--font-paragraf);
    }

    .card-custom {
        position: relative;
        width: 320px;
        height: 340px;
        border-radius: var(--radius-sudut);
        overflow: hidden; /* KUNCI: Memotong sudut bawah card-body agar melengkung rapi */
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
    }

    /* Biarkan pembungkus gambar mengambil ukuran penuh kartu */
    .card-custom .image-stack {
        width: 100%;
        height: 100%;
    }

    .card-custom img {
        width: 100%;           
        height: 100%;          
        display: block;
        object-fit: cover;
    }

    /* Mengatur Kotak Teks Melayang di Atas Gambar bagian Bawah */
    .card-body {
        position: absolute; 
        bottom: 0;          /* KUNCI: Menempel di bagian bawah kartu */
        left: 0;
        right: 0;
        
        /* Menggunakan gradien: transparan di atas, lalu menggelap di bawah */
        background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 20%); 
        
        color: #f1f1f1; 
        padding: 20px;       
        box-sizing: border-box;
        
        /* Membatasi tinggi maksimal teks melayang agar tidak menutupi seluruh gambar */
        max-height: 60%;    
        overflow-y: auto;   /* Jika teks lorem ipsum kepanjangan, bisa di-scroll tipis-tipis */
    }

    /* Merapikan teks */
    .card-body h3 {
        margin-top: 0;
        margin-bottom: 8px;
        font-size: 1.3rem;
        color: #fff;
        text-shadow: 1px 1px 3px rgba(0,0,0,0.8); /* Membantu teks makin terbaca jelas */
    }

    .text {
        font-size: 0.85rem;
        line-height: 1.4;
        margin-bottom: 0;
    }
    
    .label-pro{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: first baseline;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 0.5rem;
        margin-top: 10px;
    }

    .label-pro-1 {
        font-size: smaller;
        font-weight: bold;
        padding: 2px 10px;
        background-color: var(--warna-ungu-muda);
        color: var(--warna-pink-muda2);
        border-radius: 20px;

    }

    .label-button{
        display: flex;          
        justify-content:end ;  
        gap: 0.5rem;
        margin-top: 10px;
    }

    .button-pro{
        font-size: medium;
        width: fit-content;
        height: fit-content;
        border-radius: 20px;
        background-color: var(--warna-pink-tua);
        padding: 5px 10px;
        box-shadow: 0 0px 4px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-pro:hover{
        background-color: var(--warna-ungu-tua);
        box-shadow: 0 0px 4px var(--warna-ungu-tua);
    }

    .label-button a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
    }

     .contact{
        display: flex;
        flex-direction: row;
        gap: 0.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
        margin-top: 20px;
    }

    .contact img {
        width: 25px;
        height: 25px;
    }

    footer{
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; 
        margin: 0;
        
        /* Pengaturan Flexbox untuk posisi tengah */
        display: flex;         
        justify-content: center; /* ⬅️ Mengetengahkan teks secara HORIZONTAL */
        align-items: center;     /* Mengetengahkan teks secara VERTIKAL */
        
        color: #ffffff;        
        padding: 20px 10px;     
        font-size: 14px;  
    }

    .gmail{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 0px 6px;
        border-radius: 15px;
        font-family: var(--font-paragraf);
        gap: 1rem;
        font-weight: bolder;
        color: var(--warna-ungu-tua);
        font-size: smaller;
    }

    .linkedin{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 8px 10px;
        border-radius: 15px;
    }



/* Mengatur lebar maksimum berdasarkan media queries */
/*--------------------------------------------------------Ukuran KECIL*/
@media (min-width: 576px) { 
    .container { 
        max-width: var(--container-sm); 
        height: fit-content; 
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        margin-bottom: 80px; 
    }
    
    .container-center { 
        max-width: var(--container-sm);
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        text-align: center;
        margin-bottom: 70px;
    } 

    .center{
        height: 50vh; 
        display: flex;
        justify-content: center; 
        align-items: center;
    }

    .layer-1{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda);
        font-size: 45px;
        font-weight: bolder;
        margin-bottom: 0;
    }

    .layer-2{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda2);
        font-size: 40px;
        font-weight: bolder;
        margin: 0;
    }

    .text-white{
        font-family: var(--font-paragraf);
        color: var(--warna-latar);
    }

    .button-1{
        font-size: var(--btn-font-size-sm);
        background-color: var(--warna-pink-tua);
        color: var(--warna-teks-putih);
        border-radius: var(--btn-border-radius);
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        box-shadow: 0 0px 5px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-1:hover{
        box-shadow: 0 0px 5px var(--warna-teks-putih);
        background-color: var(--warna-teks-putih);
        color: var(--warna-pink-tua);
        transition: transform 0.5s ease, box-shadow 0.3s ease;
        background-position: right bottom;
        transform: scale(1.05); 
    }

    .text-none {
        text-decoration: none;
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .text-none:hover{
        color: var(--warna-pink-muda);
        transform: scale(1.05); 
    }

    .nav-main {
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; /* Mengganti 99.3% agar penuh dan rapi */
        margin: 0;
        display: flex;          /* Membuat nav-main ikut mendukung flex */
        align-items: center;    /* Memastikan teks menu tepat di tengah secara VERTIKAL */
    }

    .nav-warp {
        display: flex;
        justify-content: center; /* Memusatkan menu secara HORIZONTAL */
        align-items: center;
        gap: 20px;
        width: 100%;            /* Memastikan pembungkus mengambil seluruh lebar */
    }

    /* Memperbaiki teks link yang hilang */
    .nav-warp a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
        line-height: 50px;
    }

    .logo{
        color: var(--warna-teks-putih);
    }

    .nav-links {
        display: flex; /* <-- Kunci utama agar berjejer ke samping */
        list-style: none; /* Menghilangkan titik/bullet point default */
        gap: 1.5rem; /* Jarak antar menu (bisa menggunakan variabel) */
        margin: 0;
        padding: 0;
    }

    .title{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-teks-putih);
        font-size: 45px;
        font-weight: bold;
        margin-top: 50px;
    }

    .layout-2{
        width: var(--container-sm);
        display: flex;
        flex-direction: row;
        justify-content:space-between;
        gap: 40px;
    }

    .desk{
        display: flex;
        justify-content: center;
        align-items: center;
        width: calc(50% - 20px); 
        box-sizing: border-box;
        color: var(--warna-latar);
        padding: 0px 10px 0px 20px;
        text-align: left;
        font-family: var(--font-paragraf);
    }

    .desk p { 
        margin: 0;
    }

    .image-2{
       width: calc(50% - 20px); 
        box-sizing: border-box;
        display: flex;
        justify-content: center;
    }

    .profil img {
        width: 100%;           /* Memastikan gambar memenuhi ruang div 50% */
        height: 100%;          /* Menjaga proporsi gambar */
        display: block;
        object-fit: cover;
        border-radius: var(--radius-sudut);
    }

    .profil{
        border: 8px solid transparent;
        border-radius: var(--radius-sudut);
        background-image: linear-gradient(to bottom , var(--warna-pink-muda), var(--warna-pink-muda2));
        background-origin: border-box;
        background-clip: border-box;
        width: 170px;
        height: 170px;
        overflow: hidden;
        box-shadow: 0 2px 5px var(--warna-pink-muda2), -2px -2px 5px var(--warna-pink-muda);
        
        
    }

    .skill{
        display: flex;
        flex-direction: row;
        gap: 1.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
    }

    .button-skill{
        background-color: var(--warna-pink-tua);
        border-radius: 25px;
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        color: var(--warna-latar);
        box-shadow: 0 2px 10px var(--glow-pink);
        font-family: var(--font-tittle);
        font-weight: bolder;
    }

    .exp{
        display: flex;
        flex-direction: column;
        gap: 1rem;
        margin-top: 0px;
        justify-content: center;
        align-items: center;
    }

    .card-exp{
        max-width: 880px;
        width: var(--container-sm);
        height: auto;
        background-color: var(--warna-ungu-muda);
        padding: 8px;
        border: 2px solid var(--warna-ungu-muda);
        border-radius: var(--radius-sudut);
        box-shadow: 0 2px 10px var(--warna-ungu-muda);
        font-family: var(--font-paragraf);
    }

    .card-exp p{
        color: var(--warna-ungu-muda2);
    }

    .card-exp a{
        background-color: var(--warna-ungu-tua);
        color: var(--warna-ungu-muda2);
        padding: 3px 8px;
        border-radius: var(--radius-sudut);
        text-decoration: none;
    }

    .label-exp{
        border-radius: 15px;
        background-color: var(--warna-pink-tua);
        padding: 4px 8px;
        width: fit-content;
        height: fit-content;
        text-align: center;
        font-size: small;
        color: var(--warna-pink-muda2);
    }

    .project{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: center;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 1rem;
        margin-top: 0px;
        font-family: var(--font-paragraf);
    }

    .card-custom {
        position: relative;
        width: 320px;
        height: 340px;
        border-radius: var(--radius-sudut);
        overflow: hidden; /* KUNCI: Memotong sudut bawah card-body agar melengkung rapi */
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
    }

    /* Biarkan pembungkus gambar mengambil ukuran penuh kartu */
    .card-custom .image-stack {
        width: 100%;
        height: 100%;
    }

    .card-custom img {
        width: 100%;           
        height: 100%;          
        display: block;
        object-fit: cover;
    }

    /* Mengatur Kotak Teks Melayang di Atas Gambar bagian Bawah */
    .card-body {
        position: absolute; 
        bottom: 0;          /* KUNCI: Menempel di bagian bawah kartu */
        left: 0;
        right: 0;
        
        /* Menggunakan gradien: transparan di atas, lalu menggelap di bawah */
        background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 20%); 
        
        color: #f1f1f1; 
        padding: 20px;       
        box-sizing: border-box;
        
        /* Membatasi tinggi maksimal teks melayang agar tidak menutupi seluruh gambar */
        max-height: 60%;    
        overflow-y: auto;   /* Jika teks lorem ipsum kepanjangan, bisa di-scroll tipis-tipis */
    }

    /* Merapikan teks */
    .card-body h3 {
        margin-top: 0;
        margin-bottom: 8px;
        font-size: 1.3rem;
        color: #fff;
        text-shadow: 1px 1px 3px rgba(0,0,0,0.8); /* Membantu teks makin terbaca jelas */
    }

    .text {
        font-size: 0.85rem;
        line-height: 1.4;
        margin-bottom: 0;
    }
    
    .label-pro{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: first baseline;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 0.5rem;
        margin-top: 10px;
    }

    .label-pro-1 {
        font-size: smaller;
        font-weight: bold;
        padding: 2px 10px;
        background-color: var(--warna-ungu-muda);
        color: var(--warna-pink-muda2);
        border-radius: 20px;

    }

    .label-button{
        display: flex;          
        justify-content:end ;  
        gap: 0.5rem;
        margin-top: 10px;
    }

    .button-pro{
        font-size: medium;
        width: fit-content;
        height: fit-content;
        border-radius: 20px;
        background-color: var(--warna-pink-tua);
        padding: 5px 10px;
        box-shadow: 0 0px 4px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-pro:hover{
        background-color: var(--warna-ungu-tua);
        box-shadow: 0 0px 4px var(--warna-ungu-tua);
    }

    .label-button a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
    }

     .contact{
        display: flex;
        flex-direction: row;
        gap: 1.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
        margin-top: 20px;
    }

    .contact img {
        width: 40px;
        height: 40px;
    }

    footer{
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; 
        margin: 0;
        
        /* Pengaturan Flexbox untuk posisi tengah */
        display: flex;         
        justify-content: center; /* ⬅️ Mengetengahkan teks secara HORIZONTAL */
        align-items: center;     /* Mengetengahkan teks secara VERTIKAL */
        
        color: #ffffff;        
        padding: 20px 10px;     
        font-size: 16px;  
    }

    .gmail{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 3.5px 10px;
        border-radius: 15px;
        font-family: var(--font-paragraf);
        gap: 1rem;
        font-weight: bolder;
        color: var(--warna-ungu-tua);
        font-size: medium;
    }

    .linkedin{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 8px 10px;
        border-radius: 15px;
    }
}
/*--------------------------------------------------------Ukuran MEDIUM*/
@media (min-width: 768px) { 
    .container { 
        max-width: var(--container-md);
        height: fit-content; 
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        margin-bottom: 80px; 
    }
    
        .container-center { 
        max-width: var(--container-md);
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        text-align: center;
        margin-bottom: 70px;
    } 

    .center{
        height: 50vh; 
        display: flex;
        justify-content: center; 
        align-items: center;
    }

    .layer-1{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda);
        font-size: 55px;
        font-weight: bolder;
        margin-bottom: 0;
    }

    .layer-2{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda2);
        font-size: 50px;
        font-weight: bolder;
        margin: 0;
    }

    .text-white{
        font-family: var(--font-paragraf);
        color: var(--warna-latar);
    }

    .button-1{
        font-size: var(--btn-font-size-sm);
        background-color: var(--warna-pink-tua);
        color: var(--warna-teks-putih);
        border-radius: var(--btn-border-radius);
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        box-shadow: 0 0px 5px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-1:hover{
        box-shadow: 0 0px 5px var(--warna-teks-putih);
        background-color: var(--warna-teks-putih);
        color: var(--warna-pink-tua);
        transition: transform 0.5s ease, box-shadow 0.3s ease;
        background-position: right bottom;
        transform: scale(1.05); 
    }

    .text-none {
        text-decoration: none;
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .text-none:hover{
        color: var(--warna-pink-muda);
        transform: scale(1.05); 
    }

    .nav-main {
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; /* Mengganti 99.3% agar penuh dan rapi */
        margin: 0;
        display: flex;          /* Membuat nav-main ikut mendukung flex */
        align-items: center;    /* Memastikan teks menu tepat di tengah secara VERTIKAL */
    }

    .nav-warp {
        display: flex;
        justify-content: center; /* Memusatkan menu secara HORIZONTAL */
        align-items: center;
        gap: 20px;
        width: 100%;            /* Memastikan pembungkus mengambil seluruh lebar */
    }

    /* Memperbaiki teks link yang hilang */
    .nav-warp a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
        line-height: 50px;
    }

    .logo{
        color: var(--warna-teks-putih);
    }

    .nav-links {
        display: flex; /* <-- Kunci utama agar berjejer ke samping */
        list-style: none; /* Menghilangkan titik/bullet point default */
        gap: 1.5rem; /* Jarak antar menu (bisa menggunakan variabel) */
        margin: 0;
        padding: 0;
    }

    .title{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-teks-putih);
        font-size: 45px;
        font-weight: bold;
        margin-top: 50px;
    }

    .layout-2{
        width: var(--container-md);
        display: flex;
        flex-direction: row;
        justify-content:space-between;
        gap: 40px;
    }

    .desk{
        display: flex;
        justify-content: center;
        align-items: center;
        width: calc(50% - 20px); 
        box-sizing: border-box;
        color: var(--warna-latar);
        padding: 0px 10px 0px 20px;
        text-align: left;
        font-family: var(--font-paragraf);
    }

    .desk p { 
        margin: 0;
    }

    .image-2{
       width: calc(50% - 20px); 
        box-sizing: border-box;
        display: flex;
        justify-content: center;
    }

    .profil img {
        width: 100%;           /* Memastikan gambar memenuhi ruang div 50% */
        height: 100%;          /* Menjaga proporsi gambar */
        display: block;
        object-fit: cover;
        border-radius: var(--radius-sudut);
    }

    .profil{
        border: 8px solid transparent;
        border-radius: var(--radius-sudut);
        background-image: linear-gradient(to bottom , var(--warna-pink-muda), var(--warna-pink-muda2));
        background-origin: border-box;
        background-clip: border-box;
        width: 270px;
        height: 270px;
        overflow: hidden;
        box-shadow: 0 2px 5px var(--warna-pink-muda2), -2px -2px 5px var(--warna-pink-muda);
        
        
    }

    .skill{
        display: flex;
        flex-direction: row;
        gap: 1.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
    }

    .button-skill{
        background-color: var(--warna-pink-tua);
        border-radius: 25px;
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        color: var(--warna-latar);
        box-shadow: 0 2px 10px var(--glow-pink);
        font-family: var(--font-tittle);
        font-weight: bolder;
    }

    .exp{
        display: flex;
        flex-direction: column;
        gap: 1rem;
        margin-top: 0px;
        justify-content: center;
        align-items: center;
    }

    .card-exp{
        max-width: 880px;
        width: var(--container-md);
        height: auto;
        background-color: var(--warna-ungu-muda);
        padding: 8px;
        border: 2px solid var(--warna-ungu-muda);
        border-radius: var(--radius-sudut);
        box-shadow: 0 2px 10px var(--warna-ungu-muda);
        font-family: var(--font-paragraf);
    }

    .card-exp p{
        color: var(--warna-ungu-muda2);
    }

    .card-exp a{
        background-color: var(--warna-ungu-tua);
        color: var(--warna-ungu-muda2);
        padding: 3px 8px;
        border-radius: var(--radius-sudut);
        text-decoration: none;
    }

    .label-exp{
        border-radius: 15px;
        background-color: var(--warna-pink-tua);
        padding: 4px 8px;
        width: fit-content;
        height: fit-content;
        text-align: center;
        font-size: small;
        color: var(--warna-pink-muda2);
    }

    .project{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: center;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 1rem;
        margin-top: 0px;
        font-family: var(--font-paragraf);
    }

    .card-custom {
        position: relative;
        width: 320px;
        height: 340px;
        border-radius: var(--radius-sudut);
        overflow: hidden; /* KUNCI: Memotong sudut bawah card-body agar melengkung rapi */
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
    }

    /* Biarkan pembungkus gambar mengambil ukuran penuh kartu */
    .card-custom .image-stack {
        width: 100%;
        height: 100%;
    }

    .card-custom img {
        width: 100%;           
        height: 100%;          
        display: block;
        object-fit: cover;
    }

    /* Mengatur Kotak Teks Melayang di Atas Gambar bagian Bawah */
    .card-body {
        position: absolute; 
        bottom: 0;          /* KUNCI: Menempel di bagian bawah kartu */
        left: 0;
        right: 0;
        
        /* Menggunakan gradien: transparan di atas, lalu menggelap di bawah */
        background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 20%); 
        
        color: #f1f1f1; 
        padding: 20px;       
        box-sizing: border-box;
        
        /* Membatasi tinggi maksimal teks melayang agar tidak menutupi seluruh gambar */
        max-height: 60%;    
        overflow-y: auto;   /* Jika teks lorem ipsum kepanjangan, bisa di-scroll tipis-tipis */
    }

    /* Merapikan teks */
    .card-body h3 {
        margin-top: 0;
        margin-bottom: 8px;
        font-size: 1.3rem;
        color: #fff;
        text-shadow: 1px 1px 3px rgba(0,0,0,0.8); /* Membantu teks makin terbaca jelas */
    }

    .text {
        font-size: 0.85rem;
        line-height: 1.4;
        margin-bottom: 0;
    }
    
    .label-pro{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: first baseline;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 0.5rem;
        margin-top: 10px;
    }

    .label-pro-1 {
        font-size: smaller;
        font-weight: bold;
        padding: 2px 10px;
        background-color: var(--warna-ungu-muda);
        color: var(--warna-pink-muda2);
        border-radius: 20px;

    }

    .label-button{
        display: flex;          
        justify-content:end ;  
        gap: 0.5rem;
        margin-top: 10px;
    }

    .button-pro{
        font-size: medium;
        width: fit-content;
        height: fit-content;
        border-radius: 20px;
        background-color: var(--warna-pink-tua);
        padding: 5px 10px;
        box-shadow: 0 0px 4px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-pro:hover{
        background-color: var(--warna-ungu-tua);
        box-shadow: 0 0px 4px var(--warna-ungu-tua);
    }

    .label-button a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
    }

     .contact{
        display: flex;
        flex-direction: row;
        gap: 1.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
        margin-top: 20px;
    }

    .contact img {
        width: 40px;
        height: 40px;
    }

    footer{
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; 
        margin: 0;
        
        /* Pengaturan Flexbox untuk posisi tengah */
        display: flex;         
        justify-content: center; /* ⬅️ Mengetengahkan teks secara HORIZONTAL */
        align-items: center;     /* Mengetengahkan teks secara VERTIKAL */
        
        color: #ffffff;        
        padding: 20px 10px;     
        font-size: 16px; 
    }

    .gmail{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 3.5px 10px;
        border-radius: 15px;
        font-family: var(--font-paragraf);
        gap: 1rem;
        font-weight: bolder;
        color: var(--warna-ungu-tua);
        font-size: medium;
    }

    .linkedin{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 8px 10px;
        border-radius: 15px;
    }
}

/*--------------------------------------------------------Ukuran BESAR XL*/
@media (min-width: 1200px) { 
    
    .container{ 
        max-width: var(--container-xl);
        height: fit-content; 
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        margin-bottom: 80px;
    }

    .container-center { 
        max-width: var(--container-xl);
        overflow-wrap: break-word; /* Standar modern untuk memotong kata di akhir baris */
        word-break: break-word;
        text-align: center;
        margin-bottom: 80px;
    } 

    .center{
        height: 50vh; 
        display: flex;
        justify-content: center; 
        align-items: center;
    }

    .layer-1{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda);
        font-size: 55px;
        font-weight: bolder;
        margin-bottom: 0;
    }

    .layer-2{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-pink-muda2);
        font-size: 50px;
        font-weight: bolder;
        margin: 0;
    }

    .text-white{
        font-family: var(--font-paragraf);
        color: var(--warna-latar);
    }

    .button-1{
        font-size: var(--btn-font-size-sm);
        background-color: var(--warna-pink-tua);
        color: var(--warna-teks-putih);
        border-radius: var(--btn-border-radius);
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        box-shadow: 0 0px 5px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-1:hover{
        box-shadow: 0 0px 5px var(--warna-teks-putih);
        background-color: var(--warna-teks-putih);
        color: var(--warna-pink-tua);
        transition: transform 0.5s ease, box-shadow 0.3s ease;
        background-position: right bottom;
        transform: scale(1.05); 
    }

    .text-none {
        text-decoration: none;
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .text-none:hover{
        color: var(--warna-pink-muda);
        transform: scale(1.05); 
    }

    .nav-main {
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; /* Mengganti 99.3% agar penuh dan rapi */
        margin: 0;
        display: flex;          /* Membuat nav-main ikut mendukung flex */
        align-items: center;    /* Memastikan teks menu tepat di tengah secara VERTIKAL */
    }

    .nav-warp {
        display: flex;
        justify-content: center; /* Memusatkan menu secara HORIZONTAL */
        align-items: center;
        gap: 20px;
        width: 100%;            /* Memastikan pembungkus mengambil seluruh lebar */
    }

    /* Memperbaiki teks link yang hilang */
    .nav-warp a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
        line-height: 50px;
    }

    .logo{
        color: var(--warna-teks-putih);
    }

    .nav-links {
        display: flex; /* <-- Kunci utama agar berjejer ke samping */
        list-style: none; /* Menghilangkan titik/bullet point default */
        gap: 1.5rem; /* Jarak antar menu (bisa menggunakan variabel) */
        margin: 0;
        padding: 0;
    }

    .title{
        font-family: var(--font-tittle);
        text-align: center;
        color: var(--warna-teks-putih);
        font-size: 45px;
        font-weight: bold;
        margin-top: 50px;
    }

    .layout-2{
        width: var(--container-xl);
        display: flex;
        flex-direction: row;
        justify-content:space-between;
        gap: 40px;
    }

    .desk{
        display: flex;
        justify-content: center;
        align-items: center;
        width: calc(50% - 20px); 
        box-sizing: border-box;
        color: var(--warna-latar);
        padding: 0px 10px 0px 20px;
        text-align: left;
        font-family: var(--font-paragraf);
    }

    .desk p { 
        margin: 0;
    }

    .image-2{
       width: calc(50% - 20px); 
        box-sizing: border-box;
        display: flex;
        justify-content: center;
    }

    .profil img {
        width: 100%;           /* Memastikan gambar memenuhi ruang div 50% */
        height: 100%;          /* Menjaga proporsi gambar */
        display: block;
        object-fit: cover;
        border-radius: var(--radius-sudut);
    }

    .profil{
        border: 8px solid transparent;
        border-radius: var(--radius-sudut);
        background-image: linear-gradient(to bottom , var(--warna-pink-muda), var(--warna-pink-muda2));
        background-origin: border-box;
        background-clip: border-box;
        width: 320px;
        height: 320px;
        overflow: hidden;
        box-shadow: 0 2px 5px var(--warna-pink-muda2), -2px -2px 5px var(--warna-pink-muda);
        
    }

    .skill{
        display: flex;
        flex-direction: row;
        gap: 1.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
    }

    .button-skill{
        background-color: var(--warna-pink-tua);
        border-radius: 25px;
        padding: var(--btn-padding-y-lg) var(--btn-padding-x-lg);
        color: var(--warna-latar);
        box-shadow: 0 2px 10px var(--glow-pink);
        font-family: var(--font-tittle);
        font-weight: bolder;
    }

    .exp{
        display: flex;
        flex-direction: column;
        gap: 1rem;
        margin-top: 0px;
        justify-content: center;
        align-items: center;
    }

    .card-exp{
        max-width: 880px;
        width: 880px;
        height: auto;
        background-color: var(--warna-ungu-muda);
        padding: 8px;
        border: 2px solid var(--warna-ungu-muda);
        border-radius: var(--radius-sudut);
        box-shadow: 0 2px 10px var(--warna-ungu-muda);
        font-family: var(--font-paragraf);
    }

    .card-exp p{
        color: var(--warna-ungu-muda2);
    }

    .card-exp a{
        background-color: var(--warna-ungu-tua);
        color: var(--warna-ungu-muda2);
        padding: 3px 8px;
        border-radius: var(--radius-sudut);
        text-decoration: none;
    }

    .label-exp{
        border-radius: 15px;
        background-color: var(--warna-pink-tua);
        padding: 4px 8px;
        width: fit-content;
        height: fit-content;
        text-align: center;
        font-size: small;
        color: var(--warna-pink-muda2);
    }

    .project{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: center;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 1rem;
        margin-top: 0px;
        font-family: var(--font-paragraf);
    }

    .card-custom {
        position: relative;
        width: 320px;
        height: 340px;
        border-radius: var(--radius-sudut);
        overflow: hidden; /* KUNCI: Memotong sudut bawah card-body agar melengkung rapi */
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
    }

    /* Biarkan pembungkus gambar mengambil ukuran penuh kartu */
    .card-custom .image-stack {
        width: 100%;
        height: 100%;
    }

    .card-custom img {
        width: 100%;           
        height: 100%;          
        display: block;
        object-fit: cover;
    }

    /* Mengatur Kotak Teks Melayang di Atas Gambar bagian Bawah */
    .card-body {
        position: absolute; 
        bottom: 0;          /* KUNCI: Menempel di bagian bawah kartu */
        left: 0;
        right: 0;
        
        /* Menggunakan gradien: transparan di atas, lalu menggelap di bawah */
        background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 20%); 
        
        color: #f1f1f1; 
        padding: 20px;       
        box-sizing: border-box;
        
        /* Membatasi tinggi maksimal teks melayang agar tidak menutupi seluruh gambar */
        max-height: 60%;    
        overflow-y: auto;   /* Jika teks lorem ipsum kepanjangan, bisa di-scroll tipis-tipis */
    }

    /* Merapikan teks */
    .card-body h3 {
        margin-top: 0;
        margin-bottom: 8px;
        font-size: 1.3rem;
        color: #fff;
        text-shadow: 1px 1px 3px rgba(0,0,0,0.8); /* Membantu teks makin terbaca jelas */
    }

    .text {
        font-size: 0.85rem;
        line-height: 1.4;
        margin-bottom: 0;
    }
    
    .label-pro{
        display: flex;
        flex-direction: row;      /* DIUBAH: Mengatur elemen berjejer ke samping */
        flex-wrap: wrap;          /* KUNCI: Otomatis menurunkan elemen yang kelebihan ke bawah */
        justify-content: first baseline;  /* Memusatkan elemen (termasuk yang turun ke bawah) tepat di tengah */
        gap: 0.5rem;
        margin-top: 10px;
    }

    .label-pro-1 {
        font-size: smaller;
        font-weight: bold;
        padding: 2px 10px;
        background-color: var(--warna-ungu-muda);
        color: var(--warna-pink-muda2);
        border-radius: 20px;

    }

    .label-button{
        display: flex;          
        justify-content:end ;  
        gap: 0.5rem;
        margin-top: 10px;
    }

    .button-pro{
        font-size: medium;
        width: fit-content;
        height: fit-content;
        border-radius: 20px;
        background-color: var(--warna-pink-tua);
        padding: 5px 10px;
        box-shadow: 0 0px 4px var(--warna-pink-tua);
        transition: background-position 0.10s ease, color 0.10s ease, box-shadow 0.5s ease;
    }

    .button-pro:hover{
        background-color: var(--warna-ungu-tua);
        box-shadow: 0 0px 4px var(--warna-ungu-tua);
    }

    .label-button a {
        color: var(--warna-teks-putih);          /* Ganti dengan warna yang kontras dengan ungu Anda */
        text-decoration: none;   /* Menghilangkan underline */
    }

     .contact{
        display: flex;
        flex-direction: row;
        gap: 1.5rem;
        padding: 0;
        justify-content: center;
        flex-wrap: wrap;
        margin-top: 20px;
    }

    .contact img {
        width: 40px;
        height: 40px;
    }

    footer{
        background-color: var(--warna-ungu-muda);
        box-sizing: border-box;
        min-height: 70px;
        width: 100%; 
        margin: 0;
        
        /* Pengaturan Flexbox untuk posisi tengah */
        display: flex;         
        justify-content: center; /* ⬅️ Mengetengahkan teks secara HORIZONTAL */
        align-items: center;     /* Mengetengahkan teks secara VERTIKAL */
        
        color: #ffffff;        
        padding: 20px 10px;     
        font-size: 16px; 
    }

    .gmail{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 3.5px 10px;
        border-radius: 15px;
        font-family: var(--font-paragraf);
        gap: 1rem;
        font-weight: bolder;
        color: var(--warna-ungu-tua);
        font-size: medium;
    }

    .linkedin{
        display: flex;
        flex-direction: row;
        background-color: var(--warna-pink-muda2);
        width: fit-content;
        height: fit-content;
        padding: 8px 10px;
        border-radius: 15px;
    }



}
/*--------------------------------------------------------Ukuran BESAR XXL
@media (min-width: 1400px) { 
    .container { 
        max-width: var(--container-xxl); 
    } 

    


}*/
