/* /Components/Layout/EmptyLayout.razor.rz.scp.css */
/* /Components/Layout/MainLayout.razor.rz.scp.css */
.main-layout-shell[b-da9mkt0pph] {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: #f7f8fb; /* outer bg like Jurnal */
}

/* row under navbar: sidebar + content */
.main-layout-body[b-da9mkt0pph] {
    flex: 1 1 auto;
    display: flex;
    min-height: 0;
}

/* content zone to the right of sidebar */
.main-layout-content[b-da9mkt0pph] {
    flex: 1 1 auto;
    background-color: #f7f8fb;
    overflow-y: auto;
}

/* optional helper if you still want the white sheet look per page */
.page-card[b-da9mkt0pph] {
    background-color: #ffffff;
    border-radius: 12px;
    box-shadow: 0 0 0 1px #e3e6ef, 0 10px 30px rgba(15, 23, 42, 0.06);
    padding: 20px 24px;
}

/* you already had this for mobile bottom-nav spacing */
@media (max-width: 768px) {
    .app-main[b-da9mkt0pph] {
        padding-bottom: 72px; /* keep space for bottom sidebar */
        padding-left: 12px;
        padding-right: 12px;
    }
}
/* /Components/Layout/NavbarLayout.razor.rz.scp.css */
/* Top bar container � medium height */
.top-navbar[b-dgd3lcfau7] {
    flex-shrink: 0;
    z-index: 1030;
    padding-top: 0.45rem;
    padding-bottom: 0.45rem;
}

    /* Brand: biar bisa mengecil & wrap / ellipsis */
    .top-navbar .navbar-brand[b-dgd3lcfau7] {
        padding-top: 0;
        padding-bottom: 0;
        font-size: 1.05rem;
        line-height: 1.2;
        flex: 1 1 auto; /* brand boleh mengecil */
        min-width: 0; /* penting supaya text-overflow jalan */
    }

/* Logo */
.top-navbar-logo[b-dgd3lcfau7] {
    height: 26px;
    vertical-align: middle;
}

/* Company name */
.company-name[b-dgd3lcfau7] {
    white-space: nowrap;
}

