/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.0
*/

/*************** ADD CUSTOM CSS HERE.   ***************/

@font-face {
    font-family: 'SVN-Mont';
    src: url('fonts/SVN-MontBold.woff2') format('woff2'),
         url('fonts/SVN-MontBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'SVN-Mont';
    src: url('fonts/SVN-Mont.woff2') format('woff2'),
         url('fonts/SVN-Mont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Helvetica Neue';
    src: url('fonts/HelveticaNeue.woff2') format('woff2'),
         url('fonts/HelveticaNeue.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

body,html{font-family: 'SVN-Mont', sans-serif; font-weight:normal}
h1,h2,h3,h4,h5,h6{ font-family: 'SVN-Mont', sans-serif; font-weight:bold}

/* Custom Premium Page Header Hero Section */
.custom-page-header-wrapper {
    background: #f2f7fb; /* Màu xám xanh nhạt dịu mắt, pha từ màu xanh chủ đạo */
    padding: 30px 15px;
    text-align: center;
    border-top: 1px solid #e1edf6;
    border-bottom: 1px solid #e1edf6;
    margin-bottom: 30px;
    position: relative;
}

.custom-page-header-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.custom-page-title {
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #1a355e !important; /* Xanh Navy đậm sang trọng */
    margin: 0 0 10px 0 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Thanh phân tách nghệ thuật phối màu theo logo */
.page-title-divider {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 6px;
    margin-bottom: 15px;
}

.page-title-divider .line-blue {
    width: 40px;
    height: 2px;
    background: #367eb0; /* Xanh chủ đạo */
    border-radius: 2px;
}

.page-title-divider .dot-red {
    width: 6px;
    height: 6px;
    background: #d41820; /* Đỏ logo */
    border-radius: 50%;
    position: relative;
    display: inline-block;
}

.page-title-divider .dot-red::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: #d41820;
    animation: ripple-pulse 2s infinite ease-out;
    pointer-events: none;
}

@keyframes ripple-pulse {
    0% {
        transform: scale(1);
        opacity: 0.8;
    }
    100% {
        transform: scale(4.5);
        opacity: 0;
    }
}

.page-title-divider .line-red {
    width: 40px;
    height: 2px;
    background: #367eb0; /* Đồng nhất màu và kích thước để cân đối */
    border-radius: 2px;
}

.custom-breadcrumb-container {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    background: #ffffff;
    padding: 6px 20px;
    border-radius: 30px;
    border: 1px solid #e2e8f0;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.04);
}

.custom-breadcrumb-container a.breadcrumb-item {
    color: #367eb0 !important;
    text-decoration: none;
    font-weight: 600;
    font-size: 13px;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
}

.custom-breadcrumb-container a.breadcrumb-item:hover {
    color: #d41820 !important;
    transform: translateY(-0.5px);
}

.custom-breadcrumb-container .breadcrumb-separator {
    color: #b1ccd0;
    margin: 0 8px;
    font-size: 10px;
    display: inline-flex;
    align-items: center;
}

.custom-breadcrumb-container .breadcrumb-item.active {
    color: #1e2d3b;
    font-weight: 700;
    font-size: 13px;
}

/* Hiệu ứng xẹt sáng gương (Mirror Shine Effect) cho hình ảnh khi hover */
.img-inner, 
.wp-block-image, 
.box-image, 
.ux-image-box, 
.gallery-image,
.post-item .image,
.banner-bg {
    position: relative;
    overflow: hidden !important;
}

.img-inner::after, 
.wp-block-image::after, 
.box-image::after, 
.ux-image-box::after, 
.gallery-image::after,
.post-item .image::after,
.banner-bg::after {
    content: '';
    position: absolute;
    top: 0;
    left: -150%;
    width: 60%;
    height: 100%;
    background: linear-gradient(
        to right, 
        rgba(255, 255, 255, 0) 0%, 
        rgba(255, 255, 255, 0.4) 30%, 
        rgba(255, 255, 255, 0.7) 50%, 
        rgba(255, 255, 255, 0.4) 70%, 
        rgba(255, 255, 255, 0) 100%
    );
    transform: skewX(-25deg);
    transition: none;
    pointer-events: none;
    z-index: 9;
}

.img-inner:hover::after, 
.wp-block-image:hover::after, 
.box-image:hover::after, 
.ux-image-box:hover::after, 
.gallery-image:hover::after,
.post-item .image:hover::after,
.banner-bg:hover::after {
    left: 150%;
    transition: all 0.75s ease-in-out;
}

/* Kết hợp hiệu ứng Zoom nhẹ hình ảnh khi hover để tăng độ sinh động */
.img-inner img, 
.wp-block-image img, 
.box-image img, 
.ux-image-box img, 
.gallery-image img,
.post-item .image img {
    transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.img-inner:hover img, 
.wp-block-image:hover img, 
.box-image:hover img, 
.ux-image-box:hover img, 
.gallery-image:hover img,
.post-item .image:hover img {
    transform: scale(1.04);
}

@media only screen and (max-width: 48em) {
/*************** ADD MOBILE ONLY CSS HERE  ***************/

    .custom-page-header-wrapper {
        padding: 20px 10px;
        margin-bottom: 20px;
    }
    .custom-page-title {
        font-size: 22px !important;
    }
    .custom-breadcrumb-container a.breadcrumb-item,
    .custom-breadcrumb-container .breadcrumb-item.active {
        font-size: 12px;
    }
    .custom-breadcrumb-container .breadcrumb-separator {
        margin: 0 6px;
    }
}

/* Ẩn tiêu đề mặc định của Flatsome để tránh lặp lại */
.page-title.normal-title,
.page-header.page-title,
.entry-title {
    display: none !important;
}

/* Custom Premium Tabbed Mega Menu styling (Desktop) */
@media (min-width: 850px) {
    /* Khung Dropdown của Mega Menu - Thiết kế Glassmorphism đẳng cấp */
    #menu-item-1125 .nav-dropdown {
        position: absolute !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 960px !important; /* Mở rộng chiều rộng tạo sự bề thế */
        max-width: 95vw !important;
        height: 420px !important; /* Chiều cao cân đối vàng */
        border-radius: 20px !important; /* Bo góc mềm mại hơn */
        box-shadow: 0 30px 70px rgba(26, 53, 94, 0.12) !important;
        border: 1px solid rgba(226, 232, 240, 0.8) !important;
        padding: 0 !important;
        background: rgba(255, 255, 255, 0.9) !important;
        backdrop-filter: blur(20px) !important; /* Kính mờ siêu sang */
        -webkit-backdrop-filter: blur(20px) !important;
        display: block !important;
        box-sizing: border-box !important;
        overflow: hidden !important;
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1), transform 0.25s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
        transform: translate(-50%, 15px) !important;
        top: 100% !important;
        margin-top: 0 !important;
    }

    /* Hover Bridge - Cầu nối vô hình chống đứt hover khi di chuyển chuột xuống menu */
    #menu-item-1125 .nav-dropdown::after {
        content: "" !important;
        position: absolute !important;
        top: -30px !important;
        left: 0 !important;
        right: 0 !important;
        height: 30px !important;
        background: transparent !important;
        z-index: -1 !important;
    }

    /* Vẽ hình nền cột trái (Sidebar) */
    #menu-item-1125 .nav-dropdown::before {
        content: "" !important;
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        bottom: 0 !important;
        width: 280px !important;
        background: rgba(248, 250, 252, 0.65) !important; /* Nền xám gương trong suốt */
        border-right: 1px solid rgba(226, 232, 240, 0.6) !important;
        z-index: 1 !important;
    }

    /* Hiển thị khi hover */
    #menu-item-1125:hover .nav-dropdown {
        opacity: 1 !important;
        visibility: visible !important;
        transform: translate(-50%, 0) !important;
    }

    /* Reset vị trí các cột chính (li) thành static */
    #menu-item-1125 .nav-dropdown > li {
        position: static !important;
        display: block !important;
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
        width: auto !important;
        height: auto !important;
        flex: none !important;
        max-width: none !important;
    }

    /* Sidebar Header - Tiêu đề tạo cảm giác giao diện app chuyên nghiệp */
    #menu-item-1125 .nav-dropdown > li:nth-child(1)::before {
        content: "Danh mục dịch vụ" !important;
        position: absolute !important;
        top: 22px !important;
        left: 28px !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        color: #94a3b8 !important;
        letter-spacing: 1.5px !important;
        z-index: 3 !important;
        text-transform: uppercase !important;
    }

    /* Định dạng liên kết Tab cha - Dạng Pill bo tròn lồng trong sidebar */
    #menu-item-1125 .nav-dropdown > li > a {
        position: absolute !important;
        left: 15px !important;
        width: 250px !important;
        height: 46px !important;
        line-height: 46px !important;
        font-weight: 700 !important;
        font-size: 13px !important;
        color: #4a5568 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        padding: 0 15px 0 60px !important; /* Chừa khoảng trống cho vòng tròn icon 30px */
        margin: 0 !important;
        display: block !important;
        border: none !important;
        border-radius: 8px !important;
        border-left: 3px solid transparent !important;
        box-sizing: border-box !important;
        z-index: 2 !important;
        transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
        background-repeat: no-repeat !important;
        background-position: 18px center !important;
        background-size: 30px 30px !important;
        background-color: transparent !important;
    }

    /* Hover Bridge cho từng Tab cha - Bắc cầu 15px khoảng trống sang sub-menu bên phải */
    #menu-item-1125 .nav-dropdown > li > a::after {
        content: "" !important;
        position: absolute !important;
        top: 0 !important;
        right: -20px !important; /* Kéo dài vùng hover thêm 20px về phía bên phải */
        width: 20px !important;
        height: 100% !important;
        background: transparent !important;
        z-index: 10 !important;
    }

    /* Định vị trí tuyệt đối của các tab cha theo thứ tự */
    #menu-item-1125 .nav-dropdown > li:nth-child(1) > a {
        top: 54px !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23f1f5f9'/%3E%3Cpath d='M22.7 19l-9.1-9.1c.9-2.3.4-5-1.5-6.9-2-2-5-2.4-7.4-1.3L9 6 6 9 1.6 4.3C.5 6.7.9 9.8 2.9 11.8c1.9 1.9 4.6 2.4 6.9 1.5l9.1 9.1c.4.4 1 .4 1.4 0l2.4-2.4c.4-.4.4-1 0-1.4z' transform='translate%284%204%29' fill='%234a5568'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(2) > a {
        top: 114px !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23f1f5f9'/%3E%3Cpath d='M10 20v-6h4v6h5v-8h3L12 3 2 12h3v8z' transform='translate%284%204%29' fill='%234a5568'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(3) > a {
        top: 174px !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23f1f5f9'/%3E%3Cpath d='M19 2H5c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM5 8V4h14v4H5zm6 4h2v8h-2z' transform='translate%284%204%29' fill='%234a5568'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(4) > a {
        top: 234px !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23f1f5f9'/%3E%3Cpath d='M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4z' transform='translate%284%204%29' fill='%234a5568'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(5) > a {
        top: 294px !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23f1f5f9'/%3E%3Cpath d='M12 3L2 12h3v8h14v-8h3L12 3zm1 15h-2v-2h2v2zm0-4h-2v-4h2v4z' transform='translate%284%204%29' fill='%234a5568'/%3E%3C/svg%3E") !important;
    }

    /* Hiệu ứng Hover chung cho Tab */
    #menu-item-1125 .nav-dropdown > li:hover > a {
        color: #d41820 !important;
        background-color: #ffffff !important;
        box-shadow: 0 8px 25px rgba(26, 53, 94, 0.05) !important;
        border-left: 3px solid #d41820 !important;
    }

    /* Đổi màu icon + vòng tròn sang đỏ nhạt trên hover */
    #menu-item-1125 .nav-dropdown > li:nth-child(1):hover > a {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23fee2e2'/%3E%3Cpath d='M22.7 19l-9.1-9.1c.9-2.3.4-5-1.5-6.9-2-2-5-2.4-7.4-1.3L9 6 6 9 1.6 4.3C.5 6.7.9 9.8 2.9 11.8c1.9 1.9 4.6 2.4 6.9 1.5l9.1 9.1c.4.4 1 .4 1.4 0l2.4-2.4c.4-.4.4-1 0-1.4z' transform='translate%284%204%29' fill='%23d41820'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(2):hover > a {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23fee2e2'/%3E%3Cpath d='M10 20v-6h4v6h5v-8h3L12 3 2 12h3v8z' transform='translate%284%204%29' fill='%23d41820'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(3):hover > a {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23fee2e2'/%3E%3Cpath d='M19 2H5c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2zM5 8V4h14v4H5zm6 4h2v8h-2z' transform='translate%284%204%29' fill='%23d41820'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(4):hover > a {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23fee2e2'/%3E%3Cpath d='M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4z' transform='translate%284%204%29' fill='%23d41820'/%3E%3C/svg%3E") !important;
    }
    #menu-item-1125 .nav-dropdown > li:nth-child(5):hover > a {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23fee2e2'/%3E%3Cpath d='M12 3L2 12h3v8h14v-8h3L12 3zm1 15h-2v-2h2v2zm0-4h-2v-4h2v4z' transform='translate%284%204%29' fill='%23d41820'/%3E%3C/svg%3E") !important;
    }

    /* Cột phải: Khung hiển thị các dịch vụ con tương ứng với Tab được chọn */
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu {
        position: absolute !important;
        top: 0 !important;
        left: 280px !important;
        right: 0 !important;
        bottom: 0 !important;
        width: auto !important;
        height: 100% !important;
        padding: 25px 40px 35px 40px !important;
        background: #ffffff !important;
        box-sizing: border-box !important;
        display: none !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px 30px !important;
        align-content: start !important;
        box-shadow: none !important;
        border: none !important;
        overflow-y: auto !important;
        z-index: 10 !important;
    }

    /* Panel Header - Đề mục dịch vụ con sang trọng */
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu::before {
        content: "Dịch vụ chi tiết" !important;
        grid-column: 1 / -1 !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        color: #94a3b8 !important;
        letter-spacing: 1.5px !important;
        text-transform: uppercase !important;
        margin-bottom: 12px !important;
        padding-bottom: 10px !important;
        border-bottom: 1px solid #f1f5f9 !important;
        display: block !important;
    }

    /* Định dạng scrollbar cho khung bên phải tinh tế */
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu::-webkit-scrollbar {
        width: 6px !important;
    }
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu::-webkit-scrollbar-track {
        background: transparent !important;
    }
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu::-webkit-scrollbar-thumb {
        background: #cbd5e1 !important;
        border-radius: 4px !important;
    }
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu::-webkit-scrollbar-thumb:hover {
        background: #94a3b8 !important;
    }

    /* Tab 1 (Sửa Nhà Trọn Gói) hiển thị mặc định */
    #menu-item-1125 .nav-dropdown > li:first-child > ul.sub-menu {
        display: grid !important;
    }

    #menu-item-1125 .nav-dropdown > li:first-child > a {
        background-color: #ffffff !important;
        color: #d41820 !important;
        box-shadow: 0 4px 15px rgba(26, 53, 94, 0.06) !important;
        border-left: 3px solid #d41820 !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23fee2e2'/%3E%3Cpath d='M22.7 19l-9.1-9.1c.9-2.3.4-5-1.5-6.9-2-2-5-2.4-7.4-1.3L9 6 6 9 1.6 4.3C.5 6.7.9 9.8 2.9 11.8c1.9 1.9 4.6 2.4 6.9 1.5l9.1 9.1c.4.4 1 .4 1.4 0l2.4-2.4c.4-.4.4-1 0-1.4z' transform='translate%284%204%29' fill='%23d41820'/%3E%3C/svg%3E") !important;
    }

    /* Khi rê chuột vào danh sách tab, ẩn trạng thái active mặc định của Tab 1 */
    #menu-item-1125 .nav-dropdown:hover > li:first-child > ul.sub-menu {
        display: none !important;
    }
    #menu-item-1125 .nav-dropdown:hover > li:first-child > a {
        background-color: transparent !important;
        box-shadow: none !important;
        color: #4a5568 !important;
        border-left: 3px solid transparent !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23f1f5f9'/%3E%3Cpath d='M22.7 19l-9.1-9.1c.9-2.3.4-5-1.5-6.9-2-2-5-2.4-7.4-1.3L9 6 6 9 1.6 4.3C.5 6.7.9 9.8 2.9 11.8c1.9 1.9 4.6 2.4 6.9 1.5l9.1 9.1c.4.4 1 .4 1.4 0l2.4-2.4c.4-.4.4-1 0-1.4z' transform='translate%284%204%29' fill='%234a5568'/%3E%3C/svg%3E") !important;
    }

    /* Khôi phục trạng thái active của Tab 1 nếu rà chuột trực tiếp vào chính nó */
    #menu-item-1125 .nav-dropdown:hover > li:first-child:hover > ul.sub-menu {
        display: grid !important;
    }
    #menu-item-1125 .nav-dropdown:hover > li:first-child:hover > a {
        background-color: #ffffff !important;
        color: #d41820 !important;
        box-shadow: 0 4px 15px rgba(26, 53, 94, 0.06) !important;
        border-left: 3px solid #d41820 !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='15' fill='%23fee2e2'/%3E%3Cpath d='M22.7 19l-9.1-9.1c.9-2.3.4-5-1.5-6.9-2-2-5-2.4-7.4-1.3L9 6 6 9 1.6 4.3C.5 6.7.9 9.8 2.9 11.8c1.9 1.9 4.6 2.4 6.9 1.5l9.1 9.1c.4.4 1 .4 1.4 0l2.4-2.4c.4-.4.4-1 0-1.4z' transform='translate%284%204%29' fill='%23d41820'/%3E%3C/svg%3E") !important;
    }

    /* Hiện menu con khi tab tương ứng được hover */
    #menu-item-1125 .nav-dropdown > li:hover > ul.sub-menu {
        display: grid !important;
    }

    /* Định dạng danh mục con */
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu > li {
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
        box-sizing: border-box !important;
    }

    /* Các liên kết trang con */
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu > li > a {
        font-size: 14px !important;
        color: #2d3748 !important; /* Chữ đậm và rõ ràng hơn */
        padding: 6px 0 !important;
        transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
        display: inline-flex !important;
        align-items: center !important;
        font-weight: 500 !important;
        width: 100% !important;
        line-height: 1.4 !important;
        white-space: normal !important;
        word-break: break-word !important;
    }

    /* Chấm tròn nhỏ trước mỗi dịch vụ con dạng dot tối giản */
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu > li > a::before {
        content: "" !important;
        display: inline-block !important;
        width: 6px !important;
        height: 6px !important;
        border-radius: 50% !important;
        background: #cbd5e1 !important; /* Màu xám dịu */
        margin-right: 12px !important;
        transition: all 0.2s ease !important;
        flex-shrink: 0 !important;
    }

    /* Hiệu ứng tương tác cho dịch vụ con */
    #menu-item-1125 .nav-dropdown > li > ul.sub-menu > li > a:hover {
        color: #367eb0 !important; /* Màu xanh thương hiệu khi hover */
        transform: translateX(6px) !important;
    }

    #menu-item-1125 .nav-dropdown > li > ul.sub-menu > li > a:hover::before {
        background: #367eb0 !important; /* Đổi dot sang màu xanh */
        transform: scale(1.4) !important;
    }
}

