/* ============================================================
 * TAIMODS — HEADER DESKTOP (v1.8.0)
 *
 * UNIFIED SIZE:
 *   Button height:  32px
 *   Button text:    12px  |  Button icon: 12px
 *   Chevron arrow:  10px  |  Dropdown text: 12.5px
 *   Item gap:       2px   |  Icon ↔ text: 5px (flex gap)
 *
 * ============================================================ */


/* ============================================
   1. BIẾN HỆ THỐNG
   ============================================ */
:root {
    --tm-h:            32px;
    --tm-radius:       6px;
    --tm-pad-x:        10px;
    --tm-gap:          5px;
    --tm-fz:           12px;
    --tm-fz-icon:      12px;
    --tm-fz-arrow:     10px;
    --tm-fz-dropdown:  12.5px;

    --tm-text:         #ffffff;
    --tm-text-muted:   rgba(255, 255, 255, 0.55);
    --tm-border:       rgba(255, 255, 255, 0.14);
    --tm-border-hover: rgba(255, 255, 255, 0.28);
    --tm-hover-bg:     rgba(255, 255, 255, 0.07);

    --tm-panel-bg:     #1f1f23;
    --tm-panel-border: rgba(255, 255, 255, 0.08);
    --tm-panel-shadow: 0 14px 40px rgba(0, 0, 0, 0.5);
    --tm-divider:      rgba(255, 255, 255, 0.08);

    /* Dark mode content palette */
    --tm-dark-bg:        #161618;
    --tm-dark-card:      #1f1f22;
    --tm-dark-text:      #d4d4d4;
    --tm-dark-heading:   #ffffff;
    --tm-dark-border:    rgba(255, 255, 255, 0.1);
    --tm-dark-input:     #2a2a2d;
}


/* ============================================
   2. BUTTON BASE
   ============================================ */
.tm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--tm-gap);
    height: var(--tm-h);
    padding: 0 var(--tm-pad-x);
    border: 1px solid var(--tm-border);
    border-radius: var(--tm-radius);
    background: transparent;
    color: var(--tm-text) !important;
    font-size: var(--tm-fz);
    font-weight: 600;
    text-transform: uppercase;
    line-height: 1;
    letter-spacing: 0.25px;
    white-space: nowrap;
    cursor: pointer;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
    text-decoration: none !important;
}
.tm-btn > i,
.tm-btn > i[class*="fa-"] {
    font-size: var(--tm-fz-icon) !important;
    line-height: 1;
    color: inherit;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 !important;
}
.header-main .tm-btn > i + span,
.header-main .nav > li > a.tm-btn > i + span,
.header-main .nav > li > a > i + span {
    margin-left: 0 !important;
}
.tm-btn > span {
    line-height: 1;
    display: inline-flex;
    align-items: center;
}
.tm-btn:hover {
    background: var(--tm-hover-bg);
    color: var(--primary-color) !important;
    border-color: var(--tm-border-hover);
}
.tm-btn--primary,
.tm-btn--primary:hover,
.tm-btn--primary:focus,
.tm-btn--primary:active {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #fff !important;
}
.tm-btn--primary > i { color: #fff !important; }


/* ============================================
   3. ALL GAME — VERTICAL MENU
   ============================================ */
.tm-allgame { position: relative; }

.tm-arrow {
    font-size: var(--tm-fz-arrow) !important;
    line-height: 1;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    margin: 0 !important;
    color: inherit;
    transition: transform 0.25s ease;
    transform-origin: center center;
}
.tm-allgame:hover .tm-arrow { transform: rotate(180deg); }

.tm-allgame__panel {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 250px;
    background: var(--tm-panel-bg);
    border: 1px solid var(--tm-panel-border);
    border-radius: 8px;
    box-shadow: var(--tm-panel-shadow);
    padding: 6px 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
    z-index: 9999;
}
.tm-allgame:hover .tm-allgame__panel {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.tm-cat-list,
.tm-subcat { list-style: none; margin: 0; padding: 0; }

.tm-cat { position: relative; }

.tm-cat > a {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 7px 14px;
    font-size: var(--tm-fz-dropdown);
    font-weight: 500;
    color: var(--tm-text) !important;
    text-transform: none;
    text-decoration: none !important;
    transition: background 0.15s ease, color 0.15s ease, padding 0.15s ease;
}
.tm-cat > a > i:first-child {
    width: 14px;
    font-size: 11px;
    color: var(--primary-color);
    flex-shrink: 0;
    line-height: 1;
    text-align: center;
    transition: color 0.15s ease;
}
.tm-cat__name {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.tm-cat__count {
    font-size: 10px;
    font-weight: 600;
    color: var(--tm-text-muted);
    padding: 2px 6px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    min-width: 22px;
    text-align: center;
    line-height: 1.4;
    flex-shrink: 0;
}
.tm-cat__arrow {
    margin-left: 2px;
    font-size: var(--tm-fz-arrow) !important;
    line-height: 1;
    opacity: 0.5;
    flex-shrink: 0;
    transition: all 0.15s ease;
}
.tm-cat:hover > a {
    background: rgba(255, 255, 255, 0.05);
    color: var(--primary-color) !important;
    padding-left: 18px;
}
.tm-cat:hover > a > i:first-child,
.tm-cat:hover > a .tm-cat__arrow {
    color: var(--primary-color);
    opacity: 1;
}

.tm-subcat {
    position: absolute;
    top: -6px;
    left: 100%;
    min-width: 220px;
    margin-left: 6px;
    background: var(--tm-panel-bg);
    border: 1px solid var(--tm-panel-border);
    border-radius: 8px;
    box-shadow: var(--tm-panel-shadow);
    padding: 6px 0;
    opacity: 0;
    visibility: hidden;
    transform: translateX(6px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
}
.tm-cat:hover > .tm-subcat {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
}
.tm-subcat li a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 14px;
    font-size: var(--tm-fz-dropdown);
    color: var(--tm-text) !important;
    text-decoration: none !important;
    transition: all 0.15s ease;
}
.tm-subcat li a .tm-cat__count { margin-left: auto; }
.tm-subcat li a:hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--primary-color) !important;
    padding-left: 18px;
}


/* ============================================
   4. SETTING DROPDOWN
   ============================================ */
.tm-setting { position: relative; }

.tm-setting__toggle {
    width: var(--tm-h);
    padding: 0;
    justify-content: center;
}
.tm-setting__toggle > i { font-size: var(--tm-fz-icon) !important; }

.tm-setting__panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 200px;
    background: var(--tm-panel-bg);
    border: 1px solid var(--tm-panel-border);
    border-radius: 8px;
    box-shadow: var(--tm-panel-shadow);
    padding: 6px 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
    z-index: 9999;
}
.tm-setting:hover .tm-setting__panel {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.tm-setting__row { margin: 0; }
.tm-setting__row + .tm-setting__row {
    margin-top: 4px;
    padding-top: 6px;
    border-top: 1px solid var(--tm-divider);
}

.tm-setting__row > label {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 9.5px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--tm-text-muted);
    margin: 0 0 4px;
    padding: 0 14px;
    letter-spacing: 0.5px;
}
.tm-setting__row > label i { font-size: 9.5px; line-height: 1; }

.tm-switch { display: flex; }
.tm-switch--small {
    gap: 2px;
    padding: 2px;
    margin: 0 8px;
    background: rgba(255, 255, 255, 0.04);
    border-radius: 5px;
}
.tm-switch--small button {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 5px 6px;
    border-radius: 4px;
    font-size: 10.5px;
    font-weight: 600;
    color: var(--tm-text);
    text-transform: uppercase;
    letter-spacing: 0.2px;
    line-height: 1;
    transition: background 0.15s ease, color 0.15s ease;
}
.tm-switch--small button i { font-size: 10px; line-height: 1; }
.tm-switch--small button:hover { color: var(--primary-color); }
.tm-switch--small button.is-active,
.tm-switch--small button.is-active:hover {
    background: var(--primary-color);
    color: #fff;
}

.tm-switch--list {
    flex-direction: column;
    gap: 0;
    padding: 0;
    margin: 0;
    background: transparent;
}
.tm-switch--list button {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 7px 14px;
    border-radius: 0;
    font-size: var(--tm-fz-dropdown);
    font-weight: 500;
    line-height: 1.4;
    color: var(--tm-text);
    text-align: left;
    text-transform: none;
    letter-spacing: 0;
    transition: all 0.15s ease;
}
.tm-switch--list .tm-flag {
    font-size: 13px;
    line-height: 1;
    flex-shrink: 0;
}
.tm-switch--list .tm-label { flex: 1; }
.tm-switch--list .tm-check {
    margin-left: auto;
    font-size: 10px;
    line-height: 1;
    opacity: 0;
    color: inherit;
    transition: opacity 0.15s ease;
}
.tm-switch--list button.is-active {
    background: var(--primary-color);
    color: #fff;
}
.tm-switch--list button.is-active .tm-check { opacity: 1; }
.tm-switch--list button:not(.is-active):hover {
    background: rgba(255, 255, 255, 0.05);
    color: var(--primary-color) !important;
    padding-left: 18px;
}


