/* ============================================================
   Chrome Enhancements — Sidebar & Header (Minia theme)
   Dimuat setelah app.min.css agar bisa override.
   ============================================================ */

:root {
    --chrome-primary: #023aef;
    --chrome-primary-rgb: 81, 86, 190;
    --chrome-primary-dark: #002ab3;
    --chrome-accent: #0239efc7;
    --chrome-header-h: 70px;
    --chrome-footer-h: 48px;   /* padding 14px atas+bawah + 1 baris teks ~13px */
}

/* ============================================================
   HEADER / TOPBAR
   ============================================================ */
#page-topbar {
    height: var(--chrome-header-h);
    z-index: 1002;
    box-shadow: 0 2px 18px rgba(0, 0, 0, 0.08);
    backdrop-filter: saturate(180%) blur(8px);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
    transition: box-shadow .3s ease, background-color .3s ease;
}

.navbar-header {
    height: var(--chrome-header-h);
    box-shadow: none;
    transition: background-color .3s ease;
}

/* Mode terang */
body:not([data-layout-mode="dark"]) #page-topbar,
body:not([data-layout-mode="dark"]) .navbar-header {
    background: rgba(255, 255, 255, 0.85) !important;
    border-bottom: 1px solid rgba(81, 86, 190, 0.08);
}

/* Mode gelap */
body[data-layout-mode="dark"] #page-topbar,
body[data-layout-mode="dark"] .navbar-header {
    background: rgba(49, 53, 51, 0.85) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

/* Brand / Logo box */
.navbar-brand-box {
    padding: 0 1.5rem;
    width: 250px;
    border-right: 1px solid #e9e9ef;
    -webkit-box-shadow: 0 2px 2px #fbfaff;
    box-shadow: 0 2px 2px #fbfaff;
    background: linear-gradient(135deg, var(--chrome-primary), var(--chrome-primary-dark)) !important;
}

@media screen and (max-width: 992px) {
    .navbar-brand-box {
        width: unset;
        box-shadow: unset;
        border-right: unset;
        top: -3px;
        position: relative;
    }
    #vertical-menu-btn i {
        color: #002ab3 !important;
    }
    .vertical-menu {
        top: 60px;
    }
}

.navbar-brand-box::after {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 30px;
    background: linear-gradient(to bottom, transparent, rgba(var(--chrome-primary-rgb), .35), transparent);
}

.logo .logo-txt {
    font-weight: 700;
    letter-spacing: .3px;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
}

.navbar-brand-box::after {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 30px;
    background: linear-gradient(to bottom, transparent, rgba(var(--chrome-primary-rgb), .35), transparent);
}

/* Tombol-tombol header */
.header-item {
    border-radius: 10px !important;
    transition: all .25s ease;
    position: relative;
}

.header-item:hover,
.header-item:focus {
    transform: translateY(-1px);
    color: var(--chrome-primary) !important;
}

.header-item i {
    transition: transform .25s ease;
}

.header-item:hover i {
    transform: scale(1.12);
}

/* Hamburger toggle */
#vertical-menu-btn {
    border-radius: 10px !important;
}

#vertical-menu-btn i {
    transition: transform .25s ease;
}

#vertical-menu-btn:hover i {
    transform: scale(1.1);
}

/* Saat sidebar collapse, header tidak ada lagi brand-box ungu di sebelahnya
   → ikon hamburger (inline color:#fff) tak terlihat di background putih.
   Override: pakai warna primary di light mode, tetap putih di dark mode. */
body[data-sidebar-size="sm"]:not([data-layout-mode="dark"]) #vertical-menu-btn i {
    color: var(--chrome-primary) !important;
}

/* User avatar button — bulat, hanya gambar */
#page-header-user-dropdown {
    border-radius: 50% !important;
    padding: 3px !important;
    line-height: 1 !important;
    border: 1px solid transparent !important;
    background: transparent !important;
    transition: all .25s ease;
}
#page-header-user-dropdown:hover {
    box-shadow: 0 4px 14px rgba(var(--chrome-primary-rgb), 0.25);
}

.header-profile-user {
    width: 34px;
    height: 34px;
    border: 2px solid rgba(var(--chrome-primary-rgb), .35);
    transition: border-color .25s ease;
}

