:root {
    --sidebar-width: 280px;
    --sidebar-collapsed-width: 84px;
    --topbar-height: 64px;
}

body {
    min-height: 100vh;
    background: var(--bs-body-bg);
}

.topbar {
    height: var(--topbar-height);
    position: sticky;
    top: 0;
    z-index: 1030;
    backdrop-filter: blur(8px);
    background: rgba(var(--bs-body-bg-rgb), .9);
    border-bottom: 1px solid var(--bs-border-color);
}

.app {
    display: grid;
    grid-template-columns: var(--sidebar-width) 1fr;
    min-height: calc(100vh - var(--topbar-height));
}

.sidebar {
    border-right: 1px solid var(--bs-border-color);
    background: rgba(var(--bs-body-bg-rgb), .96);
    position: sticky;
    top: var(--topbar-height);
    height: calc(100vh - var(--topbar-height));
    overflow-y: auto;
}

.sidebar .brand {
    position: sticky;
    top: 0;
    z-index: 1;
    background: rgba(var(--bs-body-bg-rgb), .96);
    border-bottom: 1px solid var(--bs-border-color);
}

.sidebar .nav-link {
    display: flex;
    align-items: center;
    gap: .75rem;
    border-radius: .75rem;
    padding: .6rem .75rem;
    color: var(--bs-body-color);
}

.sidebar .nav-link:hover {
    background: rgba(var(--bs-secondary-rgb), .10);
}

.sidebar .nav-link.active {
    background: rgba(var(--bs-primary-rgb), .12);
    color: var(--bs-primary);
    font-weight: 600;
}

.content {
    padding: 1.25rem;
}

.kpi-card {
    border-radius: 1rem;
}

.soft {
    background: rgba(var(--bs-secondary-rgb), .08);
    border: 1px solid rgba(var(--bs-secondary-rgb), .20);
    border-radius: 1rem;
}

.chart-box {
    border-radius: 1rem;
    min-height: 320px;
    display: grid;
    place-items: center;
    color: var(--bs-secondary-color);
    border: 1px dashed rgba(var(--bs-secondary-rgb), .35);
    background: rgba(var(--bs-secondary-rgb), .04);
}

.table thead th {
    font-size: .85rem;
    color: var(--bs-secondary-color);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
}

@media (max-width: 991.98px) {
    .app {
        grid-template-columns: 1fr;
    }

    .sidebar {
        display: none;
    }
}

body.sidebar-collapsed .app {
    grid-template-columns: var(--sidebar-collapsed-width) 1fr;
}

body.sidebar-collapsed .sidebar .label {
    display: none;
}

body.sidebar-collapsed .sidebar .nav-link {
    justify-content: center;
}

body.sidebar-collapsed .sidebar .brand .brand-text {
    display: none;
}

body.sidebar-collapsed .sidebar .brand {
    padding-left: .75rem !important;
    padding-right: .75rem !important;
}

.brand-badge {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    border-radius: 1rem;
    background: rgb(255, 239, 239);
    border: 1px solid rgba(var(--bs-primary-rgb), .22);
    overflow: hidden;
    /* penting untuk rounding image */
}

.brand-badge img {
    width: 70%;
    height: 70%;
    object-fit: contain;
    /* PNG tidak terpotong */
}

.cursor-pointer {
    cursor: pointer;
}