/* ============================================
   6. LOGO MARGIN
   ============================================ */
.header-main .logo-left .logo,
.header-main .logo,
.header-main #logo {
    margin-left: 0 !important;
    margin-right: 10px !important;
}


/* ============================================
   7. MAIN NAV
   ============================================ */
.header-main .nav > li { margin: 0 !important; }
.header-main .nav > li + li { margin-left: 2px !important; }

.header-main .nav > li > a {
    color: var(--tm-text) !important;
    font-size: var(--tm-fz) !important;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    padding: 0 9px !important;
    line-height: var(--tm-h) !important;
}
.header-main .nav > li > a:hover,
.header-main .nav > li.active > a,
.header-main .nav > li.current-menu-item > a {
    color: var(--primary-color) !important;
}
.header-main .nav > li > a .icon-angle-down,
.header-main .nav > li > a > i {
    font-size: var(--tm-fz-arrow) !important;
    margin-left: 3px !important;
    line-height: 1;
}


/* ============================================
   8. ACCOUNT & CART
   ============================================ */
.header-main .account-item > a,
.header-main .cart-item > a,
.header-main li.account-item-dropdown > a,
.header-main li.cart-item .header-cart-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: var(--tm-gap);
    height: var(--tm-h) !important;
    padding: 0 var(--tm-pad-x) !important;
    background: transparent !important;
    border: 1px solid var(--tm-border) !important;
    border-radius: var(--tm-radius) !important;
    color: var(--tm-text) !important;
    font-size: var(--tm-fz) !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    line-height: 1 !important;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.header-main .account-item > a > i,
.header-main .cart-item > a > i,
.header-main li.cart-item .header-cart-link > i {
    font-size: var(--tm-fz-icon) !important;
    color: inherit;
    line-height: 1;
    margin: 0 !important;
}
.header-main .account-item > a:hover,
.header-main .cart-item > a:hover,
.header-main li.cart-item .header-cart-link:hover {
    background: var(--tm-hover-bg) !important;
    color: var(--primary-color) !important;
    border-color: var(--tm-border-hover) !important;
}

.header-main .header-account-title,
.header-main .account-item .header-account-title,
.header-main .account-item-dropdown .header-account-title {
    display: inline-block !important;
    max-width: 80px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    vertical-align: middle;
    line-height: 1.2;
}

.header-main .account-item img,
.header-main .account-item .avatar,
.header-main .account-item-dropdown img,
.header-main .account-item-dropdown .account-icon img,
.header-main .account-item-dropdown .image-icon img,
.header-main li.account-item-dropdown .header-avatar img,
.header-main li.account-item > a img {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px;
    border-radius: 50% !important;
    object-fit: cover;
    border: 1px solid var(--tm-border);
    margin: 0 !important;
    padding: 0 !important;
    vertical-align: middle;
    flex-shrink: 0;
}

.header-main .cart-item .cart-icon strong,
.header-main .header-cart-link .cart-item-count {
    background: var(--primary-color) !important;
    color: #fff !important;
    font-size: 10px;
    min-width: 16px;
    height: 16px;
    line-height: 16px;
    border-radius: 8px;
    padding: 0 4px;
}


/* ============================================
   8A. HEADER SEARCH — STYLE ONLY
   Chỉ đồng bộ giao diện form search / icon search.
   Không can thiệp live search, AJAX, kết quả gợi ý.
   ============================================ */

/* Nav phải được phép chiếm phần trống còn lại và đẩy các item về bên phải */
#header .header-main .flex-right {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

#header .header-main .nav-right,
#header .header-main .header-nav-main.nav-right {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: 2px !important;
    min-width: 0 !important;
}

/* Khoảng cách item search trong header */
#header .header-main li.header-search,
#header .header-main li.header-search-form,
#header .header-main li.header-search-dropdown,
#header .header-main li.header-search-lightbox,
#header .header-main .header-search-form {
    margin: 0 !important;
    padding: 0 !important;
    min-width: 0 !important;
}

/* Search form phải có chiều rộng thật trên thanh nav để không đè lên item kế bên.
   Không ép display:flex / justify-content ở wrapper vì Flatsome dùng .header-search-form
   cả trong dropdown; ép flex tại đây sẽ làm ô input bị thu nhỏ so với khung dropdown. */
#header .header-main li.header-search-form,
#header .header-main .header-search-form {
    flex: 0 1 clamp(340px, 34vw, 430px) !important;
    width: clamp(340px, 34vw, 430px) !important;
    max-width: 430px !important;
    min-width: 260px !important;
    position: relative !important;
    z-index: 2 !important;
}

/* Form search mặc định của Flatsome — giữ nguyên chức năng, chỉ đổi giao diện */
#header .header-main li.header-search-form .searchform,
#header .header-main .header-search-form .searchform,
#header .header-main li.header-search-form form.searchform,
#header .header-main .header-search-form form.searchform,
#header .header-main .ux-search-box form.searchform {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
    position: relative !important;
}

#header .header-main .searchform > .flex-row,
#header .header-main form.searchform > .flex-row,
#header .header-main .ux-search-box form.searchform > .flex-row {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    height: var(--tm-h) !important;
    min-height: var(--tm-h) !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    background: transparent !important;
    border: 1px solid var(--tm-border) !important;
    border-radius: var(--tm-radius) !important;
    box-shadow: none !important;
    transition: background 0.18s ease, border-color 0.18s ease;
}

#header .header-main .searchform:hover > .flex-row,
#header .header-main form.searchform:hover > .flex-row,
#header .header-main .ux-search-box form.searchform:hover > .flex-row,
#header .header-main .searchform:focus-within > .flex-row,
#header .header-main form.searchform:focus-within > .flex-row,
#header .header-main .ux-search-box form.searchform:focus-within > .flex-row {
    background: var(--tm-hover-bg) !important;
    border-color: var(--tm-border-hover) !important;
}

#header .header-main .searchform .flex-col,
#header .header-main .ux-search-box form.searchform .flex-col {
    padding: 0 !important;
    margin: 0 !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
}

#header .header-main .searchform .flex-grow,
#header .header-main .ux-search-box form.searchform .flex-grow {
    min-width: 0 !important;
    flex: 1 1 auto !important;
}

#header .header-main .searchform input[type="search"],
#header .header-main .searchform .search-field,
#header .header-main .ux-search-box form.searchform input[type="search"],
#header .header-main .ux-search-box form.searchform .search-field {
    width: 100% !important;
    height: calc(var(--tm-h) - 2px) !important;
    min-height: calc(var(--tm-h) - 2px) !important;
    padding: 0 10px !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    color: var(--tm-text) !important;
    font-size: var(--tm-fz) !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    text-transform: none !important;
}

#header .header-main .searchform input[type="search"]::placeholder,
#header .header-main .searchform .search-field::placeholder,
#header .header-main .ux-search-box form.searchform input[type="search"]::placeholder,
#header .header-main .ux-search-box form.searchform .search-field::placeholder {
    color: var(--tm-text-muted) !important;
    opacity: 1 !important;
}

/* Nút submit/icon trong form search */
#header .header-main .searchform .ux-search-submit,
#header .header-main .searchform .submit-button,
#header .header-main .searchform button[type="submit"],
#header .header-main .ux-search-box form.searchform .ux-search-submit,
#header .header-main .ux-search-box form.searchform .submit-button,
#header .header-main .ux-search-box form.searchform button[type="submit"] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--tm-h) !important;
    min-width: var(--tm-h) !important;
    height: calc(var(--tm-h) - 2px) !important;
    min-height: calc(var(--tm-h) - 2px) !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-left: 1px solid var(--tm-border) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: var(--tm-text) !important;
    line-height: 1 !important;
    text-shadow: none !important;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

#header .header-main .searchform .ux-search-submit:hover,
#header .header-main .searchform .submit-button:hover,
#header .header-main .searchform button[type="submit"]:hover,
#header .header-main .ux-search-box form.searchform .ux-search-submit:hover,
#header .header-main .ux-search-box form.searchform .submit-button:hover,
#header .header-main .ux-search-box form.searchform button[type="submit"]:hover {
    background: rgba(255, 255, 255, 0.08) !important;
    color: var(--primary-color) !important;
    border-left-color: var(--tm-border-hover) !important;
}

#header .header-main .searchform .ux-search-submit i,
#header .header-main .searchform .submit-button i,
#header .header-main .searchform button[type="submit"] i,
#header .header-main .ux-search-box form.searchform .ux-search-submit i,
#header .header-main .ux-search-box form.searchform .submit-button i,
#header .header-main .ux-search-box form.searchform button[type="submit"] i {
    font-size: var(--tm-fz-icon) !important;
    line-height: 1 !important;
    color: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Icon search dạng nút rời: Search dropdown / Search lightbox */
