/* qh-custom-search.css - CSS cho Element Tìm kiếm Hover-Expand của Quân (-qh) */

.custom-search-element-qh { /* Class của <li> hoặc div bao ngoài cùng do functions.php tạo ra */
    display: inline-flex; /* Giúp căn chỉnh nếu cần */
    align-items: center;
    vertical-align: middle; /* Căn chỉnh với các item khác trong header */
}

.qh-hover-search-container {
    position: relative; /* Không cần style nhiều nếu form tự xử lý */
}

.qh-hover-search-form {
    display: flex;
    align-items: center;
    height: 40px; /* Chiều cao của thanh tìm kiếm - điều chỉnh nếu cần */
    border: 1.5px solid #006A64; /* Màu viền xanh giống ảnh */
    border-radius: 22px; /* Bo tròn đều hai đầu */
    background-color: #fff;
    padding: 0 0 0 5px; /* Padding trái nhỏ ban đầu cho icon */
    width: 45px; /* Chiều rộng ban đầu, chỉ đủ cho icon và padding */
    transition: width 0.35s ease-in-out;
    overflow: hidden; /* Rất quan trọng để ẩn input khi thu gọn */
    box-sizing: border-box;
}

.qh-hover-search-icon-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px; /* Padding xung quanh icon */
    height: 100%;
    color: #006A64; /* Màu icon xanh */
    flex-shrink: 0; /* Không cho icon bị co lại */
    box-sizing: border-box;
}

.qh-hover-search-icon-wrapper .icon-search {
    font-size: 18px; /* Kích thước icon */
    display: block; /* Đảm bảo icon hiển thị đúng */
}

.qh-hover-search-input {
    flex-grow: 1; /* Input chiếm phần không gian còn lại */
    border: none;
    outline: none;
    padding: 0 10px 0 5px; /* Padding cho input: top right bottom left */
    height: 100%;
    font-size: 14px;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    color: #333;
    
    width: 0; /* Ban đầu ẩn hoàn toàn */
    opacity: 0;
    visibility: hidden; /* Ẩn khỏi trình đọc màn hình và tương tác */
    
    transition: width 0.3s ease-in-out 0.05s, opacity 0.25s ease-in-out 0.05s, visibility 0s linear 0.3s; /* Delay nhỏ cho hiệu ứng đẹp hơn */
    min-width: 0; /* Cho phép thu nhỏ về 0 trong flexbox */
    box-sizing: border-box;
}

/* Khi rê chuột vào form hoặc khi input bên trong được focus */
.qh-hover-search-form:hover,
.qh-hover-search-form:focus-within {
    width: 250px; /* Chiều rộng khi mở rộng - điều chỉnh nếu cần */
}

.qh-hover-search-form:hover .qh-hover-search-input,
.qh-hover-search-form:focus-within .qh-hover-search-input {
    width: calc(100% - 40px); /* Tính toán chiều rộng cho input, trừ đi phần icon và padding. Điều chỉnh 40px nếu kích thước icon/padding thay đổi */
    opacity: 1;
    visibility: visible;
    transition: width 0.3s ease-in-out, opacity 0.25s ease-in-out, visibility 0s linear 0s;
}

/* Class để ẩn hoàn toàn các element cho trình đọc màn hình nhưng vẫn submit được */
.visually-hidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    white-space: nowrap; /* Tránh wrap text nếu có */
}