/*
|--------------------------------------------------------------------------
| BantuKita Public UI
| Visual direction: soft creator-economy style inspired by Lynk.id
|--------------------------------------------------------------------------
*/

:root {
    --bk-primary: #23b981;
    --bk-primary-dark: #149966;
    --bk-primary-soft: #e8faf3;
    --bk-mint: #eaf8f5;
    --bk-mint-2: #f4fbf8;
    --bk-text: #263b3a;
    --bk-muted: #6f8582;
    --bk-border: #dcecea;
    --bk-card: #ffffff;
    --bk-warning: #ffb84d;
    --bk-danger: #ff5c7a;
    --bk-shadow: 0 18px 45px rgba(29, 65, 61, .08);
    --bk-shadow-soft: 0 12px 28px rgba(29, 65, 61, .06);
    --bk-radius-lg: 28px;
    --bk-radius-md: 20px;
    --bk-radius-sm: 14px;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--bk-text);
    background: linear-gradient(180deg, #e9f8f5 0%, #ffffff 34%, #f7fbfa 100%);
}

a {
    color: inherit;
    text-decoration: none;
}

.bk-navbar {
    position: sticky;
    top: 0;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    width: min(1180px, calc(100% - 32px));
    margin: 16px auto 0;
    padding: 12px 16px;
    background: rgba(255, 255, 255, .78);
    border: 1px solid rgba(255, 255, 255, .82);
    border-radius: 999px;
    box-shadow: 0 14px 38px rgba(27, 75, 70, .08);
    backdrop-filter: blur(18px);
}

.bk-brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 850;
    letter-spacing: -.03em;
}

.bk-brand-mark {
    display: inline-grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 13px;
    color: #fff;
    background: linear-gradient(135deg, var(--bk-primary), #14a3a4);
    box-shadow: 0 10px 18px rgba(35, 185, 129, .28);
    font-size: 13px;
}

.bk-navlinks {
    display: flex;
    align-items: center;
    gap: 22px;
    color: #405755;
    font-size: 14px;
    font-weight: 650;
}

.bk-navlinks a:hover {
    color: var(--bk-primary-dark);
}

.bk-nav-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.bk-link-muted {
    color: var(--bk-muted);
    font-size: 14px;
    font-weight: 650;
}

.bk-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 22px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    background: var(--bk-primary);
    box-shadow: 0 14px 28px rgba(35, 185, 129, .24);
    font-weight: 800;
    cursor: pointer;
}

.bk-btn:hover {
    background: var(--bk-primary-dark);
}

.bk-btn-sm {
    min-height: 36px;
    padding: 0 16px;
    font-size: 13px;
}

.bk-btn-light {
    color: var(--bk-text);
    background: #fff;
    border: 1px solid var(--bk-border);
    box-shadow: none;
}

.bk-btn-outline {
    color: var(--bk-primary-dark);
    background: transparent;
    border: 1px solid rgba(35, 185, 129, .35);
    box-shadow: none;
}

.bk-container {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
}

.bk-hero {
    position: relative;
    overflow: hidden;
    padding: 86px 0 72px;
}

.bk-hero-grid {
    display: grid;
    grid-template-columns: 1.04fr .96fr;
    gap: 54px;
    align-items: center;
}

.bk-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 13px;
    border-radius: 999px;
    color: var(--bk-primary-dark);
    background: rgba(255, 255, 255, .7);
    border: 1px solid rgba(35, 185, 129, .18);
    font-size: 13px;
    font-weight: 800;
}

.bk-hero h1 {
    margin: 18px 0 18px;
    font-size: clamp(40px, 6vw, 74px);
    line-height: .96;
    letter-spacing: -.065em;
}

.bk-hero p {
    max-width: 570px;
    margin: 0 0 26px;
    color: var(--bk-muted);
    font-size: 17px;
    line-height: 1.75;
}

.bk-searchbar {
    display: flex;
    align-items: center;
    width: min(620px, 100%);
    padding: 8px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(35, 185, 129, .14);
    box-shadow: var(--bk-shadow-soft);
}

.bk-searchbar input {
    flex: 1;
    height: 48px;
    border: 0;
    outline: 0;
    padding: 0 18px;
    color: var(--bk-text);
    font-size: 15px;
    background: transparent;
}

.bk-hero-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 18px;
}

.bk-hero-visual {
    position: relative;
    min-height: 520px;
}

.bk-phone-card {
    position: absolute;
    inset: 18px 70px auto auto;
    width: 310px;
    min-height: 520px;
    padding: 18px;
    border-radius: 42px;
    background: #153d37;
    box-shadow: 0 30px 70px rgba(19, 80, 73, .23);
    transform: rotate(6deg);
}

.bk-phone-screen {
    overflow: hidden;
    min-height: 484px;
    border-radius: 31px;
    background: #eefaf6;
}

.bk-phone-head {
    height: 132px;
    padding: 22px;
    color: #fff;
    background: linear-gradient(135deg, #21b87e, #0f8975);
}

.bk-phone-head small {
    display: block;
    opacity: .82;
    margin-bottom: 10px;
}

.bk-phone-head strong {
    display: block;
    font-size: 25px;
    letter-spacing: -.05em;
    line-height: 1.05;
}

.bk-mini-product {
    margin: -24px 18px 12px;
    padding: 14px;
    border-radius: 20px;
    background: #fff;
    box-shadow: var(--bk-shadow-soft);
}

.bk-mini-thumb {
    height: 86px;
    border-radius: 16px;
    background: linear-gradient(135deg, #d7f4ea, #ffffff);
    border: 1px solid var(--bk-border);
}

.bk-mini-line {
    height: 9px;
    margin-top: 12px;
    border-radius: 999px;
    background: #d8e9e5;
}

.bk-mini-line.short {
    width: 64%;
}

.bk-floating-card {
    position: absolute;
    width: 172px;
    padding: 14px;
    border-radius: 22px;
    background: #fff;
    box-shadow: var(--bk-shadow);
}

.bk-floating-card.one {
    left: 12px;
    top: 96px;
}

.bk-floating-card.two {
    right: 6px;
    bottom: 76px;
}

.bk-floating-card strong {
    display: block;
    font-size: 14px;
    margin-bottom: 6px;
}

.bk-floating-card span {
    color: var(--bk-muted);
    font-size: 12px;
    line-height: 1.45;
}

.bk-section {
    padding: 54px 0;
}

.bk-section-soft {
    background: rgba(244, 251, 248, .8);
}

.bk-section-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 24px;
    margin-bottom: 26px;
}

.bk-section-title {
    margin: 0;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1.05;
    letter-spacing: -.055em;
}

.bk-section-desc {
    max-width: 650px;
    margin: 10px 0 0;
    color: var(--bk-muted);
    line-height: 1.7;
}

.bk-category-row {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
}

.bk-category-card {
    padding: 20px;
    border: 1px solid var(--bk-border);
    border-radius: 24px;
    background: #fff;
    box-shadow: var(--bk-shadow-soft);
}

.bk-category-icon {
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
    margin-bottom: 16px;
    border-radius: 16px;
    background: var(--bk-primary-soft);
    color: var(--bk-primary-dark);
    font-weight: 900;
}

.bk-category-card strong {
    display: block;
    font-size: 15px;
    margin-bottom: 6px;
}

.bk-category-card span {
    color: var(--bk-muted);
    font-size: 13px;
}

.bk-product-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}

.bk-product-card {
    overflow: hidden;
    border: 1px solid var(--bk-border);
    border-radius: 28px;
    background: #fff;
    box-shadow: var(--bk-shadow-soft);
    transition: transform .2s ease, box-shadow .2s ease;
}

.bk-product-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--bk-shadow);
}

.bk-product-thumb {
    position: relative;
    height: 170px;
    margin: 12px 12px 0;
    border-radius: 22px;
    background: linear-gradient(135deg, #dff7ef, #f9fffd);
    border: 1px solid var(--bk-border);
}

.bk-product-thumb.dark {
    background: linear-gradient(135deg, #123c36, #2bb987);
}

.bk-product-thumb.blue {
    background: linear-gradient(135deg, #e5f2ff, #dffaf2);
}

.bk-badge {
    display: inline-flex;
    align-items: center;
    height: 28px;
    padding: 0 11px;
    border-radius: 999px;
    color: var(--bk-primary-dark);
    background: var(--bk-primary-soft);
    font-size: 12px;
    font-weight: 850;
}

.bk-product-badge {
    position: absolute;
    top: 12px;
    left: 12px;
}

.bk-product-body {
    padding: 16px 18px 18px;
}

.bk-product-title {
    display: block;
    min-height: 48px;
    font-size: 16px;
    font-weight: 850;
    line-height: 1.35;
    letter-spacing: -.02em;
}

.bk-product-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 12px 0;
    color: var(--bk-muted);
    font-size: 13px;
}

.bk-product-price {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.bk-price {
    font-size: 20px;
    font-weight: 900;
    letter-spacing: -.04em;
}

.bk-price small {
    color: var(--bk-muted);
    font-size: 12px;
    font-weight: 700;
}

.bk-icon-actions {
    display: flex;
    gap: 8px;
}

.bk-icon-btn {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    color: var(--bk-primary-dark);
    background: #f3fbf8;
    border: 1px solid var(--bk-border);
}

.bk-membership-wrap {
    padding: 44px;
    border-radius: 36px;
    background: #e6f6f2;
}

.bk-membership-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.bk-plan-card {
    padding: 24px;
    border-radius: 28px;
    background: #fff;
    border: 1px solid rgba(35, 185, 129, .14);
    box-shadow: var(--bk-shadow-soft);
}

.bk-plan-card.featured {
    transform: translateY(-10px);
    border-color: rgba(35, 185, 129, .45);
}

.bk-plan-name {
    color: var(--bk-primary-dark);
    font-weight: 900;
    letter-spacing: -.03em;
}

.bk-plan-price {
    margin: 12px 0 14px;
    font-size: 32px;
    font-weight: 950;
    letter-spacing: -.06em;
}

.bk-plan-card ul {
    display: grid;
    gap: 10px;
    padding: 0;
    margin: 0 0 18px;
    list-style: none;
    color: var(--bk-muted);
    font-size: 14px;
}

.bk-plan-card li::before {
    content: "✓";
    color: var(--bk-primary);
    font-weight: 900;
    margin-right: 8px;
}

.bk-page-hero {
    padding: 64px 0 36px;
}

.bk-page-title {
    margin: 0;
    font-size: clamp(36px, 5vw, 58px);
    line-height: 1;
    letter-spacing: -.06em;
}

.bk-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 24px;
    align-items: start;
}

.bk-sidebar {
    position: sticky;
    top: 96px;
    display: grid;
    gap: 16px;
}

.bk-filter-card {
    padding: 18px;
    border-radius: 26px;
    background: #fff;
    border: 1px solid var(--bk-border);
    box-shadow: var(--bk-shadow-soft);
}

.bk-filter-card h3 {
    margin: 0 0 14px;
    font-size: 16px;
}

.bk-filter-list {
    display: grid;
    gap: 10px;
    color: #415957;
    font-size: 14px;
    font-weight: 650;
}

.bk-content-panel {
    padding: 22px;
    border-radius: 30px;
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(220, 236, 234, .8);
}

.bk-filterbar {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 22px;
}

.bk-chip {
    display: inline-flex;
    align-items: center;
    height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    color: #405755;
    background: #fff;
    border: 1px solid var(--bk-border);
    font-size: 13px;
    font-weight: 800;
}

.bk-chip.active {
    color: #fff;
    background: var(--bk-primary);
    border-color: var(--bk-primary);
}

.bk-detail-grid {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 26px;
    align-items: start;
}

.bk-detail-card,
.bk-buy-card {
    border: 1px solid var(--bk-border);
    border-radius: 30px;
    background: #fff;
    box-shadow: var(--bk-shadow-soft);
}

.bk-detail-card {
    padding: 24px;
}

.bk-detail-preview {
    min-height: 390px;
    border-radius: 26px;
    background: linear-gradient(135deg, #103a34, #24bc83);
    margin-bottom: 22px;
}

.bk-detail-card h1 {
    margin: 0 0 12px;
    font-size: clamp(30px, 4vw, 46px);
    line-height: 1.05;
    letter-spacing: -.055em;
}

.bk-prose {
    color: #445d5a;
    line-height: 1.8;
}

.bk-prose h2 {
    color: var(--bk-text);
    margin-top: 30px;
    letter-spacing: -.03em;
}

.bk-prose ul {
    padding-left: 20px;
}

.bk-buy-card {
    position: sticky;
    top: 96px;
    padding: 22px;
}

.bk-buy-price {
    font-size: 34px;
    font-weight: 950;
    letter-spacing: -.06em;
    margin: 8px 0 16px;
}

.bk-info-list {
    display: grid;
    gap: 12px;
    margin: 18px 0;
}

.bk-info-row {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    color: var(--bk-muted);
    font-size: 14px;
}

.bk-info-row strong {
    color: var(--bk-text);
}

.bk-footer {
    margin-top: 70px;
    color: #d8e8e5;
    background: linear-gradient(180deg, #253330, #111817);
}

.bk-footer-wave {
    height: 70px;
    background: #fff;
    border-radius: 0 0 50% 50%;
}

.bk-footer-inner {
    display: grid;
    grid-template-columns: 1.4fr repeat(3, 1fr);
    gap: 34px;
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    padding: 46px 0 30px;
}

.bk-footer h4 {
    color: #fff;
    margin: 0 0 14px;
}

.bk-footer a {
    display: block;
    color: #d8e8e5;
    margin: 10px 0;
    font-size: 14px;
}

.bk-footer p {
    max-width: 330px;
    color: #b8cac7;
    line-height: 1.7;
}

.bk-brand-footer {
    color: #fff;
    margin-bottom: 12px;
}

.bk-footer-bottom {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    padding: 22px 0 34px;
    color: #99aaa7;
    border-top: 1px solid rgba(255, 255, 255, .08);
    text-align: center;
    font-size: 13px;
}

@media (max-width: 980px) {
    .bk-navbar {
        border-radius: 24px;
        align-items: flex-start;
    }

    .bk-navlinks,
    .bk-nav-actions {
        display: none;
    }

    .bk-hero-grid,
    .bk-layout,
    .bk-detail-grid {
        grid-template-columns: 1fr;
    }

    .bk-hero-visual {
        min-height: 440px;
    }

    .bk-phone-card {
        right: 50%;
        transform: translateX(50%) rotate(3deg);
    }

    .bk-category-row,
    .bk-product-grid,
    .bk-membership-grid,
    .bk-footer-inner {
        grid-template-columns: repeat(2, 1fr);
    }

    .bk-sidebar,
    .bk-buy-card {
        position: static;
    }
}

@media (max-width: 640px) {
    .bk-hero {
        padding-top: 58px;
    }

    .bk-category-row,
    .bk-product-grid,
    .bk-membership-grid,
    .bk-footer-inner {
        grid-template-columns: 1fr;
    }

    .bk-searchbar {
        border-radius: 24px;
        align-items: stretch;
        flex-direction: column;
    }

    .bk-searchbar input {
        width: 100%;
    }

    .bk-membership-wrap {
        padding: 22px;
    }

    .bk-phone-card {
        width: 270px;
    }

    .bk-floating-card {
        display: none;
    }
}

/* Phase 2: Laravel pagination */
nav[role="navigation"] {
    display: flex;
    justify-content: center;
    margin-top: 18px;
    color: var(--bk-muted);
    font-size: 14px;
}

nav[role="navigation"] a,
nav[role="navigation"] span {
    border-radius: 12px !important;
}

/* Product screenshots */
.bk-detail-preview-image {
    overflow: hidden;
    background: #eef8f5;
}

.bk-detail-preview-image img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 390px;
    object-fit: cover;
}

.bk-gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: -4px 0 20px;
}

.bk-gallery-grid img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 18px;
    border: 1px solid var(--bk-border);
    background: #eef8f5;
}

@media (max-width: 700px) {
    .bk-gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Phase: public image cards + PageSpeed-friendly layout */
.bk-product-thumb {
    aspect-ratio: 16 / 10;
    height: auto;
    min-height: 0;
}

.bk-product-thumb.has-image {
    overflow: hidden;
    background: #eef8f5;
}

.bk-product-thumb.has-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.01);
    transition: transform .24s ease;
}

.bk-product-card:hover .bk-product-thumb.has-image img {
    transform: scale(1.045);
}

.bk-product-badge {
    z-index: 2;
    box-shadow: 0 10px 20px rgba(18, 75, 67, .08);
}

.bk-product-title {
    min-height: 44px;
}

.bk-product-meta {
    min-height: 20px;
}

.bk-detail-preview {
    aspect-ratio: 16 / 10;
    min-height: 0;
}

.bk-detail-preview-image img {
    min-height: 0;
    aspect-ratio: 16 / 10;
}

.bk-footer-wave {
    height: 54px;
}

/* Keep homepage fast and stable */
.bk-phone-card,
.bk-floating-card,
.bk-product-card,
.bk-category-card,
.bk-plan-card {
    will-change: transform;
}

