/* Variabel Warna Tema Gelap (Default) */
:root {
    --primary-color: #0d1117;
    --secondary-color: #161b22;
    --border-color: #30363d;
    --text-color: #c9d1d9;
    --text-secondary-color: #8b949e;
    --accent-color: #58a6ff;
    --green-color: #238636;
    --snippet-bg-color: #010409;
    --active-header-bg-color: #1f252d;
    --response-bg-color: #010409;
    --disabled-bg-color: #21262d;
}

/* Variabel Warna Tema Terang */
body[data-theme="light"] {
    --primary-color: #f8f9fa;
    --secondary-color: #ffffff;
    --border-color: #dee2e6;
    --text-color: #212529;
    --text-secondary-color: #6c757d;
    --accent-color: #007bff;
    --snippet-bg-color: #f0f3f6;
    --active-header-bg-color: #e9ecef;
    --response-bg-color: #f0f3f6;
    --disabled-bg-color: #f8f9fa;
}

/* Aturan Umum & Reset */
body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
    background-color: var(--primary-color);
    color: var(--text-color);
    margin: 0;
    line-height: 1.6;
    transition: background-color 0.2s ease, color 0.2s ease;
}

main {
    padding: 1rem;
}

.hidden {
    display: none !important;
}

/* Header */
header {
    background-color: var(--secondary-color);
    border-bottom: 1px solid var(--border-color);
    text-align: center;
    padding: 1.5rem 1rem;
    position: relative;
}
.banner { max-width: 100%; height: auto; max-height: 200px; border-radius: 8px; margin-bottom: 1rem; }
header h1 { color: var(--accent-color); margin: 0.5rem 0; font-size: 1.8rem; }
header p { color: var(--text-secondary-color); max-width: 800px; margin: 0.5rem auto; }

/* Status Badge */
.status-badge { display: inline-block; padding: 0.3rem 0.8rem; border-radius: 20px; font-size: 0.8rem; font-weight: bold; margin-top: 1rem; }
.status-badge.online { background-color: var(--green-color); color: white; }
.status-badge.offline { background-color: #dc3545; color: white; }

/* Input API Key & Search */
/* GANTI SEMUA ATURAN LAMA ANDA DENGAN BLOK INI */

/* 1. Aturan untuk Container Utama */
.input-with-icon {
    display: flex;              /* Mengaktifkan Flexbox */
    align-items: center;        /* Kunci: Membuat semua item di dalamnya sejajar di tengah secara vertikal */
    max-width: 450px;
    margin: 1rem auto 0 auto;
    background-color: var(--primary-color);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 0 15px;            /* Padding horizontal untuk memberi ruang */
    transition: border-color 0.2s ease;
}

/* Tambahkan efek glow saat input di dalam container aktif */
.input-with-icon:focus-within {
    border-color: var(--accent-color);
}

/* 2. Aturan untuk Ikon di Dalamnya */
.input-with-icon .fa-solid {
    color: var(--text-secondary-color);
    margin-right: 10px;         /* Memberi jarak antara ikon dan teks */
}

/* 3. Aturan untuk Input di Dalamnya */
.api-key-input {
    width: 100%;
    flex: 1;                    /* Membuat input mengisi sisa ruang yang tersedia */
    padding: 0.7rem 0;          /* Padding vertikal, padding horizontal tidak perlu lagi */
    background-color: transparent; /* Latar belakang transparan, mengikuti container */
    border: none;               /* Hapus border bawaan */
    color: var(--text-color);
    font-size: 0.9rem;
    outline: none;              /* Hapus outline biru saat di-klik */
}

/* 4. Hapus margin-top dari #search-input karena sudah diatur oleh container */
#search-input {
    margin-top: 0;
}

/* Tombol Pengalih Tema */
#theme-switcher {
    position: absolute;
    top: 20px;
    right: 20px;
    background-color: var(--secondary-color);
    border: 1px solid var(--border-color);
    color: var(--text-color);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 1.2rem;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.2s ease, background-color 0.2s ease;
}
#theme-switcher:hover { transform: scale(1.1); }

/* Kategori & Endpoint */
.category { margin-bottom: 2rem; }
.category-title { font-size: 1.5rem; color: var(--text-color); border-bottom: 2px solid var(--border-color); padding-bottom: 0.5rem; margin-bottom: 1rem; }

/* Accordion Style */
.endpoint-header-collapsible {
    background-color: var(--secondary-color);
    color: var(--text-color);
    cursor: pointer;
    padding: 1rem;
    width: 100%;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    text-align: left;
    outline: none;
    font-size: 1.1rem;
    transition: background-color 0.3s ease, border-radius 0.3s ease;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}