#header li.header-search > a,
#header li.header-search-dropdown > a,
#header li.header-search-lightbox > a,
#header li.search-button > a,
#header .nav li.header-search > a,
#header .nav li.header-search-dropdown > a,
#header .nav li.header-search-lightbox > a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--tm-h) !important;
    height: var(--tm-h) !important;
    min-width: var(--tm-h) !important;
    max-width: var(--tm-h) !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 1px solid var(--tm-border) !important;
    border-radius: var(--tm-radius) !important;
    color: var(--tm-text) !important;
    line-height: 1 !important;
    text-decoration: none !important;
    box-shadow: none !important;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

#header li.header-search > a:hover,
#header li.header-search-dropdown > a:hover,
#header li.header-search-lightbox > a:hover,
#header li.search-button > a:hover,
#header .nav li.header-search > a:hover,
#header .nav li.header-search-dropdown > a:hover,
#header .nav li.header-search-lightbox > a:hover {
    background: var(--tm-hover-bg) !important;
    color: var(--primary-color) !important;
    border-color: var(--tm-border-hover) !important;
}

#header li.header-search > a i,
#header li.header-search-dropdown > a i,
#header li.header-search-lightbox > a i,
#header li.search-button > a i,
#header li.header-search > a .icon-search,
#header li.header-search-dropdown > a .icon-search,
#header li.header-search-lightbox > a .icon-search,
#header li.search-button > a .icon-search {
    font-size: var(--tm-fz-icon) !important;
    line-height: 1 !important;
    color: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
}

/* Dropdown chứa search form: rộng hơn và canh phải theo icon */
#header .header-main li.header-search-dropdown,
#header .header-main li.header-search {
    position: relative !important;
}

#header .header-main li.header-search-dropdown > .nav-dropdown,
#header .header-main li.header-search > .nav-dropdown {
    left: auto !important;
    right: 0 !important;
    width: 430px !important;
    min-width: 430px !important;
    max-width: calc(100vw - 24px) !important;
    background: var(--tm-panel-bg) !important;
    border: 1px solid var(--tm-panel-border) !important;
    border-radius: 8px !important;
    box-shadow: var(--tm-panel-shadow) !important;
    padding: 8px !important;
}

#header .header-main li.header-search-dropdown > .nav-dropdown .searchform,
#header .header-main li.header-search > .nav-dropdown .searchform {
    width: 100% !important;
    max-width: none !important;
}

@media (max-width: 1200px) {
    #header .header-main li.header-search-form,
    #header .header-main .header-search-form {
        flex-basis: clamp(280px, 28vw, 360px) !important;
        width: clamp(280px, 28vw, 360px) !important;
        max-width: 360px !important;
    }

    #header .header-main li.header-search-dropdown > .nav-dropdown,
    #header .header-main li.header-search > .nav-dropdown {
        width: 380px !important;
        min-width: 380px !important;
    }
}

@media (max-width: 849px) {
    #header .header-main li.header-search-form,
    #header .header-main .header-search-form {
        flex-basis: 240px !important;
        width: 240px !important;
        max-width: 48vw !important;
        min-width: 180px !important;
    }

    #header .header-main li.header-search-dropdown > .nav-dropdown,
    #header .header-main li.header-search > .nav-dropdown {
        width: calc(100vw - 24px) !important;
        min-width: 0 !important;
        max-width: calc(100vw - 24px) !important;
        right: 0 !important;
    }
}


/* ============================================
   8B. HEADER NAV ICON BUTTONS
   Style nút nav-icon còn lại, đồng bộ với search icon.
   ============================================ */

/* Box style — vuông 32×32, border + transparent bg */
#header li.nav-icon > a,
#header li.nav-icon.has-icon > a,
#header .nav-icon > a,
#header .mobile-nav li.nav-icon > a,
body #header li.nav-icon > a.is-small {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--tm-h) !important;
    height: var(--tm-h) !important;
    min-width: var(--tm-h) !important;
    max-width: var(--tm-h);
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 1px solid var(--tm-border) !important;
    border-radius: var(--tm-radius) !important;
    color: var(--tm-text) !important;
    line-height: 1 !important;
    text-decoration: none !important;
    box-shadow: none !important;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}

/* Icon bên trong = 12px, center */
#header li.nav-icon > a > i,
#header .nav-icon > a > i,
#header .mobile-nav li.nav-icon > a > i,
body #header li.nav-icon > a.is-small > i {
    font-size: var(--tm-fz-icon) !important;
    line-height: 1 !important;
    color: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Hover state */
#header li.nav-icon > a:hover,
#header .nav-icon > a:hover,
#header .mobile-nav li.nav-icon > a:hover,
body #header li.nav-icon > a.is-small:hover {
    background: var(--tm-hover-bg) !important;
    color: var(--primary-color) !important;
    border-color: var(--tm-border-hover) !important;
}

/* Reset wrapper li — không padding/margin/background */
#header li.nav-icon,
#header li.nav-icon.has-icon,
#header .mobile-nav li.nav-icon {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    list-style: none;
}

/* Khoảng cách giữa các icon trong mobile-nav: 2px (đồng bộ desktop) */
#header .mobile-nav > li + li,
#header .mobile-nav.nav-right > li + li,
#header .mobile-nav.nav-left > li + li {
    margin-left: 2px !important;
}


/* ============================================
   8C. ACCOUNT & CART TRÊN MOBILE/TABLET
   Cập nhật prefix #header để áp dụng cả mobile-nav
   ============================================ */
#header .mobile-nav li.account-item > a,
#header .mobile-nav li.account-item-dropdown > a,
#header .mobile-nav li.cart-item > a,
#header .mobile-nav li.cart-item .header-cart-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--tm-h) !important;
    height: var(--tm-h) !important;
    min-width: var(--tm-h) !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 1px solid var(--tm-border) !important;
    border-radius: var(--tm-radius) !important;
    color: var(--tm-text) !important;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
#header .mobile-nav li.account-item > a > i,
#header .mobile-nav li.account-item-dropdown > a > i,
#header .mobile-nav li.cart-item > a > i,
#header .mobile-nav li.cart-item .header-cart-link > i {
    font-size: var(--tm-fz-icon) !important;
    line-height: 1 !important;
    color: inherit !important;
    margin: 0 !important;
}
#header .mobile-nav li.account-item > a:hover,
#header .mobile-nav li.account-item-dropdown > a:hover,
#header .mobile-nav li.cart-item > a:hover,
#header .mobile-nav li.cart-item .header-cart-link:hover {
    background: var(--tm-hover-bg) !important;
    color: var(--primary-color) !important;
    border-color: var(--tm-border-hover) !important;
}

/* Cart badge trên mobile-nav giữ Primary */
#header .mobile-nav .cart-item .cart-icon strong,
#header .mobile-nav .header-cart-link .cart-item-count {
    background: var(--primary-color) !important;
    color: #fff !important;
    font-size: 10px;
    min-width: 16px;
    height: 16px;
    line-height: 16px;
    border-radius: 8px;
    padding: 0 4px;
}

/* Avatar account mobile — 20px tròn */
#header .mobile-nav li.account-item img,
#header .mobile-nav li.account-item-dropdown img {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px;
    border-radius: 50% !important;
    object-fit: cover;
    border: 1px solid var(--tm-border);
    margin: 0 !important;
}


/* ============================================
   9. KHOẢNG CÁCH HEADER ITEMS
   ============================================ */
.header-main .flex-row-right > * + *,
.header-main .flex-row-left > * + * {
    margin-left: 2px !important;
}
.header-main .flex-row-right > .header-nav,
.header-main .flex-row-left > .header-nav { padding: 0; }


/* ============================================
   10. SUB-MENU NAV — DARK PANEL
   ============================================ */
.header-main li:not(.cart-item):not(.account-item-dropdown) > .nav-dropdown,
.header-main ul.sub-menu {
    background: var(--tm-panel-bg) !important;
    border: 1px solid var(--tm-panel-border) !important;
    border-radius: 8px !important;
    box-shadow: var(--tm-panel-shadow) !important;
    padding: 6px 0 !important;
    min-width: 220px;
}
.header-main li:not(.cart-item):not(.account-item-dropdown) > .nav-dropdown li a,
.header-main ul.sub-menu li a {
    color: var(--tm-text) !important;
    font-size: var(--tm-fz-dropdown) !important;
    font-weight: 500 !important;
    text-transform: none !important;
    padding: 7px 14px !important;
    border-bottom: none !important;
    transition: all 0.15s ease;
    line-height: 1.4 !important;
}
.header-main li:not(.cart-item):not(.account-item-dropdown) > .nav-dropdown li a:hover,
.header-main ul.sub-menu li a:hover {
    background: rgba(255, 255, 255, 0.05) !important;
    color: var(--primary-color) !important;
    padding-left: 18px !important;
}


/* ============================================
   11. ACCOUNT DROPDOWN
   ============================================ */
