/* =========================================================
   DBN Base
========================================================= */

@font-face {
    font-family: 'Vazirmatn';
    src: url('../fonts/Vazirmatn-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'iranyekan';
    src: url('../fonts/IRANYekanXFaNum-Regular.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

.dbn-navbar-container,
.dbn-bottom-sheet-overlay,
.dbn-search-modal-overlay {
    font-family: 'iranyekan', sans-serif !important;
}

.dbn-navbar-container *,
.dbn-bottom-sheet-overlay *,
.dbn-search-modal-overlay * {
    font-family: inherit;
}

.dbn-navbar-container .dashicons,
.dbn-navbar-container .dashicons:before,
.dbn-navbar-container .dashicons:after,
.dbn-bottom-sheet-overlay .dashicons,
.dbn-bottom-sheet-overlay .dashicons:before,
.dbn-bottom-sheet-overlay .dashicons:after,
.dbn-search-modal-overlay .dashicons,
.dbn-search-modal-overlay .dashicons:before,
.dbn-search-modal-overlay .dashicons:after {
    font-family: dashicons !important;
}

.dbn-navbar-container {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 1000;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 0;
    box-sizing: border-box;
}

.dbn-navbar {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-around;
    box-sizing: border-box;
}

.dbn-item {
    appearance: none;
    -webkit-appearance: none;
    border: none;
    background: none;
    text-decoration: none;
    cursor: pointer;
    font: inherit;
    color: inherit;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: transform 0.22s ease, opacity 0.22s ease, background-color 0.22s ease, color 0.22s ease;
    box-sizing: border-box;
    position: relative;
}

.dbn-item:focus {
    outline: none;
}

.dbn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.dbn-item-label {
    line-height: 1;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
}

/* active state managed by JS */
.dbn-item.dbn-js-active,
.dbn-item.dbn-is-active {
    z-index: 2;
}

.dbn-hidden-content {
    display: none !important;
}

/* Dynamically scale custom uploaded icons across all templates */
.dbn-item .dbn-custom-icon {
    width: 1em;
    height: 1em;
    display: inline-block;
    vertical-align: middle;
    max-width: 100%;
    max-height: 100%;
}

/* =========================================================
   Minimal Template
========================================================= */

.dbn-template-minimal.dbn-navbar-container,
.dbn-template-minimal .dbn-navbar-container {
    background: transparent;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0;
}

.dbn-template-minimal .dbn-navbar {
    width: 100%;
    height: var(--dbn-navbar-height, 62px);
    background: var(--dbn-navbar-bg, #FFFFFF);
    border-top: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 -6px 20px rgba(15, 23, 42, 0.05);
    padding: 10px 8px 12px;
    display: flex;
    align-items: center;
    justify-content: space-around;
    gap: 4px;
    box-sizing: border-box;
    overflow: hidden;
}

.dbn-template-minimal .dbn-item {
    flex: 1 1 0;
    min-width: 0;
    min-height: 46px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    text-decoration: none;
    background: transparent;
    padding: 6px 4px;
    color: var(--dbn-item-icon-color, #B8C2D1);
    transition: color .2s ease, transform .18s ease, opacity .2s ease;
    box-sizing: border-box;
}

.dbn-template-minimal .dbn-item:hover {
    transform: translateY(-1px);
}

.dbn-template-minimal .dbn-item .dbn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    line-height: 1;
    color: var(--dbn-item-icon-color, #B8C2D1);
    transition: color .2s ease;
    flex-shrink: 0;
}

.dbn-template-minimal .dbn-item .dbn-item-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    color: var(--dbn-item-label-color, #B8C2D1);
    transition: color .2s ease;
    white-space: nowrap;
    text-align: center;
}

/* Active state = color only */
.dbn-template-minimal .dbn-item.dbn-is-active,
.dbn-template-minimal .dbn-item.dbn-js-active {
    color: var(--dbn-active-icon-color, #2F6BFF);
}

.dbn-template-minimal .dbn-item.dbn-is-active .dbn-icon,
.dbn-template-minimal .dbn-item.dbn-js-active .dbn-icon {
    color: var(--dbn-active-icon-color, #2F6BFF);
}

.dbn-template-minimal .dbn-item.dbn-is-active .dbn-item-label,
.dbn-template-minimal .dbn-item.dbn-js-active .dbn-item-label {
    color: var(--dbn-active-label-color, #2F6BFF);
}

/* Better dashicons alignment */
.dbn-template-minimal .dbn-item .dashicons {
    width: 22px;
    height: 22px;
    font-size: 22px;
}

/* Interactive non-link items */
.dbn-template-minimal .dbn-item.dbn-item-type-search,
.dbn-template-minimal .dbn-item.dbn-item-type-wordpress_menu,
.dbn-template-minimal .dbn-item.dbn-item-type-category_list,
.dbn-template-minimal .dbn-item.dbn-item-type-custom_html {
    cursor: pointer;
}

/* Tablet */
@media (max-width: 768px) {
    .dbn-template-minimal .dbn-navbar {
        height: var(--dbn-navbar-height, 60px);
        padding: 9px 6px 11px;
    }

    .dbn-template-minimal .dbn-item {
        min-height: 44px;
        gap: 4px;
        padding: 6px 2px;
    }

    .dbn-template-minimal .dbn-item .dbn-icon {
        font-size: 21px;
    }

    .dbn-template-minimal .dbn-item .dbn-item-label {
        font-size: 11px;
    }
}

/* Small mobile */
@media (max-width: 480px) {
    .dbn-template-minimal .dbn-navbar {
        padding: 8px 4px 10px;
    }

    .dbn-template-minimal .dbn-item {
        min-height: 42px;
    }

    .dbn-template-minimal .dbn-item .dbn-icon {
        font-size: 20px;
    }

    .dbn-template-minimal .dbn-item .dbn-item-label {
        font-size: 10.5px;
    }
}

/* =========================================================
   Default Template
========================================================= */

.dbn-template-default.dbn-navbar-container,
.dbn-template-default .dbn-navbar-container {
    background: transparent;
    padding-left: 12px;
    padding-right: 12px;
    padding-bottom: 10px;
}

.dbn-template-default .dbn-navbar {
    width: var(--dbn-navbar-width, 92%);
    height: var(--dbn-navbar-height, 72px);
    margin: 0 auto;
    background: var(--dbn-navbar-bg, #0E66E8);
    border-radius: var(--dbn-navbar-radius, 999px);
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    box-sizing: border-box;
    box-shadow: 0 12px 26px rgb(from var(--dbn-navbar-bg, #0e66e8) r g b / 0.18);
    overflow: hidden;
}

.dbn-template-default .dbn-item {
    min-width: 44px;
    min-height: 44px;
    flex: 1 1 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 10px 10px;
    border-radius: 999px;
    text-decoration: none;
    background: transparent;
    color: var(--dbn-item-icon-color, #AFC4F4);
    transition: background-color .22s ease, color .22s ease, padding .22s ease, transform .18s ease;
    box-sizing: border-box;
    overflow: hidden;
    white-space: nowrap;
}

.dbn-template-default .dbn-item:hover {
    transform: translateY(-1px);
}

.dbn-template-default .dbn-item .dbn-icon {
    font-size: 22px;
    line-height: 1;
    color: var(--dbn-item-icon-color, #AFC4F4);
    transition: color .22s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.dbn-template-default .dbn-item .dbn-item-label {
    display: none;
    margin-left: 8px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    color: var(--dbn-active-label-color, #0E66E8);
    white-space: nowrap;
}

/* Active item */
.dbn-template-default .dbn-item.dbn-is-active,
.dbn-template-default .dbn-item.dbn-js-active {
    background: var(--dbn-active-bg, #FFFFFF);
    color: var(--dbn-active-icon-color, #0E66E8);
    border-radius: var(--dbn-active-radius, 999px);
    padding: var(--dbn-active-padding, 10px 16px);
    flex: 0 0 auto;
}

.dbn-template-default .dbn-item.dbn-is-active .dbn-icon,
.dbn-template-default .dbn-item.dbn-js-active .dbn-icon {
    color: var(--dbn-active-icon-color, #0E66E8);
}

.dbn-template-default .dbn-item.dbn-is-active .dbn-item-label,
.dbn-template-default .dbn-item.dbn-js-active .dbn-item-label {
    display: inline-flex;
    align-items: center;
    margin-right: 5px;
    color: var(--dbn-active-label-color, #0E66E8);
}

/* Non-active items keep icon-only look */
.dbn-template-default .dbn-item:not(.dbn-is-active):not(.dbn-js-active) .dbn-item-label {
    display: none !important;
}

/* Search/menu/custom items inside default */
.dbn-template-default .dbn-item.dbn-item-type-search,
.dbn-template-default .dbn-item.dbn-item-type-wordpress_menu,
.dbn-template-default .dbn-item.dbn-item-type-category_list,
.dbn-template-default .dbn-item.dbn-item-type-custom_html {
    cursor: pointer;
}

/* Better visual alignment for dashicons */
.dbn-template-default .dbn-item .dashicons {
    width: 22px;
    height: 22px;
    font-size: 22px;
}

/* Tablet / mobile */
@media (min-width: 768px) {
    .dbn-template-default .dbn-item.dbn-is-active, .dbn-template-default .dbn-item.dbn-js-active {
        flex: 0.3 0 auto;
    }
}

/* Tablet / mobile */
@media (max-width: 768px) {
    .dbn-template-default .dbn-navbar {
        width: 100%;
        height: var(--dbn-navbar-height, 55px);
        padding: 8px;
        gap: 4px;
    }

    .dbn-template-default .dbn-item {
        min-width: 40px;
        min-height: 40px;
        padding: 8px 8px;
    }

    .dbn-template-default .dbn-item .dbn-icon {
        font-size: 20px;
    }

    .dbn-template-default .dbn-item .dbn-item-label {
        font-size: 13px;
    }

    .dbn-template-default .dbn-item.dbn-is-active,
    .dbn-template-default .dbn-item.dbn-js-active {
        padding: 9px 14px;
    }
}

@media (max-width: 480px) {
    .dbn-template-default.dbn-navbar-container,
    .dbn-template-default .dbn-navbar-container {
        padding-left: 8px;
        padding-right: 8px;
        padding-bottom: 8px;
    }

    .dbn-template-default .dbn-item .dbn-item-label {
        font-size: 12px;
        margin-left: 6px;
    }

    .dbn-template-default .dbn-item.dbn-is-active,
    .dbn-template-default .dbn-item.dbn-js-active {
        padding: 8px 12px;
        width: 90px;
        overflow: hidden;
    }
}

/* =========================================================
   Modern Template
   Minimal-like layout with elevated central item
========================================================= */

.dbn-template-modern.dbn-navbar-container,
.dbn-template-modern .dbn-navbar-container {
    background: transparent;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0;
}

.dbn-template-modern .dbn-navbar {
    width: 95%;
    border-radius: 40px 40px 0px 0px;
    height: var(--dbn-navbar-height, 82px);
    background: var(--dbn-navbar-bg, #FFFFFF);
    border-top: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 -10px 20px rgba(15, 23, 42, 0.05);
    padding: 10px 8px 12px;
    display: flex;
    align-items: flex-end;
    justify-content: space-around;
    gap: 4px;
    box-sizing: border-box;
    overflow: visible;
    position: relative;
}

.dbn-template-modern .dbn-item {
    flex: 1 1 0;
    min-width: 0;
    min-height: 46px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    text-decoration: none;
    background: transparent;
    padding: 6px 4px;
    color: var(--dbn-item-icon-color, #111111);
    transition: color .2s ease, transform .18s ease, opacity .2s ease;
    box-sizing: border-box;
    position: relative;
}

.dbn-template-modern .dbn-item:hover {
    transform: translateY(-1px);
}

.dbn-template-modern .dbn-item .dbn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    line-height: 1;
    color: var(--dbn-item-icon-color, #111111);
    transition: color .2s ease, background-color .2s ease;
    flex-shrink: 0;
}

.dbn-template-modern .dbn-item .dbn-item-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    color: var(--dbn-item-label-color, #111111);
    transition: color .2s ease;
    white-space: nowrap;
    text-align: center;
}

/* Active state */
.dbn-template-modern .dbn-item.dbn-is-active,
.dbn-template-modern .dbn-item.dbn-js-active {
    color: var(--dbn-active-icon-color, #111111);
}

.dbn-template-modern .dbn-item.dbn-is-active .dbn-icon,
.dbn-template-modern .dbn-item.dbn-js-active .dbn-icon {
    color: var(--dbn-active-icon-color, #111111);
}

.dbn-template-modern .dbn-item.dbn-is-active .dbn-item-label,
.dbn-template-modern .dbn-item.dbn-js-active .dbn-item-label {
    color: var(--dbn-active-label-color, #111111);
}

/* Central item */
.dbn-template-modern .dbn-item.dbn-is-central .dbn-item-label {
    margin-top: 4px;
}

.dbn-template-modern .dbn-item.dbn-is-central .dbn-icon {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: var(--dbn-central-bg, #23262F);
    color: var(--dbn-central-icon-color, #FFFFFF);
    font-size: 24px;
}

/* Active central item remains visually the same */
.dbn-template-modern .dbn-item.dbn-is-central.dbn-is-active .dbn-icon,
.dbn-template-modern .dbn-item.dbn-is-central.dbn-js-active .dbn-icon {
    background: var(--dbn-central-bg, #23262F);
    color: var(--dbn-central-icon-color, #FFFFFF);
}

/* Better dashicons alignment */
.dbn-template-modern .dbn-item .dashicons {
    width: 22px;
    height: 22px;
    font-size: 22px;
}

.dbn-template-modern .dbn-item.dbn-is-central .dashicons {
    outline: 5px solid var(--dbn-navbar-bg, #FFFFFF);
    box-shadow: 0 -10px 20px rgba(15, 23, 42, 0.20);
    width: 64px;
    height: 64px;
    font-size: 24px;
}

/* Interactive non-link items */
.dbn-template-modern .dbn-item.dbn-item-type-search,
.dbn-template-modern .dbn-item.dbn-item-type-wordpress_menu,
.dbn-template-modern .dbn-item.dbn-item-type-category_list,
.dbn-template-modern .dbn-item.dbn-item-type-custom_html {
    cursor: pointer;
}

/* Tablet */
@media (max-width: 768px) {
    .dbn-template-modern .dbn-navbar {
        width: 100%;
        height: var(--dbn-navbar-height, 78px);
        padding: 9px 6px 11px;
    }

    .dbn-template-modern .dbn-item {
        min-height: 44px;
        gap: 4px;
        padding: 6px 2px;
    }

    .dbn-template-modern .dbn-item .dbn-icon {
        font-size: 21px;
    }

    .dbn-template-modern .dbn-item .dbn-item-label {
        font-size: 11px;
    }

    .dbn-template-modern .dbn-item.dbn-is-central .dbn-icon {
        width: 50px;
        height: 50px;
        font-size: 22px;
    }
}

/* Small mobile */
@media (max-width: 480px) {
    .dbn-template-modern .dbn-navbar {
        width: 100%;
        border-radius: 20px 20px 0px 0px;
        height: var(--dbn-navbar-height, 70px);
    }

    .dbn-template-modern .dbn-item {
        min-height: 42px;
    }

    .dbn-template-modern .dbn-item .dbn-icon {
        font-size: 20px;
    }

    .dbn-template-modern .dbn-item .dbn-item-label {
        font-size: 10.5px;
    }

    .dbn-template-modern .dbn-item.dbn-is-central .dbn-icon {
        width: 46px;
        height: 46px;
        font-size: 21px;
    }
}

/* =========================================================
   Creative Template
   Labels always visible
========================================================= */

.dbn-template-creative.dbn-navbar-container,
.dbn-template-creative .dbn-navbar-container {
    background: transparent;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0;
}

.dbn-template-creative .dbn-navbar {
    width: 100%;
    height: var(--dbn-navbar-height, 82px);
    background: transparent;
    padding: 10px 8px 12px;
    display: flex;
    align-items: flex-end;
    justify-content: space-around;
    gap: 4px;
    box-sizing: border-box;
    overflow: visible;
    position: relative;
}

.dbn-navbar-creative svg {
    -webkit-filter: drop-shadow(0 1px 9px rgba(0, 0, 0, 0.09));
    filter: drop-shadow(0 -1px 6px rgba(0, 0, 0, 0.05));
    position: absolute;
    right: 50%;
    bottom: -2px;
    -moz-transform: translateX(50%);
    -webkit-transform: translateX(50%);
    -o-transform: translateX(50%.);
    -ms-transform: translateX(50%);
    transform: translateX(50%);
    fill: var(--dbn-navbar-bg, #FFFFFF);
    height: 82px;
}

.dbn-template-creative .dbn-item {
    flex: 1 1 0;
    min-width: 0;
    min-height: 46px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    text-decoration: none;
    background: transparent;
    padding: 6px 4px;
    color: var(--dbn-item-icon-color, #111111);
    transition: color .2s ease, transform .18s ease, opacity .2s ease;
    box-sizing: border-box;
    position: relative;
}

.dbn-template-creative .dbn-item:hover {
    transform: translateY(-1px);
}

.dbn-template-creative .dbn-item .dbn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    line-height: 1;
    color: var(--dbn-item-icon-color, #111111);
    transition: color .2s ease, background-color .2s ease, box-shadow .2s ease, transform .2s ease;
    flex-shrink: 0;
}

.dbn-template-creative .dbn-item .dbn-item-label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    color: var(--dbn-item-label-color, #111111);
    transition: color .2s ease;
    white-space: nowrap;
    text-align: center;
}

/* Active state */
.dbn-template-creative .dbn-item.dbn-is-active,
.dbn-template-creative .dbn-item.dbn-js-active {
    color: var(--dbn-active-icon-color, #111111);
}

.dbn-template-creative .dbn-item.dbn-is-active .dbn-icon,
.dbn-template-creative .dbn-item.dbn-js-active .dbn-icon {
    color: var(--dbn-active-icon-color, #111111);
}

.dbn-template-creative .dbn-item.dbn-is-active .dbn-item-label,
.dbn-template-creative .dbn-item.dbn-js-active .dbn-item-label {
    color: var(--dbn-active-label-color, #111111);
}

/* Central item */
.dbn-template-creative .dbn-item.dbn-is-central .dbn-item-label {
    margin-top: 4px;
}

.dbn-template-creative .dbn-item.dbn-is-central .dbn-icon {
    transform: translateY(-20px);
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: linear-gradient(180deg, color-mix(in srgb, var(--dbn-central-bg, #23262F) 12%, #b3b3b3) 0%, var(--dbn-central-bg) 100%);
    border: 1px solid color-mix(in srgb, var(--dbn-central-bg, #23262F) 80%, black);
    color: var(--dbn-central-icon-color, #FFFFFF);
    box-shadow: var(--dbn-central-shadow, 0 8px 20px rgba(0,0,0,0.28));
    transition: transform 0.54s cubic-bezier(0.22, 1, 0.36, 1);
    font-size: 24px;
}

/* Active central item remains visually the same */
.dbn-template-creative .dbn-item.dbn-is-central.dbn-is-active .dbn-icon,
.dbn-template-creative .dbn-item.dbn-is-central.dbn-js-active .dbn-icon {
    background: var(--dbn-central-bg, #23262F);
    color: var(--dbn-central-icon-color, #FFFFFF);
    box-shadow: var(--dbn-central-shadow, 0 8px 20px rgba(0,0,0,0.18));
}

/* Creative template: labels always visible */
.dbn-template-creative .dbn-item:not(.dbn-is-active):not(.dbn-js-active) .dbn-item-label {
    display: inline-flex !important;
}

/* Better dashicons alignment */
.dbn-template-creative .dbn-item .dashicons {
    width: 22px;
    height: 22px;
    font-size: 22px;
}

.dbn-template-creative .dbn-item.dbn-is-central .dashicons {
    width: 64px;
    height: 64px;
    font-size: 24px;
}

/* Interactive non-link items */
.dbn-template-creative .dbn-item.dbn-item-type-search,
.dbn-template-creative .dbn-item.dbn-item-type-wordpress_menu,
.dbn-template-creative .dbn-item.dbn-item-type-category_list,
.dbn-template-creative .dbn-item.dbn-item-type-custom_html {
    cursor: pointer;
}

/* Very Big Screens */
@media (min-width: 1440px) {
    .dbn-template-creative .dbn-navbar {
        max-width: 1440px;
    }

    .dbn-navbar-creative svg {
        height: var(--dbn-navbar-height, 82px);
        border-radius: 20px 20px 0px 0px;
    }
}

/* Tablet */
@media (max-width: 768px) {
    .dbn-template-creative .dbn-navbar {
        height: var(--dbn-navbar-height, 75px);
        padding: 9px 6px 11px;
    }

    .dbn-navbar-creative svg {
        height: var(--dbn-navbar-height, 75px);
    }

    .dbn-template-creative .dbn-item {
        min-height: 44px;
        gap: 4px;
        padding: 6px 2px;
    }

    .dbn-template-creative .dbn-item .dbn-icon {
        font-size: 21px;
    }

    .dbn-template-creative .dbn-item .dbn-item-label {
        font-size: 11px;
    }

    .dbn-template-creative .dbn-item.dbn-is-central .dbn-icon {
        transform: translateY(-14px);
        width: 50px;
        height: 50px;
        font-size: 22px;
    }
}

/* Small mobile */
@media (max-width: 480px) {
    .dbn-template-creative .dbn-navbar {
        height: var(--dbn-navbar-height, 60px);
        padding: 8px 4px 10px;
    }

    .dbn-navbar-creative svg {
        height: var(--dbn-navbar-height, 60px);
    }


    .dbn-template-creative .dbn-item {
        min-height: 42px;
    }

    .dbn-template-creative .dbn-item .dbn-icon {
        font-size: 20px;
    }

    .dbn-template-creative .dbn-item .dbn-item-label {
        font-size: 10.5px;
    }

    .dbn-template-creative .dbn-item.dbn-is-central .dbn-icon {
        transform: translateY(-5px);
        width: 46px;
        height: 46px;
        font-size: 21px;
    }
}

/* =========================================================
   Bottom Sheet
========================================================= */

.dbn-bottom-sheet-overlay {
    position: fixed;
    inset: 0;
    background: rgba(54, 65, 83, 0.18);
    backdrop-filter: blur(0px);
    z-index: 1050;
    display: block;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s ease, visibility 0.28s ease, backdrop-filter 0.28s ease;
}

.dbn-bottom-sheet-overlay.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    backdrop-filter: blur(10px);
}


.dbn-bottom-sheet-container {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    max-height: 85vh;
    background: #fff;
    border-top-left-radius: 18px;
    border-top-right-radius: 18px;
    box-shadow: 0 -12px 32px rgba(0, 0, 0, 0.14);
    transform: translateY(100%);
    transition: transform 0.34s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.dbn-bottom-sheet-overlay.active .dbn-bottom-sheet-container {
    transform: translateY(0);
    max-height: 60%;
}

.dbn-bottom-sheet-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid #eee;
    background: #f9f9f9;
    flex-shrink: 0;
}

.dbn-bottom-sheet-title {
    font-weight: 700;
    font-size: 15px;
    color: #222;
}

.dbn-bottom-sheet-close-btn {
    border: none;
    background: none;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: #888;
}

.dbn-bottom-sheet-content {
    overflow-y: auto;
    flex: 1;
}

.dbn-bottom-sheet-scrollable {
    padding: 16px;
}

body.dbn-bottom-sheet-open {
    overflow: hidden;
}

/* Bottom sheet content defaults */
.dbn-bottom-sheet-scrollable ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dbn-bottom-sheet-scrollable .dbn-custom-html-wrapper,
.dbn-bottom-sheet-scrollable .dbn-category-list-wrapper,
.dbn-bottom-sheet-scrollable .dbn-dropdown-menu {
    display: block;
}

.dbn-bottom-sheet-scrollable .dbn-custom-html-wrapper > *:last-child {
    margin-bottom: 0;
}

.dbn-bottom-sheet-scrollable .dbn-custom-html-wrapper p:first-child,
.dbn-bottom-sheet-scrollable .dbn-custom-html-wrapper h1:first-child,
.dbn-bottom-sheet-scrollable .dbn-custom-html-wrapper h2:first-child,
.dbn-bottom-sheet-scrollable .dbn-custom-html-wrapper h3:first-child,
.dbn-bottom-sheet-scrollable .dbn-custom-html-wrapper h4:first-child {
    margin-top: 0;
}

.dbn-accordion-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.dbn-accordion-group {
    display: flex;
    flex-direction: column;
}

.dbn-accordion-parent {
    width: 100%;
    margin-bottom: 10px;
    border: none;
    background: #0044cc08;
    color: #798188;
    min-height: 52px;
    border-radius: 8px;
    padding: 14px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    font-weight: 700;
    font-size: 15px;
    text-align: left;
}

.dbn-accordion-parent:hover {
    filter: brightness(1.02);
}

.dbn-accordion-toggle-icon {
    flex-shrink: 0;
    transition: transform .2s ease;
}

.dbn-accordion-group.open .dbn-accordion-toggle-icon {
    transform: rotate(180deg);
}

.dbn-accordion-children {
    display: none;
    padding-left: 14px;
    flex-direction: column;
    gap: 8px;
    opacity: 0;
    transform: translateY(-6px);
}

.dbn-accordion-group.open .dbn-accordion-children {
    opacity: 1;
    transform: translateY(0);
}

.dbn-accordion-child:first-child {
    margin-top: -5px;
}

.dbn-accordion-child:last-child {
    margin-bottom: 10px;
}

.dbn-accordion-child {
    display: flex;
    margin-bottom: 5px;
    align-items: center;
    min-height: 42px;
    border-radius: 8px;
    padding: 10px 14px;
    background: #bb753109;
    color: #362515;
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
}

.dbn-accordion-child:hover {
    filter: brightness(1.03);
    color: #fff;
}

.dbn-accordion-parent,
.dbn-accordion-child {
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}

.dbn-accordion-parent:hover,
.dbn-accordion-child:hover {
    transform: translateY(-1px);
}

.dbn-accordion-parent:active,
.dbn-accordion-child:active {
    transform: translateY(0);
}

/* =========================================================
   Search Modal
========================================================= */

.dbn-search-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(54, 65, 83, 0.18);
    backdrop-filter: blur(0px);
    z-index: 1100;
    display: flex;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s ease, visibility 0.28s ease, backdrop-filter 0.28s ease;
    align-items: center;
    justify-content: center;
}

.dbn-search-modal-overlay.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    backdrop-filter: blur(10px);
}

.dbn-search-modal-container {
    position: relative;
    width: 100%;
    max-width: 800px;
    padding: 0 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    transform: scale(0.96);
    opacity: 0;
    transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.28s ease;
}

.dbn-search-modal-overlay.active .dbn-search-modal-container {
    transform: scale(1);
    opacity: 1;
}

.dbn-search-modal-close-btn {
    position: absolute;
    top: -40px;
    right: 10px;
    border: none;
    background: none;
    font-size: 36px;
    line-height: 1;
    color: rgba(255,255,255,0.8);
    cursor: pointer;
}

.dbn-search-modal-content {
    width: 100%;
}

.dbn-search-form-modal {
    width: 100%;
    display: flex;
    justify-content: center;
}

.dbn-search-input-modal {
    width: 95%;
    max-width: 700px;
    padding: 18px 24px;
    border: none;
    border-radius: 10px;
    font-size: 24px;
    text-align: center;
    background: transparent;
    color: #111;
    outline: 2px solid #ffffff50;
    box-shadow: inset 0 0px 10px -3px rgba(0, 0, 0, 0.25);
}

.dbn-search-input-modal:focus {
    box-shadow: 0 0px 10px -3px rgba(0, 0, 0, 0.25);
    background: #fff;
}

body.dbn-search-modal-open {
    overflow: hidden;
}

/* =========================================================
   Global active state
========================================================= */

.dbn-item.active,
.dbn-item.dbn-js-active {
    z-index: 4;
}

/* =========================================================
   Responsive
========================================================= */

@media (max-width: 768px) {
    .dbn-navbar-container {
        padding-left: 8px;
        padding-right: 8px;
    }

    .dbn-template-default .dbn-navbar {
        width: 100%;
    }

    .dbn-search-input-modal {
        font-size: 20px;
        padding: 14px 18px;
    }

    .dbn-search-modal-close-btn {
        top: -34px;
        font-size: 30px;
    }
}

@media (max-width: 480px) {

    .dbn-search-input-modal {
        font-size: 18px;
        padding: 12px 16px;
    }

    .dbn-search-modal-close-btn {
        display: none;
    }
}

/* Smart Scroll Base Transitions - Ultra Smooth Layout Engine */
.dbn-enable-smart-scroll {
    will-change: transform, opacity;
    backface-visibility: hidden;
    transform-style: preserve-3d;
    transition: 
        transform 1.2s cubic-bezier(0.16, 1, 0.3, 1), 
        opacity 0.35s ease, 
        visibility 0.35s ease !important;
}

/* Hide State for standard templates */
.dbn-enable-smart-scroll.dbn-smart-scroll-hide {
    transform: translateY(110%) scale(0.96) !important;
    opacity: 0 !important;
    visibility: hidden;
    pointer-events: none;
}

/* Hide State explicitly for Expandable Floating Templates (Preserves X-centering) */
.dbn-template-expandable.dbn-enable-smart-scroll.dbn-smart-scroll-hide {
    transform: translateX(-50%) translateY(120%) scale(0.94) !important;
}