/* Tối ưu hóa hiển thị Menu trên thiết bị di động (Mobile) */
@media (max-width: 849px) {
    /* Tăng độ thụt dòng nhẹ của menu cấp 2 và cấp 3 để thấy rõ phân cấp */
    .mobile-sidebar .nav-sidebar li.menu-item-has-children > ul.sub-menu {
        background-color: #f8fafc !important;
        padding: 5px 0 !important;
    }
    
    /* Tên danh mục lớn trong mobile menu (Sửa nhà trọn gói,...) */
    .mobile-sidebar .nav-sidebar ul.sub-menu > li > a {
        font-weight: 700 !important;
        color: #1a355e !important;
        font-size: 14px !important;
        border-bottom: 1px solid #edf2f7 !important;
        padding-left: 20px !important;
    }
    
    /* Tên trang con chi tiết (Sửa nhà Hà Nội,...) */
    .mobile-sidebar .nav-sidebar ul.sub-menu ul.sub-menu > li > a {
        font-weight: 500 !important;
        color: #4a5568 !important;
        font-size: 13px !important;
        padding-left: 35px !important; /* Thụt lề rõ ràng để phân biệt */
        border: none !important;
    }
    
    /* Màu hover cho liên kết trên mobile */
    .mobile-sidebar .nav-sidebar a:active,
    .mobile-sidebar .nav-sidebar a:hover {
        color: #d41820 !important;
    }
}

/* ==========================================================================
   TỐI ƯU HÓA MAIN HEADER (DESKTOP) - CO GIÃN ĐỘNG & CĂN GIỮA MENU
   ========================================================================== */
@media (min-width: 850px) {
    /* 1. Thiết lập Flex Row co giãn tự động */
    .header-main .header-inner.flex-row {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        width: 100% !important;
    }

    /* 2. Cột Logo: Chỉ chiếm diện tích của logo, không chiếm thừa khoảng trống */
    .header-main .flex-col.logo {
        flex: 0 0 auto !important;
        max-width: fit-content !important;
        padding-right: 30px !important; /* Đệm phải thoáng đãng */
    }

    /* 3. Cột Nút / Tiêu điểm bên phải: Chỉ chiếm diện tích vừa đủ của nội dung */
    .header-main .flex-col.flex-right {
        flex: 0 0 auto !important;
        max-width: fit-content !important;
        padding-left: 30px !important;
    }

    /* 4. Cột Menu chính ở giữa: Tự động lấp đầy phần diện tích còn lại ở giữa */
    .header-main .flex-col.flex-grow {
        flex: 1 1 auto !important;
        display: flex !important;
        justify-content: center !important; /* Căn giữa ngang menu */
        align-items: center !important;
        max-width: none !important;
    }

    /* 5. Căn giữa menu danh sách và ngăn hoàn toàn tình trạng xuống hàng */
    .header-main .header-nav-main {
        display: flex !important;
        justify-content: center !important;
        flex-wrap: nowrap !important; /* Ngăn chặn menu tự ý xuống hàng */
        width: auto !important;
        float: none !important;
    }

    /* Đảm bảo các mục liên kết menu hiển thị thẳng hàng và cân đối */
    .header-main .header-nav-main > li {
        float: none !important;
        display: inline-block !important;
        flex: 0 0 auto !important;
    }
}

/* ==========================================================================
   THIẾT KẾ PREMIUM CHO SECTION: BẠN ĐANG CẦN? (TRANG CHỦ)
   ========================================================================== */

/* 1. Khu vực Tiêu đề chính đẹp và ấn tượng */
.premium-services-header {
    margin-bottom: 40px !important;
}

.premium-services-header .sub-title {
    display: block !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #367eb0 !important; /* Xanh thương hiệu */
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    margin-bottom: 10px !important;
}

.premium-services-header .main-title {
    font-size: 34px !important;
    font-weight: 800 !important;
    color: #ffffff !important; /* Nổi bật trên hình nền overlay tối */
    text-transform: uppercase !important;
    margin: 0 !important;
    letter-spacing: 0.5px !important;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3) !important;
}

/* Thanh phân tách nghệ thuật phối màu logo có chấm tròn nhấp nháy */
.premium-services-header .divider-decor {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin: 15px 0 0 0;
}

.premium-services-header .divider-decor .line-left,
.premium-services-header .divider-decor .line-right {
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, transparent, #367eb0);
}

.premium-services-header .divider-decor .line-right {
    background: linear-gradient(90deg, #367eb0, transparent);
}

.premium-services-header .divider-decor .dot-center {
    width: 8px;
    height: 8px;
    background: #d41820; /* Đỏ logo */
    border-radius: 50%;
    position: relative;
    display: inline-block;
}

.premium-services-header .divider-decor .dot-center::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: #d41820;
    animation: ripple-pulse 2s infinite ease-out;
    pointer-events: none;
}

