/* Custom CSS for E-File Application */

/* General Styles */
body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: #f8f9fa;
    font-size: 0.95rem; /* lebih proporsional untuk teks umum */
}

/* Skala font global agar responsif */
html { font-size: 16px; }
@media (max-width: 1200px) { html { font-size: 15px; } }
@media (max-width: 992px) { html { font-size: 14px; } }
@media (max-width: 768px) { html { font-size: 13.5px; } }

/* Heading lebih proporsional dan responsif */
h1 { font-size: clamp(1.5rem, 2vw + 1rem, 2.25rem); }
h2 { font-size: clamp(1.25rem, 1.5vw + 0.9rem, 1.75rem); }
h3 { font-size: clamp(1.1rem, 1.2vw + 0.8rem, 1.5rem); }
h4, h5, h6 { font-size: 1rem; }

/* Konsistensi header halaman: ukuran ikon dan teks 20px */
h2.mb-0 { font-size: 20px; line-height: 1.4; }
h2.mb-0 i { font-size: 20px; margin-right: 8px; vertical-align: middle; }

.card-title { font-size: 1rem; }
.sidebar .sidebar-link { font-size: 0.95rem; }
.table { font-size: 0.95rem; }

/* Sidebar */
body.has-sidebar {
    padding-left: 240px;
}
body.sidebar-collapsed {
    padding-left: 60px;
}

.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 240px;
    overflow-y: auto;
}
.sidebar.collapsed {
    width: 60px;
}
.sidebar .sidebar-link {
    color: #fff;
    padding: 10px 12px;
    border-radius: 6px;
    display: block;
}
.sidebar .sidebar-link:hover {
    background-color: rgba(255,255,255,0.1);
    text-decoration: none;
}
.sidebar .sidebar-link i {
    width: 22px;
    text-align: center;
}
.sidebar.collapsed .sidebar-link span {
    display: none;
}

/* Card Styles */
.card {
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    margin-bottom: 20px;
}

.card-header {
    background-color: #f8f9fa;
    border-bottom: 1px solid #eee;
    font-weight: 600;
}

/* Dashboard Stats */
.stat-card {
    border-left: 4px solid #007bff;
    transition: transform 0.3s;
}

.stat-card:hover {
    transform: translateY(-5px);
}

.stat-card .icon {
    font-size: 2rem;
    color: #007bff;
}

/* Document List */
.document-item {
    transition: background-color 0.2s;
}

.document-item:hover {
    background-color: #f1f8ff;
}

.document-actions {
    visibility: hidden;
}

.document-item:hover .document-actions {
    visibility: visible;
}

/* File Upload */
.custom-file-upload {
    border: 2px dashed #ddd;
    border-radius: 8px;
    padding: 20px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s;
}

.custom-file-upload:hover {
    border-color: #007bff;
    background-color: #f1f8ff;
}

/* Login Form */
.login-form {
    max-width: 400px;
    margin: 50px auto;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    background-color: #fff;
}

/* Login branding */
.login-brand { max-height: 84px; max-width: 140px; width: auto; height: auto; object-fit: contain; }
.login-title { font-size: 1.35rem; }

/* Status Badges */
.badge-draft {
    background-color: #6c757d;
}

.badge-menunggu_verifikasi {
    background-color: #ffc107;
}

.badge-diverifikasi {
    background-color: #28a745;
}

.badge-ditolak {
    background-color: #dc3545;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .stat-card {
        margin-bottom: 15px;
    }
    
    .login-form {
        margin: 20px auto;
    }

    /* Kurangi padding sidebar pada layar kecil */
    body.has-sidebar { padding-left: 0; }
    .sidebar { width: 220px; }
}

/* ====== Layout Sidebar Kiri & Kanan (baru) ====== */
.sidebar-left, .sidebar-right {
    position: sticky;
    top: 1rem;
}
.sidebar-left .list-group-item {
    border: 0;
}
/* Hilangkan bingkai kartu di sidebar kiri */
.sidebar-left {
    box-shadow: none !important;
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
}
.sidebar-left .list-group { border-radius: 0 !important; }
/* Sembunyikan ikon di menu sidebar kiri */
.sidebar-left .list-group-item i { display: none !important; }
/* Collapse sidebar kiri ke tampilan ikon saja */
#sidebar.collapsed { flex: 0 0 60px; max-width: 60px; }
#sidebar.collapsed .list-group-item { text-align: center; padding-left: 0.75rem; padding-right: 0.75rem; }
#sidebar.collapsed .list-group-item i { margin-right: 0 !important; }
#sidebar.collapsed .list-group-item span { display: none; }
/* (revert) hapus aturan collapse sidebar agar tampilan kembali default */
@media (max-width: 991.98px) {
    .sidebar-right { display: none; }
}

/* ====== Navbar Enhancements ====== */
.navbar .nav-link {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 600;
}
.navbar .nav-link i {
    font-size: 1rem;
}
.navbar .nav-link:hover {
    text-decoration: none;
    opacity: 0.9;
}

/* Konsistensi ukuran tombol aksi di daftar dokumen */
.btn-action {
    min-width: 90px; /* samakan lebar minimum untuk Lihat & Hapus */
}