#page-header-user-dropdown:hover .header-profile-user {
    border-color: var(--chrome-primary);
}

/* Dropdown menu user — styling kosmetik saja,
   posisi & background biarkan native Bootstrap/Minia yang handle. */
.dropdown-menu-end {
    border: 0 !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.14) !important;
    padding: .4rem !important;
    min-width: 220px !important;
}
/* Animasi HANYA opacity — jangan pakai transform,
   karena Bootstrap 5 memakai transform untuk posisi dropdown-menu-end.
   Kalau kita timpa transform, alignment kanan rusak. */
@keyframes chromeDropdown {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* Header info user — avatar + nama, dengan background tint primary */
.dropdown-user-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: .75rem .9rem;
    margin: 0 0 .35rem;
    border-radius: 10px;
}

body:not([data-layout-mode="dark"]) .dropdown-user-header {
    background: linear-gradient(135deg, rgba(var(--chrome-primary-rgb), 0.12), rgba(var(--chrome-primary-rgb), 0.05));
}

body[data-layout-mode="dark"] .dropdown-user-header {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03));
}

.dropdown-user-header .header-profile-user {
    width: 44px;
    height: 44px;
    border: 2px solid rgba(var(--chrome-primary-rgb), .30);
    flex-shrink: 0;
}

.dropdown-user-name {
    font-weight: 600;
    font-size: 14px;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 150px;
    padding-left: 6px;
}

body:not([data-layout-mode="dark"]) .dropdown-user-name { color: #3b403d; }
body[data-layout-mode="dark"] .dropdown-user-name { color: #f8f9fa; }

/* Wrapper info: nama + role + username ditumpuk vertikal */
.dropdown-user-info {
    min-width: 0;                 /* agar ellipsis pada anak bisa bekerja dalam flex */
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* Role — badge-style kecil */
.dropdown-user-role {
    font-size: 11px;
    font-weight: 600;
    line-height: 1.2;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 150px;
    display: inline-block;
    padding: 2px 8px;
    border-radius: 6px;
    background: rgba(var(--chrome-primary-rgb), .14);
    color: var(--chrome-primary);
}
body[data-layout-mode="dark"] .dropdown-user-role {
    background: rgba(255, 255, 255, .12);
    color: #cdd5ff;
}

/* Username — teks sekunder kecil */
.dropdown-user-username {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 150px;
    padding-left: 6px;
}
body:not([data-layout-mode="dark"]) .dropdown-user-username { color: #6b7280; }
body[data-layout-mode="dark"] .dropdown-user-username { color: #9aa3b2; }

/* Divider tipis */
.dropdown-menu-end .dropdown-divider {
    margin: .3rem 0;
    border-top: 1px solid rgba(81, 86, 190, 0.12);
}

body[data-layout-mode="dark"] .dropdown-menu-end .dropdown-divider {
    border-top-color: rgba(255, 255, 255, 0.08);
}

.dropdown-menu-end .dropdown-item {
    border-radius: 10px;
    padding: .55rem .9rem;
    margin: 2px 0;
    font-size: 14px;
    transition: all .18s ease;
}

.dropdown-menu-end .dropdown-item i {
    width: 18px;
    text-align: center;
}

.dropdown-menu-end .dropdown-item:hover,
.dropdown-menu-end .dropdown-item:focus {
    background-color: rgba(var(--chrome-primary-rgb), 0.10) !important;
    color: var(--chrome-primary) !important;
    transform: translateX(2px);
}

/* Item logout — tint merah agar menonjol (selector andal via class eksplisit) */
.dropdown-item-logout { color: #fd625e !important; }
.dropdown-item-logout i { color: #fd625e !important; }

.dropdown-item-logout:hover,
.dropdown-item-logout:focus {
    background-color: rgba(253, 98, 94, 0.12) !important;
    color: #fd625e !important;
}

/* ============================================================
   SIDEBAR
   ============================================================ */
.vertical-menu {
    box-shadow: 2px 0 20px rgba(0, 0, 0, 0.06);
    transition: box-shadow .3s ease, background .3s ease;
    z-index: 1001;
    border-right: 1px solid transparent;
}

body:not([data-layout-mode="dark"]) .vertical-menu {
    background: #ffffff !important;
    border-right-color: rgba(81, 86, 190, 0.06);
}

body[data-layout-mode="dark"] .vertical-menu {
    background: #2a2e2c !important;
    border-right-color: rgba(255, 255, 255, 0.05);
}

/* Custom scrollbar untuk sidebar */
.vertical-menu .simplebar-content-wrapper {
    padding: 12px 0 24px !important;
}

.vertical-menu .simplebar-vertical,
.vertical-menu .simplebar-horizontal {
    z-index: 5;
}

/* Menu titles (Apps / Setting) */
#sidebar-menu .menu-title {
    text-transform: uppercase;
    font-size: 11px;
    letter-spacing: 1.2px;
    font-weight: 700;
    padding: 2px 24px 8px !important;
    transition: color .25s ease;
    margin-top: 20px;
}

body:not([data-layout-mode="dark"]) #sidebar-menu .menu-title {
    color: rgb(0, 45, 191) !important;
}

body[data-layout-mode="dark"] #sidebar-menu .menu-title {
    color: rgba(180, 185, 245, 0.6) !important;
}

/* Menu items (link utama) */
#sidebar-menu .metismenu>li>a,
#sidebar-menu .metismenu .sub-menu li>a {
    position: relative;
    border-radius: 10px;
    margin: 3px 12px;
    padding: 10px 14px;
    transition: background-color .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
}

#sidebar-menu .metismenu>li>a {
    font-weight: 500;
}

/* Indikator vertikal saat hover — diletakkan DI LUAR overflow */
#sidebar-menu .metismenu>li>a::before {
    content: "";
    position: absolute;
    left: -12px;
    /* nempel ke tepi sidebar, di luar padding item */
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 0;
    border-radius: 0 3px 3px 0;
    background: linear-gradient(to bottom, var(--chrome-primary), var(--chrome-accent));
    transition: height .25s ease;
}

/* Ikon menghalus saat hover */
#sidebar-menu .metismenu>li>a i,
#sidebar-menu .metismenu .sub-menu li>a i {
    transition: transform .2s ease, color .2s ease;
}

