/* public/assets/style.css */

body {
    font-family: sans-serif;
    padding: 2em;
    line-height: 1.5;
}

.image-container {
    /* Penting! Agar posisi kotak absolut relatif terhadap container ini */
    position: relative; 
    
    /* Agar container pas dengan ukuran gambar */
    display: inline-block; 
    border: 1px solid #ccc;
    margin-top: 1em;
}

.image-container img {
    /* Memastikan gambar tidak "bocor" dari container */
    display: block;
    max-width: 100%;
    height: auto;
}

.face-box {
    /* Paling Krusial! Mengatur posisi kotak berdasarkan koordinat dari PHP */
    position: absolute; 
    
    /* Styling kotak */
    border: 2px solid rgba(255, 0, 0, 0.8);
    background-color: rgba(255, 0, 0, 0.1);
    
    /* Agar border dan padding tidak menambah ukuran lebar/tinggi kotak */
    box-sizing: border-box; 
}

a {
    display: inline-block;
    margin-top: 1.5em;
    padding: 10px 15px;
    background-color: #007bff;
    color: white;
    text-decoration: none;
    border-radius: 5px;
}

a:hover {
    background-color: #0056b3;
}

.upload-container {
    max-width: 600px;
    margin: 2em auto;
    padding: 2em;
    border: 1px solid #ddd;
    border-radius: 8px;
    text-align: center;
}

.custom-file-upload {
    border: 1px solid #ccc;
    display: inline-block;
    padding: 6px 12px;
    cursor: pointer;
    background-color: #f9f9f9;
    border-radius: 5px;
}

input[type="file"] {
    /* Sembunyikan input file asli */
    display: none;
}

.preview-container {
    margin-top: 20px;
    border-top: 1px solid #eee;
    padding-top: 20px;
}

.preview-container img {
    max-width: 100%; /* Pastikan gambar preview tidak terlalu besar */
    max-height: 400px;
    border: 1px solid #ccc;
    border-radius: 5px;
}

button[type="submit"] {
    margin-top: 20px;
    padding: 10px 20px;
    border: none;
    background-color: #007bff;
    color: white;
    border-radius: 5px;
    cursor: pointer;
    font-size: 16px;
}

button[type="submit"]:hover {
    background-color: #0056b3;
}

.loader-overlay {
    position: fixed; /* Tetap di posisi yang sama bahkan saat di-scroll */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.7); /* Latar belakang putih semi-transparan */
    display: flex; /* Menggunakan flexbox untuk memusatkan spinner */
    justify-content: center;
    align-items: center;
    z-index: 9999; /* Pastikan berada di atas semua elemen lain */
}

/* Lingkaran spinner itu sendiri */
.loader-spinner {
    border: 8px solid #f3f3f3; /* Lingkaran abu-abu terang */
    border-top: 8px solid #007bff; /* Warna biru untuk bagian yang berputar */
    border-radius: 50%;
    width: 60px;
    height: 60px;
    animation: spin 1s linear infinite; /* Terapkan animasi berputar */
}

/* Utility class untuk menyembunyikan elemen */
.hidden {
    display: none !important;
}

/* Animasi keyframes untuk putaran */
@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.result-container {
    max-width: 900px;
    margin: 2em auto;
    padding: 2em;
    border: 1px solid #ddd;
    border-radius: 8px;
    text-align: center;
}

#tryAgainButton {
    margin-top: 1.5em;
    padding: 10px 20px;
    border: none;
    background-color: #28a745;
    color: white;
    border-radius: 5px;
    cursor: pointer;
    font-size: 16px;
}

#tryAgainButton:hover {
    background-color: #218838;
}