.header-main .account-item-dropdown > .nav-dropdown {
    background: var(--tm-panel-bg) !important;
    border: 1px solid var(--tm-panel-border) !important;
    border-radius: 8px !important;
    box-shadow: var(--tm-panel-shadow) !important;
    padding: 6px 0 !important;
}
.header-main .account-item-dropdown > .nav-dropdown li a {
    color: var(--tm-text) !important;
    font-size: var(--tm-fz-dropdown) !important;
    padding: 7px 14px !important;
    font-weight: 500;
    text-transform: none;
    line-height: 1.4 !important;
    transition: all 0.15s ease;
}
.header-main .account-item-dropdown > .nav-dropdown li a:hover {
    background: rgba(255, 255, 255, 0.05) !important;
    color: var(--primary-color) !important;
    padding-left: 18px !important;
}


/* ============================================
   12B. CART POPUP — Compact + Pill buttons
   v1.17: tăng specificity (html body), thu nhỏ text/padding,
   handle thêm class .woocommerce-mini-cart__*
   ============================================ */

/* === Container === */
html body .cart-popup,
html body .header-main li.cart-item .nav-dropdown,
html body .header-main li.cart-item > .nav-dropdown {
    background: var(--tm-panel-bg) !important;
    border: 1px solid var(--tm-panel-border) !important;
    border-radius: 8px !important;
    box-shadow: var(--tm-panel-shadow) !important;
    color: var(--tm-text) !important;
    padding: 8px !important;
    min-width: 290px !important;
    max-width: 320px !important;
}

html body .cart-popup-inner,
html body .cart-popup .widget_shopping_cart_content {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* === List wrapper === */
html body .cart-popup .cart_list,
html body .cart-popup ul.product_list_widget,
html body .cart-popup ul.woocommerce-mini-cart {
    background: transparent !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    max-height: 260px;
    overflow-y: auto;
}

/* === Each item: image absolute trái, content padding-left === */
html body .cart-popup .cart_list li,
html body .cart-popup ul.product_list_widget li,
html body .cart-popup .woocommerce-mini-cart-item {
    position: relative !important;
    display: block !important;
    padding: 6px 20px 6px 46px !important;
    margin: 0 !important;
    border-bottom: 1px solid var(--tm-divider) !important;
    background: transparent !important;
    color: var(--tm-text) !important;
    font-size: 11.5px !important;
    line-height: 1.35;
    min-height: 50px;
}
html body .cart-popup .cart_list li:last-child,
html body .cart-popup ul.product_list_widget li:last-child {
    border-bottom: none !important;
}

/* === Image — 38×38 bo góc var(--tm-radius), absolute === */
html body .cart-popup .cart_list li img,
html body .cart-popup ul.product_list_widget li img,
html body .cart-popup .woocommerce-mini-cart-item img {
    position: absolute !important;
    left: 0 !important;
    top: 6px !important;
    width: 38px !important;
    height: 38px !important;
    border-radius: var(--tm-radius) !important;
    object-fit: cover;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid var(--tm-divider);
    background: transparent !important;
    float: none !important;
}

/* === Title link — max 2 dòng, font var(--tm-fz-dropdown) === */
html body .cart-popup .cart_list li > a:not(.remove),
html body .cart-popup ul.product_list_widget li > a:not(.remove),
html body .cart-popup .woocommerce-mini-cart-item > a:not(.remove) {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    word-break: break-word !important;
    word-wrap: break-word !important;

    /* Backup: hard cap chiều cao = 2 dòng */
    max-height: 2.7em !important;
    width: 100% !important;
    box-sizing: border-box !important;

    color: var(--tm-text) !important;
    font-size: var(--tm-fz-dropdown) !important;
    font-weight: 500 !important;
    line-height: 1.35 !important;
    text-decoration: none !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: color 0.15s ease;
}
html body .cart-popup .cart_list li > a:not(.remove):hover {
    color: var(--primary-color) !important;
}

/* === Quantity × Price === */
html body .cart-popup .cart_list li .quantity,
html body .cart-popup .woocommerce-mini-cart-item .quantity {
    display: block !important;
    margin-top: 2px !important;
    font-size: 10.5px !important;
    color: var(--tm-text-muted) !important;
    line-height: 1.4;
}
html body .cart-popup .cart_list li .quantity .amount,
html body .cart-popup .cart_list li .quantity .woocommerce-Price-amount,
html body .cart-popup .cart_list li .quantity bdi {
    color: var(--primary-color) !important;
    font-weight: 600 !important;
    font-size: 11px !important;
    margin-left: 2px !important;
}

/* === Remove (×) button === */
html body .cart-popup .cart_list li a.remove,
html body .cart-popup ul.product_list_widget li a.remove,
html body .cart-popup .woocommerce-mini-cart-item .remove,
html body .cart-popup .remove {
    position: absolute !important;
    top: 6px !important;
    right: 0 !important;
    width: 16px !important;
    height: 16px !important;
    line-height: 14px !important;
    padding: 0 !important;
    margin: 0 !important;
    text-align: center !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.08) !important;
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    border: none !important;
    text-decoration: none !important;
    transition: all 0.15s ease;
}
html body .cart-popup .cart_list li a.remove:hover,
html body .cart-popup .remove:hover {
    background: var(--primary-color) !important;
    color: #fff !important;
}

/* === Subtotal row === */
html body .cart-popup p.total,
html body .cart-popup .total,
html body .cart-popup .woocommerce-mini-cart__total {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 6px 0 !important;
    margin: 4px 0 0 0 !important;
    border-top: 1px solid var(--tm-divider) !important;
    border-bottom: none !important;
    color: var(--tm-text) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    line-height: 1.4 !important;
    text-align: left !important;
}
html body .cart-popup .total strong,
html body .cart-popup .woocommerce-mini-cart__total strong {
    color: var(--tm-text) !important;
    font-weight: 700 !important;
    font-size: 10px !important;
}
html body .cart-popup .total .amount,
html body .cart-popup .total .woocommerce-Price-amount,
html body .cart-popup .total bdi,
html body .cart-popup .woocommerce-mini-cart__total .amount {
    color: var(--primary-color) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

/* === Buttons container — 2 nút tách rời, gap 5px === */
html body .cart-popup p.buttons,
html body .cart-popup .buttons,
html body .cart-popup .woocommerce-mini-cart__buttons,
html body .widget_shopping_cart_content p.buttons,
html body .widget_shopping_cart_content .buttons {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 5px !important;
    padding: 0 !important;
    margin: 6px 0 0 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* === Style chung cho mọi button === */
html body .cart-popup p.buttons > a,
html body .cart-popup .buttons > a,
html body .cart-popup .buttons .button,
html body .cart-popup .buttons a.button,
html body .cart-popup .woocommerce-mini-cart__buttons > a,
html body .cart-popup .woocommerce-mini-cart__buttons .button,
html body .widget_shopping_cart_content .buttons > a,
html body .widget_shopping_cart_content .buttons .button {
    flex: 1 1 0 !important;
    flex-shrink: 1 !important;
    flex-basis: 0 !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: auto !important;
    height: auto !important;

    padding: 8px 6px !important;
    margin: 0 !important;
    border: none !important;
    border-radius: var(--tm-radius) !important;

    font-size: var(--tm-fz-dropdown) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.25px !important;
    line-height: 1.2 !important;
    text-decoration: none !important;
    text-align: center !important;
    white-space: normal !important;

    box-shadow: none !important;
    transition: background-color 0.15s ease, color 0.15s ease, filter 0.15s ease !important;
}

/* === Button ĐẦU (Xem giỏ hàng) — overlay nhẹ === */
html body .cart-popup .buttons > a:first-child,
html body .cart-popup .buttons > .button:first-child,
html body .cart-popup .woocommerce-mini-cart__buttons > a:first-child,
html body .widget_shopping_cart_content .buttons > a:first-child {
    background: rgba(255, 255, 255, 0.06) !important;
    background-color: rgba(255, 255, 255, 0.06) !important;
    color: var(--tm-text) !important;
}

/* Hover: bg sáng hơn + chữ + mọi child element sang Primary */
html body .cart-popup .buttons > a:first-child:hover,
html body .cart-popup .buttons > .button:first-child:hover,
html body .cart-popup .woocommerce-mini-cart__buttons > a:first-child:hover,
html body .widget_shopping_cart_content .buttons > a:first-child:hover {
    background: rgba(255, 255, 255, 0.12) !important;
    background-color: rgba(255, 255, 255, 0.12) !important;
    color: var(--primary-color) !important;
}
/* Cascade Primary xuống mọi span/text bên trong khi hover */
html body .cart-popup .buttons > a:first-child:hover *,
html body .cart-popup .buttons > a:first-child:hover span,
html body .cart-popup .buttons > a:first-child:hover bdi,
html body .cart-popup .buttons > .button:first-child:hover *,
html body .cart-popup .woocommerce-mini-cart__buttons > a:first-child:hover * {
    color: var(--primary-color) !important;
}

/* === Button CUỐI (Thanh toán) — Primary solid === */
html body .cart-popup .buttons > a:last-child,
html body .cart-popup .buttons > .button:last-child,
html body .cart-popup .woocommerce-mini-cart__buttons > a:last-child,
html body .widget_shopping_cart_content .buttons > a:last-child {
    background: var(--primary-color) !important;
    background-color: var(--primary-color) !important;
    color: #fff !important;
}
html body .cart-popup .buttons > a:last-child:hover,
html body .cart-popup .buttons > .button:last-child:hover,
html body .cart-popup .woocommerce-mini-cart__buttons > a:last-child:hover {
    background: var(--primary-color) !important;
    background-color: var(--primary-color) !important;
    color: #fff !important;
    filter: brightness(1.1) !important;
}

/* Trường hợp chỉ có 1 button (giỏ rỗng / 1 action) — luôn Primary */
html body .cart-popup .buttons > a:only-child,
html body .cart-popup .buttons > .button:only-child {
    background: var(--primary-color) !important;
    color: #fff !important;
}

/* === Empty cart message === */
html body .cart-popup .woocommerce-mini-cart__empty-message,
html body .cart-popup p.empty {
    padding: 14px 0 !important;
    margin: 0 !important;
    text-align: center !important;
    color: var(--tm-text-muted) !important;
    font-size: 11.5px !important;
    background: transparent !important;
}

/* === Scrollbar minimal === */
html body .cart-popup .cart_list::-webkit-scrollbar,
html body .cart-popup .product_list_widget::-webkit-scrollbar,
html body .cart-popup .woocommerce-mini-cart::-webkit-scrollbar {
    width: 4px;
}
html body .cart-popup .cart_list::-webkit-scrollbar-thumb,
html body .cart-popup .product_list_widget::-webkit-scrollbar-thumb,
html body .cart-popup .woocommerce-mini-cart::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.15);
    border-radius: 4px;
}