/* ---- HOVER STATE (terang) — background primary solid, teks putih ---- */
body:not([data-layout-mode="dark"]) #sidebar-menu .metismenu>li>a:hover,
body:not([data-layout-mode="dark"]) #sidebar-menu .metismenu .sub-menu li>a:hover {
    background: linear-gradient(135deg, var(--chrome-primary), var(--chrome-accent));
    color: #fff !important;
}

/* ---- HOVER STATE (gelap) ---- */
body[data-layout-mode="dark"] #sidebar-menu .metismenu>li>a:hover,
body[data-layout-mode="dark"] #sidebar-menu .metismenu .sub-menu li>a:hover {
    background: linear-gradient(135deg, var(--chrome-primary), var(--chrome-accent));
    color: #fff !important;
}

/* efek "angkat" ringan + ikon membesar saat hover */
#sidebar-menu .metismenu>li>a:hover {
    transform: translateX(2px);
}

#sidebar-menu .metismenu>li>a:hover::before {
    height: 60%;
    background: rgba(255, 255, 255, 0.6);
}

#sidebar-menu .metismenu>li>a:hover i,
#sidebar-menu .metismenu .sub-menu li>a:hover i {
    transform: scale(1.12);
}

/* ---- ACTIVE state ---- */
#sidebar-menu .metismenu>li.mm-active>a,
#sidebar-menu .metismenu .sub-menu li.mm-active>a,
#sidebar-menu .metismenu>li>a.active,
#sidebar-menu .metismenu .sub-menu li>a.active {
    background: linear-gradient(135deg, var(--chrome-primary), var(--chrome-primary-dark)) !important;
    color: #fff !important;
    box-shadow: 0 6px 16px rgba(var(--chrome-primary-rgb), 0.35);
}

/* item aktif tidak ikut bergeser saat hover */
#sidebar-menu .metismenu>li.mm-active>a:hover,
#sidebar-menu .metismenu>li>a.active:hover {
    transform: none;
}

