/*
   Fail CSS ini untuk buat website cantik
   Macam makeup untuk website
*/
/* Set warna-warna yang nak guna */
:root {
    /* Warna ungu untuk button utama */
    --primary-purple: #6366f1;
    --deep-purple: #4f46e5;
    --light-purple: #8b5cf6;
    /* Warna hijau untuk button kedua */
    --accent-teal: #14b8a6;
    --light-teal: #5eead4;
    --dark-teal: #0f766e;
    /* Warna neutral */
    --charcoal: #1f2937;    /* Hitam lembut */
    --slate: #475569;       /* Kelabu */
    --silver: #f1f5f9;      /* Kelabu terang */
    --pearl: #f8fafc;       /* Putih kelabu */
    --snow: #ffffff;        /* Putih bersih */
    /* Gradient (warna campuran) */
    --gradient-primary: linear-gradient(135deg, var(--primary-purple) 0%, var(--deep-purple) 50%, var(--light-purple) 100%);
    --gradient-accent: linear-gradient(135deg, var(--accent-teal) 0%, var(--dark-teal) 100%);
    --gradient-bg: linear-gradient(135deg, var(--pearl) 0%, var(--silver) 50%, #e2e8f0 100%);
    /* Shadow (bayang-bayang) untuk buat 3D effect */
    --shadow-soft: 0 4px 6px -1px rgba(79, 70, 229, 0.1), 0 2px 4px -1px rgba(79, 70, 229, 0.06);
    --shadow-medium: 0 10px 15px -3px rgba(79, 70, 229, 0.1), 0 4px 6px -2px rgba(79, 70, 229, 0.05);
    --shadow-large: 0 20px 25px -5px rgba(79, 70, 229, 0.1), 0 10px 10px -5px rgba(79, 70, 229, 0.04);
}
/* Reset semua element supaya konsisten */
* {
    box-sizing: border-box; /* Supaya padding tak tambah saiz */
}
/* Style untuk body (keseluruhan halaman) */
body {
    background: var(--gradient-bg);                    /* Background gradient */
    font-family: 'Inter', sans-serif;                 /* Font yang cantik */
    min-height: 100vh;                                 /* Tinggi minimum full screen */
    padding: 0;                                        /* Tak ada padding */
    margin: 0;                                         /* Tak ada margin */
    font-size: 14px;                                   /* Saiz font standard */
    line-height: 1.6;                                  /* Jarak antara baris */
    color: var(--charcoal);                           /* Warna text */
    font-weight: 400;                                  /* Ketebalan font normal */
}
/* Container utama */
.main-container {
    min-height: 100vh;          /* Tinggi minimum full screen */
    padding: 15px;              /* Ruang dalam */
    display: flex;              /* Guna flexbox */
    flex-direction: column;     /* Susun dari atas ke bawah */
    justify-content: center;    /* Tengah-tengah secara menegak */
}
/* Wrapper untuk form */
.form-wrapper {
    max-width: 420px;          /* Lebar maksimum */
    width: 100%;               /* Lebar penuh dalam had maksimum */
    margin: 0 auto;            /* Tengah-tengah secara mendatar */
}
/* Card untuk form */
.form-card {
    background: var(--snow);                          /* Background putih */
    border-radius: 20px;                              /* Sudut bulat */
    box-shadow: var(--shadow-large);                  /* Bayang-bayang besar */
    border: 1px solid rgba(99, 102, 241, 0.08);      /* Border nipis ungu */
    overflow: hidden;                                  /* Sembunyikan yang overflow */
    margin-bottom: 1.5rem;                           /* Ruang bawah */
    width: 100%;                                      /* Lebar penuh */
    backdrop-filter: blur(10px);                      /* Effect blur background */
}
/* Header card (bahagian atas) */
.card-header {
    background: var(--gradient-primary);              /* Background gradient ungu */
    color: var(--snow);                               /* Text putih */
    text-align: center;                               /* Text tengah */
    padding: 2rem 1.5rem;                            /* Ruang dalam */
    border: none;                                     /* Tak ada border */
    position: relative;                               /* Untuk animation */
    overflow: hidden;                                 /* Sembunyikan overflow */
}
/* Animation shimmer untuk header */
.card-header::before {
    content: '';                                      /* Tak ada content */
    position: absolute;                               /* Position absolute */
    top: -50%;                                        /* Atas -50% */
    left: -50%;                                       /* Kiri -50% */
    width: 200%;                                      /* Lebar 200% */
    height: 200%;                                     /* Tinggi 200% */
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
    animation: shimmer 3s ease-in-out infinite;       /* Animation berulang */
}
/* Keyframe untuk animation shimmer */
@keyframes shimmer {
    0%, 100% { transform: rotate(0deg); }            /* Mula dan akhir: 0 darjah */
    50% { transform: rotate(180deg); }               /* Tengah: 180 darjah */
}
/* Container untuk logo */
.logo-container {
    margin-bottom: 1rem;          /* Ruang bawah */
    position: relative;           /* Position relative */
    z-index: 1;                   /* Layer atas */
}
/* Style untuk logo */
.logo-icon {
    font-size: 2.8rem;                               /* Saiz besar */
    margin-bottom: 0.5rem;                           /* Ruang bawah */
    opacity: 0.95;                                   /* Sedikit transparent */
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);     /* Bayang text */
    filter: drop-shadow(0 2px 4px rgba(255, 255, 255, 0.2)); /* Drop shadow */
}
/* Style untuk heading dalam header */
.card-header h3 {
    font-size: 1.5rem;            /* Saiz font */
    margin-bottom: 0;             /* Tak ada margin bawah */
    font-weight: 600;             /* Font tebal */
    letter-spacing: -0.025em;     /* Jarak huruf rapat sikit */
    position: relative;           /* Position relative */
    z-index: 1;                   /* Layer atas */
}
/* Style untuk paragraph dalam header */
.card-header p {
    font-size: 0.9rem;            /* Saiz font kecil */
    margin: 0.5rem 0 0 0;         /* Margin atas sahaja */
    opacity: 0.9;                 /* Sedikit transparent */
    font-weight: 300;             /* Font nipis */
    position: relative;           /* Position relative */
    z-index: 1;                   /* Layer atas */
}
/* Body card (bahagian tengah) */
.card-body {
    padding: 2rem 1.5rem;         /* Ruang dalam */
    background: var(--snow);      /* Background putih */
}
/* Style untuk label form */
.form-label {
    font-weight: 500;             /* Font sederhana tebal */
    margin-bottom: 0.5rem;        /* Ruang bawah */
    font-size: 0.875rem;          /* Saiz font kecil */
    color: var(--charcoal);       /* Warna gelap */
    letter-spacing: 0.025em;      /* Jarak huruf */
}
/* Style untuk input field */
.form-control {
    border: 2px solid #e2e8f0;                       /* Border kelabu */
    border-radius: 12px;                              /* Sudut bulat */
    padding: 12px 16px;                               /* Ruang dalam */
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); /* Smooth transition */
    font-size: 14px;                                  /* Saiz font */
    width: 100%;                                      /* Lebar penuh */
    background-color: var(--pearl);                   /* Background terang */
    font-weight: 400;                                 /* Font normal */
    outline: none !important;                         /* Tak ada outline */
    box-shadow: none !important;                      /* Tak ada shadow default */
}
/* Style untuk input ketika focus (diklik) */
.form-control:focus {
    border-color: var(--primary-purple);             /* Border ungu */
    outline: none !important;                        /* Tak ada outline */
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1) !important; /* Shadow ungu */
    background-color: var(--snow);                   /* Background putih */
    transform: translateY(-1px);                     /* Naik sikit */
}
/* Style untuk input ketika hover (mouse atas) */
.form-control:hover {
    border-color: var(--light-purple);               /* Border ungu terang */
    background-color: var(--snow);                   /* Background putih */
    outline: none !important;                        /* Tak ada outline */
}
/* Style untuk placeholder text */
.form-control::placeholder {
    color: var(--slate);          /* Warna kelabu */
    opacity: 0.6;                 /* Transparent sikit */
    font-weight: 300;             /* Font nipis */
}
/* Button utama */
.btn-primary {
    background: var(--gradient-primary);             /* Background gradient */
    border: none;                                    /* Tak ada border */
    border-radius: 12px;                             /* Sudut bulat */
    padding: 14px 20px;                              /* Ruang dalam */
    font-weight: 600;                                /* Font tebal */
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); /* Smooth transition */
    width: 100%;                                     /* Lebar penuh */
    font-size: 0.95rem;                              /* Saiz font */
    min-height: 48px;                                /* Tinggi minimum */
    box-shadow: var(--shadow-soft);                  /* Bayang lembut */
    letter-spacing: 0.025em;                         /* Jarak huruf */
    position: relative;                              /* Position relative */
    overflow: hidden;                                /* Sembunyikan overflow */
}
/* Animation untuk button */
.btn-primary::before {
    content: '';                  /* Tak ada content */
    position: absolute;           /* Position absolute */
    top: 0;                       /* Atas 0 */
    left: -100%;                  /* Kiri -100% (tersembunyi) */
    width: 100%;                  /* Lebar penuh */
    height: 100%;                 /* Tinggi penuh */
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;        /* Transition untuk left */
}
/* Animation ketika hover button */
.btn-primary:hover::before {
    left: 100%;                   /* Gerak ke kanan */
}
/* Style button ketika hover */
.btn-primary:hover,
.btn-primary:active {
    transform: translateY(-2px);                     /* Naik sikit */
    box-shadow: var(--shadow-medium);                /* Bayang sederhana */
    background: linear-gradient(135deg, var(--deep-purple) 0%, var(--primary-purple) 50%, var(--light-purple) 100%);
}
/* Button kedua (outline) */
.btn-outline-secondary {
    border: 2px solid var(--accent-teal);            /* Border hijau */
    color: var(--accent-teal);                       /* Text hijau */
    background: var(--snow);                         /* Background putih */
    border-radius: 12px;                             /* Sudut bulat */
    padding: 12px 20px;                              /* Ruang dalam */
    font-weight: 500;                                /* Font sederhana tebal */
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); /* Smooth transition */
    width: 100%;                                     /* Lebar penuh */
    max-width: 280px;                                /* Lebar maksimum */
    margin: 0 auto;                                  /* Tengah */
    display: block;                                  /* Display block */
    min-height: 44px;                                /* Tinggi minimum */
    font-size: 0.875rem;                             /* Saiz font */
    box-shadow: var(--shadow-soft);                  /* Bayang lembut */
    letter-spacing: 0.025em;                         /* Jarak huruf */
}
/* Style button outline ketika hover */
.btn-outline-secondary:hover,
.btn-outline-secondary:active {
    background: var(--gradient-accent);              /* Background gradient hijau */
    border-color: var(--dark-teal);                  /* Border hijau gelap */
    color: var(--snow);                              /* Text putih */
    transform: translateY(-2px);                     /* Naik sikit */
    box-shadow: var(--shadow-medium);                /* Bayang sederhana */
}
/* Container untuk table */
.table-container {
    background: var(--snow);                         /* Background putih */
    border-radius: 16px;                             /* Sudut bulat */
    box-shadow: var(--shadow-medium);                /* Bayang sederhana */
    overflow: hidden;                                /* Sembunyikan overflow */
    margin-top: 2rem;                                /* Ruang atas */
    border: 1px solid rgba(20, 184, 166, 0.1);      /* Border hijau nipis */
}
/* Style untuk table */
.table {
    margin-bottom: 0;             /* Tak ada margin bawah */
    font-size: 0.825rem;          /* Saiz font kecil */
    font-weight: 400;             /* Font normal */
}
/* Header table */
.table thead {
    background: var(--gradient-accent);              /* Background gradient hijau */
    color: var(--snow);                              /* Text putih */
}
/* Cell header table */
.table thead th {
    border: none;                 /* Tak ada border */
    padding: 16px 12px;           /* Ruang dalam */
    font-weight: 600;             /* Font tebal */
    font-size: 0.8rem;            /* Saiz font kecil */
    letter-spacing: 0.05em;       /* Jarak huruf */
    text-transform: uppercase;    /* Huruf besar semua */
}
/* Cell body table */
.table tbody td {
    padding: 14px 12px;           /* Ruang dalam */
    border-color: #f1f5f9;        /* Warna border */
    word-wrap: break-word;        /* Potong perkataan panjang */
    max-width: 140px;             /* Lebar maksimum */
    font-size: 0.8rem;            /* Saiz font kecil */
    color: var(--charcoal);       /* Warna text */
}
/* Row table */
.table tbody tr {
    transition: all 0.2s ease;    /* Smooth transition */
}
/* Row table ketika hover */
.table tbody tr:hover {
    background: linear-gradient(90deg, var(--pearl) 0%, var(--silver) 100%); /* Background gradient */
    transform: scale(1.01);       /* Besar sikit */
}
/* Text bantuan */
.form-text {
    color: var(--slate);          /* Warna kelabu */
    font-size: 0.75rem;           /* Saiz font kecil */
    margin-top: 0.5rem;           /* Ruang atas */
    line-height: 1.4;             /* Jarak baris */
    font-weight: 300;             /* Font nipis */
}
/* Margin bottom classes */
.mb-3 { margin-bottom: 1.25rem !important; }
.mb-4 { margin-bottom: 1.5rem !important; }
/* Style untuk SweetAlert popup */
.swal2-popup {
    border-radius: 16px !important;                  /* Sudut bulat */
    font-family: 'Inter', sans-serif !important;     /* Font sama */
    box-shadow: var(--shadow-large) !important;      /* Bayang besar */
}
.swal2-title {
    font-size: 1.4rem !important;                    /* Saiz font title */
    font-weight: 600 !important;                     /* Font tebal */
    color: var(--charcoal) !important;               /* Warna gelap */
}
.swal2-content {
    font-size: 0.95rem !important;                   /* Saiz font content */
    color: var(--slate) !important;                  /* Warna kelabu */
}
.swal2-confirm {
    background: var(--gradient-primary) !important;  /* Background gradient */
    border: none !important;                         /* Tak ada border */
    border-radius: 10px !important;                  /* Sudut bulat */
    font-weight: 600 !important;                     /* Font tebal */
    padding: 12px 24px !important;                   /* Ruang dalam */
}
.swal2-cancel {
    background: var(--gradient-accent) !important;   /* Background gradient hijau */
    border: none !important;                         /* Tak ada border */
    border-radius: 10px !important;                  /* Sudut bulat */
    font-weight: 500 !important;                     /* Font sederhana tebal */
}
/* Responsive design untuk tablet */
@media (min-width: 768px) {
    .form-wrapper { max-width: 480px; }              /* Lebar maksimum lebih besar */
    .card-header { padding: 2.5rem 2rem; }           /* Ruang dalam lebih besar */
    .card-body { padding: 3rem 2.5rem; }             /* Ruang dalam lebih besar */
    .logo-icon { font-size: 3.5rem; }                /* Logo lebih besar */
    .card-header h3 { font-size: 1.875rem; }         /* Heading lebih besar */
    .table { font-size: 0.875rem; }                  /* Font table lebih besar */
}
/* Responsive design untuk desktop */
@media (min-width: 992px) {
    .form-wrapper { max-width: 520px; }              /* Lebar maksimum paling besar */
    .logo-icon { font-size: 4rem; }                  /* Logo paling besar */
    .card-header h3 { font-size: 2rem; }             /* Heading paling besar */
}
/* Style untuk notification expand */
.expand-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    background: var(--gradient-primary);
    color: var(--snow);
    padding: 12px 20px;
    border-radius: 12px;
    box-shadow: var(--shadow-medium);
    font-size: 0.875rem;
    font-weight: 500;
    z-index: 9999;
    transform: translateX(100%);
    opacity: 0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    max-width: 300px;
}
.expand-notification.show {
    transform: translateX(0);
    opacity: 1;
}
/* Responsive untuk mobile */
@media (max-width: 768px) {
    .expand-notification {
        top: 10px;
        right: 10px;
        left: 10px;
        max-width: none;
        font-size: 0.8rem;
        padding: 10px 16px;
    }
}