/* ============================================
   13. DARK MODE — ÁP DỤNG TOÀN BỘ NỘI DUNG
   Header (#header) & Footer (#footer) GIỮ NGUYÊN
   ============================================ */

/* 13.1 — Body & wrappers dark */
html[data-theme="dark"] {
    background-color: var(--tm-dark-bg);
}
html[data-theme="dark"] body {
    background-color: var(--tm-dark-bg) !important;
    color: var(--tm-dark-text);
}

/* 13.2 — Tất cả wrapper trung gian → transparent để body bg lộ ra */
html[data-theme="dark"] #wrapper,
html[data-theme="dark"] #main,
html[data-theme="dark"] #content,
html[data-theme="dark"] .page-wrapper,
html[data-theme="dark"] .main-content,
html[data-theme="dark"] .page-content,
html[data-theme="dark"] .blog-wrapper,
html[data-theme="dark"] .archive-page-header,
html[data-theme="dark"] .page-wrapper-full,
html[data-theme="dark"] .post-wrapper,
html[data-theme="dark"] article,
html[data-theme="dark"] article.row,
html[data-theme="dark"] .row:not(.row-bg):not(.row-bg-color),
html[data-theme="dark"] .col,
html[data-theme="dark"] .col-inner,
html[data-theme="dark"] .section:not(.dark):not(.section-bg-color),
html[data-theme="dark"] .post-item,
html[data-theme="dark"] .post-item-inner,
html[data-theme="dark"] .post-item-content {
    background-color: transparent !important;
}

/* 13.3 — Override inline white background-color (case phổ biến) */
html[data-theme="dark"] #main [style*="background-color:#fff"],
html[data-theme="dark"] #main [style*="background-color: #fff"],
html[data-theme="dark"] #main [style*="background-color:#FFF"],
html[data-theme="dark"] #main [style*="background-color: #FFF"],
html[data-theme="dark"] #main [style*="background-color:#ffffff"],
html[data-theme="dark"] #main [style*="background-color: #ffffff"],
html[data-theme="dark"] #main [style*="background-color: rgb(255, 255, 255)"],
html[data-theme="dark"] #main [style*="background-color:white"],
html[data-theme="dark"] #main [style*="background-color: white"],
html[data-theme="dark"] #main [style*="background:#fff"],
html[data-theme="dark"] #main [style*="background: #fff"],
html[data-theme="dark"] #main [style*="background:white"],
html[data-theme="dark"] #main [style*="background: white"] {
    background-color: var(--tm-dark-card) !important;
}

/* 13.4 — Box / Card / Product item */
html[data-theme="dark"] #main .box,
html[data-theme="dark"] #main .box-text,
html[data-theme="dark"] #main .product .box,
html[data-theme="dark"] #main .product-small .box,
html[data-theme="dark"] #main .product-default .box {
    background-color: transparent !important;
}
html[data-theme="dark"] #main .box-shadow-1 .box-text,
html[data-theme="dark"] #main .box-shadow-2 .box-text,
html[data-theme="dark"] #main .box-shadow-3 .box-text,
html[data-theme="dark"] #main .box-shadow-4 .box-text,
html[data-theme="dark"] #main .box-shadow-5 .box-text {
    background-color: var(--tm-dark-card) !important;
}

/* 13.5 — Headings */
html[data-theme="dark"] #main h1,
html[data-theme="dark"] #main h2,
html[data-theme="dark"] #main h3,
html[data-theme="dark"] #main h4,
html[data-theme="dark"] #main h5,
html[data-theme="dark"] #main h6,
html[data-theme="dark"] #main .heading-font,
html[data-theme="dark"] #main .page-title,
html[data-theme="dark"] #main .entry-title,
html[data-theme="dark"] #main .product-title {
    color: var(--tm-dark-heading) !important;
}

/* 13.6 — Body text */
html[data-theme="dark"] #main,
html[data-theme="dark"] #main p,
html[data-theme="dark"] #main li,
html[data-theme="dark"] #main td,
html[data-theme="dark"] #main label,
html[data-theme="dark"] #main .from_the_blog_excerpt,
html[data-theme="dark"] #main .post-item-description,
html[data-theme="dark"] #main .entry-content,
html[data-theme="dark"] #main .entry-meta,
html[data-theme="dark"] #main .post-meta,
html[data-theme="dark"] #main .price,
html[data-theme="dark"] #main .woocommerce-Price-amount {
    color: var(--tm-dark-text) !important;
}

/* 13.7 — Links */
html[data-theme="dark"] #main a:not(.button):not(.tm-btn):not(.add_to_cart_button):not(.checkout-button) {
    color: var(--tm-dark-text);
}
html[data-theme="dark"] #main a:not(.button):not(.tm-btn):hover { color: var(--primary-color); }

/* 13.8 — Form fields */
html[data-theme="dark"] #main input:not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]),
html[data-theme="dark"] #main textarea,
html[data-theme="dark"] #main select {
    background-color: var(--tm-dark-input) !important;
    color: var(--tm-dark-heading) !important;
    border-color: var(--tm-dark-border) !important;
}
html[data-theme="dark"] #main input::placeholder,
html[data-theme="dark"] #main textarea::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
}

/* 13.9 — Dividers */
html[data-theme="dark"] #main hr,
html[data-theme="dark"] #main .divider,
html[data-theme="dark"] #main .is-divider {
    border-color: var(--tm-dark-border) !important;
    background-color: var(--tm-dark-border) !important;
}

/* 13.10 — Sidebar widgets */
html[data-theme="dark"] .sidebar-inner,
html[data-theme="dark"] .sidebar-inner .widget {
    color: var(--tm-dark-text);
    background-color: transparent;
}
html[data-theme="dark"] .sidebar-inner .widget-title,
html[data-theme="dark"] .widget .widget-title span {
    color: var(--tm-dark-heading) !important;
}
html[data-theme="dark"] .sidebar-inner .widget ul li,
html[data-theme="dark"] .sidebar-inner .widget ul li a {
    color: var(--tm-dark-text) !important;
    border-color: var(--tm-dark-border);
}

/* 13.11 — Tables */
html[data-theme="dark"] #main table,
html[data-theme="dark"] #main table th,
html[data-theme="dark"] #main table td {
    border-color: var(--tm-dark-border);
    color: var(--tm-dark-text);
}
html[data-theme="dark"] #main table th {
    color: var(--tm-dark-heading);
    background-color: rgba(255, 255, 255, 0.04);
}

/* 13.12 — Pagination, breadcrumbs, tabs */
html[data-theme="dark"] #main .page-numbers,
html[data-theme="dark"] #main .breadcrumbs,
html[data-theme="dark"] #main .breadcrumbs a,
html[data-theme="dark"] #main .nav-tabs li a {
    color: var(--tm-dark-text);
    border-color: var(--tm-dark-border);
}

/* 13.13 — WooCommerce specifics */
html[data-theme="dark"] #main .woocommerce-tabs ul.tabs,
html[data-theme="dark"] #main .woocommerce-tabs .panel,
html[data-theme="dark"] #main .product-info,
html[data-theme="dark"] #main .summary {
    background-color: transparent !important;
    color: var(--tm-dark-text);
}
html[data-theme="dark"] #main .woocommerce-tabs ul.tabs li {
    border-color: var(--tm-dark-border) !important;
}
html[data-theme="dark"] #main .woocommerce-tabs ul.tabs li a {
    color: var(--tm-dark-text) !important;
}
html[data-theme="dark"] #main .woocommerce-tabs ul.tabs li.active a {
    color: var(--primary-color) !important;
}