#sidebar-menu .metismenu>li.mm-active>a::before,
#sidebar-menu .metismenu>li>a.active::before {
    height: 70%;
    background: rgba(255, 255, 255, 0.6);
}

/* Ikon font (mdi, fa) jadi putih saat ACTIVE & HOVER */
#sidebar-menu .metismenu>li.mm-active>a i,
#sidebar-menu .metismenu .sub-menu li.mm-active>a i,
#sidebar-menu .metismenu>li>a.active i,
#sidebar-menu .metismenu>li>a:hover i,
#sidebar-menu .metismenu .sub-menu li>a:hover i {
    color: #fff !important;
}

/* Feather SVG (ikon garis) — HANYA stroke yang putih, fill tetap none
   agar garis ikon tidak hilang */
#sidebar-menu .metismenu>li.mm-active>a svg,
#sidebar-menu .metismenu .sub-menu li.mm-active>a svg,
#sidebar-menu .metismenu>li>a.active svg,
#sidebar-menu .metismenu>li>a:hover svg,
#sidebar-menu .metismenu .sub-menu li>a:hover svg {
    stroke: #fff !important;
    fill: none !important;
    color: #fff !important;
}

/* Sub-menu items lebih kecil */
#sidebar-menu .metismenu .sub-menu li>a {
    font-size: 13.5px;
    padding: 8px 14px 8px 28px;
}

#sidebar-menu .metismenu .sub-menu {
    padding: 4px 0 !important;
    margin: 2px 12px !important;
    background: transparent !important;
}

body:not([data-layout-mode="dark"]) #sidebar-menu .metismenu .sub-menu.mm-collapse,
body:not([data-layout-mode="dark"]) #sidebar-menu .metismenu .sub-menu {
    background: #fff;
    border-radius: 10px;
}

/* Arrow indicator untuk submenu */
#sidebar-menu .metismenu .has-arrow::after {
    transition: transform .25s ease;
}

#sidebar-menu .metismenu .has-arrow[aria-expanded="true"]::after,
#sidebar-menu .metismenu li.mm-active>.has-arrow::after {
    color: #fff;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
    background: #fff;
    border-top: 1px solid rgba(81, 86, 190, 0.08);
    padding: 14px 24px !important;
    font-size: 13px;
}

body[data-layout-mode="dark"] .footer {
    border-top-color: rgba(255, 255, 255, 0.06);
}

.footer a {
    color: var(--chrome-primary);
    font-weight: 600;
    transition: opacity .2s ease;
}

.footer a:hover {
    opacity: .8;
}

/* ============================================================
   MAIN CONTENT
   ============================================================ */
.main-content {
    transition: padding .3s ease;
}

/* Saat sidebar collapsed (mobile / icon-only) — logo text tetap rapi */
.navbar-brand-box .logo-lg .logo-txt {
    transition: opacity .25s ease;
}

/* ============================================================
   MODE TOGGLE BUTTON ICON TRANSITION
   ============================================================ */
#mode-setting-btn .layout-mode-dark,
#mode-setting-btn .layout-mode-light {
    transition: transform .35s ease, opacity .25s ease;
}

/* ============================================================
   COLLAPSED SIDEBAR (data-sidebar-size="sm")
   Ikon dikunci di posisi yang SAMA saat idle maupun hover,
   sehingga tidak ada "lompatan" saat label flyout muncul.
   Trik: padding kiri identik di kedua state.
   ============================================================ */

/* ============================================================
   COLLAPSED SIDEBAR GEOMETRY (data-sidebar-size="sm")
   Footer pakai position:fixed → dijamin SELALU di paling bawah viewport,
   apa pun tinggi konten. Tidak bergantung flex/containing-block.
   ============================================================ */

/* 1. Wrapper jadi positioned ancestor (utk sidebar absolute) */
body[data-sidebar-size="sm"] #layout-wrapper {
    position: relative;
    min-height: 100vh;
}


/* 3. Main content: cadangkan ruang bawah = tinggi footer, supaya konten
      paling bawah tidak tertutup footer fixed */
body[data-sidebar-size="sm"] .main-content {
    padding-bottom: var(--chrome-footer-h) !important;
}