/* 2. Đám mây dịch vụ tương tác (Tag Cloud Connection) */
.premium-services-cloud-wrapper {
    position: relative !important;
    width: 100% !important;
    min-height: 380px !important;
    padding: 30px 10px !important;
    margin-bottom: 35px !important;
    border-radius: 20px !important;
    background: rgba(255, 255, 255, 0.02) !important;
    border: 1px solid rgba(255, 255, 255, 0.05) !important;
    box-shadow: inset 0 0 40px rgba(0, 0, 0, 0.2) !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

#cloud-connection-canvas {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

.premium-services-cloud {
    position: relative !important;
    z-index: 2 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 12px 16px !important;
    max-width: 1050px !important;
    margin: 0 auto !important;
    padding: 10px !important;
}

/* Base style cho các tag dịch vụ (Glassmorphism cực đẹp) */
.cloud-tag {
    display: inline-block !important;
    padding: 10px 22px !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    color: rgba(255, 255, 255, 0.85) !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 30px !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    transition: all 0.35s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4) !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important;
    text-decoration: none !important;
    cursor: pointer !important;
    text-transform: none !important;
}

/* Các tag phụ - Thêm chấm tròn màu tương ứng nhóm cha để phân biệt trên Mobile */
.cloud-tag.tag-sub {
    padding: 10px 20px 10px 14px !important;
}

.cloud-tag.tag-sub::before {
    content: "" !important;
    display: inline-block !important;
    width: 6.5px !important;
    height: 6.5px !important;
    border-radius: 50% !important;
    margin-right: 8px !important;
    vertical-align: middle !important;
    transition: transform 0.3s ease !important;
}

.cloud-tag.tag-sub.tag-sua-nha::before {
    background-color: #d41820 !important;
    box-shadow: 0 0 6px rgba(212, 24, 32, 0.8) !important;
}
.cloud-tag.tag-sub.tag-xay-nha::before {
    background-color: #367eb0 !important;
    box-shadow: 0 0 6px rgba(54, 126, 176, 0.8) !important;
}
.cloud-tag.tag-sub.tag-son-nha::before {
    background-color: #ffb703 !important;
    box-shadow: 0 0 6px rgba(255, 183, 3, 0.8) !important;
}
.cloud-tag.tag-sub.tag-chong-tham::before {
    background-color: #00b4d8 !important;
    box-shadow: 0 0 6px rgba(0, 180, 216, 0.8) !important;
}
.cloud-tag.tag-sub.tag-mai-ton::before {
    background-color: #7209b7 !important;
    box-shadow: 0 0 6px rgba(114, 9, 183, 0.8) !important;
}

/* Phóng to chấm tròn khi tag phụ được hover */
.cloud-tag.tag-sub:hover::before {
    transform: scale(1.4) !important;
}

/* Các tag chính - Làm nổi bật hơn bằng các màu thương hiệu đặc trưng làm màu chính mặc định */
.cloud-tag.tag-main {
    font-size: 15px !important;
    font-weight: 800 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    color: #ffffff !important;
    border: 1.5px solid transparent !important;
}

.cloud-tag.tag-main.tag-sua-nha {
    background: #d41820 !important;
    border-color: #d41820 !important;
    box-shadow: 0 4px 15px rgba(212, 24, 32, 0.3) !important;
}
.cloud-tag.tag-main.tag-xay-nha {
    background: #367eb0 !important;
    border-color: #367eb0 !important;
    box-shadow: 0 4px 15px rgba(54, 126, 176, 0.3) !important;
}
.cloud-tag.tag-main.tag-son-nha {
    background: #ffb703 !important;
    border-color: #ffb703 !important;
    box-shadow: 0 4px 15px rgba(255, 183, 3, 0.3) !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
}
.cloud-tag.tag-main.tag-chong-tham {
    background: #00b4d8 !important;
    border-color: #00b4d8 !important;
    box-shadow: 0 4px 15px rgba(0, 180, 216, 0.3) !important;
}
.cloud-tag.tag-main.tag-mai-ton {
    background: #7209b7 !important;
    border-color: #7209b7 !important;
    box-shadow: 0 4px 15px rgba(114, 9, 183, 0.3) !important;
}

/* Hiệu ứng hover và active cho từng nhóm dịch vụ đồng bộ với brand colors */

/* Nhóm 1: Sửa nhà (Đỏ Logo) */
.cloud-tag.tag-sua-nha:hover,
.premium-services-cloud:has(.tag-sua-nha:hover) .tag-sua-nha {
    background: rgba(212, 24, 32, 0.22) !important;
    border-color: #d41820 !important;
    color: #ffffff !important;
    box-shadow: 0 0 20px rgba(212, 24, 32, 0.4) !important;
    transform: scale(1.06) translateY(-2px) !important;
}
.cloud-tag.tag-sua-nha.tag-main:hover,
.premium-services-cloud:has(.tag-sua-nha:hover) .tag-sua-nha.tag-main {
    background: #d41820 !important;
    border-color: #ffffff !important;
    box-shadow: 0 0 25px rgba(212, 24, 32, 0.7) !important;
}

/* Nhóm 2: Xây nhà (Xanh Logo) */
.cloud-tag.tag-xay-nha:hover,
.premium-services-cloud:has(.tag-xay-nha:hover) .tag-xay-nha {
    background: rgba(54, 126, 176, 0.22) !important;
    border-color: #367eb0 !important;
    color: #ffffff !important;
    box-shadow: 0 0 20px rgba(54, 126, 176, 0.4) !important;
    transform: scale(1.06) translateY(-2px) !important;
}
.cloud-tag.tag-xay-nha.tag-main:hover,
.premium-services-cloud:has(.tag-xay-nha:hover) .tag-xay-nha.tag-main {
    background: #367eb0 !important;
    border-color: #ffffff !important;
    box-shadow: 0 0 25px rgba(54, 126, 176, 0.7) !important;
}

/* Nhóm 3: Sơn nhà (Vàng Hổ Phách/Gold) */
.cloud-tag.tag-son-nha:hover,
.premium-services-cloud:has(.tag-son-nha:hover) .tag-son-nha {
    background: rgba(255, 183, 3, 0.22) !important;
    border-color: #ffb703 !important;
    color: #ffffff !important;
    box-shadow: 0 0 20px rgba(255, 183, 3, 0.4) !important;
    transform: scale(1.06) translateY(-2px) !important;
}
.cloud-tag.tag-son-nha.tag-main:hover,
.premium-services-cloud:has(.tag-son-nha:hover) .tag-son-nha.tag-main {
    background: #ffb703 !important;
    border-color: #ffffff !important;
    box-shadow: 0 0 25px rgba(255, 183, 3, 0.7) !important;
}

/* Nhóm 4: Chống thấm (Xanh Bầu Trời Sáng) */
.cloud-tag.tag-chong-tham:hover,
.premium-services-cloud:has(.tag-chong-tham:hover) .tag-chong-tham {
    background: rgba(0, 180, 216, 0.22) !important;
    border-color: #00b4d8 !important;
    color: #ffffff !important;
    box-shadow: 0 0 20px rgba(0, 180, 216, 0.4) !important;
    transform: scale(1.06) translateY(-2px) !important;
}
.cloud-tag.tag-chong-tham.tag-main:hover,
.premium-services-cloud:has(.tag-chong-tham:hover) .tag-chong-tham.tag-main {
    background: #00b4d8 !important;
    border-color: #ffffff !important;
    box-shadow: 0 0 25px rgba(0, 180, 216, 0.7) !important;
}

/* Nhóm 5: Mái tôn (Tím Neon) */
.cloud-tag.tag-mai-ton:hover,
.premium-services-cloud:has(.tag-mai-ton:hover) .tag-mai-ton {
    background: rgba(114, 9, 183, 0.22) !important;
    border-color: #7209b7 !important;
    color: #ffffff !important;
    box-shadow: 0 0 20px rgba(114, 9, 183, 0.4) !important;
    transform: scale(1.06) translateY(-2px) !important;
}
.cloud-tag.tag-mai-ton.tag-main:hover,
.premium-services-cloud:has(.tag-mai-ton:hover) .tag-mai-ton.tag-main {
    background: #7209b7 !important;
    border-color: #ffffff !important;
    box-shadow: 0 0 25px rgba(114, 9, 183, 0.7) !important;
}

/* Hiệu ứng Dimming tự động qua CSS :has() */
.premium-services-cloud:hover .cloud-tag:not(:hover) {
    opacity: 0.25 !important;
    transform: scale(0.92) !important;
    filter: blur(1.5px) !important;
    box-shadow: none !important;
}

/* Giữ độ sáng bình thường cho toàn bộ nhóm đang có tag được hover */
.premium-services-cloud:has(.tag-sua-nha:hover) .tag-sua-nha,
.premium-services-cloud:has(.tag-xay-nha:hover) .tag-xay-nha,
.premium-services-cloud:has(.tag-son-nha:hover) .tag-son-nha,
.premium-services-cloud:has(.tag-chong-tham:hover) .tag-chong-tham,
.premium-services-cloud:has(.tag-mai-ton:hover) .tag-mai-ton {
    opacity: 1 !important;
    filter: none !important;
}

/* Dọn dẹp các thẻ p và br tự động sinh bởi WordPress wpautop */
.premium-services-cloud br {
    display: none !important;
}
.premium-services-cloud p {
    display: inline !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* 4. Hotline & Hiệu ứng nút nhấp nháy thu hút khách gọi */
.hotline-btn-wrapper {
    margin-top: 25px !important;
}

.pulse-button {
    animation: button-pulse 1.8s infinite !important;
    border-radius: 30px !important;
    font-weight: 700 !important;
}

@keyframes button-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(212, 24, 32, 0.7);
    }
    70% {
        box-shadow: 0 0 0 15px rgba(212, 24, 32, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(212, 24, 32, 0);
    }
}

/* 5. Tương thích thiết bị di động & Tablet */
@media (max-width: 991px) {
    .premium-services-cloud-wrapper {
        min-height: 420px !important;
        padding: 20px 10px !important;
    }
    .premium-services-cloud {
        gap: 10px 12px !important;
    }
    .cloud-tag {
        padding: 8px 16px !important;
        font-size: 12.5px !important;
    }
    .cloud-tag.tag-main {
        font-size: 13.5px !important;
    }
}

@media (max-width: 767px) {
    .premium-services-header .main-title {
        font-size: 24px !important;
    }
    .premium-services-cloud-wrapper {
        min-height: 480px !important;
    }
    .cloud-tag {
        padding: 7px 14px !important;
        font-size: 12px !important;
    }
    .cloud-tag.tag-main {
        font-size: 13px !important;
    }
}

/* 6. Ghi đè lớp phủ nền đỏ gắt sang Gradient Xanh Navy tối cao cấp */
.section-ban-dang-can .section-bg-overlay {
    background-image: linear-gradient(135deg, rgba(15, 32, 56, 0.94) 0%, rgba(26, 53, 94, 0.88) 100%) !important;
    background-color: transparent !important;
    opacity: 1 !important;
}

/* Khử hoàn toàn gradient đỏ gắt từ bất kỳ nguồn CSS nào khác */
.ban_dang_can::before,
.section-ban-dang-can::before,
.ban-dang-can::before {
    background: none !important;
    display: none !important;
}

/* ==========================================================================
   PREMIUM TIMELINE DESIGN (SECTION: QUY TRÌNH TIẾP NHẬN & THI CÔNG)
   ========================================================================== */
.ss_quytrinh {
    background: #f8fafc !important; /* Soft light backdrop */
    padding: 60px 0 !important;
}

.ss_quytrinh .ui.header {
    font-size: 30px !important;
    font-weight: 800 !important;
    color: #1a355e !important;
    text-align: center !important;
    text-transform: uppercase !important;
    margin-bottom: 10px !important;
}