/* 13.14 — Blockquote, code */
html[data-theme="dark"] #main blockquote,
html[data-theme="dark"] #main pre,
html[data-theme="dark"] #main code {
    background-color: var(--tm-dark-card) !important;
    color: var(--tm-dark-text) !important;
    border-color: var(--tm-dark-border);
}

/* 13.15 — HEADER & FOOTER giữ nguyên (KHÔNG override) */


/* ============================================
   8C. RESPONSIVE SEARCH TYPE
   Desktop dùng Dropdown; Mobile/Tablet dùng Lightbox.
   ============================================ */
@media (max-width: 849px) {
    /* Chặn dropdown search mặc định trên mobile/tablet để icon mở lightbox. */
    #header .header-main li.header-search-dropdown > .nav-dropdown,
    #header .header-main li.header-search > .nav-dropdown,
    #header .mobile-header-wrapper li.header-search-dropdown > .nav-dropdown,
    #header .mobile-header-wrapper li.header-search > .nav-dropdown,
    #header .mobile-nav li.header-search-dropdown > .nav-dropdown,
    #header .mobile-nav li.header-search > .nav-dropdown {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
        pointer-events: none !important;
    }
}

.tm-mobile-search-lightbox {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: none;
    align-items: flex-start;
    justify-content: center;
    padding: 72px 14px 24px;
}

.tm-mobile-search-lightbox.is-open {
    display: flex;
}

.tm-mobile-search-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.72);
    backdrop-filter: blur(3px);
}

.tm-mobile-search-lightbox__dialog {
    position: relative;
    z-index: 1;
    width: min(560px, 100%);
    margin: 0 auto;
    padding: 14px;
    background: var(--tm-panel-bg);
    border: 1px solid var(--tm-panel-border);
    border-radius: 10px;
    box-shadow: var(--tm-panel-shadow);
}

.tm-mobile-search-lightbox__close {
    position: absolute;
    top: -44px;
    right: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin: 0;
    padding: 0;
    color: #fff;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 8px;
    box-shadow: none;
    line-height: 1;
}

.tm-mobile-search-lightbox__close:hover {
    color: var(--primary-color);
    background: rgba(255, 255, 255, 0.18);
}

.tm-mobile-search-lightbox__inner,
.tm-mobile-search-lightbox__inner .searchform,
.tm-mobile-search-lightbox__inner form.searchform {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
}

.tm-mobile-search-lightbox__inner .searchform > .flex-row,
.tm-mobile-search-lightbox__inner form.searchform > .flex-row {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    min-height: 44px !important;
    overflow: hidden !important;
    background: transparent !important;
    border: 1px solid var(--tm-border) !important;
    border-radius: var(--tm-radius) !important;
    box-shadow: none !important;
}

.tm-mobile-search-lightbox__inner .searchform input[type="search"],
.tm-mobile-search-lightbox__inner .searchform .search-field {
    width: 100% !important;
    height: 42px !important;
    min-height: 42px !important;
    margin: 0 !important;
    padding: 0 12px !important;
    color: var(--tm-text) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

.tm-mobile-search-lightbox__inner .searchform input[type="search"]::placeholder,
.tm-mobile-search-lightbox__inner .searchform .search-field::placeholder {
    color: var(--tm-text-muted) !important;
    opacity: 1 !important;
}

.tm-mobile-search-lightbox__inner .searchform .ux-search-submit,
.tm-mobile-search-lightbox__inner .searchform .submit-button,
.tm-mobile-search-lightbox__inner .searchform button[type="submit"] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    min-width: 44px !important;
    height: 42px !important;
    min-height: 42px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: var(--tm-text) !important;
    background: transparent !important;
    border: 0 !important;
    border-left: 1px solid var(--tm-border) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.tm-mobile-search-lightbox__inner .searchform .ux-search-submit:hover,
.tm-mobile-search-lightbox__inner .searchform .submit-button:hover,
.tm-mobile-search-lightbox__inner .searchform button[type="submit"]:hover {
    color: var(--primary-color) !important;
    background: rgba(255, 255, 255, 0.08) !important;
}

body.tm-mobile-search-open {
    overflow: hidden !important;
}

@media (min-width: 850px) {
    .tm-mobile-search-lightbox {
        display: none !important;
    }
}

/* ============================================
   8D. SEARCH DROPDOWN DESKTOP — BALANCE + READABILITY
   - Cân đối lại form search trong dropdown desktop.
   - Chỉ đổi giao diện, không can thiệp cơ chế live search của Flatsome.
   ============================================ */
@media (min-width: 850px) {
    #header .header-main li.header-search-dropdown > .nav-dropdown,
    #header .header-main li.header-search > .nav-dropdown {
        width: 456px !important;
        min-width: 456px !important;
        max-width: calc(100vw - 24px) !important;
        padding: 10px !important;
        overflow: hidden !important;
    }

    #header .header-main li.header-search-dropdown > .nav-dropdown .header-search-form,
    #header .header-main li.header-search > .nav-dropdown .header-search-form,
    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform,
    #header .header-main li.header-search > .nav-dropdown .searchform,
    #header .header-main li.header-search-dropdown > .nav-dropdown form.searchform,
    #header .header-main li.header-search > .nav-dropdown form.searchform,
    #header .header-main li.header-search-dropdown > .nav-dropdown .ux-search-box,
    #header .header-main li.header-search > .nav-dropdown .ux-search-box,
    #header .header-main li.header-search-dropdown > .nav-dropdown .ux-search-box form.searchform,
    #header .header-main li.header-search > .nav-dropdown .ux-search-box form.searchform {
        display: block !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        margin: 0 !important;
        padding: 0 !important;
        flex: none !important;
    }

    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform > .flex-row,
    #header .header-main li.header-search > .nav-dropdown .searchform > .flex-row,
    #header .header-main li.header-search-dropdown > .nav-dropdown form.searchform > .flex-row,
    #header .header-main li.header-search > .nav-dropdown form.searchform > .flex-row {
        width: 100% !important;
        max-width: none !important;
        height: 36px !important;
        min-height: 36px !important;
    }

    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform .flex-grow,
    #header .header-main li.header-search > .nav-dropdown .searchform .flex-grow,
    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform .flex-col,
    #header .header-main li.header-search > .nav-dropdown .searchform .flex-col {
        min-width: 0 !important;
        max-width: none !important;
    }

    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform input[type="search"],
    #header .header-main li.header-search > .nav-dropdown .searchform input[type="search"],
    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform .search-field,
    #header .header-main li.header-search > .nav-dropdown .searchform .search-field {
        height: 34px !important;
        min-height: 34px !important;
        padding: 0 12px !important;
        color: #ffffff !important;
    }

    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform .ux-search-submit,
    #header .header-main li.header-search > .nav-dropdown .searchform .ux-search-submit,
    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform .submit-button,
    #header .header-main li.header-search > .nav-dropdown .searchform .submit-button,
    #header .header-main li.header-search-dropdown > .nav-dropdown .searchform button[type="submit"],
    #header .header-main li.header-search > .nav-dropdown .searchform button[type="submit"] {
        width: 40px !important;
        min-width: 40px !important;
        height: 34px !important;
        min-height: 34px !important;
    }
}

/* Kết quả live search mặc định của Flatsome — chỉ chỉnh màu chữ để nổi trên nền tối. */
#header .header-main .nav-dropdown .autocomplete-suggestions,
#header .header-main .nav-dropdown .live-search-results,
#header .header-main .nav-dropdown .ux-search-results {
    width: 100% !important;
    max-width: none !important;
    margin-top: 8px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: #ffffff !important;
}

/* Ép toàn bộ chữ trong live search sang trắng: tiêu đề, mô tả, giá, meta, category... */
#header .header-main .nav-dropdown .autocomplete-suggestions,
#header .header-main .nav-dropdown .autocomplete-suggestions *,
#header .header-main .nav-dropdown .live-search-results,
#header .header-main .nav-dropdown .live-search-results *,
#header .header-main .nav-dropdown .ux-search-results,
#header .header-main .nav-dropdown .ux-search-results *,
#header .header-main .nav-dropdown .autocomplete-suggestion,
#header .header-main .nav-dropdown .autocomplete-suggestion *,
#header .header-main .nav-dropdown .search-name,
#header .header-main .nav-dropdown .search-name *,
#header .header-main .nav-dropdown .search-title,
#header .header-main .nav-dropdown .product-title,
#header .header-main .nav-dropdown .post-title,
#header .header-main .nav-dropdown .entry-title,
#header .header-main .nav-dropdown .title,
#header .header-main .nav-dropdown .name,
#header .header-main .nav-dropdown .woocommerce-loop-product__title,
#header .header-main .nav-dropdown .price,
#header .header-main .nav-dropdown .amount,
#header .header-main .nav-dropdown del,
#header .header-main .nav-dropdown ins,
#header .header-main .nav-dropdown small,
#header .header-main .nav-dropdown .search-excerpt,
#header .header-main .nav-dropdown .search-meta,
#header .header-main .nav-dropdown .category,
#header .header-main .nav-dropdown .sku {
    color: #ffffff !important;
}