.endpoint-header-collapsible:hover { background-color: var(--active-header-bg-color); }
.endpoint-header-collapsible.active { border-radius: 8px 8px 0 0; background-color: var(--active-header-bg-color); }
.endpoint-header-collapsible:disabled { background-color: var(--disabled-bg-color); opacity: 0.7; cursor: not-allowed; }
.endpoint-header-collapsible:disabled:hover { background-color: var(--disabled-bg-color); }
body[data-theme="light"] .endpoint-header-collapsible { background-color: var(--secondary-color); }

.endpoint-header-collapsible .endpoint-name { font-weight: bold; margin: 0 12px; }
.endpoint-header-collapsible .endpoint-status { margin-left: auto; }

.endpoint-details { padding: 0; background-color: var(--secondary-color); border: 1px solid var(--border-color); border-top: none; border-radius: 0 0 8px 8px; overflow: hidden; max-height: 0; transition: max-height 0.4s ease-out, padding 0.4s ease-out; }
.endpoint-details-content { padding: 1.5rem; }

/* Badge (Method & Status) */
.method-badge { padding: 3px 9px; border-radius: 4px; font-size: 0.9rem; font-weight: bold; color: white; text-shadow: 1px 1px 1px rgba(0,0,0,0.2); }
.method-badge.get { background-color: #0c84e4; }
.method-badge.post { background-color: #10a37f; }
.endpoint-status { padding: 0.2rem 0.6rem; border-radius: 12px; font-size: 0.7rem; text-transform: uppercase; }
.endpoint-status.ready { background-color: var(--green-color); color: white; }
.endpoint-status.update { background-color: #dbab09; color: white; }

/* Konten di dalam Panel Detail */
.endpoint-desc { color: var(--text-secondary-color); margin-top: 0; }
.endpoint-path { background-color: var(--primary-color); padding: 0.8rem; border-radius: 6px; font-family: "SFMono-Regular", Consolas, Menlo, monospace; word-break: break-all; }

/* Snippets & Form */
.snippet-container { margin-top: 1.5rem; border: 1px solid var(--border-color); border-radius: 6px; }
.snippet-tabs { display: flex; background-color: var(--primary-color); border-bottom: 1px solid var(--border-color); border-radius: 6px 6px 0 0; }
.snippet-tab { padding: 0.7rem 1rem; cursor: pointer; background-color: transparent; border: none; color: var(--text-secondary-color); font-weight: bold; font-size: 0.8rem; }
.snippet-tab.active { color: var(--text-color); background-color: var(--secondary-color); border-bottom: 2px solid var(--accent-color); }
.snippet-content { background-color: var(--snippet-bg-color); padding: 1rem; font-family: "SFMono-Regular", Consolas, Menlo, monospace; font-size: 0.85rem; white-space: pre; overflow-x: auto; border-radius: 0 0 6px 6px; }

.api-tester-form, .try-it-out-container { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border-color); }
.param-group { margin-bottom: 1rem; }
.param-group label { display: block; margin-bottom: 0.4rem; color: var(--text-secondary-color); font-weight: bold; font-size: 0.9rem; }
.param-input, .json-body-input { width: 100%; padding: 0.8rem; background-color: var(--primary-color); border: 1px solid var(--border-color); color: var(--text-color); border-radius: 6px; font-size: 1rem; box-sizing: border-box; }
.json-body-input { min-height: 150px; font-family: "SFMono-Regular", Consolas, Menlo, monospace; resize: vertical; }

/* Tombol "Jalankan" & "Salin" */
.try-btn { background-color: var(--accent-color); color: #ffffff; border: none; padding: 0.7rem 1.5rem; border-radius: 6px; font-weight: bold; cursor: pointer; transition: background-color 0.2s ease; margin-top: 1rem; }
.try-btn:hover { filter: brightness(1.1); }
.response-container { position: relative; margin-top: 1.5rem; }
.copy-btn { position: absolute; top: 8px; right: 8px; background-color: #30363d; color: var(--text-secondary-color); border: 1px solid var(--border-color); padding: 4px 10px; border-radius: 6px; cursor: pointer; font-size: 0.8rem; opacity: 0.7; transition: all 0.2s ease; }
.response-container:hover .copy-btn { opacity: 1; }
.copy-btn:hover { background-color: #444c56; }
.copy-btn.copied { background-color: var(--green-color); color: white; }

/* Area Respons & Penyesuaian Prism.js */
.response-area {
    background-color: var(--response-bg-color);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    padding: 1.5rem;
    color: var(--text-color);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
    white-space: pre;
    overflow-x: auto;
    overflow-y: auto;
    max-height: 400px;
    overscroll-behavior-x: contain; /* <<< Tambahkan ini untuk mengunci scroll */
}
.response-area code[class*="language-"] { text-shadow: none; }
pre[class*="language-"] { background: transparent !important; margin: 0; }

/* Footer */
footer { text-align: center; padding: 2rem 1rem; margin-top: 2rem; border-top: 1px solid var(--border-color); color: var(--text-secondary-color); }

/* Animasi */
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.fade-in-up { opacity: 0; animation: fadeInUp 0.5s ease-out forwards; }

/* Media Query untuk Desktop */
@media (min-width: 768px) {
    main { max-width: 1200px; margin: 2rem auto; padding: 0 2rem; }
    header h1 { font-size: 2.5rem; }
    .category-title { font-size: 1.8rem; }
    .endpoint-header-collapsible { padding: 1.2rem 1.5rem; }
    .endpoint-status { font-size: 0.8rem; }
}

/* Style untuk Tombol "Jalankan" saat Loading */
.try-btn.loading {
    color: transparent; /* Sembunyikan teks "Jalankan" */
    cursor: wait;
    position: relative;
}

/* Membuat elemen spinner di tengah tombol */
.try-btn.loading::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    top: 50%;
    left: 50%;
    margin-top: -10px; /* Setengah dari height */
    margin-left: -10px; /* Setengah dari width */
    border: 3px solid rgba(255, 255, 255, 0.4);
    border-top-color: #ffffff;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

/* Aturan untuk warna spinner di tema terang */
body[data-theme="light"] .try-btn.loading::after {
    border-color: rgba(0, 0, 0, 0.2);
    border-top-color: var(--text-color);
}

/* Animasi putaran untuk spinner */
@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Aturan khusus untuk menghapus batasan tinggi saat respons berupa gambar */
.response-area.image-response {
    max-height: none; /* Hapus batasan tinggi */
    padding: 0.5rem;  /* Kurangi padding agar bingkai pas dengan gambar */
    overflow-y: hidden; /* Sembunyikan scroll vertikal yang tidak perlu */
}

/* Style Profesional untuk Pre-loader */
#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    background-color: var(--primary-color);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.75s ease, visibility 0.75s ease;
}

#preloader.hidden {
    opacity: 0;
    visibility: hidden;
}

.loader-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px; /* Jarak antara spinner dan teks */
}

.spinner {
    width: 40px;
    height: 40px;
    border: 4px solid var(--border-color);
    border-top-color: var(--accent-color); /* Warna aksen untuk bagian yang berputar */
    border-radius: 50%;
    animation: loader-spin 1s linear infinite;
}

#loader-text {
    color: var(--text-secondary-color); /* Warna lebih lembut */
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: 1px;
    animation: fade-in-slide-up 0.8s ease-out 0.3s forwards;
    opacity: 0; /* Awalnya transparan untuk animasi */
}

/* Animasi untuk Spinner */
@keyframes loader-spin {
    to {
        transform: rotate(360deg);
    }
}

/* Animasi untuk Teks */
@keyframes fade-in-slide-up {
    from {
        opacity: 0;
        transform: translateY(15px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Style untuk Pemilih Content-Type */
.content-type-selector {
    display: flex;
    gap: 10px;
    margin-top: 1.5rem;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 1rem;
}

.content-type-selector label {
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    font-size: 0.9rem;
}

/* Panel untuk form input */
.form-panel {
    padding-top: 1rem;
}

/*
 * Animasi untuk Code Snippet
 */

/* Atur keadaan awal snippet (sedikit ke bawah dan transparan) */
.snippet-container {
    transition: opacity 0.4s ease-out 0.15s, transform 0.4s ease-out 0.15s;
    opacity: 0;
    transform: translateY(15px);
}

/* Atur keadaan akhir snippet (terlihat) saat menu aktif/terbuka */
.endpoint-header-collapsible.active + .endpoint-details .snippet-container {
    opacity: 1;
    transform: translateY(0);
}

/* Style untuk Changelog di Footer */
#changelog-container {
    max-width: 800px;
    margin: 0 auto 2rem auto;
    padding: 1.5rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    text-align: left;
}

#changelog-container h3 {
    margin-top: 0;
    text-align: center;
    color: var(--text-color);
}

#changelog-list {
    max-height: 200px; /* Batasi tinggi agar tidak terlalu panjang */
    overflow-y: auto; /* Tambahkan scroll jika konten melebihi batas */
    padding-right: 10px; /* Ruang untuk scrollbar */
}

.changelog-item {
    display: flex;
    gap: 15px;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}

.changelog-item:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

.changelog-badge {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: bold;
    color: white;
    flex-shrink: 0; /* Mencegah badge menyusut */
    align-self: flex-start;
}

.changelog-badge.add { background-color: #238636; } /* Hijau */
.changelog-badge.update { background-color: #0969da; } /* Biru */
.changelog-badge.fix { background-color: #B65700; } /* Oranye */
.changelog-badge.remove { background-color: #CF222E; } /* Merah */

.changelog-details p {
    margin: 0;
    color: var(--text-secondary-color);
    font-size: 0.9rem;
}

.changelog-details .date {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-color);
    margin-bottom: 4px;
}

.copyright {
    color: var(--text-secondary-color);
    text-align: center;
    margin-top: 2rem;
}

/* Style untuk Tombol Scroll-to-Top */
#scrollTopBtn {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 100;

    width: 45px;
    height: 45px;
    font-size: 1.2rem;

    background-color: var(--accent-color);
    color: #ffffff;

    border: none;
    border-radius: 50%;
    cursor: pointer;

    display: flex;
    justify-content: center;
    align-items: center;

    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);

    /* State awal (tersembunyi) */
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

/* State saat terlihat */
#scrollTopBtn.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

#scrollTopBtn:hover {
    filter: brightness(1.1);
}

/* Style untuk wadah gambar dan tombol download */
.response-image-wrapper {
    position: relative; /* Diperlukan untuk posisi absolut tombol */
    display: inline-block; /* Agar wrapper pas dengan ukuran gambar */
    margin-top: 1.5rem;
    line-height: 0; /* Menghilangkan spasi ekstra di bawah gambar */
}

.response-image-wrapper img {
    max-width: 100%;
    display: block;
    border-radius: 6px;
    border: 1px solid var(--border-color);
}

.download-btn {
    position: absolute;
    bottom: 12px;
    right: 12px;

    background-color: var(--accent-color);
    color: white;

    padding: 6px 12px;
    border-radius: 6px;
    text-decoration: none;
    font-size: 0.8rem;
    font-weight: bold;

    opacity: 0; /* Sembunyikan secara default */
    transition: opacity 0.3s ease;
}

/* Tampilkan tombol saat mouse hover di atas gambar */
.response-image-wrapper:hover .download-btn {
    opacity: 1;
}

/* Wadah untuk tombol di header */
.header-buttons {
    position: absolute;
    top: 20px;
    right: 20px;
    display: flex;
    gap: 10px;
}

/* --- Tombol Header & Panel Riwayat --- */

/* Wadah untuk tombol di header */
.header-buttons {
    position: absolute;
    top: 20px;
    right: 20px;
    display: flex;
    gap: 10px;
}

/* Aturan umum untuk tombol di header */
#theme-switcher, #history-btn {
    position: static; /* Hapus 'absolute' karena sudah diatur oleh parent */
    background-color: var(--secondary-color);
    border: 1px solid var(--border-color);
    color: var(--text-color);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 1.2rem;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

#theme-switcher:hover, #history-btn:hover {
    transform: scale(1.1);
}

/* Panel Riwayat */
#history-panel {
    position: fixed;
    top: 0;
    width: 320px;
    height: 100%;
    background-color: var(--secondary-color);
    border-left: 1px solid var(--border-color);
    box-shadow: -5px 0 15px rgba(0,0,0,0.2);
    z-index: 2000;
    display: flex;
    flex-direction: column;
    transition: right 0.4s ease-in-out;
}