.ss_quytrinh .ui.header + div {
    max-width: 850px !important;
    margin: 0 auto 30px auto !important;
    text-align: center !important;
    font-size: 15px !important;
    color: #64748b !important;
    line-height: 1.7 !important;
}

/* Container cho timeline */
.ss_quytrinh .col_timeline {
    position: relative !important;
}

/* Ẩn trục line cũ */
.ss_quytrinh .col_timeline::before {
    display: none !important;
}

/* Cấu trúc Grid 3 cột x 2 hàng trên Desktop */
@media (min-width: 850px) {
    .ss_quytrinh .col_timeline .col-inner {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 40px 30px !important; /* Khoảng cách đứng 40px, ngang 30px */
        padding: 0 !important;
        width: 100% !important;
        height: auto !important;
    }

    .ss_quytrinh .col_timeline .timeline {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        box-sizing: border-box !important;
        position: relative !important;
    }

    /* Định vị lưới cho đường đi của rắn (Snake path) - 3 cột x 2 hàng hoàn chỉnh */
    .ss_quytrinh .timeline.r1 { grid-column: 1 !important; grid-row: 1 !important; }
    .ss_quytrinh .timeline.r2 { grid-column: 2 !important; grid-row: 1 !important; }
    .ss_quytrinh .timeline.r3 { grid-column: 3 !important; grid-row: 1 !important; }
    .ss_quytrinh .timeline.r4 { grid-column: 3 !important; grid-row: 2 !important; } /* Bước 4 nằm dưới Bước 3 */
    .ss_quytrinh .timeline.r5 { grid-column: 2 !important; grid-row: 2 !important; } /* Bước 5 nằm bên trái Bước 4 */
    .ss_quytrinh .timeline.r6 { grid-column: 1 !important; grid-row: 2 !important; } /* Bước 6 nằm dưới Bước 1 */

    /* Ẩn cột Flatsome trống */
    .ss_quytrinh .col_timeline .timeline .col.medium-7 {
        display: none !important;
    }

    /* Đưa cột chứa Card ra 100% chiều rộng của bước */
    .ss_quytrinh .col_timeline .timeline .col.medium-5 {
        width: 100% !important;
        max-width: 100% !important;
        display: block !important;
        padding: 0 !important;
    }

    /* ---------------------------------------------------------
     ĐƯỜNG LINE NỐI CÁC BƯỚC (DESKTOP) - DẠNG NÉT ĐỨT SANG TRỌNG
     --------------------------------------------------------- */
    /* Đường nối 1 -> 2 và 2 -> 3 (Ngang, trái sang phải) */
    .ss_quytrinh .timeline.r1::before,
    .ss_quytrinh .timeline.r2::before {
        content: "" !important;
        position: absolute !important;
        top: 50% !important;
        left: 100% !important;
        width: 30px !important; /* Khớp với gap ngang 30px */
        height: 0 !important;
        border-top: 2px dashed #367eb0 !important;
        z-index: 2 !important;
        display: block !important;
        transform: translateY(-50%) !important;
        opacity: 0.8 !important;
    }

    /* Đường nối 3 -> 4 (Dọc, đi từ đáy bước 3 xuống đỉnh bước 4) */
    .ss_quytrinh .timeline.r3::before {
        content: "" !important;
        position: absolute !important;
        top: 100% !important;
        left: 50% !important;
        width: 0 !important;
        height: 40px !important; /* Khớp với gap dọc 40px */
        border-left: 2px dashed #367eb0 !important;
        z-index: 2 !important;
        display: block !important;
        transform: translateX(-50%) !important;
        opacity: 0.8 !important;
    }

    /* Đường nối 4 -> 5 và 5 -> 6 (Ngang, phải sang trái) */
    .ss_quytrinh .timeline.r4::before,
    .ss_quytrinh .timeline.r5::before {
        content: "" !important;
        position: absolute !important;
        top: 50% !important;
        right: 100% !important;
        left: auto !important;
        width: 30px !important; /* Khớp với gap ngang 30px */
        height: 0 !important;
        border-top: 2px dashed #367eb0 !important;
        z-index: 2 !important;
        display: block !important;
        transform: translateY(-50%) !important;
        opacity: 0.8 !important;
    }
}

/* Thẻ Card Quy Trình */
.ss_quytrinh .timeline .col.medium-5 .col-inner {
    background: #ffffff !important;
    border-radius: 16px !important;
    border: 1px solid rgba(226, 232, 240, 0.8) !important;
    box-shadow: 0 8px 25px rgba(26, 53, 94, 0.04) !important;
    padding: 24px !important;
    transition: all 0.4s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
    position: relative !important;
    box-sizing: border-box !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
}

.ss_quytrinh .timeline:hover .col.medium-5 .col-inner {
    transform: translateY(-6px) !important;
    border-color: #367eb0 !important;
    box-shadow: 0 15px 35px rgba(5, 80, 154, 0.08) !important;
}

/* Thiết kế nội dung bên trong Card dạng Hàng ngang sang trọng */
.ss_quytrinh .featured-box {
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    text-align: left !important;
    gap: 16px !important;
    overflow: visible !important; /* Ngăn chặn việc cắt mất viền sáng và hiệu ứng sóng */
}

.ss_quytrinh .featured-box .icon-box,
.ss_quytrinh .featured-box .icon-box-img {
    overflow: visible !important; /* Cho phép hiệu ứng sóng lan ra ngoài */
}

.ss_quytrinh .featured-box .icon-box-img {
    width: 64px !important;
    height: 64px !important;
    max-width: 64px !important;
    max-height: 64px !important;
    border-radius: 50% !important;
    position: relative !important;
    z-index: 1 !important; /* Tạo stacking context để hiển thị viền sáng chạy quanh */
    flex-shrink: 0 !important;
    margin: 0 !important;
    background: #ffffff !important;
    animation: default-pulse 3s infinite ease-in-out !important; /* Hiệu ứng thở nhẹ thu hút chú ý mặc định */
}

/* Đảm bảo các khung bên trong là hình vuông tuyệt đối để clip-path hoặc border-radius cắt thành hình tròn hoàn hảo */
.ss_quytrinh .featured-box .icon-box-img .icon {
    width: 64px !important;
    height: 64px !important;
    max-width: 64px !important;
    max-height: 64px !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    overflow: visible !important;
}

.ss_quytrinh .featured-box .icon-box-img .icon-inner {
    width: 64px !important;
    height: 64px !important;
    max-width: 64px !important;
    max-height: 64px !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    clip-path: circle(50% at 50% 50%) !important;
    overflow: hidden !important;
}

.ss_quytrinh .featured-box .icon-box-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
    clip-path: circle(50% at 50% 50%) !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Hiệu ứng viền ánh sáng chạy vòng quanh hình tròn (xuất hiện mặc định liên tục) */