/* 4. Footer FIXED → selalu menempel paling bawah viewport.
      left:70px (LTR: geser kanan melewati sidebar kiri).
      width dihitung supaya ujung kanan ikut layar. */
body[data-sidebar-size="sm"] .footer {
    position: fixed !important;
    left: 70px !important;
    right: 0 !important;
    bottom: 0 !important;
    top: auto !important;
    height: var(--chrome-footer-h) !important;
    display: flex;
    align-items: center;
    z-index: 99;
}

/* IDLE & HOVER — padding sama persis (ikon tetap di x yang sama) */
body[data-sidebar-size="sm"] #sidebar-menu .metismenu > li > a {
    margin: 6px 8px !important;
    padding: 12px 0 !important;
    text-align: center !important;
    border-radius: 12px;
}

/* Hanya span (label) yg ditangani native Minia — ikon TIDAK diubah saat hover */
body[data-sidebar-size="sm"] #sidebar-menu .metismenu > li > a svg,
body[data-sidebar-size="sm"] #sidebar-menu .metismenu > li > a i {
    margin-left: auto !important;
    margin-right: auto !important;
    float: none !important;
    display: inline-block !important;
    transition: none !important;   /* jangan animasikan posisi ikon */
}

/* Indikator garis (::before) disembunyikan saat collapse */
body[data-sidebar-size="sm"] #sidebar-menu .metismenu > li > a::before {
    display: none !important;
}

/* Efek geser hover dinonaktifkan saat collapse */
body[data-sidebar-size="sm"] #sidebar-menu .metismenu > li > a:hover {
    transform: none;
}

/* Sub-menu flyout saat collapse — kasih background solid + shadow
   agar terlihat jelas melayang */
body[data-sidebar-size="sm"] #sidebar-menu .metismenu > li:hover > ul,
body[data-sidebar-size="sm"] .vertical-menu #sidebar-menu > ul ul {
    background-color: #ffffff !important;
    border-radius: 10px;
}

body[data-layout-mode="dark"][data-sidebar-size="sm"] #sidebar-menu .metismenu > li:hover > ul,
body[data-layout-mode="dark"][data-sidebar-size="sm"] .vertical-menu #sidebar-menu > ul ul {
    background-color: #2a2e2c !important;
}

/* Item di dalam flyout sub-menu */
body[data-sidebar-size="sm"] .vertical-menu #sidebar-menu > ul ul a {
    border-radius: 8px;
}

/* ============================================================
   FOOTER POSISI — saat collapse, Minia paksa body min-height:1000px
   yang membuat jarak konten↔footer jadi lebar. Hapus paksaan itu
   dan footer ikut konten secara natural.
   ============================================================ */
body[data-sidebar-size="sm"] {
    min-height: 100vh !important;          /* ikut viewport, bukan 1000px */
    overflow-x: hidden !important;         /* cegah horizontal scroll saat collapse */
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* Overlay gelap di belakang konten saat sidebar mobile terbuka */
.sidebar-mobile-overlay {
    display: none;
}

@media (max-width: 991.98px) {
    .vertical-menu {
        box-shadow: 4px 0 30px rgba(0, 0, 0, 0.15);
    }

    #page-topbar,
    .navbar-header {
        height: 62px;
    }

    #sidebar-menu .metismenu>li>a,
    #sidebar-menu .metismenu .sub-menu li>a {
        margin: 2px 8px;
    }

    /* Tampilkan overlay saat sidebar aktif (klik overlay => tutup) */
    body.sidebar-enable .sidebar-mobile-overlay {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 1000;               /* di bawah sidebar (1001) & topbar (1002) */
        background: rgba(0, 0, 0, 0.45);
        cursor: pointer;
        animation: sidebar-overlay-in .2s ease;
    }
}

@keyframes sidebar-overlay-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ============================================================
   CHOOSE SYSTEM PAGE  (.choose-system)
   ============================================================ */
/* Konten dipusatkan */
.choose-system {
    min-height: calc(100vh - 132px); /* viewport - header(70) - footer(~60) - padding */
    display: flex !important;
    flex-direction: column !important;
    justify-content: center;         /* center vertikal bila konten pendek */
    padding-top: 10px !important;    /* jarak atas ringkas */
    padding-bottom: 16px !important;
}
.choose-system > .container-fluid { width: 100%; }