#history-panel.open {
    right: 0; /* Pindahkan ke dalam layar */
}

.history-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
}
.history-header h3 { margin: 0; }
#close-history-btn { background: none; border: none; font-size: 1.8rem; cursor: pointer; color: var(--text-secondary-color); }

#history-list {
    padding: 1rem;
    overflow-y: auto;
    flex-grow: 1;
}

.history-item {
    padding: 12px;
    border: 1px solid var(--border-color);
    border-radius: 6px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: background-color 0.2s ease;
}
.history-item:hover {
    background-color: var(--active-header-bg-color);
}
.history-item-path {
    font-weight: bold;
    word-break: break-all;
    margin-bottom: 5px;
}
.history-item-meta {
    font-size: 0.8rem;
    color: var(--text-secondary-color);
}

/* Style Scrollbar Kustom untuk Webkit (Chrome, Safari, Opera) */
.response-area::-webkit-scrollbar {
    height: 8px; /* Tinggi scrollbar horizontal */
    width: 8px; /* Lebar scrollbar vertikal */
}

.response-area::-webkit-scrollbar-track {
    background: transparent;
}

.response-area::-webkit-scrollbar-thumb {
    background-color: var(--border-color);
    border-radius: 4px;
    border: 2px solid var(--response-bg-color); /* Memberi sedikit padding */
}

.response-area::-webkit-scrollbar-thumb:hover {
    background-color: var(--text-secondary-color);
}