.ss_quytrinh .featured-box .icon-box-img::before {
    content: "" !important;
    position: absolute !important;
    top: -3px !important;
    left: -3px !important;
    right: -3px !important;
    bottom: -3px !important;
    border-radius: 50% !important;
    background: conic-gradient(from 0deg, transparent, #367eb0, #d41820, #367eb0, transparent) !important;
    animation: rotate-border 3s linear infinite !important;
    z-index: -1 !important;
}

/* Hai lớp sóng lan tỏa (Ripple Wave) khi hover chuột vào bước quy trình, hoạt động so le */
.ss_quytrinh .featured-box .icon-box-img::after,
.ss_quytrinh .featured-box .icon-box-img .icon::after {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    border-radius: 50% !important;
    pointer-events: none !important;
    z-index: -2 !important;
    opacity: 0; /* Không dùng !important ở đây để animation có thể ghi đè */
    transform: scale(1); /* Khởi tạo thuộc tính transform */
    box-sizing: border-box !important;
}

.ss_quytrinh .featured-box .icon-box-img::after {
    border: 2px solid #367eb0 !important;
}

.ss_quytrinh .featured-box .icon-box-img .icon::after {
    border: 2px solid #d41820 !important;
}

/* Đảm bảo kích hoạt hiệu ứng hover nhạy bén từ nhiều phần tử cha */
.ss_quytrinh .timeline:hover .icon-box-img::after,
.ss_quytrinh .timeline .col-inner:hover .icon-box-img::after,
.ss_quytrinh .featured-box:hover .icon-box-img::after {
    animation: ripple-wave-1 1.6s infinite cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

.ss_quytrinh .timeline:hover .icon-box-img .icon::after,
.ss_quytrinh .timeline .col-inner:hover .icon-box-img .icon::after,
.ss_quytrinh .featured-box:hover .icon-box-img .icon::after {
    animation: ripple-wave-2 1.6s infinite cubic-bezier(0.25, 0.8, 0.25, 1) !important;
    animation-delay: 0.5s !important; /* Độ trễ so le tạo hiệu ứng sóng lan truyền liên tiếp */
}

@keyframes rotate-border {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}

@keyframes default-pulse {
    0% {
        box-shadow: 0 0 8px rgba(54, 126, 176, 0.4);
    }
    50% {
        box-shadow: 0 0 18px rgba(54, 126, 176, 0.75), 0 0 8px rgba(212, 24, 32, 0.35);
    }
    100% {
        box-shadow: 0 0 8px rgba(54, 126, 176, 0.4);
    }
}

@keyframes ripple-wave-1 {
    0% {
        transform: scale(1);
        opacity: 0.8;
    }
    100% {
        transform: scale(1.6);
        opacity: 0;
    }
}

@keyframes ripple-wave-2 {
    0% {
        transform: scale(1);
        opacity: 0.6;
    }
    100% {
        transform: scale(1.8);
        opacity: 0;
    }
}

.ss_quytrinh .featured-box .icon-box-text {
    padding: 0 !important;
    flex: 1 !important;
}

.ss_quytrinh .featured-box h4 {
    font-size: 15px !important;
    font-weight: 800 !important;
    color: #1a355e !important;
    margin-bottom: 6px !important;
    text-transform: uppercase !important;
}

.ss_quytrinh .featured-box p {
    font-size: 12.5px !important;
    color: #64748b !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    text-align: justify !important;
}

/* Nút số thứ tự bước quy trình dạng tròn đặt ở góc trên bên trái của Card */
.ss_quytrinh .col_timeline .timeline::after {
    position: absolute !important;
    left: -12px !important;
    top: -12px !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: linear-gradient(135deg, #367eb0 0%, #05509a 100%) !important;
    border: 3px solid #ffffff !important;
    box-shadow: 0 4px 10px rgba(5, 80, 154, 0.2) !important;
    color: #ffffff !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 3 !important;
    transition: all 0.3s ease !important;
}

.ss_quytrinh .timeline.r1::after { content: "01" !important; }
.ss_quytrinh .timeline.r2::after { content: "02" !important; }
.ss_quytrinh .timeline.r3::after { content: "03" !important; }
.ss_quytrinh .timeline.r4::after { content: "04" !important; }
.ss_quytrinh .timeline.r5::after { content: "05" !important; }
.ss_quytrinh .timeline.r6::after { content: "06" !important; }

.ss_quytrinh .timeline:hover::after {
    transform: scale(1.15) !important;
    box-shadow: 0 0 10px rgba(54, 126, 176, 0.4) !important;
}

/* Giao diện dọc hoàn hảo trên Mobile */
@media (max-width: 849px) {
    .ss_quytrinh {
        padding: 50px 0 !important;
    }

    .ss_quytrinh .col_timeline::before {
        content: '' !important;
        position: absolute !important;
        left: 25px !important;
        top: 20px !important;
        bottom: 20px !important;
        width: 3px !important;
        background: linear-gradient(to bottom, #367eb0 0%, #05509a 100%) !important;
        box-shadow: 0 0 10px rgba(5, 80, 154, 0.2) !important;
        z-index: 1 !important;
        bottom: 20px !important;
        right: auto !important;
        height: auto !important;
        transform: none !important;
        display: block !important;
    }

    .ss_quytrinh .col_timeline .col-inner {
        padding: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 25px !important;
        height: auto !important;
    }

    .ss_quytrinh .col_timeline .timeline {
        position: relative !important;
        padding-left: 60px !important;
        padding-right: 10px !important;
        margin: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        flex: none !important;
    }

    /* Trả lại cột medium-5 full width trên mobile */
    .ss_quytrinh .col_timeline .timeline .col.medium-5 {
        width: 100% !important;
        max-width: 100% !important;
        display: block !important;
    }

    .ss_quytrinh .timeline .col.medium-5 .col-inner {
        position: relative !important;
        padding: 20px !important;
        top: auto !important;
        bottom: auto !important;
        margin: 0 !important;
        width: 100% !important;
    }

    .ss_quytrinh .col_timeline .timeline::after {
        position: absolute !important;
        left: 5px !important;
        top: 20px !important;
        width: 42px !important;
        height: 42px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, #367eb0 0%, #05509a 100%) !important;
        border: 3px solid #ffffff !important;
        box-shadow: 0 4px 10px rgba(5, 80, 154, 0.15) !important;
        color: #ffffff !important;
        font-size: 14px !important;
        font-weight: 800 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        z-index: 3 !important;
    }

    .ss_quytrinh .timeline.r1::after { content: "01" !important; }
    .ss_quytrinh .timeline.r2::after { content: "02" !important; }
    .ss_quytrinh .timeline.r3::after { content: "03" !important; }
    .ss_quytrinh .timeline.r4::after { content: "04" !important; }
    .ss_quytrinh .timeline.r5::after { content: "05" !important; }
    .ss_quytrinh .timeline.r6::after { content: "06" !important; }

    /* Mũi tên trỏ sang trái trên mobile */
    .ss_quytrinh .timeline .col.medium-5 .col-inner::after {
        content: "" !important;
        position: absolute !important;
        top: 32px !important;
        right: 100% !important;
        width: 0 !important;
        height: 0 !important;
        border-top: 8px solid transparent !important;
        border-bottom: 8px solid transparent !important;
        border-right: 8px solid #ffffff !important;
        z-index: 2 !important;
    }

    .ss_quytrinh .featured-box {
        flex-direction: row !important;
        align-items: center !important;
        text-align: left !important;
        gap: 15px !important;
    }

    .ss_quytrinh .featured-box .icon-box-img {
        width: 60px !important;
        height: 60px !important;
        max-width: 60px !important;
        max-height: 60px !important;
    }

    .ss_quytrinh .featured-box .icon-box-img .icon,
    .ss_quytrinh .featured-box .icon-box-img .icon-inner {
        width: 60px !important;
        height: 60px !important;
        max-width: 60px !important;
        max-height: 60px !important;
    }

    .ss_quytrinh .featured-box p {
        text-align: left !important;
    }
}

/* ==========================================================================
   FIX: Preserve full post/page thumbnail images (1200x630, no cropped logos/corners)
   ========================================================================== */

/* 1. Force the correct aspect ratio (1200x630 => 52.5% padding-top) on preview containers */
.post-item .box-image .image-cover,
.post-item .box-image .img-inner,
.page-box .box-image .image-cover,
.page-box .box-image .img-inner,
.box-blog-post .box-image .image-cover,
.box-blog-post .box-image .img-inner,
.page-col .box-image .image-cover,
.page-col .box-image .img-inner,
.archive .box-image .image-cover,
.archive .box-image .img-inner,
.category .box-image .image-cover,
.category .box-image .img-inner,
.search-results .box-image .image-cover,
.search-results .box-image .img-inner {
    padding-top: 52.5% !important; /* 630px height / 1200px width = 52.5% */
    height: auto !important;
    background-color: #ffffff !important; /* White background to blend if images vary slightly */
}

/* 2. Force the preview images to contain fully without cropping */
.post-item .box-image img,
.page-box .box-image img,
.box-blog-post .box-image img,
.page-col .box-image img,
.archive .box-image img,
.category .box-image img,
.search-results .box-image img,
.post-item .image img {
    object-fit: contain !important;
    object-position: center !important;
    height: 100% !important;
    width: 100% !important;
    top: 0 !important;
    left: 0 !important;
}

/* ==========================================================================
   STYLING: Sub-services Grid Layout for Parent Service Pages
   ========================================================================== */
.sub-services-section {
    margin: 40px 0;
    padding: 30px;
    background: #f8fafc;
    border-radius: 16px;
    border: 1px solid #e2e8f0;
}

.sub-services-title {
    text-align: center;
    color: #0f2038 !important;
    font-size: 26px !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    margin-top: 0 !important;
    margin-bottom: 12px !important;
    letter-spacing: 0.5px;
}

.sub-services-desc {
    text-align: center;
    color: #475569;
    font-size: 15px;
    max-width: 700px;
    margin: 0 auto 30px auto !important;
    line-height: 1.6;
}

.sub-services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
}

.sub-services-grid > p,
.sub-services-grid > br {
    display: none !important;
}

.sub-service-card {
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(15, 32, 56, 0.05);
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
    border: 1px solid #e2e8f0;
    text-decoration: none !important;
}

.sub-service-img-wrapper {
    position: relative;
    padding-top: 52.5%; /* Match 1200x630 aspect ratio */
    overflow: hidden;
    background-color: #ffffff;
}

.sub-service-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    object-position: center !important;
    transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.sub-service-card-body {
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.sub-service-card-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin: 0 0 12px 0 !important;
    line-height: 1.4 !important;
    min-height: 44px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sub-service-card-btn {
    font-size: 14px;
    font-weight: 700;
    color: #d41820;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: auto;
    transition: color 0.2s ease;
}

.sub-service-card-btn i {
    font-size: 12px;
    transition: transform 0.2s ease;
}

/* Hover effects */
.sub-service-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 30px rgba(15, 32, 56, 0.12);
    border-color: #367eb0;
}

.sub-service-card:hover .sub-service-img {
    transform: scale(1.04);
}

.sub-service-card:hover .sub-service-card-btn {
    color: #a80f15;
}

.sub-service-card:hover .sub-service-card-btn i {
    transform: translateX(4px);
}

/* Responsive grid layout */
@media only screen and (max-width: 991px) {
    .sub-services-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    .sub-services-section {
        padding: 20px;
    }
    .sub-services-title {
        font-size: 22px !important;
    }
}

@media only screen and (max-width: 600px) {
    .sub-services-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    .sub-service-card-title {
        min-height: auto;
    }
}

/* ==========================================================================
   STYLING: Related Sibling Services Section ("Có Thể Bạn Quan Tâm")
   ========================================================================== */
.related-services-section {
    margin-top: 50px;
    padding-top: 40px;
    border-top: 2px dashed #e2e8f0;
}

.related-services-title {
    text-align: center;
    color: #0f2038 !important;
    font-size: 24px !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    margin-top: 0 !important;
    margin-bottom: 10px !important;
    letter-spacing: 0.5px;
}

.related-services-desc {
    text-align: center;
    color: #64748b;
    font-size: 15px;
    margin-bottom: 30px !important;
}

.related-services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
}

.related-services-grid > p,
.related-services-grid > br {
    display: none !important; /* Hide stray wpautop paragraph tags */
}

.related-service-card {
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(15, 32, 56, 0.04);
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
    border: 1px solid #e2e8f0;
    text-decoration: none !important;
}

.related-service-img-wrapper {
    position: relative;
    padding-top: 52.5%; /* Match 1200x630 aspect ratio */
    overflow: hidden;
    background-color: #ffffff;
}

.related-service-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    object-position: center !important;
    transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.related-service-card-body {
    padding: 15px 18px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.related-service-card-title {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin: 0 0 10px 0 !important;
    line-height: 1.4 !important;
    min-height: 42px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.related-service-card-link {
    font-size: 13px;
    font-weight: 700;
    color: #367eb0;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: auto;
    transition: color 0.2s ease;
}

.related-service-card-link i {
    font-size: 11px;
    transition: transform 0.2s ease;
}

/* Hover effects */
.related-service-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(15, 32, 56, 0.1);
    border-color: #367eb0;
}

.related-service-card:hover .related-service-img {
    transform: scale(1.03);
}

.related-service-card:hover .related-service-card-link {
    color: #d41820;
}

.related-service-card:hover .related-service-card-link i {
    transform: translateX(3px);
}

/* Responsive grid layout */
@media only screen and (max-width: 991px) {
    .related-services-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
}

@media only screen and (max-width: 600px) {
    .related-services-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    .related-service-card-title {
        min-height: auto;
    }
}

/* ==========================================================================
   STYLING: Related Sibling Services Tag List (Hybrid Layout)
   ========================================================================== */
.related-services-tags-wrapper {
    margin-top: 35px;
    border-top: 1px solid #e2e8f0;
    padding-top: 25px;
}

.related-tags-label {
    font-size: 15px;
    font-weight: 700;
    color: #1e293b;
    margin-bottom: 15px !important;
}

.related-services-tags-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.related-services-tags-list > p,
.related-services-tags-list > br {
    display: none !important; /* Hide stray wpautop paragraph tags */
}

.related-service-tag {
    display: inline-block;
    padding: 8px 16px;
    background: #f1f5f9;
    color: #475569 !important;
    font-size: 14px;
    font-weight: 600;
    border-radius: 6px;
    border: 1px solid #e2e8f0;
    transition: all 0.2s ease;
    text-decoration: none !important;
}

.related-service-tag:hover {
    background: #367eb0;
    color: #ffffff !important;
    border-color: #367eb0;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(54, 126, 176, 0.15);
}

/* ==========================================================================
   STYLING: Single Post Layout & SEO Enhancements (News / Tin Tức)
   ========================================================================== */

/* 1. Hide category listing at top of single news posts */
.single-post .entry-category {
    display: none !important;
}

/* 2. Smooth Scroll for Table of Contents links */
html {
    scroll-behavior: smooth;
}

/* 3. Estimated Reading Time bar styling */
.custom-post-meta-bar {
    margin: 15px 0 25px 0;
    padding: 10px 15px;
    background-color: #f1f5f9;
    border-left: 4px solid #367eb0;
    border-radius: 4px;
    font-size: 14px;
    color: #475569;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* 4. Table of Contents Box styling */
.table-of-contents-box {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 20px;
    margin: 30px 0;
    box-shadow: 0 4px 12px rgba(15, 32, 56, 0.02);
}

.toc-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #e2e8f0;
    padding-bottom: 12px;
    margin-bottom: 15px;
}

.toc-title {
    font-weight: 700;
    color: #0f2038;
    font-size: 16px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.toc-toggle {
    font-size: 13px;
    user-select: none;
    transition: color 0.2s ease;
}

.toc-toggle:hover {
    color: #d41820 !important;
}

.toc-list {
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.toc-list li {
    margin-bottom: 8px !important;
    padding-left: 0 !important;
    line-height: 1.5;
}

.toc-list li a {
    color: #475569 !important;
    font-size: 15px;
    text-decoration: none !important;
    transition: all 0.2s ease;
    font-weight: 500;
}

.toc-list li a:hover {
    color: #367eb0 !important;
    padding-left: 5px;
}

/* ==========================================================================
   STYLING: Related News Posts Grid ("Tin Tức Liên Quan")
   ========================================================================== */
.related-posts-section {
    margin-top: 50px;
    padding-top: 40px;
    border-top: 2px dashed #e2e8f0;
}

.related-posts-title {
    text-align: center;
    color: #0f2038 !important;
    font-size: 24px !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    margin-top: 0 !important;
    margin-bottom: 30px !important;
    letter-spacing: 0.5px;
}

.related-posts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
}

.related-posts-grid > p,
.related-posts-grid > br {
    display: none !important;
}

.related-post-card {
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(15, 32, 56, 0.04);
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
    border: 1px solid #e2e8f0;
    text-decoration: none !important;
}

.related-post-thumb-wrapper {
    position: relative;
    padding-top: 52.5%; /* 1200x630 ratio */
    overflow: hidden;
    background-color: #ffffff;
}

.related-post-thumb-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: contain !important;
    object-position: center !important;
    transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.related-post-card-body {
    padding: 15px 18px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.related-post-date {
    font-size: 12px;
    color: #64748b;
    margin-bottom: 8px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.related-post-card-title {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin: 0 0 10px 0 !important;
    line-height: 1.4 !important;
    min-height: 42px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.related-post-excerpt {
    font-size: 13px;
    color: #475569;
    line-height: 1.5;
    margin-bottom: 15px !important;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 58px;
}

.related-post-card-btn {
    font-size: 13px;
    font-weight: 700;
    color: #d41820;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: auto;
    transition: color 0.2s ease;
}

.related-post-card-btn i {
    font-size: 11px;
    transition: transform 0.2s ease;
}

.related-post-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(15, 32, 56, 0.1);
    border-color: #367eb0;
}

.related-post-card:hover .related-post-thumb-img {
    transform: scale(1.03);
}

.related-post-card:hover .related-post-card-btn {
    color: #a80f15;
}

.related-post-card:hover .related-post-card-btn i {
    transform: translateX(3px);
}

/* ==========================================================================
   STYLING: Premium Social Share Buttons
   ========================================================================== */
.blog-share {
    margin: 40px 0;
}

.blog-share .is-divider {
    margin-bottom: 25px !important;
    background-color: #e2e8f0 !important;
    height: 1px !important;
}

.blog-share .social-icons {
    display: inline-flex;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
}

.blog-share .social-icons a.icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 50% !important;
    border: 1px solid #e2e8f0 !important;
    background-color: #f8fafc !important;
    color: #64748b !important;
    font-size: 16px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.03);
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

/* Brand colors on hover */
.blog-share .social-icons a.icon.facebook:hover {
    background-color: #1877f2 !important;
    color: #ffffff !important;
    border-color: #1877f2 !important;
    transform: translateY(-3px) rotate(8deg);
    box-shadow: 0 6px 15px rgba(24, 119, 242, 0.3);
}

.blog-share .social-icons a.icon.twitter:hover {
    background-color: #1da1f2 !important;
    color: #ffffff !important;
    border-color: #1da1f2 !important;
    transform: translateY(-3px) rotate(-8deg);
    box-shadow: 0 6px 15px rgba(29, 161, 242, 0.3);
}

.blog-share .social-icons a.icon.pinterest:hover {
    background-color: #bd081c !important;
    color: #ffffff !important;
    border-color: #bd081c !important;
    transform: translateY(-3px) rotate(8deg);
    box-shadow: 0 6px 15px rgba(189, 8, 28, 0.3);
}

.blog-share .social-icons a.icon.linkedin:hover {
    background-color: #0077b5 !important;
    color: #ffffff !important;
    border-color: #0077b5 !important;
    transform: translateY(-3px) rotate(-8deg);
    box-shadow: 0 6px 15px rgba(0, 119, 181, 0.3);
}

.blog-share .social-icons a.icon.email:hover {
    background-color: #d41820 !important;
    color: #ffffff !important;
    border-color: #d41820 !important;
    transform: translateY(-3px) rotate(8deg);
    box-shadow: 0 6px 15px rgba(212, 24, 32, 0.3);
}

/* ==========================================================================
   STYLING: Premium Modern Comments Area
   ========================================================================== */
.comments-area {
    margin-top: 50px;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    padding: 30px;
    box-shadow: 0 10px 30px rgba(15, 32, 56, 0.02);
}

.comments-title {
    font-size: 20px !important;
    font-weight: 800 !important;
    color: #0f2038 !important;
    text-transform: uppercase;
    border-bottom: 2px solid #367eb0;
    padding-bottom: 10px;
    margin-bottom: 25px !important;
    letter-spacing: 0.5px;
    display: inline-block;
}

.comment-respond {
    margin-top: 40px;
    padding-top: 30px;
    border-top: 1px solid #e2e8f0;
}

.comment-reply-title {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #0f2038 !important;
    margin-bottom: 20px !important;
}

/* Comments List */
.comment-list {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.comment-list li.comment {
    margin-bottom: 25px !important;
    padding-left: 0 !important;
}

.comment-list .comment-body {
    position: relative;
    padding: 20px;
    background: #f8fafc;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    margin-left: 70px;
    transition: border-color 0.2s ease;
}

.comment-list .comment-body:hover {
    border-color: #cbd5e1;
}

.comment-list .comment-meta {
    margin-bottom: 10px;
    position: static;
}

.comment-list .comment-author {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
}

.comment-list .comment-author .avatar {
    position: absolute;
    left: -70px;
    top: 10px;
    width: 50px;
    height: 50px;
    border-radius: 50% !important;
    border: 2px solid #ffffff;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
}

.comment-list .comment-author .fn {
    font-weight: 700;
    font-style: normal;
    color: #1e293b;
    font-size: 15px;
}

.comment-list .comment-metadata {
    font-size: 12px;
    color: #64748b;
}

.comment-list .comment-metadata a {
    color: #64748b !important;
}

.comment-list .comment-content {
    font-size: 14.5px;
    color: #334155;
    line-height: 1.6;
}

.comment-list .reply {
    margin-top: 10px;
    text-align: right;
}

.comment-list .reply a {
    display: inline-block;
    padding: 4px 12px;
    background: #ffffff;
    border: 1px solid #cbd5e1;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    color: #475569 !important;
    transition: all 0.2s ease;
}

.comment-list .reply a:hover {
    background: #367eb0;
    color: #ffffff !important;
    border-color: #367eb0;
}

/* Nested comments */
.comment-list .children {
    list-style: none !important;
    margin: 20px 0 0 0 !important;
    padding-left: 40px !important;
    border-left: 2px solid #e2e8f0;
}

/* Form Fields Styling */
.comment-form p {
    margin-bottom: 15px !important;
}

.comment-form label {
    font-weight: 600;
    color: #475569;
    font-size: 13px;
    margin-bottom: 5px;
    display: block;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form textarea {
    width: 100%;
    padding: 12px 16px;
    background: #f8fafc;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 14.5px;
    color: #334155;
    transition: all 0.2s ease;
    box-shadow: none;
    box-sizing: border-box;
}

.comment-form input[type="text"]:focus,
.comment-form input[type="email"]:focus,
.comment-form textarea:focus {
    background: #ffffff;
    border-color: #367eb0;
    outline: none;
    box-shadow: 0 0 0 3px rgba(54, 126, 176, 0.15);
}

.comment-form input[type="submit"] {
    display: inline-block;
    padding: 12px 30px;
    background: linear-gradient(135deg, #d41820 0%, #a80f15 100%);
    color: #ffffff !important;
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    border: none;
    border-radius: 30px;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(212, 24, 32, 0.3);
    transition: all 0.2s ease;
}

.comment-form input[type="submit"]:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(212, 24, 32, 0.4);
}

/* Responsive fixes */
@media only screen and (max-width: 768px) {
    .related-posts-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    .comments-area {
        padding: 20px;
    }
    .comment-list .comment-body {
        margin-left: 0;
        padding-top: 70px;
    }
    .comment-list .comment-author .avatar {
        left: 20px;
        top: 20px;
    }
    .comment-list .children {
        padding-left: 15px !important;
    }
}

@media only screen and (max-width: 480px) {
    .related-posts-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }
}

/* ==========================================================================
   STYLING: Premium Consistent Right Sidebar Widgets (Sidebar Synchronization)
   ========================================================================== */

/* 1. General Widget Container */
#secondary .widget {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 25px;
    box-shadow: 0 4px 12px rgba(15, 32, 56, 0.02);
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}

#secondary .widget:hover {
    box-shadow: 0 8px 24px rgba(15, 32, 56, 0.06);
    border-color: #cbd5e1;
}

/* 2. Widget Titles styling */
#secondary .widget .widget-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #0f2038 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px !important;
    display: block;
}

#secondary .widget .is-divider.small {
    height: 3px !important;
    width: 45px !important;
    background-color: #367eb0 !important;
    margin: 10px 0 20px 0 !important;
}

/* 3. Text Lists (Pages, Categories, Archives, Menus) as Premium Vertical Tabs */
#secondary .widget_pages ul,
#secondary .widget_categories ul,
#secondary .widget_archive ul,
#secondary .widget_recent_comments ul,
#secondary .widget_meta ul,
#secondary .widget_nav_menu ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

#secondary .widget_pages ul li,
#secondary .widget_categories ul li,
#secondary .widget_archive ul li,
#secondary .widget_recent_comments ul li,
#secondary .widget_meta ul li,
#secondary .widget_nav_menu ul li {
    position: relative;
    padding: 10px 15px !important;
    margin: 0 0 6px 0 !important;
    background: #ffffff;
    border: 1px solid #f1f5f9 !important;
    border-radius: 8px;
    transition: all 0.25s cubic-bezier(0.25, 1, 0.5, 1) !important;
    line-height: 1.4;
    display: block !important;
}

#secondary .widget_pages ul li:last-child,
#secondary .widget_categories ul li:last-child,
#secondary .widget_archive ul li:last-child,
#secondary .widget_recent_comments ul li:last-child,
#secondary .widget_meta ul li:last-child,
#secondary .widget_nav_menu ul li:last-child {
    margin-bottom: 0 !important;
}