@media (max-width: 1180px) {
    .bk-product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .bk-product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .bk-category-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .bk-product-grid,
    .bk-category-row {
        grid-template-columns: 1fr;
    }

    .bk-section-head {
        align-items: flex-start;
        flex-direction: column;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Lynk-style Poppins Refinement
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Tujuan:
| - Membuat landing page lebih mirip Lynk.id
| - Typography lebih kecil, ringan, friendly
| - Font Poppins untuk seluruh public UI
| - Soft mint / green / white, rounded, airy, tidak marketplace berat
|--------------------------------------------------------------------------
*/

:root {
    --bk-primary: #20bf86;
    --bk-primary-dark: #138a67;
    --bk-primary-soft: #e9fbf5;
    --bk-mint: #e9f8f6;
    --bk-mint-2: #f7fcfa;
    --bk-text: #304240;
    --bk-muted: #728582;
    --bk-border: #e4efec;
    --bk-card: #ffffff;
    --bk-shadow: 0 12px 30px rgba(31, 72, 68, .055);
    --bk-shadow-soft: 0 8px 20px rgba(31, 72, 68, .045);
    --bk-radius-lg: 24px;
    --bk-radius-md: 18px;
    --bk-radius-sm: 12px;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: "Poppins", sans-serif;
    font-size: 13.5px;
    font-weight: 400;
    line-height: 1.65;
    color: var(--bk-text);
    background:
        radial-gradient(circle at 86% 12%, rgba(32, 191, 134, .08), transparent 24%),
        linear-gradient(180deg, #eaf8f6 0%, #ffffff 28%, #f8fcfb 100%);
    -webkit-font-smoothing: antialiased;
    text-rendering: geometricPrecision;
}

button,
input,
select,
textarea {
    font-family: "Poppins", sans-serif;
}

.bk-container,
.bk-navbar,
.bk-footer-inner,
.bk-footer-bottom {
    width: min(1050px, calc(100% - 40px));
}

/* Navbar dibuat kecil, halus, dan mirip Lynk */
.bk-navbar {
    top: 12px;
    gap: 18px;
    margin-top: 12px;
    padding: 8px 12px;
    background: rgba(255, 255, 255, .86);
    border: 1px solid rgba(224, 239, 235, .9);
    border-radius: 999px;
    box-shadow: 0 8px 24px rgba(32, 72, 68, .06);
    backdrop-filter: blur(16px);
}

.bk-brand {
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: -.02em;
}

.bk-brand-mark {
    width: 30px;
    height: 30px;
    border-radius: 11px;
    font-size: 10px;
    font-weight: 700;
    box-shadow: 0 8px 16px rgba(32, 191, 134, .2);
}

.bk-navlinks {
    gap: 24px;
    font-size: 11.5px;
    font-weight: 500;
    color: #334b48;
}

.bk-nav-actions {
    gap: 10px;
}

.bk-link-muted {
    font-size: 11.5px;
    font-weight: 500;
    color: #405855;
}

.bk-btn {
    min-height: 34px;
    padding: 0 17px;
    font-size: 11.5px;
    font-weight: 600;
    border-radius: 999px;
    box-shadow: 0 9px 20px rgba(32, 191, 134, .18);
}

.bk-btn-sm {
    min-height: 30px;
    padding: 0 14px;
    font-size: 11px;
}

.bk-btn-light {
    color: #304240;
    background: #fff;
    border: 1px solid var(--bk-border);
    box-shadow: none;
}

.bk-btn-outline {
    min-height: 32px;
    color: var(--bk-primary-dark);
    background: #fff;
    border: 1px solid rgba(32, 191, 134, .22);
    box-shadow: none;
}

/* Hero lebih ringan, tidak terlalu besar dan tebal */
.bk-hero {
    padding: 76px 0 54px;
}

.bk-hero-grid {
    grid-template-columns: 1.02fr .98fr;
    gap: 44px;
}

.bk-kicker {
    padding: 6px 10px;
    font-size: 10.5px;
    font-weight: 600;
    color: var(--bk-primary-dark);
    background: rgba(255, 255, 255, .68);
    border-color: rgba(32, 191, 134, .16);
}

.bk-hero h1 {
    max-width: 520px;
    margin: 16px 0 14px;
    font-size: clamp(30px, 4vw, 38px);
    font-weight: 700;
    line-height: 1.12;
    letter-spacing: -.045em;
}

.bk-hero p {
    max-width: 520px;
    margin-bottom: 22px;
    font-size: 13px;
    line-height: 1.75;
    color: var(--bk-muted);
}

.bk-searchbar {
    width: min(520px, 100%);
    padding: 5px;
    border-radius: 999px;
    border-color: rgba(32, 191, 134, .14);
    box-shadow: 0 9px 24px rgba(31, 72, 68, .055);
}

.bk-searchbar input {
    height: 38px;
    padding: 0 15px;
    font-size: 11.5px;
}

.bk-searchbar .bk-btn {
    min-height: 34px;
    padding: 0 16px;
}

.bk-hero-actions {
    gap: 10px;
    margin-top: 14px;
}

/* Visual hero diperkecil seperti mockup Lynk */
.bk-hero-visual {
    min-height: 405px;
}

.bk-phone-card {
    inset: 14px 78px auto auto;
    width: 245px;
    min-height: 405px;
    padding: 13px;
    border-radius: 34px;
    background: #173f38;
    box-shadow: 0 22px 54px rgba(19, 80, 73, .18);
    transform: rotate(5deg);
}

.bk-phone-screen {
    min-height: 379px;
    border-radius: 25px;
}

.bk-phone-head {
    height: 104px;
    padding: 18px;
}

.bk-phone-head small {
    margin-bottom: 7px;
    font-size: 10px;
}

.bk-phone-head strong {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -.035em;
}

.bk-mini-product {
    margin: -18px 14px 10px;
    padding: 11px;
    border-radius: 16px;
    box-shadow: 0 8px 18px rgba(31, 72, 68, .055);
}

.bk-mini-thumb {
    height: 66px;
    border-radius: 13px;
}

.bk-mini-line {
    height: 7px;
    margin-top: 9px;
}

.bk-floating-card {
    width: 150px;
    padding: 12px;
    border-radius: 17px;
    box-shadow: 0 10px 26px rgba(31, 72, 68, .065);
}

.bk-floating-card.one {
    left: 10px;
    top: 78px;
}

.bk-floating-card.two {
    right: 10px;
    bottom: 72px;
}

.bk-floating-card strong {
    margin-bottom: 4px;
    font-size: 11.5px;
    font-weight: 700;
}

.bk-floating-card span {
    font-size: 10.5px;
    line-height: 1.55;
}

/* Section dibuat lebih lega dan ringan */
.bk-section {
    padding: 46px 0;
}

.bk-section-soft {
    background: rgba(247, 252, 250, .92);
}

.bk-section-head {
    gap: 18px;
    margin-bottom: 22px;
}

.bk-section-title {
    font-size: clamp(22px, 2.4vw, 28px);
    font-weight: 700;
    line-height: 1.18;
    letter-spacing: -.045em;
}

.bk-section-desc {
    max-width: 610px;
    margin-top: 7px;
    font-size: 12px;
    line-height: 1.65;
    color: var(--bk-muted);
}

/* Kategori lebih kecil, compact, soft */
.bk-category-row {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}

.bk-category-card {
    min-height: 140px;
    padding: 16px;
    border-radius: 18px;
    border-color: var(--bk-border);
    box-shadow: 0 8px 22px rgba(31, 72, 68, .045);
}

.bk-category-icon {
    width: 34px;
    height: 34px;
    margin-bottom: 13px;
    border-radius: 13px;
    font-size: 10.5px;
    font-weight: 700;
}

.bk-category-card strong {
    margin-bottom: 5px;
    font-size: 12px;
    font-weight: 700;
}

.bk-category-card span {
    font-size: 10.8px;
    line-height: 1.5;
}

/* Produk dibuat lebih Lynk, tidak berat */
.bk-product-grid {
    gap: 18px;
}

.bk-product-card {
    border-radius: 20px;
    border-color: var(--bk-border);
    box-shadow: 0 9px 24px rgba(31, 72, 68, .045);
}

.bk-product-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 13px 28px rgba(31, 72, 68, .07);
}

.bk-product-thumb {
    margin: 10px 10px 0;
    border-radius: 16px;
    aspect-ratio: 16 / 9.6;
    background: linear-gradient(135deg, #e6faf4, #fbfffd);
}

.bk-product-thumb.dark {
    background: linear-gradient(135deg, #17433c, #1bb57f);
}

.bk-product-thumb.blue {
    background: linear-gradient(135deg, #e5f7ff, #e9fbf5);
}

.bk-badge {
    height: 22px;
    padding: 0 8px;
    font-size: 9.5px;
    font-weight: 700;
}

.bk-product-badge {
    top: 9px;
    left: 9px;
}

.bk-product-body {
    padding: 13px 14px 14px;
}

.bk-product-title {
    min-height: 39px;
    font-size: 12.5px;
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: -.015em;
}

.bk-product-meta {
    min-height: 18px;
    gap: 6px;
    margin: 9px 0;
    font-size: 10.5px;
}

.bk-price {
    font-size: 15.5px;
    font-weight: 700;
    letter-spacing: -.035em;
}

.bk-price small {
    font-size: 10px;
    font-weight: 500;
}

.bk-icon-actions {
    gap: 6px;
}

.bk-icon-btn {
    width: 27px;
    height: 27px;
    font-size: 11px;
    border-color: #e3f0ed;
    background: #f4fcf9;
}

/* Membership pricing dibuat seperti card Lynk */
.bk-membership-wrap {
    padding: 34px;
    border-radius: 28px;
    background: #e6f7f3;
    box-shadow: 0 12px 32px rgba(31, 72, 68, .035);
}

.bk-membership-grid {
    gap: 16px;
}

.bk-plan-card {
    padding: 20px;
    border-radius: 21px;
    box-shadow: 0 9px 22px rgba(31, 72, 68, .045);
}

.bk-plan-card.featured {
    transform: translateY(-5px);
    border-color: rgba(32, 191, 134, .28);
}

.bk-plan-name {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: -.02em;
}

.bk-plan-price {
    margin: 8px 0 12px;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: -.045em;
}

.bk-plan-card ul {
    gap: 7px;
    margin-bottom: 15px;
    font-size: 11.2px;
    line-height: 1.55;
}

.bk-plan-card li::before {
    margin-right: 7px;
    font-weight: 700;
}

/* Detail/listing page ikut lebih halus */
.bk-page-hero {
    padding: 54px 0 30px;
}

.bk-page-title {
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 700;
    letter-spacing: -.045em;
}

.bk-layout {
    grid-template-columns: 250px 1fr;
    gap: 20px;
}

.bk-filter-card,
.bk-content-panel,
.bk-detail-card,
.bk-buy-card {
    border-radius: 22px;
    box-shadow: 0 9px 24px rgba(31, 72, 68, .045);
}

.bk-filter-card h3 {
    font-size: 13px;
    font-weight: 700;
}

.bk-filter-list,
.bk-info-row {
    font-size: 12px;
}

.bk-chip {
    height: 31px;
    padding: 0 12px;
    font-size: 11px;
    font-weight: 600;
}

.bk-detail-card h1 {
    font-size: clamp(25px, 3vw, 34px);
    font-weight: 700;
}

.bk-buy-price {
    font-size: 26px;
    font-weight: 700;
}

/* Footer tetap gelap, tapi compact */
.bk-footer {
    margin-top: 60px;
    color: #dce9e6;
    background: linear-gradient(180deg, #203430, #111917);
}

.bk-footer-wave {
    height: 42px;
    border-radius: 0 0 44% 44%;
}

.bk-footer-inner {
    gap: 30px;
    padding: 38px 0 25px;
}

.bk-footer h4 {
    margin-bottom: 11px;
    font-size: 12px;
    font-weight: 700;
}

.bk-footer a {
    margin: 7px 0;
    font-size: 11.5px;
}

.bk-footer p {
    max-width: 300px;
    font-size: 11.5px;
    line-height: 1.75;
}

.bk-footer-bottom {
    padding: 18px 0 28px;
    font-size: 10.8px;
}

/* Responsive */
@media (max-width: 1100px) {
    .bk-category-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .bk-product-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .bk-navbar {
        border-radius: 22px;
    }

    .bk-hero {
        padding-top: 58px;
    }

    .bk-hero-grid,
    .bk-layout,
    .bk-detail-grid {
        grid-template-columns: 1fr;
    }

    .bk-hero h1 {
        max-width: 620px;
    }

    .bk-hero-visual {
        min-height: 380px;
    }

    .bk-phone-card {
        right: 50%;
        width: 230px;
        min-height: 380px;
        transform: translateX(50%) rotate(3deg);
    }

    .bk-phone-screen {
        min-height: 354px;
    }

    .bk-membership-grid,
    .bk-footer-inner {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .bk-container,
    .bk-navbar,
    .bk-footer-inner,
    .bk-footer-bottom {
        width: min(100% - 28px, 1050px);
    }

    .bk-hero {
        padding: 46px 0 38px;
    }

    .bk-hero h1 {
        font-size: 30px;
    }

    .bk-section-title {
        font-size: 23px;
    }

    .bk-section-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .bk-product-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }

    .bk-category-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
    }

    .bk-searchbar {
        border-radius: 18px;
        align-items: stretch;
        flex-direction: column;
    }

    .bk-searchbar input {
        width: 100%;
    }

    .bk-searchbar .bk-btn {
        width: 100%;
    }

    .bk-hero-actions .bk-btn {
        flex: 1 1 auto;
    }

    .bk-membership-wrap {
        padding: 22px;
        border-radius: 23px;
    }

    .bk-floating-card {
        display: none;
    }
}

@media (max-width: 560px) {
    body {
        font-size: 13px;
    }

    .bk-product-grid,
    .bk-category-row,
    .bk-membership-grid,
    .bk-footer-inner {
        grid-template-columns: 1fr;
    }

    .bk-navbar {
        top: 8px;
        width: calc(100% - 20px);
        padding: 8px 10px;
    }

    .bk-brand span:last-child {
        font-size: 12px;
    }

    .bk-phone-card {
        width: 215px;
        min-height: 355px;
    }

    .bk-phone-screen {
        min-height: 329px;
    }

    .bk-section {
        padding: 38px 0;
    }
}

/* BantuKita Lynk Exact Landing Override
   Nusa Solution www.nusasolution.com
   Purpose: membuat landing lebih dekat ke Lynk.id:
   transparent navbar, wide hero, soft blue-mint background,
   Poppins, lighter typography, bigger right mockup, geometric shape.
*/

:root {
    --bk-primary: #2fba84;
    --bk-primary-dark: #168866;
    --bk-primary-soft: #e9fbf5;
    --bk-lynk-bg: #e9fbff;
    --bk-lynk-section: #f7fbfa;
    --bk-text: #3e4447;
    --bk-heading: #3b3f42;
    --bk-muted: #6f7779;
    --bk-border: #e4eeee;
    --bk-card: #ffffff;
    --bk-shadow-soft: 0 8px 22px rgba(42, 62, 65, .09);
    --bk-shadow-card: 0 12px 28px rgba(42, 62, 65, .07);
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: "Poppins", sans-serif !important;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.7;
    color: var(--bk-text);
    background: #fff;
    -webkit-font-smoothing: antialiased;
    text-rendering: geometricPrecision;
}

button,
input,
select,
textarea {
    font-family: "Poppins", sans-serif !important;
}

a {
    text-decoration: none;
}

/* Container dibuat selebar Lynk, bukan sempit marketplace */
.bk-container,
.bk-navbar,
.bk-footer-inner,
.bk-footer-bottom {
    width: min(1440px, calc(100% - 150px)) !important;
}

/* Navbar Lynk-style: transparan, tidak pill, tidak floating card */
.bk-navbar {
    position: absolute !important;
    top: 34px !important;
    left: 50% !important;
    z-index: 50 !important;
    transform: translateX(-50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 32px !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}

.bk-brand {
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    color: #262f33 !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    letter-spacing: -.04em !important;
}

.bk-brand-mark {
    width: 42px !important;
    height: 42px !important;
    border-radius: 13px !important;
    color: #fff !important;
    background: #2fba84 !important;
    box-shadow: none !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

.bk-navlinks {
    display: flex !important;
    align-items: center !important;
    gap: 58px !important;
    margin-left: auto !important;
    color: #1f2637 !important;
    font-size: 15px !important;
    font-weight: 600 !important;
}

.bk-navlinks a {
    color: #1f2637 !important;
}

.bk-navlinks a:hover {
    color: var(--bk-primary-dark) !important;
}

.bk-nav-actions {
    display: flex !important;
    align-items: center !important;
    gap: 32px !important;
    margin-left: 30px !important;
}

.bk-link-muted {
    color: #1f2637 !important;
    font-size: 15px !important;
    font-weight: 600 !important;
}

.bk-btn {
    min-height: 46px !important;
    padding: 0 28px !important;
    border: 0 !important;
    border-radius: 10px !important;
    color: #fff !important;
    background: #2fba84 !important;
    box-shadow: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
}

.bk-btn:hover {
    background: #23a875 !important;
}

.bk-btn-sm {
    min-height: 50px !important;
    padding: 0 34px !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
}

.bk-btn-light {
    color: #2f3f40 !important;
    background: #fff !important;
    border: 1px solid #e3eded !important;
}

.bk-btn-outline {
    min-height: 38px !important;
    padding: 0 22px !important;
    color: var(--bk-primary-dark) !important;
    background: #fff !important;
    border: 1px solid rgba(47, 186, 132, .25) !important;
    border-radius: 999px !important;
}

/* Hero dibuat mirip Lynk: tinggi, full mint-blue, konten kiri, mockup kanan besar */
.bk-hero {
    position: relative !important;
    overflow: hidden !important;
    min-height: 870px !important;
    padding: 0 !important;
    background: var(--bk-lynk-bg) !important;
}

.bk-hero::before {
    content: "" !important;
    position: absolute !important;
    right: -84px !important;
    bottom: -70px !important;
    width: 330px !important;
    height: 330px !important;
    background:
        radial-gradient(circle at 0 0, transparent 0 49%, #2fba84 50% 100%),
        linear-gradient(90deg, #ffd052 0 50%, #0fd5bd 50% 100%) !important;
    border-radius: 50% 0 0 0 !important;
    opacity: 1 !important;
}

.bk-hero::after {
    content: "" !important;
    position: absolute !important;
    right: 35px !important;
    bottom: 0 !important;
    width: 210px !important;
    height: 210px !important;
    background:
        linear-gradient(90deg, #2fba84 0 50%, transparent 50% 100%),
        linear-gradient(180deg, transparent 0 50%, #2fba84 50% 100%) !important;
    border-radius: 210px 0 0 0 !important;
    opacity: .95 !important;
}

.bk-hero-grid {
    position: relative !important;
    z-index: 2 !important;
    display: grid !important;
    grid-template-columns: .92fr 1.08fr !important;
    align-items: center !important;
    gap: 88px !important;
    min-height: 870px !important;
    padding-top: 78px !important;
}

/* Kicker disamarkan, karena Lynk tidak memakai badge besar */
.bk-kicker {
    display: none !important;
}

.bk-hero h1 {
    max-width: 600px !important;
    margin: 0 0 18px !important;
    color: #42484b !important;
    font-family: "Poppins", sans-serif !important;
    font-size: clamp(42px, 4.6vw, 58px) !important;
    font-weight: 600 !important;
    line-height: 1.16 !important;
    letter-spacing: -.035em !important;
}

.bk-hero h1::after {
    content: "" !important;
    display: block !important;
    width: min(100%, 610px) !important;
    height: 20px !important;
    margin-top: 18px !important;
    border-radius: 999px !important;
    background: rgba(169, 195, 199, .42) !important;
}

.bk-hero p {
    max-width: 655px !important;
    margin: 0 0 28px !important;
    color: #6e7476 !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 1.9 !important;
    letter-spacing: -.01em !important;
}

.bk-searchbar {
    display: flex !important;
    align-items: center !important;
    width: 540px !important;
    max-width: 100% !important;
    padding: 0 !important;
    gap: 14px !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.bk-searchbar input {
    flex: 1 !important;
    height: 48px !important;
    padding: 0 24px !important;
    color: #555 !important;
    background: #fff !important;
    border: 0 !important;
    outline: 0 !important;
    border-radius: 12px !important;
    box-shadow: 0 5px 12px rgba(40, 58, 61, .18) !important;
    font-size: 15px !important;
}

.bk-searchbar .bk-btn {
    min-width: 112px !important;
    min-height: 48px !important;
    padding: 0 22px !important;
    border-radius: 999px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}

.bk-hero-actions {
    display: none !important;
}

/* Mockup kanan dibuat jauh lebih dekat ke Lynk */
.bk-hero-visual {
    position: relative !important;
    min-height: 650px !important;
}

.bk-phone-card {
    position: absolute !important;
    top: 76px !important;
    right: 110px !important;
    width: 360px !important;
    min-height: 575px !important;
    padding: 18px !important;
    border-radius: 36px !important;
    background: #193d38 !important;
    box-shadow: 0 26px 52px rgba(19, 62, 58, .24) !important;
    transform: rotate(3.5deg) !important;
}

.bk-phone-card::before {
    content: "" !important;
    position: absolute !important;
    top: 32px !important;
    right: -64px !important;
    z-index: -1 !important;
    width: 235px !important;
    height: 555px !important;
    border-radius: 28px !important;
    background: linear-gradient(180deg, #effcff, #ffffff) !important;
    box-shadow: 0 12px 24px rgba(50, 80, 84, .09) !important;
    transform: rotate(2deg) !important;
}

.bk-phone-screen {
    overflow: hidden !important;
    min-height: 539px !important;
    border-radius: 26px !important;
    background: #effaf7 !important;
}

.bk-phone-head {
    position: relative !important;
    height: 190px !important;
    padding: 28px 26px !important;
    color: #fff !important;
    background:
        radial-gradient(circle at 78% 28%, rgba(255,255,255,.18), transparent 22%),
        linear-gradient(135deg, #075a55 0%, #03856e 50%, #27b982 100%) !important;
}

.bk-phone-head small {
    display: block !important;
    margin-bottom: 14px !important;
    color: rgba(255,255,255,.86) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

.bk-phone-head strong {
    display: block !important;
    max-width: 270px !important;
    color: #fff !important;
    font-size: 24px !important;
    font-weight: 600 !important;
    line-height: 1.22 !important;
    letter-spacing: -.025em !important;
}

.bk-mini-product {
    position: relative !important;
    margin: -44px 26px 18px !important;
    padding: 18px !important;
    border-radius: 17px !important;
    background: #fff !important;
    box-shadow: 0 12px 24px rgba(40, 58, 61, .13) !important;
}

.bk-mini-product + .bk-mini-product {
    margin-top: 0 !important;
}

.bk-mini-thumb {
    height: 88px !important;
    border-radius: 16px !important;
    background: linear-gradient(135deg, #d8fbf2, #ffffff) !important;
}

.bk-mini-line {
    height: 10px !important;
    margin-top: 14px !important;
    border-radius: 999px !important;
    background: #d4e9e5 !important;
}

.bk-mini-line.short {
    width: 62% !important;
}

.bk-floating-card {
    position: absolute !important;
    z-index: 5 !important;
    width: 168px !important;
    padding: 16px !important;
    color: #51595b !important;
    background: #fff !important;
    border: 0 !important;
    border-radius: 16px !important;
    box-shadow: 0 12px 28px rgba(40, 58, 61, .13) !important;
}

.bk-floating-card.one {
    left: 44px !important;
    top: 210px !important;
}

.bk-floating-card.two {
    right: 0 !important;
    bottom: 145px !important;
}

.bk-floating-card strong {
    display: block !important;
    margin-bottom: 8px !important;
    color: #3e4548 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

.bk-floating-card span {
    display: block !important;
    color: #7a8587 !important;
    font-size: 12px !important;
    line-height: 1.75 !important;
}

/* Section bawah tetap BantuKita, tapi dibuat lebih Lynk: lebih ringan */
.bk-section {
    padding: 72px 0 !important;
    background: #fff !important;
}

.bk-section-soft {
    background: #f7fbfa !important;
}

.bk-section-head {
    display: flex !important;
    align-items: end !important;
    justify-content: space-between !important;
    gap: 20px !important;
    margin-bottom: 34px !important;
}

.bk-section-title {
    margin: 0 !important;
    color: #3c4547 !important;
    font-size: 30px !important;
    font-weight: 600 !important;
    line-height: 1.25 !important;
    letter-spacing: -.035em !important;
}

.bk-section-desc {
    max-width: 640px !important;
    margin: 8px 0 0 !important;
    color: #7a8587 !important;
    font-size: 14px !important;
    line-height: 1.8 !important;
}

.bk-category-row {
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 24px !important;
}

.bk-category-card {
    min-height: 160px !important;
    padding: 24px !important;
    background: #fff !important;
    border: 1px solid var(--bk-border) !important;
    border-radius: 20px !important;
    box-shadow: 0 8px 24px rgba(42, 62, 65, .055) !important;
}

.bk-category-icon {
    width: 38px !important;
    height: 38px !important;
    margin-bottom: 18px !important;
    color: #7a9290 !important;
    background: #e9fbf5 !important;
    border-radius: 14px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}

.bk-category-card strong {
    display: block !important;
    margin-bottom: 8px !important;
    color: #334043 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}

.bk-category-card span {
    color: #7a8587 !important;
    font-size: 12.5px !important;
    line-height: 1.75 !important;
}

.bk-product-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 26px !important;
}

.bk-product-card {
    overflow: hidden !important;
    background: #fff !important;
    border: 1px solid var(--bk-border) !important;
    border-radius: 22px !important;
    box-shadow: 0 10px 28px rgba(42, 62, 65, .06) !important;
}

.bk-product-thumb {
    margin: 12px 12px 0 !important;
    border-radius: 17px !important;
    aspect-ratio: 16 / 10 !important;
    background: linear-gradient(135deg, #e4fbf4, #fbfffd) !important;
}

.bk-product-thumb.dark {
    background: linear-gradient(135deg, #10594e, #28bd88) !important;
}

.bk-product-thumb.blue {
    background: linear-gradient(135deg, #e7fbff, #ecfff8) !important;
}

.bk-badge {
    min-height: 22px !important;
    padding: 0 9px !important;
    border-radius: 999px !important;
    color: #168866 !important;
    background: #e9fbf5 !important;
    font-size: 10px !important;
    font-weight: 600 !important;
}

.bk-product-body {
    padding: 16px !important;
}

.bk-product-title {
    min-height: 40px !important;
    color: #334043 !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
}

.bk-product-meta {
    color: #7a8587 !important;
    font-size: 11.5px !important;
}

.bk-price {
    color: #334043 !important;
    font-size: 17px !important;
    font-weight: 600 !important;
}

.bk-icon-btn {
    width: 30px !important;
    height: 30px !important;
    color: #168866 !important;
    background: #f1fbf7 !important;
    border: 1px solid #dcf1eb !important;
}

/* Membership tidak terlalu berat */
.bk-membership-wrap {
    padding: 44px !important;
    background: #e9f8f5 !important;
    border-radius: 30px !important;
    box-shadow: none !important;
}

.bk-membership-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 22px !important;
}

.bk-plan-card {
    padding: 26px !important;
    background: #fff !important;
    border: 1px solid var(--bk-border) !important;
    border-radius: 23px !important;
    box-shadow: 0 10px 26px rgba(42, 62, 65, .055) !important;
}

.bk-plan-card.featured {
    transform: none !important;
    border-color: rgba(47, 186, 132, .28) !important;
}

.bk-plan-name {
    color: #168866 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

.bk-plan-price {
    margin: 9px 0 14px !important;
    color: #334043 !important;
    font-size: 28px !important;
    font-weight: 600 !important;
    letter-spacing: -.04em !important;
}

.bk-plan-card li {
    color: #6f7779 !important;
    font-size: 12.5px !important;
}

/* Footer compact */
.bk-footer {
    margin-top: 70px !important;
    background: #10201e !important;
}

.bk-footer-wave {
    height: 38px !important;
}

.bk-footer h4 {
    font-size: 13px !important;
    font-weight: 600 !important;
}

.bk-footer p,
.bk-footer a,
.bk-footer-bottom {
    font-size: 12px !important;
    font-weight: 400 !important;
}

/* Responsive */
@media (max-width: 1200px) {
    .bk-container,
    .bk-navbar,
    .bk-footer-inner,
    .bk-footer-bottom {
        width: min(100% - 56px, 1140px) !important;
    }

    .bk-navlinks {
        gap: 28px !important;
    }

    .bk-hero-grid {
        gap: 48px !important;
    }

    .bk-phone-card {
        right: 50px !important;
        width: 320px !important;
    }

    .bk-category-row {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 980px) {
    .bk-navbar {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        transform: none !important;
        width: calc(100% - 32px) !important;
        padding: 18px 0 !important;
        flex-wrap: wrap !important;
    }

    .bk-navlinks {
        order: 3 !important;
        width: 100% !important;
        justify-content: center !important;
        gap: 22px !important;
        overflow-x: auto !important;
    }

    .bk-nav-actions {
        margin-left: 0 !important;
        gap: 14px !important;
    }

    .bk-hero {
        min-height: auto !important;
        padding: 30px 0 70px !important;
    }

    .bk-hero-grid {
        grid-template-columns: 1fr !important;
        min-height: auto !important;
        padding-top: 30px !important;
    }

    .bk-hero h1 {
        font-size: 40px !important;
    }

    .bk-hero p {
        font-size: 16px !important;
    }

    .bk-hero-visual {
        min-height: 580px !important;
    }

    .bk-phone-card {
        left: 50% !important;
        right: auto !important;
        transform: translateX(-50%) rotate(3deg) !important;
    }

    .bk-product-grid,
    .bk-membership-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    .bk-container,
    .bk-navbar,
    .bk-footer-inner,
    .bk-footer-bottom {
        width: calc(100% - 28px) !important;
    }

    .bk-brand {
        font-size: 16px !important;
    }

    .bk-navlinks {
        justify-content: flex-start !important;
        font-size: 13px !important;
    }

    .bk-link-muted {
        font-size: 13px !important;
    }

    .bk-btn-sm {
        min-height: 40px !important;
        padding: 0 18px !important;
        font-size: 13px !important;
    }

    .bk-hero h1 {
        font-size: 32px !important;
    }

    .bk-hero h1::after {
        height: 12px !important;
    }

    .bk-hero p {
        font-size: 14px !important;
    }

    .bk-searchbar {
        width: 100% !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
    }

    .bk-searchbar .bk-btn {
        width: 100% !important;
    }

    .bk-hero-visual {
        min-height: 450px !important;
    }

    .bk-phone-card {
        width: 250px !important;
        min-height: 420px !important;
    }

    .bk-phone-screen {
        min-height: 384px !important;
    }

    .bk-phone-head {
        height: 150px !important;
    }

    .bk-phone-head strong {
        font-size: 18px !important;
    }

    .bk-floating-card {
        display: none !important;
    }

    .bk-category-row,
    .bk-product-grid,
    .bk-membership-grid {
        grid-template-columns: 1fr !important;
    }

    .bk-section {
        padding: 48px 0 !important;
    }

    .bk-section-title {
        font-size: 24px !important;
    }

    .bk-membership-wrap {
        padding: 24px !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Hero Lottie Refinement
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Update:
| - Hero memakai lottie custom dari user
| - Visual lebih rapi, modern, soft seperti Lynk
| - Mengurangi kesan marketplace tebal/kaku
|--------------------------------------------------------------------------
*/

.bk-hero {
    min-height: 790px !important;
}

.bk-hero-grid {
    min-height: 790px !important;
    grid-template-columns: .9fr 1.1fr !important;
    gap: 70px !important;
}

.bk-hero h1 {
    max-width: 610px !important;
    font-size: clamp(40px, 4.2vw, 54px) !important;
    font-weight: 600 !important;
    line-height: 1.16 !important;
    color: #3f4648 !important;
}

.bk-hero p {
    max-width: 640px !important;
    font-size: 17px !important;
    line-height: 1.85 !important;
    color: #717c7e !important;
}

.bk-hero h1::after {
    width: min(100%, 600px) !important;
    height: 17px !important;
    margin-top: 18px !important;
    background: rgba(166, 194, 199, .42) !important;
}

.bk-searchbar {
    width: 535px !important;
}

.bk-searchbar input {
    height: 48px !important;
    border-radius: 13px !important;
}

.bk-searchbar .bk-btn {
    height: 48px !important;
    border-radius: 999px !important;
}

/* Lottie hero */
.bk-hero-visual-lottie {
    position: relative !important;
    display: grid !important;
    place-items: center !important;
    min-height: 610px !important;
}

.bk-hero-lottie-glow {
    position: absolute !important;
    inset: 50% auto auto 50% !important;
    width: 520px !important;
    height: 520px !important;
    transform: translate(-50%, -50%) !important;
    border-radius: 999px !important;
    background:
        radial-gradient(circle, rgba(47, 186, 132, .22) 0%, rgba(47, 186, 132, .09) 38%, transparent 68%) !important;
    filter: blur(4px) !important;
    pointer-events: none !important;
}

.bk-lottie-panel {
    position: relative !important;
    z-index: 2 !important;
    width: min(600px, 100%) !important;
    min-height: 520px !important;
    display: grid !important;
    place-items: center !important;
    padding: 16px !important;
}

.bk-hero-lottie {
    width: min(560px, 100%) !important;
    height: 500px !important;
    display: block !important;
    filter: drop-shadow(0 28px 46px rgba(32, 72, 68, .12)) !important;
}

/* Floating cards diposisikan ulang mengikuti lottie */
.bk-hero-visual-lottie .bk-floating-card {
    z-index: 4 !important;
    width: 178px !important;
    padding: 17px 18px !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, .92) !important;
    border: 1px solid rgba(224, 239, 235, .88) !important;
    box-shadow: 0 16px 34px rgba(42, 62, 65, .12) !important;
    backdrop-filter: blur(12px) !important;
}

.bk-hero-visual-lottie .bk-floating-card.one {
    left: 42px !important;
    top: 185px !important;
}

.bk-hero-visual-lottie .bk-floating-card.two {
    right: 24px !important;
    bottom: 138px !important;
}

.bk-hero-visual-lottie .bk-floating-card strong {
    color: #334043 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

.bk-hero-visual-lottie .bk-floating-card span {
    color: #738082 !important;
    font-size: 12px !important;
    line-height: 1.75 !important;
}

/* Dekorasi kanan bawah tetap Lynk-like tapi lebih halus agar tidak tabrakan dengan lottie */
.bk-hero::before {
    right: -105px !important;
    bottom: -95px !important;
    width: 340px !important;
    height: 340px !important;
    opacity: .88 !important;
}

.bk-hero::after {
    right: 24px !important;
    width: 190px !important;
    height: 190px !important;
    opacity: .86 !important;
}

/* Section pertama dinaikkan agar transisi hero lebih premium */
.bk-hero + .bk-section {
    padding-top: 70px !important;
}

/* Navbar sedikit dipoles agar tidak terasa terlalu besar */
.bk-navbar {
    top: 30px !important;
}

.bk-brand {
    font-size: 18px !important;
}

.bk-brand-mark {
    width: 38px !important;
    height: 38px !important;
    border-radius: 12px !important;
}

.bk-navlinks {
    gap: 46px !important;
    font-size: 14px !important;
}

.bk-nav-actions {
    gap: 25px !important;
}

.bk-link-muted {
    font-size: 14px !important;
}

.bk-btn-sm {
    min-height: 46px !important;
    padding: 0 30px !important;
    font-size: 14px !important;
}

/* Product/cards refinement */
.bk-section-title {
    font-size: 28px !important;
    font-weight: 600 !important;
}

.bk-category-card,
.bk-product-card,
.bk-plan-card {
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease !important;
}

.bk-category-card:hover,
.bk-product-card:hover,
.bk-plan-card:hover {
    transform: translateY(-3px) !important;
    border-color: rgba(47, 186, 132, .22) !important;
    box-shadow: 0 16px 34px rgba(42, 62, 65, .08) !important;
}

@media (max-width: 1200px) {
    .bk-hero-grid {
        gap: 42px !important;
    }

    .bk-lottie-panel {
        width: min(520px, 100%) !important;
    }

    .bk-hero-lottie {
        width: min(500px, 100%) !important;
        height: 460px !important;
    }

    .bk-hero-visual-lottie .bk-floating-card.one {
        left: 0 !important;
    }

    .bk-hero-visual-lottie .bk-floating-card.two {
        right: 0 !important;
    }
}

@media (max-width: 980px) {
    .bk-hero {
        min-height: auto !important;
    }

    .bk-hero-grid {
        min-height: auto !important;
        grid-template-columns: 1fr !important;
    }

    .bk-hero-visual-lottie {
        min-height: 500px !important;
    }

    .bk-lottie-panel {
        min-height: 470px !important;
    }

    .bk-hero-lottie {
        height: 440px !important;
    }

    .bk-hero-visual-lottie .bk-floating-card.one {
        left: 40px !important;
        top: 120px !important;
    }

    .bk-hero-visual-lottie .bk-floating-card.two {
        right: 40px !important;
        bottom: 90px !important;
    }
}

@media (max-width: 640px) {
    .bk-hero h1 {
        font-size: 32px !important;
    }

    .bk-hero p {
        font-size: 14px !important;
    }

    .bk-hero-visual-lottie {
        min-height: 360px !important;
    }

    .bk-lottie-panel {
        min-height: 340px !important;
        padding: 0 !important;
    }

    .bk-hero-lottie {
        height: 330px !important;
    }

    .bk-hero-visual-lottie .bk-floating-card {
        display: none !important;
    }

    .bk-hero::before,
    .bk-hero::after {
        opacity: .42 !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Ideal Typography Refinement
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Tujuan:
| - Font tidak terlalu kecil
| - Tetap clean, soft, dan Lynk-like
| - Lebih nyaman dibaca di card, section, navbar, footer
|--------------------------------------------------------------------------
*/

body {
    font-size: 15px !important;
    line-height: 1.72 !important;
    font-weight: 400 !important;
}

/* Navbar ideal: tidak kebesaran, tapi terbaca */
.bk-brand {
    font-size: 18px !important;
    font-weight: 700 !important;
}

.bk-brand-mark {
    width: 38px !important;
    height: 38px !important;
    font-size: 12px !important;
}

.bk-navlinks,
.bk-link-muted {
    font-size: 14.5px !important;
    font-weight: 600 !important;
}

.bk-navlinks {
    gap: 42px !important;
}

.bk-btn,
.bk-btn-sm,
.bk-searchbar .bk-btn {
    font-size: 14.5px !important;
    font-weight: 600 !important;
}

/* Hero: tetap elegan, tidak terlalu kecil */
.bk-hero h1 {
    font-size: clamp(42px, 4.4vw, 56px) !important;
    font-weight: 600 !important;
    line-height: 1.15 !important;
    letter-spacing: -.035em !important;
}

.bk-hero p {
    max-width: 660px !important;
    font-size: 18px !important;
    line-height: 1.82 !important;
    color: #697577 !important;
}

.bk-searchbar input {
    font-size: 15px !important;
}

/* Section title dan deskripsi */
.bk-section-title {
    font-size: 31px !important;
    font-weight: 600 !important;
    line-height: 1.25 !important;
    letter-spacing: -.035em !important;
}

.bk-section-desc {
    font-size: 14.5px !important;
    line-height: 1.75 !important;
    color: #6f7c7e !important;
}

/* Kategori: sebelumnya terlalu kecil */
.bk-category-card {
    min-height: 172px !important;
    padding: 25px !important;
}

.bk-category-icon {
    width: 40px !important;
    height: 40px !important;
    font-size: 12.5px !important;
}

.bk-category-card strong {
    font-size: 14.5px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
}

.bk-category-card span {
    font-size: 13.3px !important;
    line-height: 1.72 !important;
    color: #6f7c7e !important;
}

/* Product card: judul, meta, harga dibesarkan ideal */
.bk-product-body {
    padding: 17px !important;
}

.bk-product-title {
    min-height: 44px !important;
    font-size: 14.2px !important;
    font-weight: 600 !important;
    line-height: 1.46 !important;
    color: #313f42 !important;
}

.bk-product-meta {
    font-size: 12.5px !important;
    line-height: 1.55 !important;
    color: #748183 !important;
}

.bk-price {
    font-size: 18px !important;
    font-weight: 600 !important;
}

.bk-badge {
    min-height: 24px !important;
    padding: 0 10px !important;
    font-size: 10.8px !important;
    font-weight: 600 !important;
}

.bk-icon-btn {
    width: 31px !important;
    height: 31px !important;
    font-size: 13px !important;
}

/* Membership pricing */
.bk-membership-wrap {
    padding: 44px !important;
}

.bk-plan-name {
    font-size: 14px !important;
    font-weight: 600 !important;
}

.bk-plan-price {
    font-size: 30px !important;
    font-weight: 600 !important;
}

.bk-plan-card ul,
.bk-plan-card li {
    font-size: 13.4px !important;
    line-height: 1.7 !important;
}

.bk-plan-card .bk-btn,
.bk-plan-card .bk-btn-light {
    font-size: 14px !important;
}

/* Artikel */
.bk-article-card .bk-product-title,
.bk-article-card strong,
.bk-post-title,
.bk-card-title {
    font-size: 14.5px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
}

.bk-article-card p,
.bk-post-excerpt,
.bk-card-text {
    font-size: 13.5px !important;
    line-height: 1.75 !important;
}

/* Floating card hero */
.bk-floating-card strong,
.bk-hero-visual-lottie .bk-floating-card strong {
    font-size: 14px !important;
    font-weight: 600 !important;
}

.bk-floating-card span,
.bk-hero-visual-lottie .bk-floating-card span {
    font-size: 13px !important;
    line-height: 1.7 !important;
}

/* Footer jangan kekecilan */
.bk-footer h4 {
    font-size: 14px !important;
    font-weight: 600 !important;
}

.bk-footer p,
.bk-footer a {
    font-size: 13.2px !important;
    line-height: 1.75 !important;
}

.bk-footer-bottom {
    font-size: 12.5px !important;
}

/* Page umum/listing/detail kalau ada */
.bk-page-title {
    font-size: clamp(34px, 4vw, 48px) !important;
    font-weight: 600 !important;
}

.bk-filter-card h3,
.bk-content-panel h3,
.bk-detail-card h3,
.bk-buy-card h3 {
    font-size: 16px !important;
    font-weight: 600 !important;
}

.bk-filter-list,
.bk-info-row,
.bk-chip {
    font-size: 13.5px !important;
}

/* Mobile: tetap tidak membesar berlebihan */
@media (max-width: 760px) {
    body {
        font-size: 14px !important;
    }

    .bk-hero h1 {
        font-size: 34px !important;
    }

    .bk-hero p {
        font-size: 15px !important;
    }

    .bk-section-title {
        font-size: 25px !important;
    }

    .bk-section-desc {
        font-size: 13.8px !important;
    }

    .bk-category-card strong,
    .bk-product-title {
        font-size: 14px !important;
    }

    .bk-category-card span,
    .bk-product-meta,
    .bk-plan-card li,
    .bk-footer p,
    .bk-footer a {
        font-size: 13px !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Product Access Flow v1
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Update:
| - filter katalog aktif
| - detail produk lebih readable
| - access-check page untuk guest/member
|--------------------------------------------------------------------------
*/

.bk-filter-list a.is-active {
    color: #168866 !important;
    background: #e9fbf5 !important;
    border-radius: 999px !important;
    padding: 7px 11px !important;
    font-weight: 600 !important;
}

.bk-filterbar a.bk-chip {
    text-decoration: none !important;
}

.bk-result-note {
    margin: 0 0 18px !important;
    color: #748183 !important;
    font-size: 13.5px !important;
}

.bk-empty-state {
    grid-column: 1 / -1 !important;
    display: grid !important;
    gap: 6px !important;
    padding: 34px !important;
    border: 1px solid #e4eeee !important;
    border-radius: 24px !important;
    background: #ffffff !important;
    color: #334043 !important;
    box-shadow: 0 10px 28px rgba(42, 62, 65, .055) !important;
}

.bk-empty-state strong {
    font-size: 18px !important;
    font-weight: 600 !important;
}

.bk-empty-state span {
    color: #748183 !important;
    font-size: 14px !important;
}

.bk-preview-placeholder {
    display: grid !important;
    place-content: center !important;
    min-height: 330px !important;
    gap: 10px !important;
    text-align: center !important;
    border-radius: 22px !important;
    background: linear-gradient(135deg, #e6fbf4, #fbfffd) !important;
}

.bk-preview-placeholder span {
    justify-self: center !important;
    padding: 6px 12px !important;
    border-radius: 999px !important;
    color: #168866 !important;
    background: #ffffff !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}

.bk-preview-placeholder strong {
    max-width: 520px !important;
    color: #334043 !important;
    font-size: 26px !important;
    font-weight: 600 !important;
    line-height: 1.25 !important;
}

.bk-buy-desc {
    margin: 8px 0 18px !important;
    color: #748183 !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
}

.bk-access-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 360px !important;
    gap: 24px !important;
    align-items: start !important;
}

.bk-access-card {
    padding: 34px !important;
    border: 1px solid #e4eeee !important;
    border-radius: 28px !important;
    background: #ffffff !important;
    box-shadow: 0 12px 32px rgba(42, 62, 65, .06) !important;
}

.bk-access-card h2 {
    margin: 18px 0 10px !important;
    color: #334043 !important;
    font-size: 30px !important;
    font-weight: 600 !important;
    letter-spacing: -.035em !important;
}

.bk-access-card p {
    max-width: 640px !important;
    color: #6f7c7e !important;
    font-size: 15px !important;
    line-height: 1.75 !important;
}

.bk-access-status {
    display: grid !important;
    gap: 5px !important;
    margin: 24px 0 !important;
    padding: 20px !important;
    border-radius: 22px !important;
    border: 1px solid #e4eeee !important;
    background: #f8fcfb !important;
}

.bk-access-status strong {
    font-size: 18px !important;
    font-weight: 600 !important;
}

.bk-access-status span {
    color: #748183 !important;
    font-size: 14px !important;
}

.bk-access-status.is-allowed {
    border-color: rgba(47, 186, 132, .28) !important;
    background: #e9fbf5 !important;
}

.bk-access-status.is-locked {
    border-color: rgba(222, 172, 65, .3) !important;
    background: #fffaf0 !important;
}

.bk-access-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
}

.bk-alert {
    margin-bottom: 16px !important;
    padding: 14px 16px !important;
    border-radius: 18px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}

.bk-alert.success {
    color: #168866 !important;
    background: #e9fbf5 !important;
}

.bk-alert.danger {
    color: #bd3850 !important;
    background: #fff0f3 !important;
}

@media (max-width: 980px) {
    .bk-access-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 640px) {
    .bk-access-card {
        padding: 24px !important;
    }

    .bk-access-card h2 {
        font-size: 24px !important;
    }

    .bk-access-actions .bk-btn,
    .bk-access-actions form {
        width: 100% !important;
    }

    .bk-access-actions button,
    .bk-access-actions a {
        width: 100% !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Membership Purchase Flow v1
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
*/

.bk-membership-status-card {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin-bottom: 22px !important;
    padding: 24px !important;
    border: 1px solid #e4eeee !important;
    border-radius: 26px !important;
    background: linear-gradient(135deg, #ffffff, #f4fffb) !important;
    box-shadow: 0 12px 30px rgba(42, 62, 65, .055) !important;
}

.bk-membership-status-card h2 {
    margin: 12px 0 6px !important;
    color: #334043 !important;
    font-size: 26px !important;
    font-weight: 600 !important;
    letter-spacing: -.035em !important;
}

.bk-membership-status-card p {
    margin: 0 !important;
    color: #6f7c7e !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
}

.bk-plan-duration {
    display: inline-flex !important;
    align-items: center !important;
    width: max-content !important;
    min-height: 28px !important;
    margin: 0 0 14px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    color: #168866 !important;
    background: #e9fbf5 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}

.bk-plan-card form {
    margin-top: auto !important;
}

.bk-membership-login-note {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    margin-top: 22px !important;
    padding: 18px !important;
    border: 1px solid #e4eeee !important;
    border-radius: 22px !important;
    background: #ffffff !important;
    box-shadow: 0 10px 26px rgba(42, 62, 65, .045) !important;
}

.bk-membership-login-note strong {
    color: #334043 !important;
    font-size: 15px !important;
    font-weight: 600 !important;
}

.bk-membership-login-note span {
    flex: 1 !important;
    color: #6f7c7e !important;
    font-size: 14px !important;
}

@media (max-width: 760px) {
    .bk-membership-status-card,
    .bk-membership-login-note {
        align-items: stretch !important;
        flex-direction: column !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Public Catalog Refine v1
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Fokus:
| - Category/product listing lebih rapi
| - Navbar tidak nabrak title
| - Hero listing tidak terlalu tinggi/kosong
| - Card katalog lebih ideal
|--------------------------------------------------------------------------
*/

/* Navbar public listing: lebih stabil di halaman internal */
.bk-navbar {
    z-index: 100 !important;
}

body:has(.bk-catalog-hero) .bk-navbar {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
    width: min(1440px, calc(100% - 150px)) !important;
    margin: 28px auto 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

body:has(.bk-catalog-hero) .bk-brand {
    font-size: 18px !important;
}

body:has(.bk-catalog-hero) .bk-brand-mark {
    width: 38px !important;
    height: 38px !important;
    border-radius: 12px !important;
}

body:has(.bk-catalog-hero) .bk-navlinks {
    gap: 38px !important;
    font-size: 14px !important;
}

body:has(.bk-catalog-hero) .bk-nav-actions {
    gap: 18px !important;
}

body:has(.bk-catalog-hero) .bk-nav-actions .bk-link-muted,
body:has(.bk-catalog-hero) .bk-nav-actions a {
    font-size: 14px !important;
    font-weight: 600 !important;
}

body:has(.bk-catalog-hero) .bk-nav-actions .bk-btn,
body:has(.bk-catalog-hero) .bk-nav-actions button.bk-btn {
    min-height: 44px !important;
    padding: 0 26px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
}

/* Page hero listing jangan terlalu tinggi */
.bk-catalog-hero {
    padding: 48px 0 34px !important;
    background: #ffffff !important;
}

.bk-catalog-hero .bk-container {
    width: min(1440px, calc(100% - 150px)) !important;
}

.bk-catalog-hero .bk-kicker {
    display: inline-flex !important;
    margin-bottom: 12px !important;
    padding: 6px 11px !important;
    border-radius: 999px !important;
    color: #168866 !important;
    background: #e9fbf5 !important;
    border: 1px solid rgba(32, 191, 134, .16) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
}

.bk-catalog-hero .bk-page-title {
    max-width: 820px !important;
    margin: 0 !important;
    color: #3f4648 !important;
    font-size: clamp(42px, 5vw, 64px) !important;
    font-weight: 600 !important;
    line-height: 1.08 !important;
    letter-spacing: -.055em !important;
}

.bk-catalog-hero .bk-section-desc {
    max-width: 720px !important;
    margin-top: 18px !important;
    color: #6f7c7e !important;
    font-size: 16px !important;
    line-height: 1.75 !important;
}

/* Listing section lebih naik dan tidak terlalu kosong */
.bk-catalog-section {
    padding: 34px 0 78px !important;
    background: #ffffff !important;
}

.bk-catalog-section > .bk-container,
.bk-catalog-layout {
    width: min(1440px, calc(100% - 150px)) !important;
}

/* Sidebar filter dibuat lebih compact tapi readable */
.bk-catalog-layout {
    grid-template-columns: 250px minmax(0, 1fr) !important;
    gap: 22px !important;
    align-items: start !important;
}

.bk-sidebar {
    display: grid !important;
    gap: 16px !important;
}

.bk-filter-card {
    padding: 22px !important;
    border-radius: 23px !important;
    border: 1px solid #e4eeee !important;
    background: #ffffff !important;
    box-shadow: 0 10px 26px rgba(42, 62, 65, .045) !important;
}

.bk-filter-card h3 {
    margin: 0 0 14px !important;
    color: #3f4c4e !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    letter-spacing: -.02em !important;
}

.bk-filter-list {
    display: grid !important;
    gap: 4px !important;
}

.bk-filter-list a,
.bk-filter-list span {
    display: flex !important;
    align-items: center !important;
    min-height: 36px !important;
    padding: 0 11px !important;
    border-radius: 999px !important;
    color: #435b58 !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
}

.bk-filter-list a:hover {
    color: #168866 !important;
    background: #f1fbf7 !important;
}

.bk-filter-list a.is-active {
    color: #168866 !important;
    background: #e9fbf5 !important;
}

/* Content panel lebih efisien, tidak terlalu lebar kosong */
.bk-catalog-panel {
    padding: 34px !important;
    border: 1px solid #e4eeee !important;
    border-radius: 26px !important;
    background: #ffffff !important;
    box-shadow: 0 12px 30px rgba(42, 62, 65, .045) !important;
}

/* Search katalog */
.bk-catalog-panel .bk-searchbar {
    width: min(680px, 100%) !important;
    margin-bottom: 18px !important;
    gap: 12px !important;
}

.bk-catalog-panel .bk-searchbar input {
    height: 46px !important;
    border-radius: 13px !important;
    font-size: 14px !important;
    box-shadow: 0 8px 18px rgba(42, 62, 65, .08) !important;
}

.bk-catalog-panel .bk-searchbar .bk-btn {
    min-width: 104px !important;
    min-height: 46px !important;
    border-radius: 999px !important;
    font-size: 14px !important;
}

.bk-catalog-panel .bk-filterbar {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-bottom: 22px !important;
}

.bk-catalog-panel .bk-chip {
    min-height: 34px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    border: 1px solid #e2eeee !important;
    color: #435b58 !important;
    background: #ffffff !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

.bk-catalog-panel .bk-chip.active {
    color: #ffffff !important;
    background: #2fba84 !important;
    border-color: #2fba84 !important;
}

.bk-result-note {
    margin: 4px 0 22px !important;
    color: #768588 !important;
    font-size: 14px !important;
}

/* Product grid kategori: isi kiri, card ideal, kanan tidak terasa kosong */
.bk-catalog-panel .bk-product-grid {
    grid-template-columns: repeat(auto-fill, minmax(238px, 1fr)) !important;
    gap: 22px !important;
    align-items: stretch !important;
}

.bk-catalog-panel .bk-product-card {
    max-width: none !important;
    border-radius: 22px !important;
    box-shadow: 0 10px 26px rgba(42, 62, 65, .06) !important;
}

.bk-catalog-panel .bk-product-thumb {
    margin: 12px 12px 0 !important;
    aspect-ratio: 16 / 9.8 !important;
    border-radius: 18px !important;
}

.bk-catalog-panel .bk-product-body {
    padding: 17px !important;
}

.bk-catalog-panel .bk-product-title {
    min-height: 42px !important;
    color: #334043 !important;
    font-size: 14.3px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
}

.bk-catalog-panel .bk-product-meta {
    margin: 11px 0 !important;
    color: #768588 !important;
    font-size: 12.5px !important;
}

.bk-catalog-panel .bk-price {
    font-size: 18px !important;
    font-weight: 600 !important;
}

/* Logged-in nav: supaya Dashboard/Admin/Logout tidak bikin sesak */
@media (min-width: 981px) {
    body:has(.bk-catalog-hero) .bk-navlinks {
        margin-left: auto !important;
    }

    body:has(.bk-catalog-hero) .bk-nav-actions {
        margin-left: 18px !important;
    }
}

/* Responsive */
@media (max-width: 1200px) {
    body:has(.bk-catalog-hero) .bk-navbar,
    .bk-catalog-hero .bk-container,
    .bk-catalog-section > .bk-container,
    .bk-catalog-layout {
        width: min(100% - 56px, 1140px) !important;
    }

    body:has(.bk-catalog-hero) .bk-navlinks {
        gap: 22px !important;
    }

    .bk-catalog-layout {
        grid-template-columns: 230px minmax(0, 1fr) !important;
    }

    .bk-catalog-panel .bk-product-grid {
        grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
    }
}

@media (max-width: 980px) {
    body:has(.bk-catalog-hero) .bk-navbar {
        width: calc(100% - 32px) !important;
        margin-top: 18px !important;
        flex-wrap: wrap !important;
    }

    body:has(.bk-catalog-hero) .bk-navlinks {
        order: 3 !important;
        width: 100% !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        gap: 18px !important;
        padding-bottom: 4px !important;
    }

    .bk-catalog-hero {
        padding: 34px 0 28px !important;
    }

    .bk-catalog-hero .bk-page-title {
        font-size: 42px !important;
    }

    .bk-catalog-layout {
        grid-template-columns: 1fr !important;
    }

    .bk-sidebar {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .bk-sidebar .bk-filter-card:last-child {
        grid-column: 1 / -1 !important;
    }

    .bk-catalog-panel {
        padding: 24px !important;
    }
}

@media (max-width: 640px) {
    body:has(.bk-catalog-hero) .bk-navbar,
    .bk-catalog-hero .bk-container,
    .bk-catalog-section > .bk-container,
    .bk-catalog-layout {
        width: calc(100% - 28px) !important;
    }

    .bk-catalog-hero .bk-page-title {
        font-size: 34px !important;
    }

    .bk-catalog-hero .bk-section-desc {
        font-size: 14px !important;
    }

    .bk-sidebar {
        grid-template-columns: 1fr !important;
    }

    .bk-catalog-panel {
        padding: 18px !important;
        border-radius: 22px !important;
    }

    .bk-catalog-panel .bk-searchbar {
        display: grid !important;
        width: 100% !important;
    }

    .bk-catalog-panel .bk-searchbar .bk-btn {
        width: 100% !important;
    }

    .bk-catalog-panel .bk-product-grid {
        grid-template-columns: 1fr !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Public Header Consistency v1
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Tujuan:
| - Homepage boleh punya hero besar Lynk-style.
| - Semua halaman internal public memakai header compact yang konsisten.
| - Products/category/membership/articles tidak punya header berbeda-beda.
|--------------------------------------------------------------------------
*/

/* Default public navbar untuk halaman internal */
body:not(:has(.bk-hero:not(.bk-page-hero))) .bk-navbar,
body:has(.bk-page-hero) .bk-navbar,
body:has(.bk-catalog-hero) .bk-navbar {
    position: sticky !important;
    top: 16px !important;
    left: auto !important;
    z-index: 100 !important;
    transform: none !important;
    width: min(1180px, calc(100% - 48px)) !important;
    min-height: 58px !important;
    margin: 16px auto 0 !important;
    padding: 8px 10px !important;
    border: 1px solid rgba(224, 239, 235, .92) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .92) !important;
    box-shadow: 0 10px 26px rgba(42, 62, 65, .06) !important;
    backdrop-filter: blur(16px) !important;
}

/* Homepage tetap boleh absolute/hero besar */
body:has(.bk-hero-grid) .bk-navbar {
    position: absolute !important;
    top: 30px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: min(1440px, calc(100% - 150px)) !important;
    min-height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}

/* Tapi kalau halaman internal juga punya bk-catalog-hero, override homepage rule */
body:has(.bk-catalog-hero) .bk-navbar,
body:has(.bk-internal-hero) .bk-navbar {
    position: sticky !important;
    top: 16px !important;
    left: auto !important;
    transform: none !important;
    width: min(1180px, calc(100% - 48px)) !important;
    margin: 16px auto 0 !important;
    padding: 8px 10px !important;
    border: 1px solid rgba(224, 239, 235, .92) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .92) !important;
    box-shadow: 0 10px 26px rgba(42, 62, 65, .06) !important;
    backdrop-filter: blur(16px) !important;
}

/* Navbar sizing konsisten */
body:has(.bk-page-hero) .bk-brand,
body:has(.bk-catalog-hero) .bk-brand,
body:has(.bk-internal-hero) .bk-brand {
    gap: 10px !important;
    color: #263735 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: -.03em !important;
}

body:has(.bk-page-hero) .bk-brand-mark,
body:has(.bk-catalog-hero) .bk-brand-mark,
body:has(.bk-internal-hero) .bk-brand-mark {
    width: 36px !important;
    height: 36px !important;
    border-radius: 13px !important;
    font-size: 11px !important;
}

body:has(.bk-page-hero) .bk-navlinks,
body:has(.bk-catalog-hero) .bk-navlinks,
body:has(.bk-internal-hero) .bk-navlinks {
    gap: 30px !important;
    margin-left: auto !important;
    color: #1f2d2b !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
}

body:has(.bk-page-hero) .bk-navlinks a,
body:has(.bk-catalog-hero) .bk-navlinks a,
body:has(.bk-internal-hero) .bk-navlinks a {
    color: #1f2d2b !important;
}

body:has(.bk-page-hero) .bk-nav-actions,
body:has(.bk-catalog-hero) .bk-nav-actions,
body:has(.bk-internal-hero) .bk-nav-actions {
    gap: 12px !important;
    margin-left: 18px !important;
}

body:has(.bk-page-hero) .bk-link-muted,
body:has(.bk-catalog-hero) .bk-link-muted,
body:has(.bk-internal-hero) .bk-link-muted {
    color: #1f2d2b !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
}

body:has(.bk-page-hero) .bk-nav-actions .bk-btn,
body:has(.bk-catalog-hero) .bk-nav-actions .bk-btn,
body:has(.bk-internal-hero) .bk-nav-actions .bk-btn {
    min-height: 40px !important;
    padding: 0 22px !important;
    border-radius: 999px !important;
    font-size: 13.5px !important;
}

/* Header internal seragam */
.bk-page-hero,
.bk-catalog-hero,
.bk-internal-hero {
    position: relative !important;
    overflow: hidden !important;
    margin-top: 18px !important;
    padding: 54px 0 44px !important;
    background:
        radial-gradient(circle at 82% 18%, rgba(47, 186, 132, .09), transparent 28%),
        linear-gradient(180deg, #eefcfb 0%, #ffffff 100%) !important;
}

.bk-page-hero::after,
.bk-catalog-hero::after,
.bk-internal-hero::after {
    content: "" !important;
    position: absolute !important;
    right: -90px !important;
    bottom: -120px !important;
    width: 260px !important;
    height: 260px !important;
    border-radius: 999px !important;
    background: rgba(47, 186, 132, .11) !important;
    pointer-events: none !important;
}

.bk-page-hero .bk-container,
.bk-catalog-hero .bk-container,
.bk-internal-hero .bk-container {
    position: relative !important;
    z-index: 2 !important;
    width: min(1180px, calc(100% - 48px)) !important;
}

.bk-page-hero .bk-kicker,
.bk-catalog-hero .bk-kicker,
.bk-internal-hero .bk-kicker {
    display: inline-flex !important;
    align-items: center !important;
    width: max-content !important;
    min-height: 28px !important;
    margin-bottom: 16px !important;
    padding: 0 12px !important;
    border: 1px solid rgba(47, 186, 132, .16) !important;
    border-radius: 999px !important;
    color: #168866 !important;
    background: #e9fbf5 !important;
    font-size: 11.5px !important;
    font-weight: 700 !important;
}

.bk-page-title,
.bk-catalog-hero .bk-page-title,
.bk-internal-hero .bk-page-title {
    max-width: 860px !important;
    margin: 0 !important;
    color: #344341 !important;
    font-size: clamp(38px, 4.8vw, 58px) !important;
    font-weight: 600 !important;
    line-height: 1.1 !important;
    letter-spacing: -.052em !important;
}

.bk-page-hero .bk-section-desc,
.bk-catalog-hero .bk-section-desc,
.bk-internal-hero .bk-section-desc {
    max-width: 760px !important;
    margin-top: 18px !important;
    color: #697577 !important;
    font-size: 16px !important;
    line-height: 1.75 !important;
}

/* Catalog area setelah header internal */
.bk-catalog-section {
    padding-top: 46px !important;
}

.bk-catalog-section > .bk-container,
.bk-catalog-layout {
    width: min(1180px, calc(100% - 48px)) !important;
}

/* Catalog layout tidak terlalu melebar agar sama dengan internal header */
.bk-catalog-layout {
    grid-template-columns: 250px minmax(0, 1fr) !important;
    gap: 22px !important;
}

.bk-catalog-panel {
    padding: 28px !important;
    border-radius: 26px !important;
}

.bk-catalog-panel .bk-product-grid {
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)) !important;
    gap: 20px !important;
}

/* Remove konflik lama dari catalog refine yang bikin products/category beda */
body:has(.bk-catalog-hero) .bk-catalog-hero {
    background:
        radial-gradient(circle at 82% 18%, rgba(47, 186, 132, .09), transparent 28%),
        linear-gradient(180deg, #eefcfb 0%, #ffffff 100%) !important;
}

/* Responsive */
@media (max-width: 1180px) {
    body:has(.bk-page-hero) .bk-navbar,
    body:has(.bk-catalog-hero) .bk-navbar,
    body:has(.bk-internal-hero) .bk-navbar,
    .bk-page-hero .bk-container,
    .bk-catalog-hero .bk-container,
    .bk-internal-hero .bk-container,
    .bk-catalog-section > .bk-container,
    .bk-catalog-layout {
        width: min(100% - 40px, 1080px) !important;
    }

    body:has(.bk-page-hero) .bk-navlinks,
    body:has(.bk-catalog-hero) .bk-navlinks,
    body:has(.bk-internal-hero) .bk-navlinks {
        gap: 20px !important;
    }
}

@media (max-width: 980px) {
    body:has(.bk-page-hero) .bk-navbar,
    body:has(.bk-catalog-hero) .bk-navbar,
    body:has(.bk-internal-hero) .bk-navbar {
        top: 10px !important;
        width: calc(100% - 28px) !important;
        flex-wrap: wrap !important;
        border-radius: 24px !important;
    }

    body:has(.bk-page-hero) .bk-navlinks,
    body:has(.bk-catalog-hero) .bk-navlinks,
    body:has(.bk-internal-hero) .bk-navlinks {
        order: 3 !important;
        width: 100% !important;
        justify-content: flex-start !important;
        gap: 16px !important;
        overflow-x: auto !important;
        padding: 4px 4px 2px !important;
    }

    .bk-page-hero,
    .bk-catalog-hero,
    .bk-internal-hero {
        padding: 42px 0 36px !important;
    }

    .bk-page-title,
    .bk-catalog-hero .bk-page-title,
    .bk-internal-hero .bk-page-title {
        font-size: 38px !important;
    }

    .bk-catalog-layout {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 640px) {
    body:has(.bk-page-hero) .bk-navbar,
    body:has(.bk-catalog-hero) .bk-navbar,
    body:has(.bk-internal-hero) .bk-navbar,
    .bk-page-hero .bk-container,
    .bk-catalog-hero .bk-container,
    .bk-internal-hero .bk-container,
    .bk-catalog-section > .bk-container,
    .bk-catalog-layout {
        width: calc(100% - 28px) !important;
    }

    .bk-page-hero,
    .bk-catalog-hero,
    .bk-internal-hero {
        padding: 34px 0 30px !important;
    }

    .bk-page-title,
    .bk-catalog-hero .bk-page-title,
    .bk-internal-hero .bk-page-title {
        font-size: 32px !important;
    }

    .bk-page-hero .bk-section-desc,
    .bk-catalog-hero .bk-section-desc,
    .bk-internal-hero .bk-section-desc {
        font-size: 14px !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Public Header Route Class Fix v1
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Fix final:
| - Homepage memakai .bk-page-home
| - Internal page memakai .bk-page-internal
| - Tidak mengandalkan :has() untuk membedakan header
|--------------------------------------------------------------------------
*/

/* HOME: tetap Lynk-style hero besar */
body.bk-page-home .bk-navbar {
    position: absolute !important;
    top: 30px !important;
    left: 50% !important;
    z-index: 100 !important;
    transform: translateX(-50%) !important;
    width: min(1440px, calc(100% - 150px)) !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}

/* INTERNAL: navbar compact konsisten */
body.bk-page-internal .bk-navbar {
    position: sticky !important;
    top: 14px !important;
    left: auto !important;
    z-index: 100 !important;
    transform: none !important;
    width: min(1180px, calc(100% - 48px)) !important;
    min-height: 58px !important;
    margin: 16px auto 0 !important;
    padding: 8px 10px !important;
    border: 1px solid rgba(224, 239, 235, .92) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .94) !important;
    box-shadow: 0 10px 26px rgba(42, 62, 65, .06) !important;
    backdrop-filter: blur(16px) !important;
}

/* Internal navbar sizing */
body.bk-page-internal .bk-brand {
    gap: 10px !important;
    color: #263735 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: -.03em !important;
}

body.bk-page-internal .bk-brand-mark {
    width: 36px !important;
    height: 36px !important;
    border-radius: 13px !important;
    font-size: 11px !important;
}

body.bk-page-internal .bk-navlinks {
    gap: 30px !important;
    margin-left: auto !important;
    color: #1f2d2b !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
}

body.bk-page-internal .bk-navlinks a {
    color: #1f2d2b !important;
}

body.bk-page-internal .bk-nav-actions {
    gap: 12px !important;
    margin-left: 18px !important;
}

body.bk-page-internal .bk-link-muted {
    color: #1f2d2b !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
}

body.bk-page-internal .bk-nav-actions .bk-btn,
body.bk-page-internal .bk-nav-actions button.bk-btn {
    min-height: 40px !important;
    padding: 0 22px !important;
    border-radius: 999px !important;
    font-size: 13.5px !important;
}

/* Internal hero compact, tidak boleh jadi hero homepage */
body.bk-page-internal .bk-page-hero,
body.bk-page-internal .bk-catalog-hero,
body.bk-page-internal .bk-internal-hero {
    position: relative !important;
    overflow: hidden !important;
    min-height: 0 !important;
    margin-top: 18px !important;
    padding: 58px 0 46px !important;
    background:
        radial-gradient(circle at 82% 18%, rgba(47, 186, 132, .09), transparent 28%),
        linear-gradient(180deg, #eefcfb 0%, #ffffff 100%) !important;
}

/* Jangan tampilkan elemen hero homepage di internal kalau kebawa karena selector lama */
body.bk-page-internal .bk-hero-grid,
body.bk-page-internal .bk-hero-visual,
body.bk-page-internal .bk-hero-visual-lottie,
body.bk-page-internal .bk-lottie-panel,
body.bk-page-internal .bk-hero-lottie,
body.bk-page-internal .bk-hero-lottie-glow {
    display: none !important;
}

body.bk-page-internal .bk-page-hero::after,
body.bk-page-internal .bk-catalog-hero::after,
body.bk-page-internal .bk-internal-hero::after {
    content: "" !important;
    position: absolute !important;
    right: -90px !important;
    bottom: -120px !important;
    width: 260px !important;
    height: 260px !important;
    border-radius: 999px !important;
    background: rgba(47, 186, 132, .11) !important;
    pointer-events: none !important;
}

body.bk-page-internal .bk-page-hero .bk-container,
body.bk-page-internal .bk-catalog-hero .bk-container,
body.bk-page-internal .bk-internal-hero .bk-container {
    position: relative !important;
    z-index: 2 !important;
    width: min(1180px, calc(100% - 48px)) !important;
}

body.bk-page-internal .bk-kicker {
    display: inline-flex !important;
    align-items: center !important;
    width: max-content !important;
    min-height: 28px !important;
    margin-bottom: 16px !important;
    padding: 0 12px !important;
    border: 1px solid rgba(47, 186, 132, .16) !important;
    border-radius: 999px !important;
    color: #168866 !important;
    background: #e9fbf5 !important;
    font-size: 11.5px !important;
    font-weight: 700 !important;
}

body.bk-page-internal .bk-page-title {
    max-width: 860px !important;
    margin: 0 !important;
    color: #344341 !important;
    font-size: clamp(38px, 4.8vw, 58px) !important;
    font-weight: 600 !important;
    line-height: 1.1 !important;
    letter-spacing: -.052em !important;
}

body.bk-page-internal .bk-page-hero .bk-section-desc,
body.bk-page-internal .bk-catalog-hero .bk-section-desc,
body.bk-page-internal .bk-internal-hero .bk-section-desc {
    max-width: 760px !important;
    margin-top: 18px !important;
    color: #697577 !important;
    font-size: 16px !important;
    line-height: 1.75 !important;
}

/* Catalog layout internal */
body.bk-page-internal .bk-catalog-section {
    padding: 46px 0 78px !important;
    background: #ffffff !important;
}

body.bk-page-internal .bk-catalog-section > .bk-container,
body.bk-page-internal .bk-catalog-layout {
    width: min(1180px, calc(100% - 48px)) !important;
}

body.bk-page-internal .bk-catalog-layout {
    grid-template-columns: 250px minmax(0, 1fr) !important;
    gap: 22px !important;
    align-items: start !important;
}

body.bk-page-internal .bk-catalog-panel {
    padding: 28px !important;
    border-radius: 26px !important;
}

body.bk-page-internal .bk-catalog-panel .bk-searchbar {
    width: min(680px, 100%) !important;
}

body.bk-page-internal .bk-catalog-panel .bk-product-grid {
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)) !important;
    gap: 20px !important;
}

/* Hilangkan efek rule lama yang membuat /products jadi hero besar */
body.bk-page-internal .bk-hero {
    min-height: 0 !important;
}

body.bk-page-internal .bk-hero::before {
    display: none !important;
}

/* Responsive */
@media (max-width: 1180px) {
    body.bk-page-home .bk-navbar {
        width: min(100% - 56px, 1140px) !important;
    }

    body.bk-page-internal .bk-navbar,
    body.bk-page-internal .bk-page-hero .bk-container,
    body.bk-page-internal .bk-catalog-hero .bk-container,
    body.bk-page-internal .bk-internal-hero .bk-container,
    body.bk-page-internal .bk-catalog-section > .bk-container,
    body.bk-page-internal .bk-catalog-layout {
        width: min(100% - 40px, 1080px) !important;
    }

    body.bk-page-internal .bk-navlinks {
        gap: 20px !important;
    }
}

@media (max-width: 980px) {
    body.bk-page-home .bk-navbar,
    body.bk-page-internal .bk-navbar {
        position: sticky !important;
        top: 10px !important;
        left: auto !important;
        transform: none !important;
        width: calc(100% - 28px) !important;
        flex-wrap: wrap !important;
        margin: 12px auto 0 !important;
        padding: 8px 10px !important;
        border: 1px solid rgba(224, 239, 235, .92) !important;
        border-radius: 24px !important;
        background: rgba(255, 255, 255, .94) !important;
        box-shadow: 0 10px 26px rgba(42, 62, 65, .06) !important;
    }

    body.bk-page-internal .bk-navlinks,
    body.bk-page-home .bk-navlinks {
        order: 3 !important;
        width: 100% !important;
        justify-content: flex-start !important;
        gap: 16px !important;
        overflow-x: auto !important;
        padding: 4px 4px 2px !important;
    }

    body.bk-page-internal .bk-page-hero,
    body.bk-page-internal .bk-catalog-hero,
    body.bk-page-internal .bk-internal-hero {
        padding: 42px 0 36px !important;
    }

    body.bk-page-internal .bk-page-title {
        font-size: 38px !important;
    }

    body.bk-page-internal .bk-catalog-layout {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 640px) {
    body.bk-page-internal .bk-navbar,
    body.bk-page-internal .bk-page-hero .bk-container,
    body.bk-page-internal .bk-catalog-hero .bk-container,
    body.bk-page-internal .bk-internal-hero .bk-container,
    body.bk-page-internal .bk-catalog-section > .bk-container,
    body.bk-page-internal .bk-catalog-layout {
        width: calc(100% - 28px) !important;
    }

    body.bk-page-internal .bk-page-hero,
    body.bk-page-internal .bk-catalog-hero,
    body.bk-page-internal .bk-internal-hero {
        padding: 34px 0 30px !important;
    }

    body.bk-page-internal .bk-page-title {
        font-size: 32px !important;
    }

    body.bk-page-internal .bk-page-hero .bk-section-desc,
    body.bk-page-internal .bk-catalog-hero .bk-section-desc,
    body.bk-page-internal .bk-internal-hero .bk-section-desc {
        font-size: 14px !important;
    }

    body.bk-page-internal .bk-catalog-panel .bk-product-grid {
        grid-template-columns: 1fr !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Match Internal Header To Home v1
| Nusa Solution www.nusasolution.com
|--------------------------------------------------------------------------
| Header/navbar halaman internal disamakan dengan homepage.
|--------------------------------------------------------------------------
*/

/* Semua public navbar: transparent seperti homepage */
body.bk-page-home .bk-navbar,
body.bk-page-internal .bk-navbar {
    position: absolute !important;
    top: 30px !important;
    left: 50% !important;
    z-index: 100 !important;
    transform: translateX(-50%) !important;
    width: min(1440px, calc(100% - 150px)) !important;
    min-height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}

body.bk-page-home .bk-brand,
body.bk-page-internal .bk-brand {
    gap: 12px !important;
    color: #263735 !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    letter-spacing: -.03em !important;
}

body.bk-page-home .bk-brand-mark,
body.bk-page-internal .bk-brand-mark {
    width: 38px !important;
    height: 38px !important;
    border-radius: 14px !important;
    font-size: 11px !important;
}

body.bk-page-home .bk-navlinks,
body.bk-page-internal .bk-navlinks {
    gap: 36px !important;
    margin-left: auto !important;
    color: #1f2d2b !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
}

body.bk-page-home .bk-navlinks a,
body.bk-page-internal .bk-navlinks a {
    color: #1f2d2b !important;
    text-decoration: none !important;
}

body.bk-page-home .bk-nav-actions,
body.bk-page-internal .bk-nav-actions {
    gap: 14px !important;
    margin-left: 24px !important;
}

body.bk-page-home .bk-link-muted,
body.bk-page-internal .bk-link-muted {
    color: #1f2d2b !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
}

body.bk-page-home .bk-nav-actions .bk-btn,
body.bk-page-internal .bk-nav-actions .bk-btn,
body.bk-page-home .bk-nav-actions button.bk-btn,
body.bk-page-internal .bk-nav-actions button.bk-btn {
    min-height: 46px !important;
    padding: 0 28px !important;
    border-radius: 11px !important;
    font-size: 13.5px !important;
    font-weight: 700 !important;
}

/* Internal hero diberi ruang atas karena navbar absolute */
body.bk-page-internal .bk-page-hero,
body.bk-page-internal .bk-catalog-hero,
body.bk-page-internal .bk-internal-hero {
    margin-top: 0 !important;
    padding: 148px 0 56px !important;
    background:
        radial-gradient(circle at 82% 18%, rgba(47, 186, 132, .09), transparent 28%),
        linear-gradient(180deg, #eefcfb 0%, #ffffff 100%) !important;
}

/* Products/category tidak boleh menarik hero homepage/lottie */
body.bk-page-internal .bk-hero-grid,
body.bk-page-internal .bk-hero-visual,
body.bk-page-internal .bk-hero-visual-lottie,
body.bk-page-internal .bk-lottie-panel,
body.bk-page-internal .bk-hero-lottie,
body.bk-page-internal .bk-hero-lottie-glow {
    display: none !important;
}

/* Container internal align dengan header home */
body.bk-page-internal .bk-page-hero .bk-container,
body.bk-page-internal .bk-catalog-hero .bk-container,
body.bk-page-internal .bk-internal-hero .bk-container,
body.bk-page-internal .bk-catalog-section > .bk-container,
body.bk-page-internal .bk-catalog-layout {
    width: min(1440px, calc(100% - 150px)) !important;
}

/* Judul internal tetap lebih compact dari homepage */
body.bk-page-internal .bk-page-title {
    max-width: 860px !important;
    margin: 0 !important;
    color: #344341 !important;
    font-size: clamp(42px, 4.5vw, 64px) !important;
    font-weight: 600 !important;
    line-height: 1.08 !important;
    letter-spacing: -.055em !important;
}

body.bk-page-internal .bk-page-hero .bk-section-desc,
body.bk-page-internal .bk-catalog-hero .bk-section-desc,
body.bk-page-internal .bk-internal-hero .bk-section-desc {
    max-width: 760px !important;
    margin-top: 18px !important;
    color: #697577 !important;
    font-size: 16px !important;
    line-height: 1.75 !important;
}

body.bk-page-internal .bk-catalog-section {
    padding-top: 46px !important;
}

/* Tablet */
@media (max-width: 1180px) {
    body.bk-page-home .bk-navbar,
    body.bk-page-internal .bk-navbar,
    body.bk-page-internal .bk-page-hero .bk-container,
    body.bk-page-internal .bk-catalog-hero .bk-container,
    body.bk-page-internal .bk-internal-hero .bk-container,
    body.bk-page-internal .bk-catalog-section > .bk-container,
    body.bk-page-internal .bk-catalog-layout {
        width: min(100% - 56px, 1140px) !important;
    }

    body.bk-page-home .bk-navlinks,
    body.bk-page-internal .bk-navlinks {
        gap: 22px !important;
    }
}

/* Mobile: baru pakai pill agar menu tetap usable */
@media (max-width: 980px) {
    body.bk-page-home .bk-navbar,
    body.bk-page-internal .bk-navbar {
        position: sticky !important;
        top: 10px !important;
        left: auto !important;
        transform: none !important;
        width: calc(100% - 28px) !important;
        flex-wrap: wrap !important;
        margin: 12px auto 0 !important;
        padding: 8px 10px !important;
        border: 1px solid rgba(224, 239, 235, .92) !important;
        border-radius: 24px !important;
        background: rgba(255, 255, 255, .94) !important;
        box-shadow: 0 10px 26px rgba(42, 62, 65, .06) !important;
        backdrop-filter: blur(16px) !important;
    }

    body.bk-page-home .bk-navlinks,
    body.bk-page-internal .bk-navlinks {
        order: 3 !important;
        width: 100% !important;
        justify-content: flex-start !important;
        gap: 16px !important;
        overflow-x: auto !important;
        padding: 4px 4px 2px !important;
    }

    body.bk-page-internal .bk-page-hero,
    body.bk-page-internal .bk-catalog-hero,
    body.bk-page-internal .bk-internal-hero {
        padding: 46px 0 38px !important;
    }

    body.bk-page-internal .bk-page-title {
        font-size: 38px !important;
    }
}

@media (max-width: 640px) {
    body.bk-page-internal .bk-page-hero .bk-container,
    body.bk-page-internal .bk-catalog-hero .bk-container,
    body.bk-page-internal .bk-internal-hero .bk-container,
    body.bk-page-internal .bk-catalog-section > .bk-container,
    body.bk-page-internal .bk-catalog-layout {
        width: calc(100% - 28px) !important;
    }

    body.bk-page-internal .bk-page-title {
        font-size: 32px !important;
    }

    body.bk-page-internal .bk-page-hero .bk-section-desc,
    body.bk-page-internal .bk-catalog-hero .bk-section-desc,
    body.bk-page-internal .bk-internal-hero .bk-section-desc {
        font-size: 14px !important;
    }
}

/*
|--------------------------------------------------------------------------
| BantuKita Unified Landing Header
| Single source header + mobile bottom icon navigation
|--------------------------------------------------------------------------
*/

.bk-navbar[data-bk-header] {
    isolation: isolate;
}

.bk-navbar[data-bk-header] .bk-navlinks a {
    position: relative;
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    color: #243936;
    transition: color .18s ease, background .18s ease;
}

.bk-navbar[data-bk-header] .bk-navlinks a.is-active,
.bk-navbar[data-bk-header] .bk-navlinks a:hover {
    color: var(--bk-primary-dark);
}

.bk-navbar[data-bk-header] .bk-navlinks a.is-active::after {
    content: "";
    position: absolute;
    left: 12%;
    right: 12%;
    bottom: 2px;
    height: 2px;
    border-radius: 999px;
    background: var(--bk-primary);
}

.bk-logout-form {
    margin: 0;
}

.bk-logout-form .bk-btn {
    border: 0;
}

.bk-mobile-tabbar {
    display: none;
}

@media (min-width: 981px) {
    body.bk-page-home .bk-navbar[data-bk-header],
    body.bk-page-internal .bk-navbar[data-bk-header] {
        position: sticky !important;
        top: 18px !important;
        left: auto !important;
        right: auto !important;
        transform: none !important;
        width: min(1440px, calc(100% - 150px)) !important;
        margin: 18px auto 0 !important;
        padding: 12px 16px !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, .86) !important;
        border: 1px solid rgba(225, 239, 236, .86) !important;
        box-shadow: 0 14px 38px rgba(27, 75, 70, .08) !important;
        backdrop-filter: blur(18px) !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-brand,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-brand {
        flex: 0 0 auto !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-navlinks,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-navlinks {
        display: flex !important;
        justify-content: center !important;
        flex: 1 1 auto !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-nav-actions,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-nav-actions {
        flex: 0 0 auto !important;
    }
}

@media (max-width: 1180px) and (min-width: 981px) {
    body.bk-page-home .bk-navbar[data-bk-header],
    body.bk-page-internal .bk-navbar[data-bk-header] {
        width: min(100% - 56px, 1140px) !important;
    }
}

@media (max-width: 980px) {
    body {
        padding-bottom: calc(76px + env(safe-area-inset-bottom));
    }

    body.bk-page-home .bk-navbar[data-bk-header],
    body.bk-page-internal .bk-navbar[data-bk-header] {
        position: sticky !important;
        top: 10px !important;
        z-index: 40 !important;
        display: flex !important;
        flex-wrap: nowrap !important;
        width: calc(100% - 28px) !important;
        margin: 12px auto 0 !important;
        padding: 9px 10px !important;
        border-radius: 22px !important;
        background: rgba(255, 255, 255, .94) !important;
        border: 1px solid rgba(224, 239, 235, .92) !important;
        box-shadow: 0 10px 26px rgba(42, 62, 65, .06) !important;
        backdrop-filter: blur(16px) !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-brand,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-brand {
        min-width: 0 !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-brand span:last-child,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-brand span:last-child {
        font-size: 14px !important;
        white-space: nowrap !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-brand-mark,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-brand-mark {
        width: 34px !important;
        height: 34px !important;
        border-radius: 12px !important;
        font-size: 12px !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-navlinks,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-navlinks {
        display: none !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-nav-actions,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-nav-actions {
        margin-left: auto !important;
        gap: 8px !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-nav-actions .bk-link-muted,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-nav-actions .bk-link-muted {
        display: none !important;
    }

    body.bk-page-home .bk-navbar[data-bk-header] .bk-nav-actions .bk-btn,
    body.bk-page-internal .bk-navbar[data-bk-header] .bk-nav-actions .bk-btn {
        min-height: 34px !important;
        padding: 0 13px !important;
        border-radius: 12px !important;
        font-size: 12px !important;
        box-shadow: none !important;
    }

    .bk-mobile-tabbar {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: calc(10px + env(safe-area-inset-bottom));
        z-index: 70;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 4px;
        min-height: 64px;
        padding: 8px;
        border-radius: 24px;
        background: rgba(255, 255, 255, .94);
        border: 1px solid rgba(215, 234, 230, .9);
        box-shadow: 0 20px 48px rgba(23, 58, 55, .14);
        backdrop-filter: blur(18px);
    }

    .bk-mobile-tabbar a {
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4px;
        min-width: 0;
        min-height: 48px;
        border-radius: 17px;
        color: #667b78;
        font-size: 10.5px;
        font-weight: 750;
        line-height: 1;
        transition: color .18s ease, background .18s ease, transform .18s ease;
    }

    .bk-mobile-tabbar a svg {
        width: 21px;
        height: 21px;
        fill: currentColor;
    }

    .bk-mobile-tabbar a span {
        display: block;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .bk-mobile-tabbar a.is-active {
        color: var(--bk-primary-dark);
        background: var(--bk-primary-soft);
    }

    .bk-mobile-tabbar a:active {
        transform: translateY(1px);
    }

    body.bk-page-internal .bk-page-hero,
    body.bk-page-internal .bk-catalog-hero,
    body.bk-page-internal .bk-internal-hero {
        padding-top: 44px !important;
    }
}

@media (max-width: 420px) {
    .bk-mobile-tabbar {
        left: 8px;
        right: 8px;
        bottom: calc(8px + env(safe-area-inset-bottom));
        border-radius: 22px;
    }

    .bk-mobile-tabbar a {
        font-size: 10px;
        border-radius: 15px;
    }

    .bk-mobile-tabbar a svg {
        width: 20px;
        height: 20px;
    }
}

/* === BANTUKITA MOBILE FRIENDLY REVAMP START === */
/*
|--------------------------------------------------------------------------
| BantuKita Mobile Friendly Revamp
| Scope: mobile/tablet only. Desktop tetap mengikuti style existing.
|--------------------------------------------------------------------------
*/

@media (max-width: 980px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    body {
        padding-bottom: calc(82px + env(safe-area-inset-bottom)) !important;
        background: linear-gradient(180deg, #eefaf7 0%, #ffffff 32%, #f8fcfb 100%) !important;
    }

    .bk-container,
    .bk-footer-inner,
    .bk-footer-bottom {
        width: min(100% - 28px, 760px) !important;
    }

    /*
    | Header mobile
    */
    .bk-navbar,
    .bk-navbar[data-bk-header] {
        position: sticky !important;
        top: 8px !important;
        z-index: 60 !important;
        width: calc(100% - 24px) !important;
        min-height: 52px !important;
        margin: 10px auto 0 !important;
        padding: 8px 10px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 10px !important;
        border-radius: 20px !important;
        background: rgba(255, 255, 255, .94) !important;
        border: 1px solid rgba(222, 239, 235, .9) !important;
        box-shadow: 0 10px 28px rgba(31, 72, 68, .08) !important;
        backdrop-filter: blur(16px) !important;
    }

    .bk-brand {
        min-width: 0 !important;
        gap: 8px !important;
        font-size: 14px !important;
    }

    .bk-brand-mark {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        border-radius: 12px !important;
        font-size: 11px !important;
        box-shadow: none !important;
    }

    .bk-brand span:last-child {
        max-width: 130px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        font-size: 14px !important;
        letter-spacing: -.03em !important;
    }

    .bk-navlinks {
        display: none !important;
    }

    .bk-nav-actions {
        margin-left: auto !important;
        gap: 8px !important;
        flex-shrink: 0 !important;
    }

    .bk-nav-actions .bk-link-muted {
        display: none !important;
    }

    .bk-nav-actions .bk-btn,
    .bk-logout-form .bk-btn {
        min-height: 32px !important;
        padding: 0 12px !important;
        border-radius: 12px !important;
        font-size: 11.5px !important;
        box-shadow: none !important;
    }

    /*
    | Bottom navigation
    */
    .bk-mobile-tabbar {
        left: 10px !important;
        right: 10px !important;
        bottom: calc(9px + env(safe-area-inset-bottom)) !important;
        min-height: 62px !important;
        padding: 7px !important;
        border-radius: 22px !important;
        background: rgba(255, 255, 255, .95) !important;
        border: 1px solid rgba(214, 234, 230, .94) !important;
        box-shadow: 0 18px 42px rgba(20, 63, 58, .16) !important;
        backdrop-filter: blur(18px) !important;
    }

    .bk-mobile-tabbar a {
        min-height: 47px !important;
        border-radius: 16px !important;
        gap: 3px !important;
        font-size: 10px !important;
        font-weight: 700 !important;
    }

    .bk-mobile-tabbar a svg {
        width: 20px !important;
        height: 20px !important;
    }

    /*
    | Hero mobile
    */
    .bk-hero {
        min-height: auto !important;
        padding: 30px 0 34px !important;
    }

    .bk-hero-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        min-height: auto !important;
        padding-top: 0 !important;
        align-items: start !important;
    }

    .bk-kicker {
        padding: 6px 10px !important;
        border-radius: 999px !important;
        font-size: 10.5px !important;
        line-height: 1.2 !important;
    }

    .bk-hero h1 {
        max-width: 100% !important;
        margin: 14px 0 12px !important;
        font-size: clamp(28px, 9vw, 38px) !important;
        line-height: 1.03 !important;
        letter-spacing: -.055em !important;
    }

    .bk-hero p {
        max-width: 100% !important;
        margin: 0 0 16px !important;
        font-size: 13px !important;
        line-height: 1.65 !important;
    }

    .bk-searchbar {
        width: 100% !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 7px !important;
        padding: 6px !important;
        border-radius: 18px !important;
        box-shadow: 0 8px 22px rgba(31, 72, 68, .06) !important;
    }

    .bk-searchbar input {
        width: 100% !important;
        min-width: 0 !important;
        height: 40px !important;
        padding: 0 12px !important;
        font-size: 12px !important;
    }

    .bk-searchbar .bk-btn {
        min-height: 40px !important;
        padding: 0 14px !important;
        border-radius: 14px !important;
        font-size: 12px !important;
        white-space: nowrap !important;
    }

    .bk-hero-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 9px !important;
        margin-top: 12px !important;
    }

    .bk-hero-actions .bk-btn {
        width: 100% !important;
        min-height: 40px !important;
        padding: 0 12px !important;
        border-radius: 14px !important;
        font-size: 12px !important;
        box-shadow: none !important;
    }

    /*
    | Hero illustration mobile dibuat lebih pendek supaya tidak makan layar
    */
    .bk-hero-visual,
    .bk-hero-visual-lottie {
        min-height: 250px !important;
        height: 250px !important;
        margin-top: 2px !important;
        overflow: hidden !important;
    }

    .bk-lottie-panel {
        width: min(280px, 86vw) !important;
        height: 230px !important;
        left: 50% !important;
        right: auto !important;
        top: 8px !important;
        transform: translateX(-50%) !important;
        border-radius: 30px !important;
    }

    .bk-hero-lottie {
        width: 100% !important;
        height: 100% !important;
        transform: none !important;
    }

    .bk-hero-lottie-glow {
        width: 280px !important;
        height: 280px !important;
        left: 50% !important;
        top: 0 !important;
        transform: translateX(-50%) !important;
        opacity: .72 !important;
    }

    .bk-phone-card {
        width: 230px !important;
        min-height: 350px !important;
        left: 50% !important;
        right: auto !important;
        transform: translateX(-50%) rotate(3deg) !important;
    }

    .bk-phone-screen {
        min-height: 318px !important;
    }

    .bk-floating-card {
        display: none !important;
    }

    /*
    | Section spacing
    */
    .bk-section {
        padding: 28px 0 !important;
    }

    .bk-section-soft {
        background: #f7fcfa !important;
    }

    .bk-section-head {
        display: flex !important;
        align-items: flex-start !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        gap: 12px !important;
        margin-bottom: 14px !important;
    }

    .bk-section-head > div {
        min-width: 0 !important;
    }

    .bk-section-title {
        margin: 0 !important;
        font-size: clamp(20px, 6vw, 26px) !important;
        line-height: 1.12 !important;
        letter-spacing: -.045em !important;
    }

    .bk-section-desc {
        margin-top: 6px !important;
        font-size: 12px !important;
        line-height: 1.6 !important;
    }

    .bk-section-head .bk-btn,
    .bk-section-head .bk-btn-outline {
        min-height: 32px !important;
        padding: 0 10px !important;
        border-radius: 11px !important;
        font-size: 10.5px !important;
        white-space: nowrap !important;
        box-shadow: none !important;
    }

    /*
    | Category cards
    */
    .bk-category-row {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    .bk-category-card {
        display: grid !important;
        grid-template-columns: 34px minmax(0, 1fr) !important;
        column-gap: 11px !important;
        row-gap: 2px !important;
        align-items: center !important;
        padding: 13px !important;
        border-radius: 18px !important;
        box-shadow: 0 8px 20px rgba(31, 72, 68, .045) !important;
    }

    .bk-category-icon {
        grid-row: span 2 !important;
        width: 34px !important;
        height: 34px !important;
        margin: 0 !important;
        border-radius: 12px !important;
        font-size: 11px !important;
    }

    .bk-category-card strong {
        margin: 0 !important;
        font-size: 12.5px !important;
        line-height: 1.25 !important;
    }

    .bk-category-card span:not(.bk-category-icon) {
        display: block !important;
        min-width: 0 !important;
        color: var(--bk-muted) !important;
        font-size: 11.2px !important;
        line-height: 1.45 !important;
    }

    /*
    | Product cards
    */
    .bk-product-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .bk-product-card {
        border-radius: 20px !important;
        box-shadow: 0 8px 22px rgba(31, 72, 68, .05) !important;
        transform: none !important;
    }

    .bk-product-card:hover {
        transform: none !important;
    }

    .bk-product-thumb {
        margin: 10px 10px 0 !important;
        border-radius: 16px !important;
        aspect-ratio: 16 / 9 !important;
        height: auto !important;
        min-height: 128px !important;
    }

    .bk-badge,
    .bk-product-badge {
        height: 23px !important;
        padding: 0 8px !important;
        border-radius: 999px !important;
        font-size: 9.8px !important;
        font-weight: 750 !important;
    }

    .bk-product-badge {
        top: 9px !important;
        left: 9px !important;
    }

    .bk-product-body {
        padding: 11px 13px 13px !important;
    }

    .bk-product-title {
        min-height: 0 !important;
        display: -webkit-box !important;
        overflow: hidden !important;
        -webkit-box-orient: vertical !important;
        -webkit-line-clamp: 2 !important;
        font-size: 13px !important;
        line-height: 1.35 !important;
        letter-spacing: -.02em !important;
    }

    .bk-product-meta {
        min-height: 0 !important;
        margin: 7px 0 9px !important;
        gap: 6px !important;
        font-size: 10.8px !important;
        line-height: 1.4 !important;
    }

    .bk-product-price {
        gap: 8px !important;
    }

    .bk-price {
        font-size: 15px !important;
        letter-spacing: -.035em !important;
    }

    .bk-icon-actions {
        gap: 6px !important;
    }

    .bk-icon-btn {
        width: 28px !important;
        height: 28px !important;
        min-width: 28px !important;
        font-size: 12px !important;
    }

    /*
    | Membership
    */
    .bk-membership-wrap {
        padding: 16px !important;
        border-radius: 22px !important;
    }

    .bk-membership-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .bk-plan-card {
        padding: 16px !important;
        border-radius: 18px !important;
        box-shadow: 0 8px 20px rgba(31, 72, 68, .045) !important;
    }

    .bk-plan-card.featured {
        transform: none !important;
    }

    .bk-plan-name {
        font-size: 12px !important;
    }

    .bk-plan-price {
        margin: 7px 0 9px !important;
        font-size: 21px !important;
        letter-spacing: -.045em !important;
    }

    .bk-plan-card ul {
        gap: 6px !important;
        margin-bottom: 12px !important;
        font-size: 11.2px !important;
        line-height: 1.45 !important;
    }

    .bk-plan-card .bk-btn {
        min-height: 36px !important;
        border-radius: 12px !important;
        font-size: 11.5px !important;
        box-shadow: none !important;
    }

    /*
    | Listing/catalog pages
    */
    .bk-page-hero,
    .bk-catalog-hero,
    .bk-internal-hero {
        padding: 36px 0 22px !important;
    }

    .bk-page-title {
        font-size: clamp(30px, 10vw, 42px) !important;
        line-height: 1.04 !important;
    }

    .bk-layout,
    .bk-detail-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .bk-sidebar,
    .bk-buy-card {
        position: static !important;
    }

    .bk-filter-card,
    .bk-content-panel,
    .bk-detail-card,
    .bk-buy-card {
        border-radius: 20px !important;
        padding: 14px !important;
        box-shadow: 0 8px 22px rgba(31, 72, 68, .045) !important;
    }

    .bk-filter-list {
        display: flex !important;
        overflow-x: auto !important;
        gap: 8px !important;
        padding-bottom: 2px !important;
        scrollbar-width: none !important;
    }

    .bk-filter-list::-webkit-scrollbar {
        display: none !important;
    }

    .bk-filter-list a,
    .bk-filter-list span {
        flex: 0 0 auto !important;
        padding: 8px 11px !important;
        border-radius: 999px !important;
        background: #f4fbf8 !important;
        border: 1px solid #e1efec !important;
        font-size: 11.5px !important;
        line-height: 1 !important;
    }

    .bk-filterbar {
        gap: 7px !important;
        margin-bottom: 14px !important;
        overflow-x: auto !important;
        flex-wrap: nowrap !important;
        padding-bottom: 2px !important;
        scrollbar-width: none !important;
    }

    .bk-filterbar::-webkit-scrollbar {
        display: none !important;
    }

    .bk-chip {
        flex: 0 0 auto !important;
        height: 31px !important;
        padding: 0 11px !important;
        font-size: 11px !important;
    }

    /*
    | Detail product
    */
    .bk-detail-preview {
        border-radius: 18px !important;
        min-height: 180px !important;
        aspect-ratio: 16 / 10 !important;
        margin-bottom: 14px !important;
    }

    .bk-detail-card h1 {
        font-size: clamp(26px, 8vw, 36px) !important;
        line-height: 1.08 !important;
    }

    .bk-prose {
        font-size: 12.5px !important;
        line-height: 1.75 !important;
    }

    .bk-buy-price {
        font-size: 26px !important;
    }

    .bk-info-row {
        font-size: 12px !important;
    }

    /*
    | Footer mobile
    */
    .bk-footer {
        margin-top: 36px !important;
    }

    .bk-footer-wave {
        height: 26px !important;
    }

    .bk-footer-inner {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 18px 14px !important;
        padding: 28px 0 18px !important;
    }

    .bk-footer-about {
        grid-column: 1 / -1 !important;
    }

    .bk-footer h4 {
        margin-bottom: 8px !important;
        font-size: 12px !important;
    }

    .bk-footer p {
        max-width: 100% !important;
        margin: 8px 0 0 !important;
        font-size: 11.5px !important;
        line-height: 1.65 !important;
    }

    .bk-footer a {
        margin: 7px 0 !important;
        font-size: 11.5px !important;
        line-height: 1.35 !important;
    }

    .bk-footer-bottom {
        padding: 16px 0 calc(26px + env(safe-area-inset-bottom)) !important;
        font-size: 10.5px !important;
    }
}

@media (max-width: 420px) {
    .bk-container,
    .bk-footer-inner,
    .bk-footer-bottom {
        width: calc(100% - 22px) !important;
    }

    .bk-navbar,
    .bk-navbar[data-bk-header] {
        width: calc(100% - 18px) !important;
        border-radius: 18px !important;
    }

    .bk-brand span:last-child {
        max-width: 112px !important;
        font-size: 13px !important;
    }

    .bk-nav-actions .bk-btn,
    .bk-logout-form .bk-btn {
        padding: 0 10px !important;
        font-size: 11px !important;
    }

    .bk-hero {
        padding-top: 24px !important;
    }

    .bk-searchbar {
        grid-template-columns: 1fr !important;
    }

    .bk-searchbar .bk-btn {
        width: 100% !important;
    }

    .bk-hero-actions {
        grid-template-columns: 1fr !important;
    }

    .bk-hero-visual,
    .bk-hero-visual-lottie {
        height: 220px !important;
        min-height: 220px !important;
    }

    .bk-lottie-panel {
        width: min(250px, 88vw) !important;
        height: 205px !important;
    }

    .bk-product-thumb {
        min-height: 118px !important;
    }

    .bk-section {
        padding: 24px 0 !important;
    }

    .bk-section-head {
        flex-direction: column !important;
        gap: 8px !important;
    }

    .bk-section-head .bk-btn,
    .bk-section-head .bk-btn-outline {
        align-self: flex-start !important;
    }

    .bk-mobile-tabbar {
        left: 7px !important;
        right: 7px !important;
        bottom: calc(7px + env(safe-area-inset-bottom)) !important;
        padding: 6px !important;
        border-radius: 20px !important;
    }

    .bk-mobile-tabbar a {
        font-size: 9.5px !important;
    }

    .bk-mobile-tabbar a svg {
        width: 19px !important;
        height: 19px !important;
    }
}
/* === BANTUKITA MOBILE FRIENDLY REVAMP END === */

/* === BANTUKITA DESKTOP DROPDOWN MENU START === */
@media (min-width: 981px) {
    .bk-navbar-menu {
        width: min(1540px, calc(100% - 72px)) !important;
        min-height: 68px !important;
        padding: 12px 18px !important;
        gap: 22px !important;
        border-radius: 999px !important;
    }

    .bk-navbar-menu .bk-brand {
        flex: 0 0 auto !important;
    }

    .bk-navbar-menu .bk-navlinks-dropdown {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        flex: 1 1 auto !important;
        min-width: 0 !important;
    }

    .bk-menu-item {
        position: relative;
        display: inline-flex;
        align-items: center;
    }

    .bk-menu-trigger,
    .bk-nav-icon-only,
    .bk-cart-link,
    .bk-account-link,
    .bk-lang-pill {
        appearance: none;
        border: 0;
        background: transparent;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 7px;
        min-height: 42px;
        padding: 0 9px;
        border-radius: 14px;
        color: #213936;
        font-size: 14px;
        font-weight: 800;
        line-height: 1;
        letter-spacing: -.02em;
        cursor: pointer;
        white-space: nowrap;
        text-decoration: none;
        transition: background .18s ease, color .18s ease, transform .18s ease;
    }

    .bk-menu-trigger svg,
    .bk-nav-icon-only svg,
    .bk-cart-link svg,
    .bk-account-link svg {
        width: 20px;
        height: 20px;
        fill: currentColor;
        flex: 0 0 auto;
    }

    .bk-menu-trigger:hover,
    .bk-menu-trigger.is-active,
    .bk-menu-item.is-open > .bk-menu-trigger,
    .bk-nav-icon-only:hover,
    .bk-nav-icon-only.is-active,
    .bk-cart-link:hover,
    .bk-account-link:hover,
    .bk-account-link.is-active {
        color: var(--bk-primary-dark);
        background: rgba(226, 247, 241, .86);
    }

    .bk-menu-dropdown {
        position: absolute;
        top: calc(100% + 11px);
        left: 50%;
        transform: translateX(-50%) translateY(8px);
        z-index: 120;
        display: grid;
        min-width: 226px;
        padding: 10px;
        border-radius: 18px;
        background: rgba(255, 255, 255, .98);
        border: 1px solid rgba(217, 230, 226, .95);
        box-shadow: 0 22px 54px rgba(20, 50, 47, .16);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
        backdrop-filter: blur(18px);
    }

    .bk-menu-dropdown::before {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: -12px;
        height: 12px;
    }

    .bk-menu-dropdown-lg {
        min-width: 250px;
    }

    .bk-menu-item:hover > .bk-menu-dropdown,
    .bk-menu-item.is-open > .bk-menu-dropdown {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateX(-50%) translateY(0);
    }

    .bk-menu-dropdown a {
        display: flex;
        align-items: center;
        gap: 10px;
        min-height: 40px;
        padding: 0 12px;
        border-radius: 12px;
        color: #243936;
        font-size: 13.5px;
        font-weight: 750;
        line-height: 1.2;
        letter-spacing: -.018em;
        text-decoration: none;
        transition: background .16s ease, color .16s ease, transform .16s ease;
    }

    .bk-menu-dropdown a:hover {
        color: var(--bk-primary-dark);
        background: #edf9f5;
        transform: translateX(2px);
    }

    .bk-caret,
    .bk-external {
        width: 16px;
        min-width: 16px;
        color: #1f3e3a;
        opacity: .82;
        font-size: 18px;
        font-weight: 900;
        line-height: 1;
    }

    .bk-external {
        font-size: 15px;
    }

    .bk-nav-actions-menu {
        flex: 0 0 auto !important;
        display: flex !important;
        align-items: center !important;
        gap: 7px !important;
    }

    .bk-cart-link span {
        font-size: 12px;
        font-weight: 900;
    }

    .bk-lang-pill {
        padding: 0 8px;
        cursor: default;
    }

    .bk-navbar-menu .bk-btn-sm {
        min-height: 40px !important;
        padding: 0 16px !important;
        border-radius: 14px !important;
        font-size: 13px !important;
        box-shadow: none !important;
    }
}

@media (min-width: 981px) and (max-width: 1280px) {
    .bk-navbar-menu {
        width: min(100% - 34px, 1180px) !important;
        gap: 12px !important;
    }

    .bk-navbar-menu .bk-brand span:last-child {
        display: none !important;
    }

    .bk-navbar-menu .bk-navlinks-dropdown {
        gap: 2px !important;
    }

    .bk-menu-trigger,
    .bk-nav-icon-only,
    .bk-cart-link,
    .bk-account-link,
    .bk-lang-pill {
        padding: 0 7px !important;
        font-size: 12.5px !important;
        gap: 5px !important;
    }

    .bk-menu-trigger svg,
    .bk-nav-icon-only svg,
    .bk-cart-link svg,
    .bk-account-link svg {
        width: 18px !important;
        height: 18px !important;
    }

    .bk-navbar-menu .bk-btn-sm {
        padding: 0 12px !important;
        font-size: 12px !important;
    }
}

@media (max-width: 980px) {
    .bk-navbar-menu .bk-navlinks-dropdown {
        display: none !important;
    }

    .bk-navbar-menu .bk-cart-link,
    .bk-navbar-menu .bk-account-link,
    .bk-navbar-menu .bk-lang-pill {
        display: none !important;
    }
}
/* === BANTUKITA DESKTOP DROPDOWN MENU END === */

/* === BANTUKITA HEADER OVERLAP FIX START === */
/*
|--------------------------------------------------------------------------
| Fix desktop menu collision
| Header tetap 1 bar, menu bisa scroll halus, brand/action tidak nabrak.
|--------------------------------------------------------------------------
*/

@media (min-width: 981px) {
    .bk-navbar-menu,
    .bk-navbar[data-bk-header].bk-navbar-menu {
        display: grid !important;
        grid-template-columns: auto minmax(0, 1fr) auto !important;
        align-items: center !important;
        width: min(1780px, calc(100% - 80px)) !important;
        max-width: calc(100% - 80px) !important;
        min-height: 72px !important;
        padding: 12px 18px !important;
        gap: 18px !important;
        overflow: visible !important;
    }

    .bk-navbar-menu .bk-brand {
        position: relative !important;
        z-index: 2 !important;
        min-width: 0 !important;
        flex: none !important;
        white-space: nowrap !important;
    }

    .bk-navbar-menu .bk-brand-mark {
        flex: 0 0 auto !important;
    }

    .bk-navbar-menu .bk-brand span:last-child {
        display: inline-block !important;
        max-width: 142px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    .bk-navbar-menu .bk-navlinks-dropdown {
        min-width: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 0 4px !important;
        mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%) !important;
    }

    .bk-navbar-menu .bk-navlinks-dropdown::-webkit-scrollbar {
        display: none !important;
    }

    .bk-navbar-menu .bk-menu-item,
    .bk-navbar-menu .bk-nav-icon-only {
        flex: 0 0 auto !important;
    }

    .bk-navbar-menu .bk-menu-trigger,
    .bk-navbar-menu .bk-nav-icon-only,
    .bk-navbar-menu .bk-cart-link,
    .bk-navbar-menu .bk-account-link,
    .bk-navbar-menu .bk-lang-pill {
        min-height: 40px !important;
        padding: 0 8px !important;
        gap: 6px !important;
        font-size: 13px !important;
        font-weight: 800 !important;
    }

    .bk-navbar-menu .bk-menu-trigger svg,
    .bk-navbar-menu .bk-nav-icon-only svg,
    .bk-navbar-menu .bk-cart-link svg,
    .bk-navbar-menu .bk-account-link svg {
        width: 18px !important;
        height: 18px !important;
    }

    .bk-navbar-menu .bk-nav-actions-menu {
        position: relative !important;
        z-index: 3 !important;
        flex: none !important;
        min-width: max-content !important;
        white-space: nowrap !important;
        background: rgba(255, 255, 255, .78) !important;
        border-radius: 18px !important;
        padding-left: 4px !important;
    }

    .bk-navbar-menu .bk-btn-sm {
        min-height: 40px !important;
        padding: 0 18px !important;
        border-radius: 14px !important;
    }

    .bk-navbar-menu .bk-menu-dropdown {
        position: fixed !important;
        top: 86px !important;
        transform: translateY(8px) !important;
    }

    .bk-navbar-menu .bk-menu-item:hover > .bk-menu-dropdown,
    .bk-navbar-menu .bk-menu-item.is-open > .bk-menu-dropdown {
        transform: translateY(0) !important;
    }
}

/* Laptop / layar sedang: hemat ruang, icon + teks penting saja */
@media (min-width: 981px) and (max-width: 1380px) {
    .bk-navbar-menu,
    .bk-navbar[data-bk-header].bk-navbar-menu {
        width: calc(100% - 36px) !important;
        max-width: calc(100% - 36px) !important;
        gap: 10px !important;
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .bk-navbar-menu .bk-brand span:last-child {
        max-width: 108px !important;
    }

    .bk-navbar-menu .bk-menu-trigger,
    .bk-navbar-menu .bk-nav-icon-only,
    .bk-navbar-menu .bk-cart-link,
    .bk-navbar-menu .bk-account-link,
    .bk-navbar-menu .bk-lang-pill {
        padding: 0 7px !important;
        font-size: 12px !important;
        gap: 5px !important;
    }

    .bk-navbar-menu .bk-btn-sm {
        padding: 0 13px !important;
        font-size: 12px !important;
    }
}

/* Layar lebih sempit tapi masih desktop: sembunyikan teks menu non-prioritas */
@media (min-width: 981px) and (max-width: 1180px) {
    .bk-navbar-menu .bk-menu-trigger span {
        display: none !important;
    }

    .bk-navbar-menu .bk-account-link span,
    .bk-navbar-menu .bk-cart-link span {
        display: none !important;
    }

    .bk-navbar-menu .bk-menu-trigger,
    .bk-navbar-menu .bk-nav-icon-only,
    .bk-navbar-menu .bk-cart-link,
    .bk-navbar-menu .bk-account-link {
        width: 40px !important;
        padding: 0 !important;
    }

    .bk-navbar-menu .bk-lang-pill {
        display: none !important;
    }

    .bk-navbar-menu .bk-brand span:last-child {
        display: none !important;
    }
}

/* Ultra wide: menu boleh full tanpa terasa sempit */
@media (min-width: 1500px) {
    .bk-navbar-menu .bk-menu-trigger,
    .bk-navbar-menu .bk-nav-icon-only,
    .bk-navbar-menu .bk-cart-link,
    .bk-navbar-menu .bk-account-link,
    .bk-navbar-menu .bk-lang-pill {
        padding-left: 10px !important;
        padding-right: 10px !important;
        font-size: 13.5px !important;
    }
}
/* === BANTUKITA HEADER OVERLAP FIX END === */

/* === BANTUKITA ADMIN MANAGED HEADER START === */
@media (min-width: 981px) {
    .bk-navbar-managed,
    .bk-navbar[data-bk-header].bk-navbar-managed {
        position: sticky !important;
        top: 18px !important;
        z-index: 80 !important;
        display: grid !important;
        grid-template-columns: auto minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 18px !important;
        width: min(1680px, calc(100% - 96px)) !important;
        min-height: 72px !important;
        margin: 18px auto 0 !important;
        padding: 12px 18px !important;
        border-radius: 999px !important;
        background: rgba(255,255,255,.92) !important;
        border: 1px solid rgba(223, 238, 234, .92) !important;
        box-shadow: 0 18px 44px rgba(24, 63, 58, .08) !important;
        backdrop-filter: blur(18px) !important;
        overflow: visible !important;
    }

    .bk-navbar-managed .bk-brand {
        min-width: 170px !important;
        max-width: 190px !important;
        white-space: nowrap !important;
        z-index: 2 !important;
    }

    .bk-navbar-managed .bk-brand span:last-child {
        display: inline-block !important;
        max-width: 126px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    .bk-managed-nav {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        min-width: 0 !important;
        overflow: visible !important;
    }

    .bk-managed-item {
        position: relative !important;
        display: inline-flex !important;
        align-items: center !important;
        flex: 0 0 auto !important;
    }

    .bk-managed-trigger,
    .bk-managed-link,
    .bk-lang-pill {
        appearance: none !important;
        border: 0 !important;
        background: transparent !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 7px !important;
        min-height: 42px !important;
        padding: 0 11px !important;
        border-radius: 15px !important;
        color: #203936 !important;
        font-size: 13.5px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        letter-spacing: -.02em !important;
        white-space: nowrap !important;
        text-decoration: none !important;
        cursor: pointer !important;
        transition: background .16s ease, color .16s ease, transform .16s ease !important;
    }

    .bk-managed-trigger svg,
    .bk-managed-link svg {
        width: 18px !important;
        height: 18px !important;
        fill: currentColor !important;
        flex: 0 0 auto !important;
    }

    .bk-managed-trigger:hover,
    .bk-managed-link:hover,
    .bk-managed-item.is-open > .bk-managed-trigger {
        color: var(--bk-primary-dark) !important;
        background: #eaf8f3 !important;
    }

    .bk-managed-dropdown {
        position: absolute !important;
        top: calc(100% + 10px) !important;
        left: 50% !important;
        z-index: 120 !important;
        display: grid !important;
        min-width: 232px !important;
        padding: 10px !important;
        border-radius: 18px !important;
        background: rgba(255,255,255,.98) !important;
        border: 1px solid rgba(218, 231, 227, .95) !important;
        box-shadow: 0 24px 56px rgba(20, 54, 50, .16) !important;
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transform: translateX(-50%) translateY(8px) !important;
        transition: opacity .16s ease, transform .16s ease, visibility .16s ease !important;
        backdrop-filter: blur(18px) !important;
    }

    .bk-managed-dropdown::before {
        content: "" !important;
        position: absolute !important;
        left: 0 !important;
        right: 0 !important;
        top: -12px !important;
        height: 12px !important;
    }

    .bk-managed-item:hover > .bk-managed-dropdown,
    .bk-managed-item.is-open > .bk-managed-dropdown {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: translateX(-50%) translateY(0) !important;
    }

    .bk-managed-dropdown a {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        min-height: 40px !important;
        padding: 0 12px !important;
        border-radius: 12px !important;
        color: #243936 !important;
        font-size: 13.2px !important;
        font-weight: 750 !important;
        line-height: 1.2 !important;
        text-decoration: none !important;
        transition: background .16s ease, color .16s ease, transform .16s ease !important;
    }

    .bk-managed-dropdown a:hover {
        color: var(--bk-primary-dark) !important;
        background: #edf9f5 !important;
        transform: translateX(2px) !important;
    }

    .bk-caret,
    .bk-external {
        width: 16px !important;
        min-width: 16px !important;
        color: currentColor !important;
        opacity: .78 !important;
        font-size: 18px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
    }

    .bk-external {
        font-size: 15px !important;
    }

    .bk-managed-actions {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: 7px !important;
        min-width: max-content !important;
        z-index: 2 !important;
    }

    .bk-managed-actions .bk-btn-sm {
        min-height: 42px !important;
        padding: 0 18px !important;
        border-radius: 15px !important;
        font-size: 13px !important;
        box-shadow: none !important;
    }

    .bk-lang-pill {
        padding: 0 7px !important;
        cursor: default !important;
    }
}

@media (min-width: 981px) and (max-width: 1420px) {
    .bk-navbar-managed,
    .bk-navbar[data-bk-header].bk-navbar-managed {
        width: calc(100% - 40px) !important;
        grid-template-columns: auto minmax(0, 1fr) auto !important;
        gap: 10px !important;
        padding: 10px 14px !important;
    }

    .bk-navbar-managed .bk-brand {
        min-width: 54px !important;
        max-width: 54px !important;
    }

    .bk-navbar-managed .bk-brand span:last-child {
        display: none !important;
    }

    .bk-managed-nav {
        justify-content: flex-start !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 0 4px !important;
        mask-image: linear-gradient(90deg, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%) !important;
    }

    .bk-managed-nav::-webkit-scrollbar {
        display: none !important;
    }

    .bk-managed-trigger,
    .bk-managed-link {
        padding: 0 9px !important;
        font-size: 12.5px !important;
        gap: 6px !important;
    }

    .bk-managed-actions .bk-lang-pill {
        display: none !important;
    }

    .bk-managed-actions .bk-managed-link.is-compact {
        padding: 0 8px !important;
    }

    .bk-managed-actions .bk-btn-sm {
        padding: 0 14px !important;
        font-size: 12px !important;
    }
}

@media (min-width: 981px) and (max-width: 1120px) {
    .bk-managed-trigger span,
    .bk-managed-link:not(.is-compact) span {
        display: none !important;
    }

    .bk-managed-trigger,
    .bk-managed-link:not(.is-compact) {
        width: 40px !important;
        padding: 0 !important;
    }
}

@media (max-width: 980px) {
    .bk-navbar-managed .bk-managed-nav,
    .bk-navbar-managed .bk-managed-actions .bk-managed-link,
    .bk-navbar-managed .bk-managed-actions .bk-lang-pill {
        display: none !important;
    }
}
/* === BANTUKITA ADMIN MANAGED HEADER END === */

/* === BANTUKITA CLEAN MANAGED HEADER FINAL START === */
/*
|--------------------------------------------------------------------------
| Final header cleanup
| Desktop: menu utama ringkas, sisanya Lainnya. Mobile tetap bottom nav.
|--------------------------------------------------------------------------
*/

@media (min-width: 981px) {
    body .bk-navbar.bk-navbar-managed,
    body .bk-navbar[data-bk-header].bk-navbar-managed {
        position: sticky !important;
        top: 18px !important;
        z-index: 90 !important;
        display: grid !important;
        grid-template-columns: 190px minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 18px !important;
        width: min(1720px, calc(100% - 120px)) !important;
        max-width: calc(100% - 120px) !important;
        min-height: 72px !important;
        margin: 18px auto 0 !important;
        padding: 12px 18px !important;
        border-radius: 999px !important;
        overflow: visible !important;
        background: rgba(255, 255, 255, .94) !important;
        border: 1px solid rgba(222, 238, 234, .95) !important;
        box-shadow: 0 18px 44px rgba(23, 63, 58, .08) !important;
        backdrop-filter: blur(18px) !important;
    }

    body .bk-navbar-managed .bk-brand {
        width: 190px !important;
        min-width: 190px !important;
        max-width: 190px !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 10px !important;
        overflow: hidden !important;
        white-space: nowrap !important;
    }

    body .bk-navbar-managed .bk-brand-mark {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        border-radius: 15px !important;
        font-size: 12px !important;
    }

    body .bk-navbar-managed .bk-brand span:last-child {
        display: inline-block !important;
        max-width: 122px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        font-size: 16px !important;
        font-weight: 850 !important;
        letter-spacing: -.035em !important;
    }

    body .bk-navbar-managed .bk-managed-nav {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        min-width: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: visible !important;
    }

    body .bk-navbar-managed .bk-managed-item {
        position: relative !important;
        flex: 0 0 auto !important;
        min-width: 0 !important;
    }

    body .bk-navbar-managed .bk-managed-trigger,
    body .bk-navbar-managed .bk-managed-link,
    body .bk-navbar-managed .bk-lang-pill {
        appearance: none !important;
        border: 0 !important;
        background: transparent !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 7px !important;
        min-height: 42px !important;
        height: 42px !important;
        padding: 0 10px !important;
        border-radius: 15px !important;
        color: #203936 !important;
        font-size: 13px !important;
        font-weight: 800 !important;
        line-height: 1 !important;
        letter-spacing: -.018em !important;
        white-space: nowrap !important;
        text-decoration: none !important;
        box-shadow: none !important;
        cursor: pointer !important;
    }

    body .bk-navbar-managed .bk-managed-trigger svg,
    body .bk-navbar-managed .bk-managed-link svg {
        width: 18px !important;
        height: 18px !important;
        min-width: 18px !important;
        fill: currentColor !important;
    }

    body .bk-navbar-managed .bk-managed-trigger:hover,
    body .bk-navbar-managed .bk-managed-link:hover,
    body .bk-navbar-managed .bk-managed-item.is-open > .bk-managed-trigger {
        color: var(--bk-primary-dark) !important;
        background: #eaf8f3 !important;
    }

    body .bk-navbar-managed .bk-managed-actions {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: 7px !important;
        min-width: max-content !important;
        width: max-content !important;
        max-width: none !important;
        margin-left: 0 !important;
        position: relative !important;
        z-index: 5 !important;
    }

    body .bk-navbar-managed .bk-managed-actions .bk-managed-link.is-compact {
        padding: 0 9px !important;
    }

    body .bk-navbar-managed .bk-managed-actions .bk-btn,
    body .bk-navbar-managed .bk-managed-actions .bk-btn-sm {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-height: 42px !important;
        height: 42px !important;
        padding: 0 18px !important;
        border-radius: 15px !important;
        font-size: 13px !important;
        font-weight: 850 !important;
        white-space: nowrap !important;
        box-shadow: none !important;
    }

    body .bk-navbar-managed .bk-lang-pill {
        padding: 0 8px !important;
        cursor: default !important;
    }

    body .bk-navbar-managed .bk-managed-dropdown {
        position: absolute !important;
        top: calc(100% + 10px) !important;
        left: 50% !important;
        z-index: 150 !important;
        display: grid !important;
        min-width: 238px !important;
        max-width: min(320px, 92vw) !important;
        max-height: min(520px, calc(100vh - 130px)) !important;
        overflow-y: auto !important;
        padding: 10px !important;
        border-radius: 18px !important;
        background: rgba(255, 255, 255, .98) !important;
        border: 1px solid rgba(218, 231, 227, .95) !important;
        box-shadow: 0 24px 56px rgba(20, 54, 50, .16) !important;
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transform: translateX(-50%) translateY(8px) !important;
        transition: opacity .16s ease, transform .16s ease, visibility .16s ease !important;
        backdrop-filter: blur(18px) !important;
    }

    body .bk-navbar-managed .bk-managed-dropdown-right {
        left: auto !important;
        right: 0 !important;
        transform: translateY(8px) !important;
    }

    body .bk-navbar-managed .bk-managed-item:hover > .bk-managed-dropdown,
    body .bk-navbar-managed .bk-managed-item.is-open > .bk-managed-dropdown {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: translateX(-50%) translateY(0) !important;
    }

    body .bk-navbar-managed .bk-managed-item:hover > .bk-managed-dropdown-right,
    body .bk-navbar-managed .bk-managed-item.is-open > .bk-managed-dropdown-right {
        transform: translateY(0) !important;
    }

    body .bk-navbar-managed .bk-managed-dropdown a {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        min-height: 40px !important;
        padding: 0 12px !important;
        border-radius: 12px !important;
        color: #243936 !important;
        font-size: 13px !important;
        font-weight: 750 !important;
        line-height: 1.2 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
    }

    body .bk-navbar-managed .bk-managed-dropdown a:hover {
        color: var(--bk-primary-dark) !important;
        background: #edf9f5 !important;
    }

    body .bk-navbar-managed .bk-submenu-indent {
        padding-left: 28px !important;
        font-size: 12.5px !important;
        color: #5c716e !important;
    }

    body .bk-navbar-managed .bk-caret,
    body .bk-navbar-managed .bk-external {
        width: 16px !important;
        min-width: 16px !important;
        font-size: 17px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        color: currentColor !important;
        opacity: .72 !important;
    }
}

@media (min-width: 981px) and (max-width: 1460px) {
    body .bk-navbar.bk-navbar-managed,
    body .bk-navbar[data-bk-header].bk-navbar-managed {
        grid-template-columns: 54px minmax(0, 1fr) auto !important;
        width: calc(100% - 44px) !important;
        max-width: calc(100% - 44px) !important;
        gap: 12px !important;
        padding: 10px 14px !important;
    }

    body .bk-navbar-managed .bk-brand {
        width: 54px !important;
        min-width: 54px !important;
        max-width: 54px !important;
    }

    body .bk-navbar-managed .bk-brand span:last-child {
        display: none !important;
    }

    body .bk-navbar-managed .bk-managed-nav {
        justify-content: flex-start !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 0 4px !important;
        mask-image: linear-gradient(90deg, transparent 0, #000 14px, #000 calc(100% - 14px), transparent 100%) !important;
    }

    body .bk-navbar-managed .bk-managed-nav::-webkit-scrollbar {
        display: none !important;
    }

    body .bk-navbar-managed .bk-managed-trigger,
    body .bk-navbar-managed .bk-managed-link {
        padding: 0 9px !important;
        font-size: 12.5px !important;
    }

    body .bk-navbar-managed .bk-lang-pill {
        display: none !important;
    }

    body .bk-navbar-managed .bk-managed-actions .bk-btn,
    body .bk-navbar-managed .bk-managed-actions .bk-btn-sm {
        padding: 0 14px !important;
        font-size: 12px !important;
    }
}

@media (min-width: 981px) and (max-width: 1160px) {
    body .bk-navbar-managed .bk-managed-trigger span,
    body .bk-navbar-managed .bk-managed-link:not(.is-compact) span {
        display: none !important;
    }

    body .bk-navbar-managed .bk-managed-trigger,
    body .bk-navbar-managed .bk-managed-link:not(.is-compact) {
        width: 40px !important;
        padding: 0 !important;
    }

    body .bk-navbar-managed .bk-managed-actions .bk-managed-link.is-compact span {
        display: none !important;
    }

    body .bk-navbar-managed .bk-managed-actions .bk-managed-link.is-compact {
        width: 40px !important;
        padding: 0 !important;
    }
}

@media (max-width: 980px) {
    body .bk-navbar-managed .bk-managed-nav,
    body .bk-navbar-managed .bk-managed-actions .bk-managed-link,
    body .bk-navbar-managed .bk-managed-actions .bk-lang-pill {
        display: none !important;
    }
}
/* === BANTUKITA CLEAN MANAGED HEADER FINAL END === */

/* === BANTUKITA UNIFIED HEADER FINAL STABLE START === */
@media (min-width: 981px) {
    body .bk-navbar,
    body .bk-navbar-menu,
    body .bk-navbar-managed {
        display: none !important;
    }

    body .bk-unified-header {
        position: sticky !important;
        top: 18px !important;
        z-index: 1000 !important;
        display: grid !important;
        grid-template-columns: 210px minmax(0, 1fr) auto !important;
        align-items: center !important;
        gap: 18px !important;
        width: min(1720px, calc(100% - 120px)) !important;
        max-width: calc(100% - 120px) !important;
        min-height: 72px !important;
        margin: 18px auto 0 !important;
        padding: 12px 18px !important;
        border-radius: 999px !important;
        background: rgba(255,255,255,.94) !important;
        border: 1px solid rgba(222,238,234,.95) !important;
        box-shadow: 0 18px 44px rgba(23,63,58,.08) !important;
        backdrop-filter: blur(18px) !important;
        overflow: visible !important;
    }

    body .bk-unified-brand {
        display: inline-flex !important;
        align-items: center !important;
        gap: 10px !important;
        min-width: 0 !important;
        color: #203936 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
    }

    body .bk-unified-brand span {
        display: grid !important;
        place-items: center !important;
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        border-radius: 15px !important;
        background: var(--bk-primary, #27b883) !important;
        color: #fff !important;
        font-size: 12px !important;
        font-weight: 900 !important;
    }

    body .bk-unified-brand strong {
        display: block !important;
        max-width: 132px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        font-size: 17px !important;
        font-weight: 900 !important;
        letter-spacing: -.04em !important;
    }

    body .bk-unified-menu {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        min-width: 0 !important;
        overflow: visible !important;
    }

    body .bk-unified-item {
        position: relative !important;
        display: inline-flex !important;
        align-items: center !important;
        flex: 0 0 auto !important;
    }

    body .bk-unified-trigger,
    body .bk-unified-link,
    body .bk-unified-action,
    body .bk-unified-lang,
    body .bk-unified-cta {
        appearance: none !important;
        border: 0 !important;
        background: transparent !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 7px !important;
        height: 42px !important;
        min-height: 42px !important;
        padding: 0 10px !important;
        border-radius: 15px !important;
        color: #203936 !important;
        font-size: 13px !important;
        font-weight: 850 !important;
        line-height: 1 !important;
        letter-spacing: -.018em !important;
        white-space: nowrap !important;
        text-decoration: none !important;
        box-shadow: none !important;
        cursor: pointer !important;
    }

    body .bk-unified-trigger svg,
    body .bk-unified-link svg,
    body .bk-unified-action svg,
    body .bk-mobile-tabbar svg {
        display: block !important;
        width: 18px !important;
        height: 18px !important;
        min-width: 18px !important;
        max-width: 18px !important;
        max-height: 18px !important;
        fill: currentColor !important;
        flex: 0 0 auto !important;
    }

    body .bk-unified-trigger:hover,
    body .bk-unified-link:hover,
    body .bk-unified-action:hover,
    body .bk-unified-item.is-open > .bk-unified-trigger,
    body .bk-unified-trigger.is-more {
        color: var(--bk-primary-dark, #158460) !important;
        background: #eaf8f3 !important;
    }

    body .bk-unified-actions {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: 7px !important;
        min-width: max-content !important;
        width: max-content !important;
        position: relative !important;
        z-index: 5 !important;
    }

    body .bk-unified-cta {
        background: var(--bk-primary, #27b883) !important;
        color: #fff !important;
        padding: 0 20px !important;
        font-weight: 900 !important;
    }

    body .bk-unified-cta.is-logout {
        padding: 0 16px !important;
    }

    body .bk-unified-lang {
        padding: 0 8px !important;
        cursor: default !important;
    }

    body .bk-unified-dropdown {
        position: absolute !important;
        top: calc(100% + 10px) !important;
        left: 50% !important;
        z-index: 2000 !important;
        display: grid !important;
        gap: 2px !important;
        min-width: 230px !important;
        max-width: min(340px, 92vw) !important;
        max-height: min(520px, calc(100vh - 130px)) !important;
        overflow-y: auto !important;
        padding: 10px !important;
        border-radius: 18px !important;
        background: rgba(255,255,255,.98) !important;
        border: 1px solid rgba(218,231,227,.95) !important;
        box-shadow: 0 24px 56px rgba(20,54,50,.16) !important;
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        transform: translateX(-50%) translateY(8px) !important;
        transition: opacity .16s ease, transform .16s ease, visibility .16s ease !important;
        backdrop-filter: blur(18px) !important;
    }

    body .bk-unified-item.is-open > .bk-unified-dropdown {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        transform: translateX(-50%) translateY(0) !important;
    }

    body .bk-unified-dropdown a {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        min-height: 39px !important;
        padding: 0 12px !important;
        border-radius: 12px !important;
        color: #243936 !important;
        font-size: 13px !important;
        font-weight: 800 !important;
        line-height: 1.2 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        background: transparent !important;
    }

    body .bk-unified-dropdown a:hover {
        color: var(--bk-primary-dark, #158460) !important;
        background: #edf9f5 !important;
    }

    body .bk-unified-dropdown svg {
        display: block !important;
        width: 16px !important;
        height: 16px !important;
        min-width: 16px !important;
        max-width: 16px !important;
        max-height: 16px !important;
        fill: currentColor !important;
    }

    body .bk-mini-caret,
    body .bk-mini-external {
        display: inline-grid !important;
        place-items: center !important;
        width: 16px !important;
        min-width: 16px !important;
        height: 16px !important;
        color: currentColor !important;
        opacity: .68 !important;
        font-size: 16px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
    }

    body .bk-unified-more {
        right: 0 !important;
        left: auto !important;
        width: 310px !important;
        transform: translateY(8px) !important;
    }

    body .bk-unified-item.is-open > .bk-unified-more {
        transform: translateY(0) !important;
    }

    body .bk-more-group {
        display: grid !important;
        gap: 2px !important;
        padding: 4px 0 !important;
        border-bottom: 1px solid #edf4f2 !important;
    }

    body .bk-more-group:last-child {
        border-bottom: 0 !important;
    }

    body .bk-unified-dropdown a.bk-more-parent {
        font-weight: 900 !important;
        color: #203936 !important;
    }

    body .bk-unified-dropdown a.bk-more-child {
        min-height: 34px !important;
        padding-left: 34px !important;
        color: #607572 !important;
        font-size: 12.5px !important;
        font-weight: 750 !important;
    }
}

@media (min-width: 981px) and (max-width: 1460px) {
    body .bk-unified-header {
        grid-template-columns: 54px minmax(0, 1fr) auto !important;
        width: calc(100% - 44px) !important;
        max-width: calc(100% - 44px) !important;
        gap: 12px !important;
        padding: 10px 14px !important;
    }

    body .bk-unified-brand strong {
        display: none !important;
    }

    body .bk-unified-menu {
        justify-content: flex-start !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 0 4px !important;
    }

    body .bk-unified-menu::-webkit-scrollbar {
        display: none !important;
    }

    body .bk-unified-trigger,
    body .bk-unified-link,
    body .bk-unified-action {
        padding: 0 9px !important;
        font-size: 12.5px !important;
    }

    body .bk-unified-lang {
        display: none !important;
    }

    body .bk-unified-cta {
        padding: 0 14px !important;
        font-size: 12px !important;
    }
}

@media (min-width: 981px) and (max-width: 1120px) {
    body .bk-unified-trigger span,
    body .bk-unified-link:not(.is-icon-only) span,
    body .bk-unified-action span {
        display: none !important;
    }

    body .bk-unified-trigger,
    body .bk-unified-link,
    body .bk-unified-action {
        width: 40px !important;
        padding: 0 !important;
    }
}

@media (max-width: 980px) {
    body .bk-unified-header {
        position: sticky !important;
        top: 10px !important;
        z-index: 80 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        width: calc(100% - 24px) !important;
        min-height: 54px !important;
        margin: 12px auto 0 !important;
        padding: 8px 10px !important;
        border-radius: 20px !important;
        background: rgba(255,255,255,.94) !important;
        border: 1px solid rgba(222,238,234,.92) !important;
        box-shadow: 0 10px 26px rgba(42,62,65,.06) !important;
        backdrop-filter: blur(16px) !important;
    }

    body .bk-unified-brand {
        display: inline-flex !important;
        align-items: center !important;
        gap: 8px !important;
        color: #203936 !important;
        text-decoration: none !important;
    }

    body .bk-unified-brand span {
        display: grid !important;
        place-items: center !important;
        width: 34px !important;
        height: 34px !important;
        border-radius: 12px !important;
        background: var(--bk-primary, #27b883) !important;
        color: #fff !important;
        font-size: 11px !important;
        font-weight: 900 !important;
    }

    body .bk-unified-brand strong {
        font-size: 14px !important;
        font-weight: 900 !important;
    }

    body .bk-unified-menu,
    body .bk-unified-action,
    body .bk-unified-lang {
        display: none !important;
    }

    body .bk-unified-actions {
        margin-left: auto !important;
    }

    body .bk-unified-cta {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-height: 34px !important;
        padding: 0 12px !important;
        border-radius: 12px !important;
        background: var(--bk-primary, #27b883) !important;
        color: #fff !important;
        font-size: 11.5px !important;
        font-weight: 900 !important;
        text-decoration: none !important;
        border: 0 !important;
    }
}
/* === BANTUKITA UNIFIED HEADER FINAL STABLE END === */


/* === BANTUKITA HEADER MID SCREEN DROPDOWN FIX START === */
/*
|--------------------------------------------------------------------------
| Nusa Solution www.nusasolution.com
| BantuKita public header dropdown fix
|--------------------------------------------------------------------------
| Fix dropdown ter-clip pada layar tanggung/tablet-desktop.
*/

@media (min-width: 981px) {
    html,
    body {
        overflow-x: clip !important;
    }

    body .bk-unified-header {
        z-index: 9999 !important;
        overflow: visible !important;
        isolation: isolate !important;
    }

    body .bk-unified-menu,
    body .bk-unified-item,
    body .bk-unified-actions {
        overflow: visible !important;
    }

    body .bk-unified-dropdown {
        z-index: 10020 !important;
        will-change: transform, opacity !important;
    }

    body main,
    body .bk-hero,
    body .bk-home,
    body .bk-footer {
        position: relative !important;
        z-index: 1 !important;
    }
}

@media (min-width: 981px) and (max-width: 1460px) {
    body .bk-unified-menu {
        overflow: visible !important;
        scrollbar-width: auto !important;
        -webkit-overflow-scrolling: auto !important;
        padding: 0 2px !important;
        gap: 5px !important;
    }

    body .bk-unified-menu::-webkit-scrollbar {
        display: none !important;
    }

    body .bk-unified-trigger,
    body .bk-unified-link,
    body .bk-unified-action {
        height: 40px !important;
        min-height: 40px !important;
        padding: 0 8px !important;
        border-radius: 14px !important;
        font-size: 12px !important;
        gap: 6px !important;
    }

    body .bk-unified-trigger svg,
    body .bk-unified-link svg,
    body .bk-unified-action svg {
        width: 17px !important;
        height: 17px !important;
        min-width: 17px !important;
    }

    body .bk-unified-dropdown {
        top: calc(100% + 12px) !important;
        max-width: min(320px, calc(100vw - 28px)) !important;
    }

    body .bk-unified-more {
        width: min(310px, calc(100vw - 28px)) !important;
    }
}

@media (min-width: 981px) and (max-width: 1240px) {
    body .bk-unified-header {
        grid-template-columns: 48px minmax(0, 1fr) auto !important;
        width: calc(100% - 28px) !important;
        max-width: calc(100% - 28px) !important;
        gap: 8px !important;
        padding: 9px 11px !important;
    }

    body .bk-unified-trigger span,
    body .bk-unified-link:not(.is-icon-only) span {
        display: none !important;
    }

    body .bk-unified-trigger,
    body .bk-unified-link {
        width: 38px !important;
        padding: 0 !important;
    }

    body .bk-unified-trigger.is-more {
        width: auto !important;
        padding: 0 10px !important;
    }

    body .bk-unified-trigger.is-more span {
        display: inline !important;
        font-size: 12px !important;
    }

    body .bk-unified-actions {
        gap: 5px !important;
    }

    body .bk-unified-cta {
        padding: 0 12px !important;
        font-size: 11.5px !important;
    }
}

@media (min-width: 981px) and (max-width: 1080px) {
    body .bk-unified-actions .bk-unified-action span {
        display: none !important;
    }

    body .bk-unified-actions .bk-unified-action {
        width: 38px !important;
        padding: 0 !important;
    }

    body .bk-unified-trigger.is-more span {
        display: none !important;
    }

    body .bk-unified-trigger.is-more {
        width: 38px !important;
        padding: 0 !important;
    }
}
/* === BANTUKITA HEADER MID SCREEN DROPDOWN FIX END === */


/* === BANTUKITA SYSTEM BRANDING FIX START === */
/*
|--------------------------------------------------------------------------
| Nusa Solution www.nusasolution.com
| BantuKita dynamic logo rendering
|--------------------------------------------------------------------------
*/
.bk-unified-brand-logo {
    width: 42px;
    height: 42px;
    object-fit: contain;
    border-radius: 14px;
    display: block;
}

.bk-unified-brand-logo.is-full {
    width: auto;
    max-width: 156px;
    height: 42px;
    border-radius: 0;
}

.bk-brand-footer img.bk-brand-mark {
    width: 34px;
    height: 34px;
    object-fit: contain;
    border-radius: 10px;
}

@media (max-width: 560px) {
    .bk-unified-brand-logo.is-full {
        max-width: 128px;
        height: 38px;
    }
}
/* === BANTUKITA SYSTEM BRANDING FIX END === */


/* === BANTUKITA ADAPTIVE BRAND LOGO START === */
/*
|--------------------------------------------------------------------------
| Nusa Solution www.nusasolution.com
| BantuKita adaptive full logo / icon logo
|--------------------------------------------------------------------------
*/

body .bk-unified-brand {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    min-width: fit-content !important;
    max-width: min(260px, 22vw) !important;
    flex-shrink: 0 !important;
    overflow: visible !important;
    text-decoration: none !important;
}

body .bk-unified-brand.has-full-logo {
    width: auto !important;
    min-width: 120px !important;
    max-width: min(280px, 22vw) !important;
}

body .bk-unified-brand-symbol {
    display: grid !important;
    place-items: center !important;
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    border-radius: 15px !important;
    background: var(--bk-primary, #27b883) !important;
    overflow: hidden !important;
}

body .bk-unified-brand-logo.is-icon {
    width: 78% !important;
    height: 78% !important;
    object-fit: contain !important;
    object-position: center center !important;
    display: block !important;
}

body .bk-unified-brand-logo.is-full {
    display: block !important;
    width: auto !important;
    max-width: min(240px, 100%) !important;
    height: clamp(30px, 2.4vw, 42px) !important;
    object-fit: contain !important;
    object-position: left center !important;
    border-radius: 0 !important;
}

body .bk-unified-brand.has-full-logo strong,
body .bk-unified-brand.has-full-logo span:not(.bk-unified-brand-symbol) {
    display: none !important;
}

@media (max-width: 1460px) {
    body .bk-unified-brand.has-full-logo {
        min-width: 104px !important;
        max-width: min(220px, 18vw) !important;
    }

    body .bk-unified-brand-logo.is-full {
        max-width: min(210px, 100%) !important;
        height: 38px !important;
    }
}

@media (min-width: 981px) and (max-width: 1240px) {
    body .bk-unified-brand {
        max-width: 170px !important;
    }

    body .bk-unified-brand.has-full-logo {
        min-width: 96px !important;
        max-width: 180px !important;
    }

    body .bk-unified-brand-logo.is-full {
        max-width: 180px !important;
        height: 34px !important;
    }

    body .bk-unified-brand strong {
        max-width: 96px !important;
        font-size: 14px !important;
    }
}

@media (max-width: 980px) {
    body .bk-unified-brand {
        max-width: 160px !important;
    }

    body .bk-unified-brand.has-full-logo {
        min-width: 88px !important;
        max-width: 148px !important;
    }

    body .bk-unified-brand-logo.is-full {
        max-width: 148px !important;
        height: 32px !important;
    }

    body .bk-unified-brand-symbol {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        border-radius: 12px !important;
    }
}

@media (max-width: 560px) {
    body .bk-unified-brand.has-full-logo {
        min-width: 80px !important;
        max-width: 132px !important;
    }

    body .bk-unified-brand-logo.is-full {
        max-width: 132px !important;
        height: 28px !important;
    }
}
/* === BANTUKITA ADAPTIVE BRAND LOGO END === */