.choose-wrap { margin-top: 0; }

/* HERO — blob gradient + lottie */
.choose-hero {
    position: relative;
    text-align: center;
    padding: 22px 18px 20px;
    overflow: hidden;
    border-radius: 20px;
}

body:not([data-layout-mode="dark"]) .choose-hero {
        background: linear-gradient(135deg, var(--chrome-primary), var(--chrome-primary-dark)) !important;
        box-shadow: 0 12px 40px rgba(var(--chrome-primary-rgb), 0.10);
}
body[data-layout-mode="dark"] .choose-hero {
    background:
        radial-gradient(120% 140% at 15% 0%, rgba(var(--chrome-primary-rgb), 0.22), transparent 55%),
        radial-gradient(120% 140% at 85% 100%, rgba(255, 255, 255, 0.05), transparent 55%);
    border: 1px solid rgba(255, 255, 255, 0.07);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.30);
}

/* Blob bulat di belakang lottie */
.choose-hero__blob {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 160px;
    height: 130px;
    margin-bottom: 14px;
}
.choose-hero__blob::before {
    content: "";
    position: absolute;
    inset: -20px;
    border-radius: 50%;
    background: conic-gradient(from 140deg, var(--chrome-primary), #25D366, var(--chrome-accent), var(--chrome-primary));
    filter: blur(24px);
    opacity: .40;
    animation: chooseBlob 7s ease-in-out infinite;
}
.choose-hero__blob lottie-player {
    position: absolute;
    z-index: 1;
    bottom: 10px;
    top: -60px;
}
@keyframes chooseBlob {
    0%, 100% { transform: scale(1) rotate(0deg); opacity: .35; }
    50%      { transform: scale(1.08) rotate(12deg); opacity: .50; }
}
.img-thumbnail {
  border-radius: 50%;
}
.img-publikasi {
    border-radius:unset;
}
/* Varian split: lottie kolom 4, teks kolom 8 */
.choose-hero--split { text-align: left; padding: 14px 20px; margin-bottom: 0; margin-top: 80px; min-height: 200px;}
.choose-hero--split .row { width: 100%; }
.choose-hero--split .choose-hero__blob {
    width: auto; height: auto; margin: 0; display: inline-flex;
}
.choose-hero__text {
    padding-right: 8px;
    text-align: left; 
    top: 22px;
    position: relative;         /* rata kiri */
}
.choose-hero__text .choose-badge { margin-bottom: 8px; }
.choose-hero__text .choose-title { text-align: left; }
.choose-hero__text .choose-sub { margin-left: 0; max-width: 100%; text-align: left; }

/* Badge — diletakkan lebih rendah, di bawah lottie */
.choose-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    margin-top: 4px;
    margin-bottom: 12px !important;
    font-size: 11.5px;
    font-weight: 600;
    letter-spacing: .4px;
    border-radius: 999px;
    color: #fff;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.18);
}
body[data-layout-mode="dark"] .choose-badge {
    color: #c5c9ff;
    background: rgba(var(--chrome-primary-rgb), 0.22);
}
.choose-badge i { font-size: 14px; }

