/* ==========================================================================
   CSS cho Off-Canvas sử dụng <dialog> trên màn hình mobile (dưới 768px)
   ========================================================================== */

@media (max-width: 768px) {
  /* --- 1. Tinh chỉnh Header cơ bản --- */
  .site-header {
    padding: 10px;
    height: auto; /* Chiều cao tự động để vừa nội dung */
    position: relative; /* Cần cho vị trí của nút menu */
  }
  .right-header {
    display: block;
    padding-top: 10px;
  }
  .main-logo {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .main-logo a img {
    margin-top: 0;
    max-width: 180px; /* Điều chỉnh kích thước logo nếu cần */
    height: auto;
  }
  .seach-bar,
  .language_icon {
    display: none; /* Ẩn tìm kiếm và ngôn ngữ trên mobile header */
  }
  .phanphoi-title {
    font-size: clamp(0.7rem, 4vw, 1rem);
    text-align: center;
  }
  .furuno-logo {
    display: block;
    margin: 5px auto 0;
  }

  /* --- 2. Ẩn menu desktop và hiển thị nút hamburger --- */
  .site-header__menu {
    display: none;
  }
  .menu-toggle {
    display: block; /* Hiển thị nút hamburger */
    /* Các style khác cho nút đã có trong file style.css của bạn */
  }

  /* --- 3. Định dạng cho thẻ <dialog> --- */
  .offcanvas-dialog {
    /* Vị trí và kích thước */
    position: fixed;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0;
    width: 80vw;
    max-width: 85vw; /* Không rộng hơn 85% chiều rộng màn hình */
    height: 100vh;

    /* Giao diện */
    background-color: #fff;
    border: none;
    box-shadow: 2px 0 15px rgba(0, 0, 0, 0.2);

    /* ✨ THAY ĐỔI HIỆU ỨNG Ở ĐÂY ✨ */
    transform: translateX(-100%);
    /*
      - Tăng thời gian lên 0.4s
      - Thêm timing-function để chuyển động mượt hơn
    */
    transition-property: transform;
    transition-duration: 0.4s;
    transition-timing-function: cubic-bezier(0.23, 1, 0.32, 1);
  }

  /* Khi dialog được mở */
  .offcanvas-dialog[open] {
    transform: translateX(0);
  }

  /* --- 4. Định dạng cho lớp phủ (Backdrop) --- */
  .offcanvas-dialog::backdrop {
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    /* ✨ ĐỒNG BỘ HIỆU ỨNG CHO LỚP PHỦ ✨ */
    transition-property: opacity;
    transition-duration: 0.4s;
    transition-timing-function: ease-in-out;
  }

  .offcanvas-dialog[open]::backdrop {
    opacity: 1;
  }

  /* --- 5. Bố cục bên trong Off-Canvas --- */
  .offcanvas-header {
    display: flex;
    justify-content: flex-end;
    padding: 10px 15px;
    border-bottom: 1px solid #eee;
  }
  .close-dialog-btn {
    background: none;
    border: none;
    font-size: 2.5rem;
    font-weight: 300;
    line-height: 1;
    cursor: pointer;
    color: #555;
    padding: 0 5px;
  }

  .offcanvas-navigation {
    padding: 10px 15px;
  }

  .main-menu-list-mobile {
    list-style: none;
    padding: 0;
    margin: 0;
  }
  .main-menu-list-mobile li {
    border-bottom: 1px solid #f0f0f0;
  }
  .main-menu-list-mobile li:last-child {
    border-bottom: none;
  }
  .main-menu-list-mobile a {
    display: block;
    padding: 12px 5px;
    text-decoration: none;
    color: #333;
    font-weight: 500;
  }
  .main-menu-list-mobile a:hover,
  .main-menu-list-mobile .current-menu-item > a {
    background-color: #f8f8f8;
    color: #0056b3;
  }

  /* Style cho menu con (nếu có) */
  .main-menu-list-mobile .sub-menu {
    list-style: none;
    padding-left: 20px;
    margin: 0;
  }
  .main-menu-list-mobile .sub-menu a {
    font-weight: 400;
    color: #555;
  }
  .offcanvas-header {
    display: flex;
    justify-content: center;
  }
  .offcanvas-header .button {
    color: #333;
  }

  .off-logo {
    text-align: right;
  }
  .off-logo a img {
    width: 150px;
    height: auto;
  }

  /* --- CSS cho Off-Canvas Dialog --- */

  /* 1. Căn chỉnh Header: Logo bên trái, nút đóng bên phải */
  .offcanvas-header {
    display: flex;
    justify-content: space-between; /* Đẩy các item về 2 phía */
    align-items: center; /* Căn giữa theo chiều dọc */
    padding: 10px 15px;
    border-bottom: 1px solid #eee;
  }

  .off-logo img {
    height: auto; /* Điều chỉnh chiều cao logo nếu cần */
    width: 150px;
    display: block;
    margin-bottom: 5px;
    margin-top: 5px;
  }

  .close-dialog-btn {
    /* Reset lại style mặc định của button */
    background: none;
    border: none;
    padding: 5px; /* Thêm chút đệm để dễ nhấn hơn */
    cursor: pointer;
    line-height: 1; /* Loại bỏ chiều cao dòng thừa */

    /* Bắt buộc: Đặt màu cho icon để nó hiện ra */
    color: #555; /* Một màu xám đậm dễ nhìn */

    /* Thêm hiệu ứng chuyển động mượt mà */
    transition: color 0.2s ease-in-out, transform 0.2s ease-in-out;
    margin-top: 5px;
  }

  .close-dialog-btn i {
    /* Đặt kích thước cho icon */
    font-size: 1.6rem;
    display: block; /* Giúp icon căn chỉnh tốt hơn */

    color: #0056b3;
  }

  /* Thêm hiệu ứng khi rê chuột */
  .close-dialog-btn:hover {
    color: #000; /* Đổi thành màu đen khi hover */
    transform: scale(1.1); /* Phóng to nhẹ để tạo cảm giác tương tác */
  }

  /* 2. Căn giữa thanh tìm kiếm */
  .search-bar-offCanvas {
    display: flex;
    justify-content: center; /* Căn giữa theo chiều ngang */
    padding: 20px 15px;
  }

  /* 3. Căn giữa icon ngôn ngữ */
  .language_icon-offCanvas {
    /*display: flex;*/
    display: none;
    justify-content: center; /* Căn giữa theo chiều ngang */
  }
}