/* Remove default dots/bullets */
#secondary .widget_pages ul li::before,
#secondary .widget_categories ul li::before,
#secondary .widget_archive ul li::before,
#secondary .widget_recent_comments ul li::before,
#secondary .widget_meta ul li::before,
#secondary .widget_nav_menu ul li::before {
    display: none !important;
}

/* Left highlight line on hover */
#secondary .widget_pages ul li::after,
#secondary .widget_categories ul li::after,
#secondary .widget_archive ul li::after,
#secondary .widget_recent_comments ul li::after,
#secondary .widget_meta ul li::after,
#secondary .widget_nav_menu ul li::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background-color: #367eb0;
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;
    opacity: 0;
    transition: opacity 0.2s ease;
}

#secondary .widget_pages ul li:hover::after,
#secondary .widget_categories ul li:hover::after,
#secondary .widget_archive ul li:hover::after,
#secondary .widget_recent_comments ul li:hover::after,
#secondary .widget_meta ul li:hover::after,
#secondary .widget_nav_menu ul li:hover::after {
    opacity: 1;
}

#secondary .widget_pages ul li:hover,
#secondary .widget_categories ul li:hover,
#secondary .widget_archive ul li:hover,
#secondary .widget_recent_comments ul li:hover,
#secondary .widget_meta ul li:hover,
#secondary .widget_nav_menu ul li:hover {
    background: #f8fafc !important;
    border-color: #cbd5e1 !important;
    box-shadow: 0 2px 8px rgba(15, 32, 56, 0.04);
}

#secondary .widget_pages ul li a,
#secondary .widget_categories ul li a,
#secondary .widget_archive ul li a,
#secondary .widget_recent_comments ul li a,
#secondary .widget_meta ul li a,
#secondary .widget_nav_menu ul li a {
    color: #475569 !important;
    font-size: 14.5px;
    font-weight: 600;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    display: inline-block !important;
    max-width: calc(100% - 30px) !important;
}

#secondary .widget_pages ul li:hover > a,
#secondary .widget_categories ul li:hover > a,
#secondary .widget_archive ul li:hover > a,
#secondary .widget_recent_comments ul li:hover > a,
#secondary .widget_meta ul li:hover > a,
#secondary .widget_nav_menu ul li:hover > a {
    color: #367eb0 !important;
    padding-left: 6px !important;
}

/* 4. Nested Children styling (Hierarchical list items) */
#secondary .widget_pages ul.children,
#secondary .widget_categories ul.children,
#secondary .widget_nav_menu ul.sub-menu {
    margin-top: 10px !important;
    margin-bottom: -10px !important;
    margin-left: -15px !important;
    margin-right: -15px !important;
    padding: 10px 15px 10px 25px !important; /* Add left padding to indent nested child items inside the panel */
    background: #f8fafc !important;
    border-radius: 0 0 8px 8px !important;
    border-left: none !important;
    border-top: 1px solid #e2e8f0 !important;
    list-style: none !important;
    display: none; /* Hide by default to prevent flashing. JavaScript accordion will handle showing/hiding. */
    width: auto !important;
}