/* Title + sub */
.choose-title {
    font-size: 22px;
    font-weight: bold;
    letter-spacing: -.2px;
    margin-bottom: 6px;
}
body:not([data-layout-mode="dark"]) .choose-title { color: #2a2f2c; }
body[data-layout-mode="dark"] .choose-title       { color: #f4f6ff; }

.choose-sub {
    max-width: 520px;
    margin: 0 auto;
    font-size: 13px;
    line-height: 1.55;
}
body:not([data-layout-mode="dark"]) .choose-sub { color: #6b7280; }
body[data-layout-mode="dark"] .choose-sub       { color: #aeb4c4; }

/* ===== PANEL LIST PILIH SISTEM ===== */
.choose-panel {
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(var(--chrome-primary-rgb), 0.10);
    box-shadow: 0 12px 40px rgba(var(--chrome-primary-rgb), 0.10);
}
body:not([data-layout-mode="dark"]) .choose-panel { background: #ffffff; }
body[data-layout-mode="dark"] .choose-panel {
    background: #2a2e2c;
    border-color: rgba(255, 255, 255, 0.07);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.30);
}

/* ----- Pencarian ----- */
.choose-search {
    position: relative;
    display: flex;
    align-items: center;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(var(--chrome-primary-rgb), 0.10);
}
body[data-layout-mode="dark"] .choose-search { border-bottom-color: rgba(255, 255, 255, 0.07); }

.choose-search__icon {
    position: absolute;
    left: 28px;
    font-size: 18px;
    color: #9aa0b5;
    pointer-events: none;
}
.choose-search__input {
    height: 42px;
    padding-left: 42px;
    padding-right: 42px;
    border-radius: 12px;
    border: 1.5px solid rgba(var(--chrome-primary-rgb), 0.16);
    background: transparent;
    transition: border-color .2s ease, box-shadow .2s ease;
}
body:not([data-layout-mode="dark"]) .choose-search__input { background: #f7f8fc; }
body[data-layout-mode="dark"] .choose-search__input {
    background: rgba(255, 255, 255, 0.04);
    color: #f4f6ff;
}
.choose-search__input:focus {
    border-color: var(--chrome-primary);
    box-shadow: 0 0 0 3px rgba(var(--chrome-primary-rgb), 0.16);
    background: #fff;
}
body[data-layout-mode="dark"] .choose-search__input:focus { background: rgba(255, 255, 255, 0.06); }

.choose-search__clear {
    position: absolute;
    right: 28px;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 50%;
    font-size: 16px;
    color: #9aa0b5;
    background: rgba(var(--chrome-primary-rgb), 0.10);
    cursor: pointer;
    transition: background .2s ease, color .2s ease;
}
.choose-search__clear:hover {
    color: #fff;
    background: var(--chrome-primary);
}

/* ----- Daftar ----- */
.choose-list {
    max-height: 200px;
    overflow-y: auto;
    padding: 6px;
}
.choose-list::-webkit-scrollbar { width: 8px; }
.choose-list::-webkit-scrollbar-thumb {
    background: rgba(var(--chrome-primary-rgb), 0.25);
    border-radius: 8px;
}
.choose-list::-webkit-scrollbar-thumb:hover { background: rgba(var(--chrome-primary-rgb), 0.40); }

.choose-item {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 7px 11px;
    margin: 2px 0;
    text-align: left;
    border: 1.5px solid transparent;
    border-radius: 11px;
    background: transparent;
    cursor: pointer;
    transition: background-color .2s ease, border-color .2s ease, transform .2s ease;
}
body:not([data-layout-mode="dark"]) .choose-item:hover {
    background: rgba(var(--chrome-primary-rgb), 0.06);
    border-color: rgba(var(--chrome-primary-rgb), 0.18);
}
body[data-layout-mode="dark"] .choose-item:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.10);
}
.choose-item:hover { transform: translateX(3px); }

.choose-item__ico {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    font-size: 18px;
    color: #fff;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--chrome-primary), var(--chrome-accent));
    box-shadow: 0 6px 14px rgba(var(--chrome-primary-rgb), 0.30);
    transition: transform .2s ease;
}
.choose-item:hover .choose-item__ico { transform: scale(1.06); }

.choose-item__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.choose-item__name {
    font-size: 14.5px;
    font-weight: 600;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
body:not([data-layout-mode="dark"]) .choose-item__name { color: #2a2f2c; }
body[data-layout-mode="dark"] .choose-item__name       { color: #f4f6ff; }

.choose-item__hint {
    font-size: 12px;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
body:not([data-layout-mode="dark"]) .choose-item__hint { color: #8a90a2; }
body[data-layout-mode="dark"] .choose-item__hint       { color: #9aa0b5; }

/* centang saat terpilih */
.choose-item__check {
    flex-shrink: 0;
    font-size: 22px;
    color: var(--chrome-primary);
    opacity: 0;
    transform: scale(.4);
    transition: opacity .2s ease, transform .2s ease;
}
.choose-item.is-selected {
    border-color: var(--chrome-primary);
    background: rgba(var(--chrome-primary-rgb), 0.08);
    box-shadow: 0 0 0 3px rgba(var(--chrome-primary-rgb), 0.14);
}
.choose-item.is-selected .choose-item__check {
    opacity: 1;
    transform: scale(1);
}

/* state kosong */
.choose-empty {
    text-align: center;
    padding: 40px 16px;
    color: #9aa0b5;
}
.choose-empty i {
    display: block;
    font-size: 40px;
    margin-bottom: 10px;
    opacity: .6;
}

/* ----- Footer aksi ----- */
.choose-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    padding: 10px 14px;
    border-top: 1px solid rgba(var(--chrome-primary-rgb), 0.10);
}
body[data-layout-mode="dark"] .choose-footer { border-top-color: rgba(255, 255, 255, 0.07); }

.choose-count {
    font-size: 12.5px;
    font-weight: 500;
}
body:not([data-layout-mode="dark"]) .choose-count { color: #6b7280; }
body[data-layout-mode="dark"] .choose-count       { color: #aeb4c4; }

/* ===== TOMBOL UTAMA ===== */
.btn-choose-primary {
    min-width: 200px;
    padding: 11px 24px;
    font-size: 14.5px;
    font-weight: 600;
    color: #fff !important;
    border: 0;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--chrome-primary), var(--chrome-accent));
    box-shadow: 0 10px 24px rgba(var(--chrome-primary-rgb), 0.38);
    transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}
.btn-choose-primary:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(var(--chrome-primary-rgb), 0.48);
}
.btn-choose-primary:active:not(:disabled) { transform: translateY(0); }
.btn-choose-primary:disabled {
    opacity: .55;
    cursor: not-allowed;
    box-shadow: none;
}
.btn-choose-primary i { margin-right: 4px; }

/* Layar kecil */
@media (max-width: 991.98px) {
    .choose-hero { padding: 18px 16px 16px; }
    .choose-hero--split .choose-hero__blob lottie-player { width: 170px !important; height: 140px !important; }
    .choose-title { font-size: 17px; }
    .choose-sub { font-size: 12.5px; }
    .choose-list { max-height: 240px; }
}

@media (max-width: 575.98px) {
    .choose-hero { padding: 16px 12px 14px; border-radius: 16px; }
    /* split tetap 2 kolom di mobile, tapi lottie lebih kecil */
    .choose-hero--split .choose-hero__blob lottie-player { width: 120px !important; height: 100px !important; }
    .choose-hero--split { padding: 14px 12px; }
    .choose-title { font-size: 16px; }
    .choose-footer { justify-content: center; }
    .btn-choose-primary { width: 100%; min-width: 0; }
}

/* ============================================================
   PENCARIAN CUSTOM PAGE  (halaman /auth/custompage)
   ============================================================ */
/* item nestable yang ter-filter keluar */
.dd-item.cp-hide { display: none !important; }

.cp-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.cp-search-icon {
    position: absolute;
    left: 12px;
    font-size: 17px;
    color: #9aa0b5;
    pointer-events: none;
    z-index: 2;
}
.cp-search-input {
    height: 40px;
    padding-left: 38px;
    padding-right: 38px;
    border-radius: 10px;
    border: 1.5px solid rgba(var(--chrome-primary-rgb), 0.16);
    background: transparent;
    transition: border-color .2s ease, box-shadow .2s ease;
}
body:not([data-layout-mode="dark"]) .cp-search-input { background: #f7f8fc; }
body[data-layout-mode="dark"] .cp-search-input {
    background: rgba(255, 255, 255, 0.04);
    color: #f4f6ff;
}
.cp-search-input:focus {
    border-color: var(--chrome-primary);
    box-shadow: 0 0 0 3px rgba(var(--chrome-primary-rgb), 0.16);
    background: #fff;
}
body[data-layout-mode="dark"] .cp-search-input:focus { background: rgba(255, 255, 255, 0.06); }

.cp-search-clear {
    position: absolute;
    right: 8px;
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 50%;
    font-size: 15px;
    color: #9aa0b5;
    background: rgba(var(--chrome-primary-rgb), 0.10);
    cursor: pointer;
    z-index: 2;
    transition: background .2s ease, color .2s ease;
}
.cp-search-clear:hover {
    color: #fff;
    background: var(--chrome-primary);
}