#header .header-main .nav-dropdown .autocomplete-suggestion a:hover,
#header .header-main .nav-dropdown .autocomplete-suggestion a:hover *,
#header .header-main .nav-dropdown .live-search-results a:hover,
#header .header-main .nav-dropdown .live-search-results a:hover *,
#header .header-main .nav-dropdown .ux-search-results a:hover,
#header .header-main .nav-dropdown .ux-search-results a:hover *,
#header .header-main .nav-dropdown .search-name a:hover,
#header .header-main .nav-dropdown .search-name a:hover * {
    color: #ffffff !important;
}

#header .header-main .nav-dropdown .autocomplete-suggestion:hover,
#header .header-main .nav-dropdown .live-search-results li:hover,
#header .header-main .nav-dropdown .ux-search-results li:hover {
    background: rgba(255, 255, 255, 0.06) !important;
}


/* ============================================================
   14. POST CARD — BLOG GRID / ARCHIVE
   Style gọn giống header: border mảnh, bo góc, không shadow, không excerpt
   ============================================================ */
.tm-post-cat {
    display: none;
}

#main .post-item {
    /* Flatsome đã có padding/gutter mặc định cho .col; bỏ margin cộng thêm để card gọn như mặc định. */
    margin-bottom: 0 !important;
}

#main .post-item > .col-inner {
    height: 100%;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
}

#main .post-item .box-blog-post,
#main .post-item .box {
    height: 100%;
    border: 1px solid rgba(15, 15, 18, 0.075) !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    box-shadow: none !important;
    overflow: hidden !important;
    transition: border-color 0.18s ease, background 0.18s ease;
}

#main .post-item .box:hover,
#main .post-item .box-blog-post:hover {
    border-color: rgba(255, 103, 0, 0.42) !important;
    box-shadow: none !important;
}

#main .post-item .box-image,
#main .post-item .entry-image,
#main .post-item .post-thumbnail {
    position: relative !important;
    display: block !important;
    margin: 0 !important;
    border-radius: 10px 10px 0 0 !important;
    overflow: hidden !important;
    background: #f4f4f5 !important;
}

#main .post-item .box-image a:not(.tm-post-cat),
#main .post-item .entry-image a:not(.tm-post-cat),
#main .post-item .post-thumbnail a:not(.tm-post-cat) {
    display: block !important;
    width: 100% !important;
}

#main .post-item .box-image img,
#main .post-item .entry-image img,
#main .post-item .post-thumbnail img {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 16 / 9;
    height: auto !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    transition: none !important;
}

#main .post-item:hover .box-image img,
#main .post-item:hover .entry-image img,
#main .post-item:hover .post-thumbnail img {
    transform: none !important;
    filter: none !important;
}

#main .post-item .box-image .tm-post-cat,
#main .post-item .entry-image .tm-post-cat,
#main .post-item .post-thumbnail .tm-post-cat {
    position: absolute !important;
    top: 7px !important;
    left: 7px !important;
    z-index: 5 !important;
    display: inline-flex !important;
    align-items: center !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: calc(100% - 14px) !important;
    right: auto !important;
    padding: 4px 7px !important;
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    border-radius: var(--tm-radius) !important;
    background: rgba(15, 15, 18, 0.62) !important;
    -webkit-backdrop-filter: blur(8px) saturate(160%);
    backdrop-filter: blur(8px) saturate(160%);
    color: #ffffff !important;
    font-size: 9.5px !important;
    font-weight: 700 !important;
    line-height: 1.05 !important;
    letter-spacing: 0.18px !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    text-decoration: none !important;
    cursor: pointer !important;
    pointer-events: auto !important;
}

#main .post-item .box-image .tm-post-cat:hover,
#main .post-item .entry-image .tm-post-cat:hover,
#main .post-item .post-thumbnail .tm-post-cat:hover {
    border-color: rgba(255, 255, 255, 0.30) !important;
    background: rgba(255, 103, 0, 0.86) !important;
    color: #ffffff !important;
    text-decoration: none !important;
}

#main .post-item .box-text,
#main .post-item .entry-summary {
    padding: 11px 12px 13px !important;
    background: transparent !important;
}

#main .post-item .box-text-inner,
#main .post-item .blog-post-inner {
    padding: 0 !important;
}

#main .post-item .post-title,
#main .post-item .post-title a,
#main .post-item .entry-title,
#main .post-item .entry-title a,
#main .post-item h5,
#main .post-item h5 a {
    margin: 0 !important;
    padding: 0 !important;
    color: #171717 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
    text-decoration: none !important;
    text-transform: none !important;
}

#main .post-item .post-title,
#main .post-item .post-title a,
#main .post-item .entry-title,
#main .post-item .entry-title a,
#main .post-item h5,
#main .post-item h5 a {
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden !important;
}

#main .post-item .post-title a:hover,
#main .post-item .entry-title a:hover,
#main .post-item h5 a:hover {
    color: var(--primary-color) !important;
}

#main .post-item .is-divider,
#main .post-item .from_the_blog_excerpt,
#main .post-item .post-item-description,
#main .post-item .post-meta,
#main .post-item .entry-meta,
#main .post-item .badge {
    display: none !important;
}

html[data-theme="dark"] #main .post-item > .col-inner {
    background: transparent !important;
    border-color: transparent !important;
}

html[data-theme="dark"] #main .post-item .box-blog-post,
html[data-theme="dark"] #main .post-item .box {
    background: var(--tm-dark-card) !important;
    border-color: var(--tm-dark-border) !important;
}

html[data-theme="dark"] #main .post-item .box:hover,
html[data-theme="dark"] #main .post-item .box-blog-post:hover {
    border-color: rgba(255, 103, 0, 0.55) !important;
}

html[data-theme="dark"] #main .post-item .box-image,
html[data-theme="dark"] #main .post-item .entry-image,
html[data-theme="dark"] #main .post-item .post-thumbnail {
    background: #252528 !important;
}

html[data-theme="dark"] #main .post-item .post-title,
html[data-theme="dark"] #main .post-item .post-title a,
html[data-theme="dark"] #main .post-item .entry-title,
html[data-theme="dark"] #main .post-item .entry-title a,
html[data-theme="dark"] #main .post-item h5,
html[data-theme="dark"] #main .post-item h5 a {
    color: var(--tm-dark-heading) !important;
}

@media (max-width: 549px) {
    #main .post-item {
        margin-bottom: 0 !important;
    }

    #main .post-item .box-text,
    #main .post-item .entry-summary {
        padding: 10px 11px 12px !important;
    }

    #main .post-item .post-title,
    #main .post-item .post-title a,
    #main .post-item .entry-title,
    #main .post-item .entry-title a,
    #main .post-item h5,
    #main .post-item h5 a {
        font-size: 13.5px !important;
    }
}

/* ============================================================
   15. PAGINATION — PAGE NUMBERS / NAV PAGINATION
   Đồng bộ style header: gọn, border rõ, bo góc var(--tm-radius), không shadow
   ============================================================ */
#main .nav-pagination,
#main ul.page-numbers {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin: 22px 0 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

#main .nav-pagination > li,
#main ul.page-numbers > li {
    margin: 0 !important;
    padding: 0 !important;
}

#main .nav-pagination li > a,
#main .nav-pagination li > span,
#main ul.page-numbers li > a,
#main ul.page-numbers li > span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: var(--tm-h) !important;
    height: var(--tm-h) !important;
    padding: 0 10px !important;
    border: 1px solid rgba(15, 15, 18, 0.12) !important;
    border-radius: var(--tm-radius) !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #171717 !important;
    font-size: var(--tm-fz) !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease !important;
}

#main .nav-pagination li > a:hover,
#main ul.page-numbers li > a:hover {
    background: rgba(255, 103, 0, 0.08) !important;
    border-color: rgba(255, 103, 0, 0.55) !important;
    color: var(--primary-color) !important;
}

#main .nav-pagination li > .current,
#main ul.page-numbers li > .current,
#main .nav-pagination li > span.current,
#main ul.page-numbers li > span.current {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #ffffff !important;
}

#main .nav-pagination li > .dots,
#main ul.page-numbers li > .dots {
    min-width: auto !important;
    padding: 0 4px !important;
    border-color: transparent !important;
    background: transparent !important;
    color: rgba(15, 15, 18, 0.45) !important;
}

#main .nav-pagination i,
#main ul.page-numbers i {
    margin: 0 !important;
    font-size: var(--tm-fz-icon) !important;
    line-height: 1 !important;
}

html[data-theme="dark"] #main .nav-pagination li > a,
html[data-theme="dark"] #main .nav-pagination li > span,
html[data-theme="dark"] #main ul.page-numbers li > a,
html[data-theme="dark"] #main ul.page-numbers li > span {
    background: transparent !important;
    border-color: var(--tm-dark-border) !important;
    color: var(--tm-dark-text) !important;
}

html[data-theme="dark"] #main .nav-pagination li > a:hover,
html[data-theme="dark"] #main ul.page-numbers li > a:hover {
    background: rgba(255, 103, 0, 0.12) !important;
    border-color: rgba(255, 103, 0, 0.70) !important;
    color: var(--primary-color) !important;
}