#secondary .widget_pages ul.children li,
#secondary .widget_categories ul.children li,
#secondary .widget_nav_menu ul.sub-menu li {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 6px 0 6px 12px !important;
    box-shadow: none !important;
}

#secondary .widget_pages ul.children li::after,
#secondary .widget_categories ul.children li::after,
/* Hide default Flatsome toggle buttons */
#secondary .widget_pages ul li button.toggle,
#secondary .widget_nav_menu ul li button.toggle {
    display: none !important;
}

/* Custom Sidebar Toggle Button */
#secondary .custom-sidebar-toggle {
    position: absolute;
    right: 15px !important;
    top: 10px !important;
    width: 24px;
    height: 24px;
    border-radius: 6px !important;
    background: #f1f5f9 !important;
    border: 1px solid #e2e8f0 !important;
    color: #64748b !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 10px !important;
    cursor: pointer !important;
    transition: all 0.25s ease !important;
    user-select: none !important;
    z-index: 10 !important;
}

#secondary .custom-sidebar-toggle:hover {
    background: #367eb0 !important;
    border-color: #367eb0 !important;
    color: #ffffff !important;
}

#secondary .custom-sidebar-toggle.active {
    background: #d41820 !important;
    border-color: #d41820 !important;
    color: #ffffff !important;
    transform: rotate(180deg); /* Smoothly rotate down chevron into up chevron */
}
#secondary .widget_nav_menu ul.sub-menu li::after {
    display: none !important;
}

/* Bullet dot for child elements */
#secondary .widget_pages ul.children li::before,
#secondary .widget_categories ul.children li::before,
#secondary .widget_nav_menu ul.sub-menu li::before {
    content: "" !important;
    position: absolute;
    left: 0;
    top: 14px;
    width: 4px;
    height: 4px;
    background-color: #cbd5e1;
    border-radius: 50%;
    display: block !important;
    transition: all 0.2s ease;
}

#secondary .widget_pages ul.children li:hover::before,
#secondary .widget_categories ul.children li:hover::before,
#secondary .widget_nav_menu ul.sub-menu li:hover::before {
    background-color: #367eb0;
    transform: scale(1.3);
}

#secondary .widget_pages ul.children li:hover,
#secondary .widget_categories ul.children li:hover,
#secondary .widget_nav_menu ul.sub-menu li:hover {
    background: transparent !important;
    padding-left: 16px !important;
    box-shadow: none !important;
}

#secondary .widget_pages ul.children li a,
#secondary .widget_categories ul.children li a,
#secondary .widget_nav_menu ul.sub-menu li a {
    font-size: 13px;
    color: #64748b !important;
    font-weight: 500;
    display: inline-block;
}

#secondary .widget_pages ul.children li a:hover,
#secondary .widget_categories ul.children li a:hover,
#secondary .widget_nav_menu ul.sub-menu li a:hover {
    color: #367eb0 !important;
}

/* Flatsome toggle buttons customization */
#secondary .widget_pages ul li.page_item_has_children {
    position: relative;
}

#secondary .widget_pages ul li.page_item_has_children > button.toggle {
    position: absolute;
    right: 15px !important;
    top: 10px !important;
    width: 24px;
    height: 24px;
    border-radius: 6px !important;
    background: #f1f5f9 !important;
    border: 1px solid #e2e8f0 !important;
    color: #64748b !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 10px !important;
    padding: 0 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    outline: none !important;
}

#secondary .widget_pages ul li.page_item_has_children > button.toggle:hover {
    background: #367eb0 !important;
    border-color: #367eb0 !important;
    color: #ffffff !important;
}

#secondary .widget_pages ul li.page_item_has_children > button.toggle.active {
    background: #d41820 !important;
    border-color: #d41820 !important;
    color: #ffffff !important;
}

/* 5. Flatsome Recent Posts Styling Reset */
#secondary .widget.flatsome_recent_posts ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

#secondary .widget.flatsome_recent_posts ul li {
    padding: 0 !important;
    border-bottom: none !important;
    margin: 0 !important;
}

#secondary .widget.flatsome_recent_posts ul li::before {
    display: none !important;
}

#secondary .widget.flatsome_recent_posts ul li:hover {
    padding-left: 0 !important;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts-li {
    border-bottom: 1px dashed #e2e8f0 !important;
    padding: 12px 0 !important;
    transition: all 0.25s ease;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts-li:last-child {
    border-bottom: none !important;
    padding-bottom: 0 !important;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts-li:first-child {
    padding-top: 0 !important;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    padding: 0 !important;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts .flex-col.mr-half {
    margin-right: 12px !important;
    flex-shrink: 0;
}

/* Featured Images */
#secondary .widget.flatsome_recent_posts .recent-blog-posts .badge.post-date {
    width: 60px !important;
    height: 60px !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: #f1f5f9 !important;
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 2px 6px rgba(15, 32, 56, 0.04) !important;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts .badge.post-date .badge-inner {
    width: 100% !important;
    height: 100% !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 0 !important;
    transition: transform 0.3s ease !important;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts-li:hover .badge.post-date .badge-inner {
    transform: scale(1.08);
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts .flex-col.flex-grow {
    padding-left: 0 !important;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts a {
    font-size: 13.5px !important;
    font-weight: 600 !important;
    color: #334155 !important;
    line-height: 1.4 !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
    margin-bottom: 2px !important;
    
    /* Limit post titles to exactly 2 lines with ellipsis */
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    max-height: 2.8em;
}

#secondary .widget.flatsome_recent_posts .recent-blog-posts a:hover {
    color: #367eb0 !important;
}

/* Hide comments count / screen reader text */
#secondary .widget.flatsome_recent_posts .recent-blog-posts .post_comments,
#secondary .widget.flatsome_recent_posts .recent-blog-posts .screen-reader-text {
    display: none !important;
}

/* Post Date meta placeholder */
#secondary .widget.flatsome_recent_posts .recent-blog-posts-li .post-date-meta {
    font-size: 11px;
    color: #94a3b8;
    display: block;
}

/* 6. General Search Form Widget Styling */
#secondary .widget_search .searchform {
    margin: 0;
}

#secondary .widget_search .flex-row.relative {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    background-color: #f8fafc;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    padding: 4px 6px;
    transition: all 0.2s ease;
}

#secondary .widget_search .flex-row.relative:focus-within {
    background-color: #ffffff;
    border-color: #367eb0;
    box-shadow: 0 0 0 3px rgba(54, 126, 176, 0.15);
}

#secondary .widget_search input[type="search"] {
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 8px 10px !important;
    font-size: 14.5px !important;
    color: #334155 !important;
    width: 100% !important;
    margin: 0 !important;
}

#secondary .widget_search input[type="search"]:focus {
    outline: none !important;
}

#secondary .widget_search button[type="submit"] {
    background-color: #367eb0 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 8px 16px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    height: auto !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
}

#secondary .widget_search button[type="submit"]:hover {
    background-color: #d41820 !important;
}

/* 7. Tag Cloud Widget Styling */
#secondary .widget_tag_cloud .tagcloud {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding-top: 5px;
}

#secondary .widget_tag_cloud .tagcloud a {
    display: inline-block !important;
    padding: 6px 12px !important;
    background: #f8fafc !important;
    color: #475569 !important;
    font-size: 12px !important; /* Normalize the messy WordPress tag sizes */
    font-weight: 600 !important;
    border-radius: 6px !important;
    border: 1px solid #e2e8f0 !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
    margin: 0 !important;
}

#secondary .widget_tag_cloud .tagcloud a:hover {
    background: #367eb0 !important;
    color: #ffffff !important;
    border-color: #367eb0 !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(54, 126, 176, 0.15);
}

/* ==========================================================================
   STYLING: Premium Single Post Headings & Content Typography
   ========================================================================== */

/* Post Content Body Styles */
.single-post .entry-content {
    font-size: 16px !important;
    line-height: 1.8 !important;
    color: #334155 !important;
}

/* 1. Article H2 Headings */
.single-post .entry-content h2 {
    font-size: 22px !important;
    font-weight: 800 !important;
    color: #0f2038 !important;
    margin: 45px 0 20px 0 !important;
    padding: 12px 18px !important;
    border-left: 5px solid #367eb0 !important;
    background: linear-gradient(90deg, #f8fafc 0%, rgba(248, 250, 252, 0) 100%) !important;
    border-radius: 0 8px 8px 0 !important;
    line-height: 1.4 !important;
    box-shadow: none !important;
}

/* 2. Article H3 Headings */
.single-post .entry-content h3 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin: 30px 0 15px 0 !important;
    line-height: 1.4 !important;
    display: flex;
    align-items: center;
    gap: 8px;
}

.single-post .entry-content h3::before {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    background-color: #d41820; /* Brand red dot */
    border-radius: 50%;
    flex-shrink: 0;
}

/* 3. Article H4 Headings */
.single-post .entry-content h4 {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #475569 !important;
    margin: 25px 0 12px 0 !important;
    line-height: 1.4 !important;
}

/* Paragraph spacing */
.single-post .entry-content p {
    margin-bottom: 20px !important;
}

/* Bullets styling */
.single-post .entry-content ul {
    padding-left: 20px !important;
    margin-bottom: 20px !important;
}

.single-post .entry-content ul li {
    margin-bottom: 8px !important;
    line-height: 1.6 !important;
    color: #334155 !important;
}

/* ==========================================================================
   STYLING: Premium Modern Sidebar/Article FAQ Section
   ========================================================================== */

/* FAQ Section Container Override */
.single-post .entry-content .faq-section {
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-left: 5px solid #367eb0 !important;
    border-radius: 16px !important;
    padding: 30px 30px 10px 30px !important;
    margin: 50px 0 35px 0 !important;
    box-shadow: 0 4px 20px rgba(15, 32, 56, 0.03) !important;
    box-sizing: border-box !important;
}

/* FAQ Section Header (H3) */
.single-post .entry-content .faq-section h3 {
    font-size: 20px !important;
    font-weight: 800 !important;
    color: #0f2038 !important;
    margin: 0 0 25px 0 !important;
    border-bottom: 2px solid #e2e8f0 !important;
    padding-bottom: 12px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: block !important;
}

.single-post .entry-content .faq-section h3::before {
    display: none !important; /* Hide dot bullet for section title */
}

/* FAQ Items */
.single-post .entry-content .faq-item {
    background-color: #f8fafc !important;
    border: 1px solid #f1f5f9 !important;
    border-radius: 12px !important;
    padding: 20px !important;
    margin-bottom: 20px !important;
    transition: all 0.25s cubic-bezier(0.25, 1, 0.5, 1) !important;
    box-shadow: none !important;
}

.single-post .entry-content .faq-item:hover {
    background-color: #ffffff !important;
    border-color: #cbd5e1 !important;
    box-shadow: 0 6px 15px rgba(15, 32, 56, 0.05) !important;
    transform: translateY(-2px) !important;
}

/* FAQ Questions (Strong tag inside faq-item) */
.single-post .entry-content .faq-item strong[style*="display: block"],
.single-post .entry-content .faq-item > strong:first-child {
    color: #0f2038 !important;
    font-size: 16.5px !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    margin-bottom: 10px !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
}

/* FAQ Answer (Paragraph) */
.single-post .entry-content .faq-item p {
    color: #334155 !important;
    font-size: 14.5px !important;
    line-height: 1.6 !important;
    margin: 0 !important;
}

/* Highlight the "Trả lời" prefix inside the paragraph */
.single-post .entry-content .faq-item p strong:first-child {
    color: #d41820 !important; /* Brand red for "Trả lời" label */
    font-weight: 700 !important;
}

/* ==========================================================================
   STYLING: Premium Contact Page Layout & Glassmorphism Cards
   ========================================================================== */
.premium-contact-page {
    margin: 40px 0;
}

.premium-contact-page .contact-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
}

/* Titles */
.premium-contact-page .contact-section-title {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: #0f2038 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 0 !important;
    margin-bottom: 8px !important;
}