/* Right side isinya jangan ikut mengecil */
.navbar-actions[b-dgd3lcfau7] {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

/* Avatar */
.navbar-user-avatar[b-dgd3lcfau7] {
    width: 26px;
    height: 26px;
}

/* Nav link padding */
.top-navbar .nav-link[b-dgd3lcfau7] {
    padding-top: 0.15rem;
    padding-bottom: 0.15rem;
}

/* Divider */
.topbar-divider[b-dgd3lcfau7] {
    width: 1px;
    height: 2.2rem;
    background-color: rgba(0, 0, 0, 0.08);
}

/* === Extra rules untuk layar kecil === */
@media (max-width: 575.98px) {
    .top-navbar[b-dgd3lcfau7] {
        padding-top: 0.4rem;
        padding-bottom: 0.4rem;
    }

        .top-navbar .container-fluid[b-dgd3lcfau7] {
            padding-left: 0.5rem;
            padding-right: 0.5rem;
        }

    .top-navbar-logo[b-dgd3lcfau7] {
        height: 22px;
    }

    .company-name[b-dgd3lcfau7] {
        font-size: 0.77rem; /* lebih kecil di mobile */
        max-width: 55vw; /* batasi lebar */
        overflow: hidden;
        text-overflow: ellipsis; /* kalau terlalu panjang, pake ... */
    }

    .navbar-user-avatar[b-dgd3lcfau7] {
        width: 24px;
        height: 24px;
    }

    .top-navbar .nav-link[b-dgd3lcfau7] {
        padding-left: 0.25rem;
        padding-right: 0.25rem;
    }
}
/* /Components/Layout/SidebarLayout.razor.rz.scp.css */
/* Root container */
.app-sidebar[b-tkmjn3q5bw] {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    background-color: #f7f8fb;
    /*border-right: 1px solid #e3e6ef;*/
    transition: width 0.2s ease;
    min-height: 0;
}

/* Expanded vs collapsed width */
.sidebar-expanded[b-tkmjn3q5bw] {
    width: 230px;
}

.sidebar-collapsed[b-tkmjn3q5bw] {
    width: 55px;
}

/* Header / logo */
.sidebar-header[b-tkmjn3q5bw] {
    padding: 12px 12px 8px 12px;
    border-bottom: 1px solid #e3e6ef;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.sidebar-logo-icon[b-tkmjn3q5bw] {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background: #0052ff;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    margin-right: 8px;
    font-size: 0.9rem;
}

.sidebar-logo-text[b-tkmjn3q5bw] {
    line-height: 1.1;
}

.sidebar-logo-main[b-tkmjn3q5bw] {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #7f8ab2;
}

.sidebar-logo-sub[b-tkmjn3q5bw] {
    font-size: 0.95rem;
    font-weight: 600;
    color: #111827;
}

/* Scrollable area */
.sidebar-scroll[b-tkmjn3q5bw] {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 8px 8px 12px 8px;
}

/* Sections / dividers */
.sidebar-section[b-tkmjn3q5bw] {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sidebar-divider[b-tkmjn3q5bw] {
    border-top: 1px solid #e3e6ef;
    margin: 8px 0;
}

/* Links */
.sidebar-link[b-tkmjn3q5bw] {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 10px;
    border-radius: 8px;
    font-size: 0.9rem;
    color: #4b5563 !important;
    text-decoration: none;
    transition: background-color 0.15s ease, color 0.15s ease;
    cursor: pointer; /* Make sure the pointer cursor is active */
}

    .sidebar-link:hover[b-tkmjn3q5bw] {
        background-color: #e0e7ff !important;
        color: #1d4ed8 !important;
    }

.sidebar-link-active[b-tkmjn3q5bw] {
    background-color: #2563eb !important;
    color: #ffffff !important;
}

.sidebar-link-active .sidebar-icon[b-tkmjn3q5bw] {
    color: #ffffff;
}

/* Icon + text */
.sidebar-icon[b-tkmjn3q5bw] {
    font-size: 1.1rem;
    width: 20px;
    text-align: center;
    color: #9ca3af;
}

.sidebar-text[b-tkmjn3q5bw] {
    white-space: nowrap;
}

/* Collapsed behaviour � only show icons */
.sidebar-collapsed .sidebar-text[b-tkmjn3q5bw],
.sidebar-collapsed .sidebar-logo-text[b-tkmjn3q5bw] {
    display: none;
}

.sidebar-collapsed .sidebar-scroll[b-tkmjn3q5bw] {
    padding-left: 6px;
    padding-right: 6px;
}

.sidebar-collapsed .sidebar-link[b-tkmjn3q5bw] {
    justify-content: center;
    padding-left: 0;
    padding-right: 0;
}

.sidebar-toggle-btn[b-tkmjn3q5bw] {
    border: none;
    background: transparent;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #9ca3af;
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease;
}

    .sidebar-toggle-btn:hover[b-tkmjn3q5bw] {
        background-color: rgba(148, 163, 184, 0.2);
        color: #4b5563;
    }

/* keep button visible when collapsed */
.sidebar-collapsed .sidebar-toggle-btn[b-tkmjn3q5bw] {
    margin-left: 4px;
}


/* Fine-tune header when collapsed so arrow isn't cut */
.sidebar-collapsed .sidebar-header[b-tkmjn3q5bw] {
    padding-left: 6px;
    padding-right: 6px;
}

.sidebar-collapsed .sidebar-logo-icon[b-tkmjn3q5bw] {
    width: 28px;
    height: 28px;
    margin-right: 0; /* no text next to it anyway */
}

.sidebar-collapsed .sidebar-toggle-btn[b-tkmjn3q5bw] {
    width: 24px;
    height: 24px;
    margin-left: 0;   /* pull it in a bit */
}


/* Responsive: small screens -> sidebar jadi bottom nav */
@media (max-width: 768px) {

    /* Sidebar jadi baris bawah, full width */
    .app-sidebar[b-tkmjn3q5bw] {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100% !important;
        height: 80px;
        flex-direction: row;
        border-right: none;
        border-top: 1px solid #e3e6ef;
        z-index: 1040;
    }

    /* Header (logo + toggle) disembunyiin di mobile */
    .sidebar-header[b-tkmjn3q5bw] {
        display: none;
    }

    /* Isi sidebar jadi baris scroll horizontal */
    .sidebar-scroll[b-tkmjn3q5bw] {
        flex: 1 1 auto;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px;
        display: flex;
    }

    .sidebar-section[b-tkmjn3q5bw] {
        flex-direction: row;
    }

    .sidebar-divider[b-tkmjn3q5bw] {
        display: none;
    }

    /* Item jadi icon + text kecil vertikal */
    .sidebar-link[b-tkmjn3q5bw] {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        padding: 4px 10px;
        min-width: 64px;
    }

    .sidebar-icon[b-tkmjn3q5bw] {
        margin-bottom: 2px;
    }

    .sidebar-text[b-tkmjn3q5bw] {
        font-size: 0.7rem;
    }

    /* ?? OVERRIDE: walaupun .sidebar-collapsed, label tetap tampil di mobile */
    .app-sidebar.sidebar-collapsed .sidebar-text[b-tkmjn3q5bw],
    .app-sidebar.sidebar-collapsed .sidebar-logo-text[b-tkmjn3q5bw] {
        display: inline-block !important;
    }
}


@media (max-width: 768px) {
    .app-main[b-tkmjn3q5bw] {
        padding-bottom: 72px; /* sedikit lebih besar dari tinggi sidebar */
    }
}