html[data-theme="dark"] #main .nav-pagination li > .current,
html[data-theme="dark"] #main ul.page-numbers li > .current,
html[data-theme="dark"] #main .nav-pagination li > span.current,
html[data-theme="dark"] #main ul.page-numbers li > span.current {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: #ffffff !important;
}

html[data-theme="dark"] #main .nav-pagination li > .dots,
html[data-theme="dark"] #main ul.page-numbers li > .dots {
    border-color: transparent !important;
    background: transparent !important;
    color: rgba(255, 255, 255, 0.42) !important;
}

@media (max-width: 549px) {
    #main .nav-pagination,
    #main ul.page-numbers {
        gap: 4px !important;
        margin-top: 18px !important;
    }

    #main .nav-pagination li > a,
    #main .nav-pagination li > span,
    #main ul.page-numbers li > a,
    #main ul.page-numbers li > span {
        min-width: 30px !important;
        height: 30px !important;
        padding: 0 8px !important;
        font-size: 11.5px !important;
    }
}

/* ============================================================
   16. BLOG SINGLE POST
   Match child theme language: thin border, 10px radius, no shadow.
   ============================================================ */
.single-post #main .entry-header .entry-header-text,
.single-post #main .entry-content.single-page,
.single-post #main .entry-author.author-box,
.single-post #main .comments-area {
    border: 1px solid rgba(15, 15, 18, 0.075) !important;
    border-radius: 10px !important;
    box-shadow: none !important;
    background: #ffffff !important;
}

.single-post #main .entry-header .entry-header-text {
    padding: 14px 16px 12px !important;
}

.single-post #main .entry-header .entry-title {
    margin: 0 !important;
    color: #171717 !important;
    font-size: clamp(26px, 3vw, 36px) !important;
    line-height: 1.22 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

.single-post #main .entry-header .entry-meta {
    margin-top: 8px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-size: 12px !important;
    color: rgba(23, 23, 23, 0.72) !important;
}

.single-post #main .entry-content.single-page {
    margin-top: 12px !important;
    padding: 16px !important;
    border-radius: 10px !important;
}

.single-post #main .entry-content.single-page,
.single-post #main .entry-content.single-page * {
    box-shadow: none !important;
}

.single-post #main .entry-content.single-page img {
    border-radius: 0 !important;
}

.single-post #main .entry-content.single-page .blog-share {
    margin-top: 16px !important;
}

.tm-single-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin: 0 0 10px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.4;
    text-transform: none;
    letter-spacing: 0.24px;
}

.tm-single-breadcrumb a,
.tm-single-breadcrumb span {
    color: rgba(23, 23, 23, 0.68) !important;
    text-decoration: none !important;
    text-transform: none !important;
}

.tm-single-breadcrumb a:hover {
    color: var(--primary-color) !important;
}

.tm-single-breadcrumb__sep {
    color: rgba(23, 23, 23, 0.32) !important;
    text-transform: none !important;
}

.tm-single-breadcrumb__home i {
    font-size: 11px;
    line-height: 1;
}

.tm-related-posts {
    margin-top: 24px;
}

.tm-related-posts__title {
    margin: 0 0 12px;
    color: #171717;
    font-size: 20px;
    font-weight: 800;
    line-height: 1.3;
}

.tm-related-posts__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.tm-related-post {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border: 1px solid rgba(15, 15, 18, 0.075) !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    box-shadow: none !important;
    overflow: hidden;
    transition: border-color 0.18s ease;
}

.tm-related-post:hover {
    border-color: rgba(255, 103, 0, 0.42) !important;
}

.tm-related-post__thumb {
    display: block;
    aspect-ratio: 16 / 9;
    background: #f4f4f5 !important;
    border-radius: 10px 10px 0 0 !important;
    overflow: hidden !important;
}

.tm-related-post__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.tm-related-post__thumb-placeholder {
    display: block;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(15, 15, 18, 0.06), rgba(15, 15, 18, 0.12));
}

.tm-related-post__body {
    display: flex;
    flex-direction: column;
    gap: 7px;
    padding: 11px 12px 13px !important;
    background: transparent !important;
}

.tm-related-post__title {
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
}

.tm-related-post__title a {
    color: #171717 !important;
    text-decoration: none !important;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.tm-related-post__title a:hover {
    color: var(--primary-color) !important;
}

html[data-theme="dark"] .single-post #main .entry-header .entry-header-text,
html[data-theme="dark"] .single-post #main .entry-content.single-page,
html[data-theme="dark"] .single-post #main .entry-author.author-box,
html[data-theme="dark"] .single-post #main .comments-area,
html[data-theme="dark"] .tm-related-post {
    background: var(--tm-dark-card) !important;
    border-color: var(--tm-dark-border) !important;
}

html[data-theme="dark"] .single-post #main .entry-header .entry-title,
html[data-theme="dark"] .tm-related-post__title a,
html[data-theme="dark"] .tm-related-posts__title {
    color: var(--tm-dark-heading) !important;
}

html[data-theme="dark"] .tm-single-breadcrumb a,
html[data-theme="dark"] .tm-single-breadcrumb span,
html[data-theme="dark"] .single-post #main .entry-header .entry-meta {
    color: rgba(255, 255, 255, 0.7) !important;
}

.single-post #main .nav-links {
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.single-post #main .comments-area {
    margin-top: 10px !important;
    padding: 14px 16px !important;
}

.single-post #main .comments-area .comment-respond {
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
}

.single-post #main .comments-area .comment-reply-title {
    margin: 0 0 10px !important;
    color: #171717 !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    text-transform: none !important;
}

.single-post #main .comments-area p,
.single-post #main .comments-area label,
.single-post #main .comments-area .logged-in-as,
.single-post #main .comments-area .logged-in-as a,
.single-post #main .comments-area .comment-notes {
    color: rgba(23, 23, 23, 0.78) !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
    text-transform: none !important;
}

.single-post #main .comments-area label {
    display: block;
    margin-bottom: 6px;
    font-weight: 700;
}

.single-post #main .comments-area input[type="text"],
.single-post #main .comments-area input[type="email"],
.single-post #main .comments-area input[type="url"],
.single-post #main .comments-area textarea {
    width: 100%;
    border: 1px solid rgba(15, 15, 18, 0.14) !important;
    border-radius: 10px !important;
    box-shadow: none !important;
    background: #ffffff !important;
    color: #171717 !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
}

.single-post #main .comments-area input[type="text"],
.single-post #main .comments-area input[type="email"],
.single-post #main .comments-area input[type="url"] {
    height: 42px !important;
    padding: 0 12px !important;
}

.single-post #main .comments-area textarea {
    min-height: 130px !important;
    padding: 12px !important;
    resize: vertical;
}

.single-post #main .comments-area input[type="text"]:focus,
.single-post #main .comments-area input[type="email"]:focus,
.single-post #main .comments-area input[type="url"]:focus,
.single-post #main .comments-area textarea:focus {
    border-color: rgba(255, 103, 0, 0.65) !important;
    box-shadow: none !important;
    outline: 0 !important;
}

.single-post #main .comments-area .form-submit {
    margin: 12px 0 0 !important;
}

.single-post #main .comments-area .tm-comment-submit,
.single-post #main .comments-area .submit {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 40px !important;
    padding: 0 16px !important;
    border: 1px solid var(--primary-color) !important;
    border-radius: 6px !important;
    background: var(--primary-color) !important;
    color: #ffffff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.2px !important;
    box-shadow: none !important;
}

.single-post #main .comments-area .tm-comment-submit:hover,
.single-post #main .comments-area .submit:hover {
    background: #ff7a1f !important;
    border-color: #ff7a1f !important;
}

html[data-theme="dark"] .single-post #main .comments-area .comment-reply-title {
    color: var(--tm-dark-heading) !important;
}

html[data-theme="dark"] .single-post #main .comments-area p,
html[data-theme="dark"] .single-post #main .comments-area label,
html[data-theme="dark"] .single-post #main .comments-area .logged-in-as,
html[data-theme="dark"] .single-post #main .comments-area .logged-in-as a,
html[data-theme="dark"] .single-post #main .comments-area .comment-notes {
    color: var(--tm-dark-text) !important;
}

html[data-theme="dark"] .single-post #main .comments-area input[type="text"],
html[data-theme="dark"] .single-post #main .comments-area input[type="email"],
html[data-theme="dark"] .single-post #main .comments-area input[type="url"],
html[data-theme="dark"] .single-post #main .comments-area textarea {
    background: var(--tm-dark-input) !important;
    border-color: var(--tm-dark-border) !important;
    color: var(--tm-dark-heading) !important;
}

@media (max-width: 849px) {
    .tm-related-posts__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 549px) {
    .single-post #main .entry-header .entry-header-text,
    .single-post #main .entry-content.single-page {
        padding: 12px !important;
    }

    .single-post #main .entry-header .entry-title {
        font-size: clamp(22px, 7.2vw, 29px) !important;
    }

    .tm-related-posts__grid {
        grid-template-columns: 1fr;
    }
}