.premium-contact-page .contact-section-subtitle {
    font-size: 14.5px;
    color: #64748b;
    margin-bottom: 30px !important;
}

/* Left panel: cards */
.premium-contact-page .contact-cards-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.premium-contact-page .contact-info-card {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 24px;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    box-shadow: 0 4px 12px rgba(15, 32, 56, 0.02);
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}

.premium-contact-page .contact-info-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(15, 32, 56, 0.06);
    border-color: #cbd5e1;
}

/* Card Icons */
.premium-contact-page .contact-info-card .card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background-color: #f1f5f9;
    color: #367eb0;
    font-size: 18px;
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.premium-contact-page .contact-info-card:hover .card-icon {
    background-color: #fee2e2;
    color: #d41820;
}

/* Card Content */
.premium-contact-page .contact-info-card .card-content h3 {
    font-size: 16.5px !important;
    font-weight: 700 !important;
    color: #0f2038 !important;
    margin-top: 0 !important;
    margin-bottom: 8px !important;
}

.premium-contact-page .contact-info-card .card-content p {
    font-size: 14.5px;
    color: #475569;
    margin-bottom: 6px !important;
    line-height: 1.5;
}

.premium-contact-page .contact-info-card .card-content p:last-child {
    margin-bottom: 0 !important;
}

.premium-contact-page .contact-info-card .card-content a {
    color: #367eb0 !important;
    text-decoration: none !important;
    transition: color 0.2s ease;
}

.premium-contact-page .contact-info-card .card-content a:hover {
    color: #d41820 !important;
}

/* Right Panel: Form Card */
.premium-contact-page .contact-form-card {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    padding: 35px;
    box-shadow: 0 10px 30px rgba(15, 32, 56, 0.03);
}

/* Contact Form Fields Styling */
.contact-form-premium .form-group {
    margin-bottom: 20px;
}

.contact-form-premium label {
    font-weight: 600;
    color: #475569;
    font-size: 13.5px;
    margin-bottom: 6px;
    display: block;
}

.contact-form-premium label .required {
    color: #d41820;
}

.contact-form-premium input[type="text"],
.contact-form-premium input[type="tel"] {
    width: 100%;
    height: 48px;
    padding: 0 16px;
    background: #f8fafc;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 14.5px;
    color: #334155;
    transition: all 0.2s ease;
    box-sizing: border-box;
}

.contact-form-premium textarea {
    width: 100%;
    padding: 12px 16px;
    background: #f8fafc;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 14.5px;
    color: #334155;
    transition: all 0.2s ease;
    box-sizing: border-box;
    height: 120px;
    resize: vertical;
}

.contact-form-premium input[type="text"]:focus,
.contact-form-premium input[type="tel"]:focus,
.contact-form-premium textarea:focus {
    background: #ffffff;
    border-color: #367eb0;
    outline: none;
    box-shadow: 0 0 0 3px rgba(54, 126, 176, 0.15);
}

/* Spam challenge row */
.contact-form-premium .spam-challenge-row {
    display: flex;
    gap: 12px;
    align-items: center;
}

.contact-form-premium .spam-challenge-row input[type="text"] {
    max-width: 100% !important;
}

.contact-form-premium .spam-challenge-row input,
.contact-form-premium .spam-challenge-row .spam-question {
    margin: 0 !important;
}

/* Submit Button */
.contact-form-premium .form-submit-row {
    margin-top: 25px;
}

.contact-form-premium input[type="submit"] {
    width: 100%;
    display: block;
    padding: 14px 30px;
    background: linear-gradient(135deg, #d41820 0%, #a80f15 100%);
    color: #ffffff !important;
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    border: none;
    border-radius: 30px;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(212, 24, 32, 0.3);
    transition: all 0.25s ease;
}

.contact-form-premium input[type="submit"]:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(212, 24, 32, 0.4);
}

/* Responsive */
@media only screen and (max-width: 768px) {
    .premium-contact-page .contact-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    .premium-contact-page .contact-form-card {
        padding: 25px;
    }
}

/* Custom Contact Form Coded Styles */
.contact-form-premium .spam-challenge-row .spam-question {
    font-size: 14px;
    font-weight: 700;
    color: #0f2038;
    background: #f1f5f9;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    white-space: nowrap;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 48px;
    padding: 0 16px;
    box-sizing: border-box;
}

.contact-form-premium button[type="submit"] {
    width: 100%;
    display: block;
    padding: 14px 30px;
    background: linear-gradient(135deg, #d41820 0%, #a80f15 100%);
    color: #ffffff !important;
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    border: none;
    border-radius: 30px;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(212, 24, 32, 0.3);
    transition: all 0.25s ease;
    outline: none;
    line-height: 1;
}

.contact-form-premium button[type="submit"]:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(212, 24, 32, 0.4);
}

.contact-form-premium button[type="submit"]:disabled {
    background: #94a3b8 !important;
    box-shadow: none !important;
    cursor: not-allowed;
    transform: none !important;
}

/* Success / Error Message Alerts */
.contact-form-premium .success-msg {
    display: block;
    margin-top: 15px;
    padding: 12px 16px;
    background: #f0fdf4 !important;
    border: 1px solid #bbf7d0 !important;
    color: #166534 !important;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.5;
}

.contact-form-premium .error-msg {
    display: block;
    margin-top: 15px;
    padding: 12px 16px;
    background: #fef2f2 !important;
    border: 1px solid #fca5a5 !important;
    color: #991b1b !important;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.5;
}

/* Fail-safe to hide any empty p tags injected by WordPress wpautop inside the grid */
.premium-contact-page .contact-grid > p {
    display: none !important;
}

/* 2-column layout for Họ tên & Số điện thoại */
.contact-form-premium .form-row-2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

@media only screen and (max-width: 600px) {
    .contact-form-premium .form-row-2col {
        grid-template-columns: 1fr;
        gap: 0;
    }
}

/* ==========================================================================
   STYLING: Premium Consultation & Quote Modal Popup (#yeu-cau-tu-van-bao-gia)
   ========================================================================== */
body.modal-open-blur {
    overflow: hidden !important;
}

.consult-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(15, 32, 56, 0.45);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
}

.consult-modal-container {
    background: #ffffff;
    border-radius: 20px;
    max-width: 600px;
    width: 100%;
    box-shadow: 0 20px 50px rgba(15, 32, 56, 0.15);
    position: relative;
    padding: 35px;
    box-sizing: border-box;
    max-height: 90vh;
    overflow-y: auto;
    animation: modalZoomIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes modalZoomIn {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(-20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.consult-modal-close {
    position: absolute;
    top: 15px;
    right: 20px;
    background: transparent;
    border: none;
    font-size: 32px;
    font-weight: 300;
    color: #94a3b8;
    cursor: pointer;
    line-height: 1;
    transition: all 0.2s ease;
    outline: none;
    padding: 5px;
}

.consult-modal-close:hover {
    color: #d41820;
    transform: rotate(90deg);
}

.consult-modal-header {
    text-align: center;
    margin-bottom: 25px;
    border-bottom: 1px solid #f1f5f9;
    padding-bottom: 15px;
}

.consult-modal-header h3 {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #0f2038 !important;
    text-transform: none !important;
    margin: 0 0 6px 0 !important;
    letter-spacing: 0.5px;
}

.consult-modal-header p {
    font-size: 13.5px;
    color: #64748b;
    margin: 0 !important;
}

/* Modal Form Controls */
.consult-modal-body select {
    width: 100%;
    height: 48px;
    padding: 0 16px;
    background: #f8fafc;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 14.5px;
    color: #334155;
    transition: all 0.2s ease;
    box-sizing: border-box;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23475569'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpolyline%20points='6%209%2012%2015%2018%209'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 16px;
}

.consult-modal-body select:focus {
    background-color: #ffffff;
    border-color: #367eb0;
    outline: none;
    box-shadow: 0 0 0 3px rgba(54, 126, 176, 0.15);
}

/* Custom Scrollbar for Modal Container */
.consult-modal-container::-webkit-scrollbar {
    width: 6px;
}
.consult-modal-container::-webkit-scrollbar-track {
    background: #f1f5f9;
    border-radius: 10px;
}
.consult-modal-container::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 10px;
}
.consult-modal-container::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

@media only screen and (max-width: 600px) {
    .consult-modal-container {
        padding: 25px 20px;
        border-radius: 15px;
    }
    .consult-modal-header h3 {
        font-size: 18px !important;
    }
}

/* ==========================================================================
   HOMEPAGE SLIDER NAVIGATION BEAUTIFICATION & VISIBILITY IMPROVEMENT
   ========================================================================== */
/* Prev/Next Navigation Buttons */
.ux-slider-wrapper .flickity-prev-next-button {
    width: 48px !important;
    height: 48px !important;
    background: rgba(15, 32, 56, 0.6) !important; /* Premium dark navy translucent background */
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 50% !important;
    color: #ffffff !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15) !important;
    opacity: 0.8 !important;
}

/* Adjust position slightly inside wrapper */
.ux-slider-wrapper .flickity-prev-next-button.previous {
    left: 20px !important;
}
.ux-slider-wrapper .flickity-prev-next-button.next {
    right: 20px !important;
}

/* Inner SVG Arrow styling */
.ux-slider-wrapper .flickity-prev-next-button svg {
    width: 35% !important;
    height: 35% !important;
    fill: currentColor !important;
    transition: transform 0.3s ease !important;
}

/* Hover effects */
.ux-slider-wrapper .flickity-prev-next-button:hover {
    background: #367eb0 !important; /* Brand Blue */
    color: #ffffff !important;
    opacity: 1 !important;
    border-color: #367eb0 !important;
    box-shadow: 0 0 15px rgba(54, 126, 176, 0.5) !important;
    transform: translateY(-50%) scale(1.1) !important;
}
.ux-slider-wrapper .flickity-prev-next-button.previous:hover svg {
    transform: translateX(-2px) !important;
}
.ux-slider-wrapper .flickity-prev-next-button.next:hover svg {
    transform: translateX(2px) !important;
}

/* Pagination Dots */
.ux-slider-wrapper .flickity-page-dots {
    bottom: 25px !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    z-index: 10 !important;
}

/* Individual Dots */
.ux-slider-wrapper .flickity-page-dots .dot {
    width: 10px !important;
    height: 10px !important;
    background: rgba(255, 255, 255, 0.5) !important; /* White translucent */
    border: 1px solid rgba(15, 32, 56, 0.2) !important;
    opacity: 0.7 !important;
    margin: 0 6px !important;
    border-radius: 50% !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1) !important;
    cursor: pointer !important;
}

/* Selected Active Dot (Premium Horizontal Dash) */
.ux-slider-wrapper .flickity-page-dots .dot.is-selected {
    width: 26px !important; /* Expanding into modern dash */
    height: 10px !important;
    background: #d41820 !important; /* Brand Red highlight */
    border-color: #d41820 !important;
    border-radius: 5px !important;
    opacity: 1 !important;
    box-shadow: 0 0 10px rgba(212, 24, 32, 0.5) !important;
}

/* Hover over dots */
.ux-slider-wrapper .flickity-page-dots .dot:hover {
    background: #ffffff !important;
    opacity: 1 !important;
}

/* Mobile responsive adjustments */
@media only screen and (max-width: 600px) {
    .ux-slider-wrapper .flickity-prev-next-button {
        width: 38px !important;
        height: 38px !important;
        opacity: 0.9 !important;
    }
    .ux-slider-wrapper .flickity-prev-next-button.previous {
        left: 10px !important;
    }
    .ux-slider-wrapper .flickity-prev-next-button.next {
        right: 10px !important;
    }
    .ux-slider-wrapper .flickity-page-dots {
        bottom: 15px !important;
    }
    .ux-slider-wrapper .flickity-page-dots .dot {
        width: 8px !important;
        height: 8px !important;
        margin: 0 4px !important;
    }
    .ux-slider-wrapper .flickity-page-dots .dot.is-selected {
        width: 20px !important;
        height: 8px !important;
    }
}