﻿:root {
      --primary: #c8a96b;
      --primary-2: #e6cb98;
      --dark: #0c0f14;
      --dark-2: #131821;
      --dark-3: #191f29;
      --white: #ffffff;
      --text: #d7dde8;
      --muted: #9ba6b8;
      --line: rgba(255,255,255,.08);
      --soft-line: rgba(255,255,255,.05);
      --success: #23c483;
      --danger: #ff6b6b;
      --shadow: 0 20px 55px rgba(0,0,0,.28);
      --radius-lg: 28px;
      --radius-md: 22px;
      --radius-sm: 16px;
    }
    body[data-theme="light"] {
      --dark: #f5f7fb;
      --dark-2: #ffffff;
      --dark-3: #eef2f8;
      --text: #334155;
      --muted: #64748b;
      --line: rgba(15,23,42,.10);
      --soft-line: rgba(15,23,42,.06);
      --shadow: 0 20px 50px rgba(15,23,42,.10);
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      margin: 0;
      font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
      background: var(--dark);
      color: var(--text);
      line-height: 1.65;
    }

    a { text-decoration: none; }
    img { max-width: 100%; display: block; }
    .text-gold { color: var(--primary); }
    .section-padding { padding: 96px 0; }
    .section-dark { background: linear-gradient(180deg, #11161d 0%, #0c0f14 100%); }
    .section-soft { background: linear-gradient(180deg, #171d27 0%, #10151d 100%); }

    .topbar {
      background: #0a0d12;
      border-bottom: 1px solid rgba(255,255,255,.05);
      font-size: 14px;
      color: #c9d2df;
    }
    .topbar-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px 24px;
      flex-wrap: wrap;
    }
    .topbar-group {
      display: flex;
      align-items: center;
      gap: 0 18px;
      flex-wrap: wrap;
      min-height: 42px;
    }
    .topbar-right {
      margin-left: auto;
    }
    .topbar .item {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-right: 0;
      padding: 10px 0;
      line-height: 1;
      white-space: nowrap;
    }
    .topbar .item a.topbar-contact-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      color: inherit;
      text-decoration: none;
      line-height: 1;
    }
    .topbar .item a.topbar-contact-link:hover {
      color: var(--primary);
      text-decoration: underline;
    }
    .topbar .item i {
      width: 16px;
      min-width: 16px;
      text-align: center;
      line-height: 1;
    }
    /* Zalo: không có trong Font Awesome bundle — SVG monochrome theo currentColor */
    .uc-icon-zalo {
      display: inline-block;
      flex-shrink: 0;
      vertical-align: middle;
    }
    .uc-icon-zalo path {
      fill: currentColor;
    }
    .topbar .item .uc-icon-zalo {
      width: 16px;
      height: 16px;
    }
    .footer .uc-icon-zalo {
      width: 1em;
      height: 1em;
      vertical-align: -0.2em;
    }
    .floating-contact .zalo .uc-icon-zalo {
      width: 24px;
      height: 24px;
    }

    .navbar {
      --nav-menu-gap: 10px;
      --nav-dropdown-gap: 14px;
      padding: 12px 0 10px;
      background: rgba(10, 13, 18, .78);
      backdrop-filter: blur(14px);
      border-bottom: 1px solid rgba(255,255,255,.06);
      overflow: visible;
    }
    /*
     * BS: .sticky-top và .sticky-lg-top đều 1020 — $body (article + sidebar) sau navbar trong DOM
     * nên đè toàn bộ lớp header khi trùng vùng. z-index trên .dropdown-menu không có tác dụng vượt
     * khỏi ngữ cảnh xếp lớp của navbar — phải nâng z-index của chính .navbar.sticky-top.
     */
    .navbar.sticky-top {
      z-index: 1030;
    }
    .navbar .container {
      position: relative;
    }
    .navbar .navbar-collapse {
      align-items: flex-end;
    }
    .navbar-brand {
      display: inline-flex;
      align-items: center;
      flex-shrink: 0;
      margin-right: 20px;
      padding: 0;
      border-radius: 0;
      background: transparent;
      border: 0;
      box-shadow: none;
    }
    .brand-logo {
      display: block;
      width: 252px;
      max-width: 100%;
      height: auto;
      filter: brightness(1.14) saturate(1.12) contrast(1.04) drop-shadow(0 6px 18px rgba(242,201,114,.14));
    }
    .navbar .nav-item { position: relative; }
    .navbar .nav-item.position-static { position: static; }
    .nav-compact {
      display: inline-flex;
      gap: 8px;
      align-items: center;
      margin-top: 4px;
      padding: 0;
      border-radius: 0;
      background: transparent;
      border: 0;
      box-shadow: none;
    }
    .navbar .nav-link {
      position: relative;
      color: #edf1f7;
      font-size: .96rem;
      font-weight: 600;
      margin: 0 2px;
      padding: 10px 12px !important;
      border-radius: 999px;
      background: transparent;
      box-shadow: none;
      transition: color .2s ease, background .2s ease, transform .2s ease;
    }
    .navbar .nav-link:not(.dropdown-toggle)::after {
      content: "";
      position: absolute;
      left: 12px;
      right: 12px;
      bottom: 5px;
      height: 2px;
      border-radius: 999px;
      background: rgba(200,169,107,.9);
      transform: scaleX(0);
      transform-origin: center;
      transition: transform .2s ease, opacity .2s ease;
      opacity: 0;
    }
    .navbar .nav-link.dropdown-toggle::after {
      display: none;
    }
    .navbar .nav-link .nav-submenu-icon {
      font-size: 0.62em;
      opacity: 0.88;
      transition: transform 0.2s ease, opacity 0.2s ease;
    }
    .navbar .nav-link.dropdown-toggle[aria-expanded="true"] .nav-submenu-icon {
      transform: rotate(180deg);
      opacity: 1;
    }
    .navbar .nav-link:hover,
    .navbar .nav-link.active {
      color: var(--primary-2);
      background: transparent;
      box-shadow: none;
      transform: translateY(-1px);
    }
    .navbar .nav-link:not(.dropdown-toggle):hover::after {
      transform: scaleX(.72);
      opacity: .85;
    }
    .navbar .nav-link:not(.dropdown-toggle).active::after {
      transform: scaleX(1);
      opacity: 1;
    }
    .nav-actions {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      flex-shrink: 0;
      margin-top: 4px;
      padding: 0;
      border-radius: 0;
      background: transparent;
      border: 0;
      box-shadow: none;
    }
    .btn-nav-primary {
      padding: 10px 18px;
      font-size: .95rem;
      white-space: nowrap;
    }
    .theme-toggle {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0;
      width: 48px;
      min-width: 48px;
      height: 48px;
      padding: 0;
      white-space: nowrap;
      border-color: transparent;
      background: transparent;
      box-shadow: none;
    }
    .theme-toggle i {
      font-size: 1rem;
      line-height: 1;
    }
    .mega-menu {
      width: 100%;
      max-width: 100%;
      left: 0 !important;
      right: 0 !important;
      top: 100% !important;
      transform: none !important;
      margin-top: var(--nav-menu-gap) !important;
      padding: 0;
      border: 1px solid rgba(200,169,107,.18);
      border-radius: 24px;
      background: linear-gradient(180deg, rgba(22,27,36,.99) 0%, rgba(11,15,22,.99) 100%);
      box-shadow: 0 28px 70px rgba(0,0,0,.42);
      overflow: visible;
    }
    .mega-menu::before,
    .nav-dropdown-menu::before {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      top: calc(-1 * var(--nav-menu-gap));
      height: var(--nav-menu-gap);
      background: transparent;
      pointer-events: auto;
    }
    .mega-menu > .container-fluid {
      border-radius: inherit;
      overflow: hidden;
    }
    .mega-menu[data-bs-popper] {
      left: 0 !important;
      right: 0 !important;
      top: 100% !important;
      transform: none !important;
      inset: auto 0 auto 0 !important;
      margin-top: var(--nav-menu-gap) !important;
    }
    .nav-dropdown-menu {
      min-width: 260px;
      left: 50% !important;
      right: auto !important;
      top: 100% !important;
      transform: translateX(-50%) !important;
      margin-top: var(--nav-dropdown-gap) !important;
      padding: 10px;
      border: 1px solid rgba(200,169,107,.18);
      border-radius: 18px;
      background: linear-gradient(180deg, rgba(22,27,36,.99) 0%, rgba(11,15,22,.99) 100%);
      box-shadow: 0 22px 56px rgba(0,0,0,.28);
    }
    .nav-dropdown-menu::before {
      top: calc(-1 * var(--nav-dropdown-gap));
      height: var(--nav-dropdown-gap);
    }
    .nav-dropdown-menu[data-bs-popper] {
      left: 50% !important;
      right: auto !important;
      top: 100% !important;
      transform: translateX(-50%) !important;
      inset: auto auto auto 50% !important;
      margin-top: var(--nav-dropdown-gap) !important;
    }
    .nav-dropdown-menu .dropdown-item {
      display: flex;
      align-items: center;
      padding: 11px 12px;
      border-radius: 12px;
      color: #d7dde8;
      font-size: .95rem;
    }
    .nav-dropdown-menu .dropdown-item:hover {
      background: rgba(255,255,255,.06);
      color: #fff;
    }
    .mega-menu .dropdown-item {
      color: #d7dde8;
      padding: 14px 16px;
      border-radius: 18px;
      white-space: normal;
      border: 1px solid transparent;
    }
    .mega-menu .dropdown-item:hover {
      background: rgba(255,255,255,.06);
      border-color: rgba(200,169,107,.22);
      color: #fff;
      transform: translateY(-1px);
    }
    .mega-menu .mega-title {
      color: #fff;
      font-weight: 700;
      margin-bottom: 14px;
      font-size: 1rem;
    }
    .mega-link {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      transition: .22s ease;
    }
    .mega-icon {
      width: 42px;
      height: 42px;
      min-width: 42px;
      border-radius: 14px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: var(--primary-2);
      background: linear-gradient(180deg, rgba(200,169,107,.16) 0%, rgba(200,169,107,.08) 100%);
      border: 1px solid rgba(200,169,107,.18);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
    }
    .mega-copy {
      display: block;
      flex: 1;
    }
    .mega-label {
      display: block;
      color: #fff;
      font-weight: 700;
      font-size: 15px;
      line-height: 1.3;
    }
    .mega-menu .mega-sub {
      color: var(--muted);
      font-size: 13px;
      margin-top: 4px;
      display: block;
    }
    .mega-highlight {
      position: relative;
      border-radius: 22px;
      overflow: visible;
      min-height: 100%;
      padding: 0;
      background: transparent;
      border: 0;
    }
    .mega-highlight::before {
      display: none;
    }
    .mega-highlight-content {
      position: relative;
      left: auto;
      right: auto;
      bottom: auto;
      z-index: 1;
      height: 100%;
    }
    .mega-highlight-card {
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
      height: 100%;
      min-height: 100%;
      padding: 22px 22px 20px;
      border-radius: 20px;
      background: linear-gradient(180deg, rgba(18,23,32,.94) 0%, rgba(12,16,24,.98) 100%);
      border: 1px solid rgba(255,255,255,.08);
      backdrop-filter: none;
      box-shadow: 0 16px 34px rgba(0,0,0,.18);
    }
    .mega-highlight .chip {
      background: rgba(255,255,255,.06);
      border-color: rgba(255,255,255,.08);
      color: #dfe7f2;
      margin-bottom: 12px !important;
    }
    .mega-highlight-kicker {
      display: inline-flex;
      align-items: center;
      padding: 6px 10px;
      margin-bottom: 10px;
      border-radius: 999px;
      background: rgba(255,255,255,.08);
      color: #dfe7f2;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .02em;
    }
    .mega-highlight-card h5 {
      font-size: 1.45rem;
      line-height: 1.18;
      margin-bottom: 12px;
    }
    .mega-highlight-card p {
      color: rgba(255,255,255,.82);
      font-size: .95rem;
      line-height: 1.6;
      margin-bottom: 16px !important;
    }
    .mega-highlight-points {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 18px;
    }
    .mega-highlight-points span {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(255,255,255,.07);
      border: 1px solid rgba(255,255,255,.10);
      color: #f1f5fb;
      font-size: 13px;
    }

    /* Dùng .btn.btn-gold để thắng độ đặc hiệu của Bootstrap .btn và .footer a */
    .btn.btn-gold,
    a.btn.btn-gold,
    button.btn.btn-gold {
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      color: #141210;
      border: none;
      border-radius: 999px;
      font-weight: 700;
      padding: 12px 24px;
      box-shadow: 0 14px 30px rgba(200,169,107,.22);
      transition: .25s ease;
    }
    .btn.btn-gold:hover,
    a.btn.btn-gold:hover,
    button.btn.btn-gold:hover {
      color: #0a0908;
      transform: translateY(-2px);
    }
    .btn-outline-light-custom {
      border: 1px solid rgba(255,255,255,.10);
      background: transparent;
      color: #fff;
      border-radius: 999px;
      padding: 12px 24px;
      font-weight: 600;
      transition: .25s ease;
    }
    .btn-outline-light-custom:hover {
      background: rgba(255,255,255,.05);
      color: #fff;
    }
    .btn-dark-glass {
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(255,255,255,.05);
      color: #fff;
      border-radius: 999px;
      padding: 10px 18px;
      font-weight: 600;
    }

    .hero {
      position: relative;
      min-height: auto;
      overflow-x: hidden;
      background: #0a0c11;
    }
    .hero .container {
      position: relative;
      z-index: 3;
      padding-left: 28px;
      padding-right: 28px;
    }
    .hero .owl-carousel,
    .hero .owl-stage-outer,
    .hero .owl-stage,
    .hero .owl-item,
    .hero-slide {
      height: auto;
      min-height: 480px;
    }
    .hero .owl-stage-outer {
      overflow: hidden;
    }
    .hero-slide {
      position: relative;
      background-size: cover;
      background-position: center;
      display: flex;
      align-items: flex-start;
      padding: 88px 0 64px;
    }
    .hero-slide .row {
      --bs-gutter-x: 2.75rem;
      justify-content: space-between;
      align-items: flex-start;
    }
    .hero-slide::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, rgba(9,12,18,.72) 0%, rgba(9,12,18,.44) 42%, rgba(9,12,18,.18) 100%);
    }
    .hero-slide::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(0,0,0,.02) 0%, rgba(0,0,0,.12) 65%, rgba(0,0,0,.28) 100%);
    }
    .hero-content,
    .hero-form,
    .hero-trust {
      position: relative;
      z-index: 3;
    }
    .hero-content {
      padding: 6px 0 4px;
      border-radius: 0;
      background: transparent;
      border: 0;
      box-shadow: none;
      backdrop-filter: none;
      max-width: 900px;
    }
    .hero-badge {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      padding: 6px 14px 6px 9px;
      border-radius: 999px;
      background: rgba(10,14,20,.26);
      color: #f5dfb8;
      border: 0;
      font-size: 13px;
      margin-bottom: 12px;
      box-shadow: 0 10px 24px rgba(0,0,0,.12);
      backdrop-filter: blur(8px);
    }
    .hero-badge i,
    .hero-trust .trust-item i {
      width: 24px;
      height: 24px;
      min-width: 24px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      background: rgba(200,169,107,.16);
    }
    .hero h1,
    .hero h2.hero-heading {
      color: #fff;
      font-size: clamp(1.65rem, 3.1vw, 2.85rem);
      line-height: 1.12;
      font-weight: 800;
      margin-bottom: 10px;
      max-width: 680px;
      text-shadow: 0 6px 24px rgba(0,0,0,.22);
    }
    .hero .lead {
      color: #e8edf4;
      font-size: 0.92rem;
      line-height: 1.5;
      max-width: 620px;
      margin-bottom: 14px;
      text-shadow: 0 2px 10px rgba(0,0,0,.18);
    }
    .hero-highlights {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
      margin: 16px 0 14px;
      max-width: 100%;
    }
    @media (min-width: 992px) {
      .hero-highlights {
        grid-template-columns: repeat(4, minmax(0, 1fr));
      }
    }
    .hero-highlights .item {
      padding: 11px 12px;
      border-radius: 18px;
      background: linear-gradient(180deg, rgba(12,16,24,.44) 0%, rgba(12,16,24,.24) 100%);
      border: 0;
      min-width: 0;
      backdrop-filter: blur(8px);
      position: relative;
      min-height: 68px;
      box-shadow: 0 12px 28px rgba(0,0,0,.10);
    }
    .hero-highlights .item::after {
      display: none;
    }
    .hero-highlights .item:last-child::after {
      display: none;
    }
    .hero-highlights strong {
      display: block;
      color: #fff;
      font-size: clamp(0.95rem, 1.1vw, 1.08rem);
      margin-bottom: 5px;
      line-height: 1.25;
    }
    .hero-highlights span {
      display: block;
      color: rgba(236,241,248,.86);
      line-height: 1.45;
      font-size: 0.88rem;
    }
    .hero-trust {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 14px;
      max-width: 640px;
      color: #f0f3f8;
      font-size: 12px;
    }
    .hero-trust .trust-item {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 7px 12px;
      border-radius: 999px;
      background: rgba(12,16,24,.30);
      border: 0;
      backdrop-filter: blur(8px);
      box-shadow: 0 8px 20px rgba(0,0,0,.10);
    }

    .hero-form {
      background: linear-gradient(180deg, rgba(9,13,19,.34) 0%, rgba(9,13,19,.52) 100%);
      border: 1px solid rgba(255,255,255,.10);
      border-radius: 22px;
      padding: 16px;
      box-shadow: 0 14px 36px rgba(0,0,0,.18);
      backdrop-filter: blur(12px);
      max-width: 404px;
      margin-left: auto;
      margin-top: 4px;
    }
    .hero-form .mini-tag {
      display: inline-block;
      font-size: 11px;
      letter-spacing: .05em;
      padding: 5px 10px;
      border-radius: 999px;
      background: rgba(35,196,131,.12);
      color: #85f3c2;
      border: 1px solid rgba(35,196,131,.15);
      margin-bottom: 8px;
      font-weight: 700;
      text-transform: uppercase;
    }
    .hero-form h5 {
      color: #fff;
      margin-bottom: 4px;
      font-weight: 800;
      font-size: 1.12rem;
      line-height: 1.25;
      text-shadow: 0 2px 10px rgba(0,0,0,.28);
    }
    .hero-form p {
      color: #dfe7f2;
      margin-bottom: 10px;
      font-size: 0.88rem;
      line-height: 1.45;
    }
    .hero-form .form-control,
    .hero-form .form-select {
      min-height: 44px;
      padding-top: 0.42rem;
      padding-bottom: 0.42rem;
      border-radius: 12px;
      font-size: 0.92rem;
    }
    .form-control,
    .form-select {
      min-height: 50px;
      border-radius: 15px;
      background: rgba(8,11,17,.64);
      border: 1px solid rgba(255,255,255,.14);
      color: #fff;
    }
    .form-control::placeholder { color: #d0d8e4; }
    .form-control:focus,
    .form-select:focus {
      background: rgba(8,11,17,.78);
      color: #fff;
      border-color: rgba(200,169,107,.45);
      box-shadow: 0 0 0 .25rem rgba(200,169,107,.12);
    }
    textarea.form-control { min-height: 120px; }

    #priceModal .modal-dialog {
      max-width: 980px;
    }
    #priceModal .price-modal-content {
      background: linear-gradient(180deg, rgba(22,27,36,.98) 0%, rgba(14,18,24,.98) 100%) !important;
      border: 1px solid rgba(255,255,255,.08) !important;
      box-shadow: 0 28px 70px rgba(0,0,0,.28);
    }
    #priceModal .price-modal-visual {
      min-height: 620px;
    }
    #priceModal .price-modal-visual-overlay {
      background: linear-gradient(180deg, rgba(4,8,14,.16) 0%, rgba(4,8,14,.42) 48%, rgba(4,8,14,.88) 100%) !important;
    }
    #priceModal .price-modal-visual-copy {
      text-shadow: 0 4px 18px rgba(0,0,0,.36);
    }
    #priceModal .price-modal-visual-copy .chip {
      background: rgba(255,255,255,.14);
      border-color: rgba(255,255,255,.18);
      color: #fff3d1;
      box-shadow: 0 10px 24px rgba(0,0,0,.14);
    }
    #priceModal .price-modal-visual-copy h4 {
      color: #ffffff !important;
      line-height: 1.2;
      margin-bottom: 10px;
    }
    #priceModal .price-modal-visual-copy p {
      color: rgba(245,248,252,.94) !important;
      line-height: 1.65;
    }
    #priceModal .price-modal-form-pane {
      background: rgba(12,16,22,.94);
    }
    #priceModal .price-modal-head .sub {
      color: #f2cb7b;
    }
    #priceModal .price-modal-head h3 {
      color: #ffffff !important;
      line-height: 1.18;
    }
    #priceModal .price-modal-head p {
      color: #dbe4ee !important;
      line-height: 1.65;
    }
    #priceModal .invalid-feedback {
      color: #ffb0b0;
    }

    .hero-mini-contact {
      margin-top: 12px;
      padding-top: 0;
      border-top: 0;
      display: flex;
      justify-content: space-between;
      gap: 10px;
      flex-wrap: wrap;
      color: #edf2f8;
      font-size: 12px;
    }
    .text-light-emphasis {
      color: rgba(231,238,247,.84) !important;
    }
    .text-light {
      color: rgba(244,247,251,.90) !important;
    }

    .owl-nav button.owl-prev,
    .owl-nav button.owl-next {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 54px;
      height: 54px;
      border-radius: 50% !important;
      background: rgba(255,255,255,.14) !important;
      color: #fff !important;
      font-size: 18px !important;
      border: 1px solid rgba(255,255,255,.18) !important;
      display: flex !important;
      align-items: center;
      justify-content: center;
      transition: .25s ease;
    }
    .owl-nav button.owl-prev:hover,
    .owl-nav button.owl-next:hover {
      background: rgba(200,169,107,.9) !important;
      color: #111 !important;
    }
    .owl-nav button.owl-prev { left: 24px; }
    .owl-nav button.owl-next { right: 24px; }
    .owl-dots {
      position: absolute;
      left: 50%;
      bottom: 14px;
      transform: translateX(-50%);
    }
    .owl-theme .owl-dots .owl-dot span { background: rgba(255,255,255,.36); }
    .owl-theme .owl-dots .owl-dot.active span { background: var(--primary); width: 28px; }

    .floating-contact {
      position: fixed;
      right: 18px;
      bottom: 18px;
      z-index: 1080;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }
    .floating-contact a {
      width: 56px;
      height: 56px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      box-shadow: var(--shadow);
      font-size: 19px;
      border: 1px solid rgba(255,255,255,.10);
      transition: transform .22s ease, box-shadow .22s ease, opacity .22s ease;
    }
    .floating-contact a:hover {
      transform: translateY(-3px);
      color: #fff;
    }
    .floating-contact .phone { background: linear-gradient(135deg, #c8a96b, #ebcf9a); color: #111; }
    .floating-contact .zalo { background: linear-gradient(135deg, #1564ff, #41b0ff); }
    .floating-contact .mess { background: linear-gradient(135deg, #7657ff, #02a7ff); }
    .floating-contact .mail { background: linear-gradient(135deg, #0f766e, #14b8a6); }
    .floating-contact .support { background: linear-gradient(135deg, #f97316, #fb7185); }
    .floating-contact .back-to-top {
      background: linear-gradient(135deg, #1f2937, #475569);
      opacity: 0;
      pointer-events: none;
      transform: translateY(10px);
    }
    .floating-contact .back-to-top.is-visible {
      opacity: 1;
      pointer-events: auto;
      transform: translateY(0);
    }

    .stats-wrap {
      margin-top: -10px;
      position: relative;
      z-index: 30;
      padding: 40px 0 48px;
      background: linear-gradient(180deg, #0a0d12 0%, #0d1117 45%, rgba(12, 15, 20, 0.96) 100%);
      border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    }
    .stats-grid {
      justify-content: center;
    }
    .stats-grid > .stats-item {
      display: flex;
    }
    .stat-card,
    .glass-card {
      background: linear-gradient(180deg, rgba(23,28,37,.96) 0%, rgba(17,22,29,.96) 100%);
      border: 1px solid rgba(255,255,255,.08);
      border-radius: 24px;
      box-shadow: var(--shadow);
    }
    .stat-card {
      padding: 28px;
      height: 100%;
      width: 100%;
      text-align: center;
    }
    .stat-card .icon,
    .feature-card .icon,
    .mini-icon {
      width: 58px;
      height: 58px;
      border-radius: 18px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: rgba(200,169,107,.12);
      color: var(--primary);
      font-size: 22px;
      margin-bottom: 18px;
    }
    .stat-card h3 {
      font-size: clamp(1.65rem, 3vw, 2.15rem);
      color: #fff;
      font-weight: 800;
      margin-bottom: 4px;
      letter-spacing: -0.02em;
    }
    .stat-card p {
      margin: 0;
      color: var(--muted);
    }

    .section-heading {
      margin-bottom: 46px;
    }
    .section-heading .sub {
      display: inline-block;
      color: var(--primary);
      text-transform: uppercase;
      letter-spacing: .16em;
      font-size: .82rem;
      font-weight: 800;
      margin-bottom: 12px;
    }
    .section-heading h2 {
      color: #fff;
      font-size: clamp(2rem, 4vw, 3.2rem);
      line-height: 1.15;
      font-weight: 800;
      margin-bottom: 14px;
    }
    .section-heading p {
      color: var(--muted);
      max-width: 760px;
      margin: 0 auto;
    }
    .section-heading.text-start p { margin: 0; }

    .glass-card {
      padding: 28px;
      /* height: 100%; */
      transition: .25s ease;
    }
    .glass-card.inventory-card {
      padding: 20px 22px;
    }
    .glass-card:hover {
      transform: translateY(-6px);
      border-color: rgba(200,169,107,.22);
    }

    .project-info-list { display: grid; gap: 16px; }
    .project-info-item {
      display: flex;
      gap: 15px;
      padding: 18px;
      border-radius: 20px;
      background: rgba(255,255,255,.03);
      border: 1px solid rgba(255,255,255,.06);
    }
    .project-info-item .ic {
      width: 46px;
      height: 46px;
      border-radius: 14px;
      background: rgba(200,169,107,.12);
      color: var(--primary);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .project-info-item strong {
      display: block;
      color: #fff;
      margin-bottom: 3px;
    }

    .project-visual {
      position: relative;
      border-radius: 30px;
      overflow: hidden;
      min-height: 560px;
      border: 1px solid rgba(255,255,255,.08);
      background: url('../images/official/hero-main.jpg') center/cover no-repeat;
    }
    .project-visual::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.70) 100%);
    }
    .project-float-box {
      position: absolute;
      left: 24px;
      right: 24px;
      bottom: 24px;
      z-index: 2;
      background: rgba(12,16,24,.94);
      border: 1px solid rgba(255,255,255,.10);
      border-radius: 24px;
      padding: 24px;
      backdrop-filter: blur(16px);
    }
    .project-float-box p {
      color: rgba(235,241,248,.88) !important;
    }

    /* Tổng quan: cân 2 cột — ảnh kéo cao theo cột trái; 4 thẻ info dạng lưới 2×2 (≥lg) */
    #tong-quan .project-info-list--grid {
      grid-template-columns: 1fr;
    }
    @media (min-width: 992px) {
      #tong-quan .project-info-list--grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px 16px;
      }
      #tong-quan .project-info-item {
        padding: 16px 14px;
        height: 100%;
      }
      #tong-quan .project-info-item strong {
        font-size: 0.95rem;
        line-height: 1.35;
      }
      #tong-quan .project-info-item span {
        font-size: 0.88rem;
        line-height: 1.45;
      }
    }
    #tong-quan .project-visual.project-visual--stretch {
      min-height: 320px;
      height: 100%;
      flex: 1 1 auto;
      align-self: stretch;
    }
    @media (min-width: 992px) {
      #tong-quan .project-visual.project-visual--stretch {
        min-height: 0;
      }
    }

    .tong-quan-deck {
      color: var(--muted);
      max-width: 760px;
      margin: 0;
      line-height: 1.65;
    }
    .tong-quan-intro-stack .tong-quan-intro {
      color: var(--text);
      margin: 0 0 1rem;
      line-height: 1.75;
    }
    .tong-quan-intro-stack .tong-quan-intro:last-child {
      margin-bottom: 0;
    }
    .tong-quan-spec-list {
      display: flex;
      flex-direction: column;
      gap: 0;
      border-radius: var(--radius-md);
      border: 1px solid rgba(255, 255, 255, 0.08);
      background: rgba(255, 255, 255, 0.02);
      overflow: hidden;
    }
    .tong-quan-spec-row {
      display: grid;
      grid-template-columns: 1fr;
      gap: 6px 16px;
      padding: 14px 16px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    }
    .tong-quan-spec-row:last-child {
      border-bottom: 0;
    }
    @media (min-width: 576px) {
      .tong-quan-spec-row {
        grid-template-columns: minmax(140px, 38%) 1fr;
        align-items: start;
      }
    }
    .tong-quan-spec-label {
      font-size: 0.78rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--primary);
      line-height: 1.4;
    }
    .tong-quan-spec-value {
      color: rgba(235, 241, 248, 0.92);
      font-size: 0.95rem;
      line-height: 1.55;
    }
    .project-float-box__p:last-of-type {
      margin-bottom: 0 !important;
    }

    .product-card {
      overflow: hidden;
      padding: 0;
    }
    .product-thumb {
      height: 260px;
      overflow: hidden;
      position: relative;
    }
    .product-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: .5s ease;
    }
    .product-card:hover .product-thumb img { transform: scale(1.08); }
    .product-thumb .tag,
    .status-badge {
      position: absolute;
      left: 18px;
      top: 18px;
      background: rgba(15,17,21,.84);
      color: #fff;
      padding: 8px 14px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,.10);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .02em;
    }
    .product-body { padding: 24px; }
    .product-body h4,
    .inventory-card h5,
    .feature-card h5,
    .testimonial h6,
    .price-card h4,
    .news-card h5 {
      color: #fff;
      font-weight: 700;
    }
    .product-meta,
    .inventory-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin: 14px 0 18px;
    }
    .product-meta,
    .inventory-meta {
      flex-wrap: nowrap;
      overflow-x: auto;
      overflow-y: hidden;
      padding-bottom: 6px;
      scrollbar-width: thin;
      scrollbar-color: rgba(200,169,107,.55) rgba(255,255,255,.06);
    }
    .product-meta::-webkit-scrollbar,
    .inventory-meta::-webkit-scrollbar {
      height: 5px;
    }
    .product-meta::-webkit-scrollbar-track,
    .inventory-meta::-webkit-scrollbar-track {
      background: rgba(255,255,255,.05);
      border-radius: 999px;
    }
    .product-meta::-webkit-scrollbar-thumb,
    .inventory-meta::-webkit-scrollbar-thumb {
      background: rgba(200,169,107,.55);
      border-radius: 999px;
    }
    .product-meta::-webkit-scrollbar-thumb:hover,
    .inventory-meta::-webkit-scrollbar-thumb:hover {
      background: rgba(200,169,107,.75);
    }
    .product-meta span,
    .inventory-meta span,
    .chip {
      font-size: 13px;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(255,255,255,.05);
      border: 1px solid rgba(255,255,255,.06);
      color: #dbe1ea;
    }
    .product-meta span,
    .inventory-meta span {
      flex: 0 0 auto;
      white-space: nowrap;
    }

    .inventory-toolbar {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      justify-content: center;
      margin-bottom: 28px;
    }
    .inventory-search-wrap {
      max-width: 980px;
      margin: 0 auto 26px;
    }
    .inventory-search-box {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      padding: 18px;
      border-radius: 22px;
      background: linear-gradient(180deg, rgba(22,27,36,.96) 0%, rgba(14,18,24,.98) 100%);
      border: 1px solid rgba(255,255,255,.08);
      box-shadow: var(--shadow);
    }
    .inventory-search-box .form-control,
    .inventory-search-box .form-select {
      min-height: 50px;
    }
    .inventory-filter {
      cursor: pointer;
    }
    .inventory-filter.active {
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
      color: #111;
      border-color: transparent;
      font-weight: 700;
    }

    /* Trang Bảng hàng — một panel gọn, đồng nhất */
    .bang-hang-page.section-padding {
      padding-top: 56px;
      padding-bottom: 64px;
    }
    .bang-hang-page {
      position: relative;
    }
    .bang-hang-panel {
      position: relative;
      /* max-width: 1080px; */
      margin: 0 auto 1.25rem;
      padding: 0.95rem 1.1rem 1rem;
      border-radius: 20px;
      background:
        radial-gradient(ellipse 90% 70% at 50% -25%, rgba(200, 169, 107, 0.1), transparent 52%),
        linear-gradient(165deg, rgba(22, 16, 32, 0.65) 0%, rgba(6, 4, 10, 0.92) 100%);
      border: 1px solid rgba(200, 169, 107, 0.16);
      box-shadow:
        0 22px 52px rgba(0, 0, 0, 0.34),
        inset 0 1px 0 rgba(255, 248, 235, 0.05);
      overflow: hidden;
    }
    .bang-hang-panel::before {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      top: 0;
      height: 2px;
      background: linear-gradient(90deg, transparent, rgba(236, 217, 168, 0.5), transparent);
      pointer-events: none;
    }
    .bang-hang-panel__bar {
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 0.45rem 1rem;
      padding-bottom: 0.6rem;
      margin-bottom: 0.65rem;
      border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    }
    .bang-hang-breadcrumb {
      padding: 0;
      margin: 0 !important;
      border: none;
    }
    .bang-hang-panel__intro {
      text-align: left;
      margin-bottom: 0.75rem;
    }
    .bang-hang-kicker {
      display: block;
      margin-bottom: 0.25rem;
      font-size: 0.68rem;
      font-weight: 700;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--primary-2);
    }
    .bang-hang-title {
      font-size: clamp(1.35rem, 3vw, 1.85rem);
      font-weight: 700;
      line-height: 1.18;
      letter-spacing: 0.03em;
      color: #fffef8;
      margin-bottom: 0.35rem;
      text-shadow: 0 3px 22px rgba(0, 0, 0, 0.32);
    }
    .bang-hang-lead {
      font-size: 0.9rem;
      line-height: 1.5;
      color: rgba(230, 236, 245, 0.86);
      margin-bottom: 0;
      max-width: 42rem;
    }
    .bang-hang-stat {
      display: flex;
      justify-content: flex-end;
      align-items: center;
    }
    .bang-hang-stat__inner {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      padding: 0.35rem 0.85rem;
      border-radius: 999px;
      font-size: 0.82rem;
      color: rgba(245, 240, 232, 0.9);
      background: rgba(0, 0, 0, 0.22);
      border: 1px solid rgba(200, 169, 107, 0.2);
    }
    .bang-hang-stat__inner strong {
      color: var(--primary-2);
      font-weight: 700;
    }
    .bang-hang-stat__ico {
      color: var(--primary);
      opacity: 0.95;
      font-size: 0.88em;
    }
    .bang-hang-panel__filters {
      border-top: 1px solid rgba(200, 169, 107, 0.1);
      padding-top: 0.7rem;
      margin-top: 0.1rem;
    }
    .bang-hang-page .bang-hang-search-wrap.inventory-search-wrap {
      max-width: none;
      margin: 0;
      padding: 0 0 0.5rem !important;
    }
    .bang-hang-page .bang-hang-search-box.inventory-search-box {
      margin: 0;
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      padding: 10px !important;
      border-radius: 14px !important;
      border: 1px solid rgba(200, 169, 107, 0.12);
      background: linear-gradient(180deg, rgba(12, 10, 18, 0.9) 0%, rgba(8, 6, 14, 0.95) 100%);
      box-shadow: inset 0 1px 0 rgba(255, 248, 235, 0.04);
    }
    .bang-hang-page .bang-hang-search-box .bang-hang-field--grow {
      flex: 1 1 220px;
      min-width: 0;
    }
    .bang-hang-page .bang-hang-search-box .bang-hang-field--sm {
      flex: 1 1 130px;
      max-width: 200px;
    }
    .bang-hang-page .bang-hang-search-box .bang-hang-field--btn {
      flex: 0 0 auto;
      min-width: 104px;
    }
    .bang-hang-page .bang-hang-search-box .form-control,
    .bang-hang-page .bang-hang-search-box .form-select {
      min-height: 44px !important;
      font-size: 0.9rem;
    }
    .bang-hang-types-row {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px 12px;
      padding-top: 2px;
    }
    .bang-hang-types-inline-label {
      font-size: 0.62rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(236, 217, 168, 0.85);
      flex-shrink: 0;
    }
    .bang-hang-page .bang-hang-toolbar.inventory-toolbar {
      margin-bottom: 0 !important;
      justify-content: flex-start !important;
      gap: 8px;
      flex: 1;
      min-width: 0;
    }
    .bang-hang-page .bang-hang-toolbar .inventory-filter {
      padding: 0.38rem 0.75rem !important;
      font-size: 0.78rem;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, 0.1);
      transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
    }
    .bang-hang-page .bang-hang-toolbar .inventory-filter:hover {
      border-color: rgba(200, 169, 107, 0.35);
      transform: translateY(-1px);
    }
    @media (min-width: 768px) {
      .bang-hang-panel {
        padding: 1.05rem 1.35rem 1.1rem;
      }
    }
    @media (max-width: 575.98px) {
      .bang-hang-page.section-padding {
        padding-top: 48px;
        padding-bottom: 56px;
      }
      .bang-hang-page .bang-hang-search-wrap.inventory-search-wrap {
        padding: 0 0 0.45rem !important;
      }
      .bang-hang-page .bang-hang-search-box .bang-hang-field--sm {
        max-width: none;
      }
      .bang-hang-page .bang-hang-toolbar.inventory-toolbar {
        justify-content: flex-start;
        overflow-x: auto;
        flex-wrap: nowrap;
        padding-bottom: 6px;
        -webkit-overflow-scrolling: touch;
      }
    }

    .inventory-card {
      position: relative;
      overflow: hidden;
    }
    .inventory-card--thumb {
      padding-top: 0;
    }
    .inventory-card-media {
      position: relative;
      border-radius: 16px 16px 0 0;
      overflow: hidden;
    }
    .inventory-card--thumb .inventory-card-media {
      margin: -20px -22px 14px -22px;
      width: calc(100% + 44px);
      max-width: none;
      border-radius: 20px 20px 0 0;
    }
    .inventory-card-thumb {
      margin: 0;
      border-radius: 0;
      overflow: hidden;
      aspect-ratio: 16 / 9;
      background: rgba(255, 255, 255, 0.04);
    }
    .inventory-card-overlay--top {
      position: absolute;
      top: 10px;
      right: 10px;
      z-index: 3;
      max-width: calc(100% - 20px);
    }
    .inventory-card-overlay--bottom {
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 2;
      padding: 32px 12px 0;
      background: linear-gradient(180deg, transparent 0%, rgba(8, 10, 14, 0.2) 35%, rgba(8, 10, 14, 0.88) 100%);
      pointer-events: none;
    }
    .inventory-meta.inventory-meta--on-image {
      margin: 0 0 10px !important;
      padding: 0 !important;
      flex-wrap: wrap !important;
      overflow: visible !important;
      white-space: normal !important;
      gap: 6px !important;
      pointer-events: auto;
    }
    .inventory-meta.inventory-meta--on-image span {
      font-size: 11px !important;
      padding: 5px 9px !important;
      line-height: 1.25;
      background: rgba(12, 14, 18, 0.78) !important;
      box-shadow: 0 1px 0 rgba(255, 255, 255, 0.06);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      border: 1px solid rgba(255, 255, 255, 0.12) !important;
      color: #e8edf4 !important;
    }
    .inventory-card-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }
    .inventory-card .top-row {
      display: flex;
      justify-content: space-between;
      gap: 10px;
      align-items: flex-start;
      margin-bottom: 8px;
    }
    .inventory-card .top-row h5 {
      font-size: 1.05rem;
      line-height: 1.35;
      margin-bottom: 0.2rem !important;
    }
    .inventory-card .price {
      font-size: 1.3rem;
      font-weight: 800;
      color: #fff;
      margin-bottom: 4px;
      line-height: 1.2;
    }
    .inventory-card .code {
      color: var(--primary);
      font-size: 13px;
      font-weight: 700;
      letter-spacing: .03em;
    }
    .inventory-card > p {
      font-size: 0.9rem;
      line-height: 1.5;
      margin-bottom: 0;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
      overflow: hidden;
    }
    .inventory-card .inventory-meta {
      margin: 10px 0 12px !important;
    }
    .inventory-card .inventory-actions {
      padding-top: 12px;
      margin-top: 12px;
      border-top: 1px solid rgba(255,255,255,.08);
    }
    .status-chip {
      font-size: 12px;
      font-weight: 800;
      padding: 8px 12px;
      border-radius: 999px;
      white-space: nowrap;
      line-height: 1;
      box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
    }
    .status-available {
      background: rgba(35,196,131,.22);
      color: #b8ffe0;
      border: 1px solid rgba(35,196,131,.32);
    }
    .status-hot {
      background: rgba(255,107,107,.22);
      color: #ffd0d0;
      border: 1px solid rgba(255,107,107,.34);
    }
    .status-booking {
      background: rgba(200,169,107,.24);
      color: #fff0c9;
      border: 1px solid rgba(200,169,107,.34);
    }
    .status-sold {
      background: rgba(120,130,145,.22);
      color: #e6e9ef;
      border: 1px solid rgba(120,130,145,.34);
    }

    .feature-card {
      position: relative;
      text-align: center;
      padding: 28px 22px 24px;
      height: 100%;
      overflow: hidden;
      isolation: isolate;
    }
    .feature-card::before {
      content: "";
      position: absolute;
      inset: 18px 22px auto;
      height: 108px;
      border-radius: 999px;
      background: radial-gradient(circle, rgba(200,169,107,.18) 0%, rgba(200,169,107,0) 72%);
      z-index: 0;
    }
    .feature-media,
    .feature-card h5,
    .feature-card p {
      position: relative;
      z-index: 1;
    }
    .feature-media {
      position: relative;
      width: 136px;
      height: 136px;
      margin: 0 auto 20px;
      border-radius: 50%;
      padding: 6px;
      background: linear-gradient(180deg, rgba(200,169,107,.34) 0%, rgba(200,169,107,.10) 100%);
      box-shadow: 0 16px 34px rgba(0,0,0,.22);
    }
    .feature-media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: 50%;
      border: 2px solid rgba(255,255,255,.08);
      transition: transform .35s ease;
    }
    .feature-card:hover .feature-media img {
      transform: scale(1.06);
    }
    .feature-icon {
      position: absolute;
      right: 2px;
      bottom: 6px;
      width: 42px;
      height: 42px;
      border-radius: 50%;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(135deg, rgba(16,22,31,.96), rgba(27,35,48,.94));
      border: 1px solid rgba(200,169,107,.28);
      color: var(--primary-2);
      box-shadow: 0 10px 24px rgba(0,0,0,.22);
      font-size: 16px;
    }
    .feature-card h5 {
      margin-bottom: 10px;
      line-height: 1.3;
    }
    .feature-card p {
      color: var(--muted);
      margin-bottom: 0;
      max-width: 260px;
      margin-left: auto;
      margin-right: auto;
      line-height: 1.7;
    }
    .section-card-carousel .owl-stage {
      display: flex;
      align-items: stretch;
    }
    .section-card-carousel .owl-item {
      height: auto;
    }
    .carousel-card-item {
      height: 100%;
      padding: 2px 0 6px;
    }
    .section-card-carousel .glass-card {
      height: 100%;
      margin: 0;
    }
    .section-card-carousel .owl-dots {
      position: static;
      transform: none;
      left: auto;
      bottom: auto;
      margin-top: 14px;
      text-align: center;
    }
    .section-card-carousel .owl-dots .owl-dot span {
      width: 10px;
      height: 10px;
      margin: 0 5px;
      background: rgba(255,255,255,.20);
      transition: .22s ease;
    }
    .section-card-carousel .owl-dots .owl-dot.active span,
    .section-card-carousel .owl-dots .owl-dot:hover span {
      width: 28px;
      background: var(--primary);
    }

    .gallery-item {
      position: relative;
      border-radius: 24px;
      overflow: hidden;
      height: 320px;
      border: 1px solid rgba(255,255,255,.08);
    }
    .gallery-item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: .45s ease;
    }
    .gallery-item:hover img { transform: scale(1.06); }
    .gallery-item .overlay {
      position: absolute;
      inset: auto 0 0 0;
      padding: 16px 18px;
      background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.78) 100%);
      color: #fff;
      font-weight: 600;
    }
    a.uc-gallery-lightbox {
      display: block;
      text-decoration: none;
      color: inherit;
      cursor: zoom-in;
    }
    a.uc-gallery-lightbox:focus-visible {
      outline: 2px solid var(--primary);
      outline-offset: 3px;
      border-radius: 24px;
    }

    .timeline {
      position: relative;
      padding-left: 26px;
    }
    .timeline::before {
      content: "";
      position: absolute;
      left: 7px;
      top: 0;
      bottom: 0;
      width: 2px;
      background: linear-gradient(180deg, var(--primary), rgba(200,169,107,.06));
    }
    .timeline-item {
      position: relative;
      padding: 0 0 24px 24px;
    }
    .timeline-item::before {
      content: "";
      position: absolute;
      left: -1px;
      top: 7px;
      width: 16px;
      height: 16px;
      border-radius: 50%;
      background: var(--primary);
      box-shadow: 0 0 0 6px rgba(200,169,107,.16);
    }
    .timeline-item h6 {
      color: #fff;
      font-weight: 700;
      margin-bottom: 6px;
    }
    .timeline-item p { margin: 0; color: var(--muted); }

    .price-card .price {
      font-size: 2rem;
      color: #fff;
      font-weight: 800;
      margin: 8px 0 14px;
    }
    .policy-layout > [class*="col-"] {
      display: flex;
      flex-direction: column;
    }
    .policy-intro {
      max-width: 560px;
      margin-bottom: 24px;
    }
    .policy-intro h2 {
      max-width: 560px;
      margin-bottom: 16px;
    }
    .policy-intro p {
      max-width: 520px;
      margin-bottom: 18px;
    }
    .policy-summary {
      display: flex;
      flex-wrap: nowrap;
      gap: 10px;
      margin-top: 6px;
    }
    .policy-summary span {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 9px 14px;
      border-radius: 999px;
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.08);
      color: #dbe2ec;
      font-size: 12.5px;
      font-weight: 600;
      white-space: nowrap;
      flex: 1 1 auto;
      justify-content: center;
    }
    .policy-card,
    .price-card {
      padding: 30px;
      border-radius: 28px;
    }
    .policy-card {
      display: flex;
      flex-direction: column;
      justify-content: center;
    }
    .price-list {
      list-style: none;
      padding: 0;
      margin: 0 0 22px;
    }
    .price-list li {
      display: flex;
      gap: 10px;
      padding: 10px 0;
      border-bottom: 1px dashed rgba(255,255,255,.08);
      color: #dbe1ea;
    }
    .price-list li i { color: var(--primary); margin-top: 4px; }
    .price-card {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }
    .price-card-kicker {
      display: inline-flex;
      align-items: center;
      width: fit-content;
      padding: 8px 12px;
      border-radius: 999px;
      background: rgba(200,169,107,.12);
      border: 1px solid rgba(200,169,107,.18);
    }
    .price-card h4 {
      line-height: 1.2;
      max-width: 420px;
      margin-bottom: 4px;
    }
    .price-card-media {
      position: relative;
      overflow: hidden;
      border-radius: 22px;
      min-height: 180px;
      margin: 2px 0 18px;
      border: 1px solid rgba(255,255,255,.10);
      background: #11161d;
    }
    .price-card-media img {
      width: 100%;
      height: 180px;
      object-fit: cover;
    }
    .price-card-media::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(8,11,16,.06) 0%, rgba(8,11,16,.16) 32%, rgba(8,11,16,.82) 100%);
    }
    .price-card-media-copy {
      position: absolute;
      left: 18px;
      right: 18px;
      bottom: 16px;
      z-index: 2;
      display: flex;
      flex-direction: column;
      gap: 5px;
    }
    .price-card-media-copy strong {
      color: #fff;
      font-size: 1rem;
      line-height: 1.3;
    }
    .price-card-media-copy span {
      color: rgba(244,247,251,.88);
      font-size: 13px;
      line-height: 1.55;
    }
    .policy-actions {
      padding-top: 4px;
      margin-top: auto;
    }

    .policy-card .policy-row {
      display: flex;
      gap: 14px;
      align-items: flex-start;
      padding: 18px 0;
      border-bottom: 1px dashed rgba(255,255,255,.08);
    }
    .policy-card .policy-row:last-child { border-bottom: none; }
    .policy-card .policy-row h5 {
      margin-bottom: 6px !important;
      line-height: 1.3;
    }
    .policy-card .policy-row p {
      line-height: 1.65;
    }

    .detail-card {
      overflow: hidden;
      padding: 0;
    }
    .detail-thumb {
      position: relative;
      height: 320px;
      overflow: hidden;
    }
    .detail-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: .5s ease;
    }
    .detail-card:hover .detail-thumb img { transform: scale(1.06); }
    .detail-body { padding: 28px; }
    .detail-price {
      font-size: 2rem;
      color: #fff;
      font-weight: 800;
      margin: 10px 0 16px;
    }
    .detail-list {
      list-style: none;
      padding: 0;
      margin: 0 0 20px;
    }
    .detail-list li {
      display: flex;
      gap: 10px;
      padding: 10px 0;
      border-bottom: 1px dashed rgba(255,255,255,.08);
      color: #dbe1ea;
    }
    .detail-list li i { color: var(--primary); margin-top: 4px; }

    .progress-card {
      position: relative;
      overflow: hidden;
    }
    .progress-top {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      margin-bottom: 14px;
    }
    .progress-line {
      width: 100%;
      height: 10px;
      border-radius: 999px;
      background: rgba(255,255,255,.08);
      overflow: hidden;
      margin-bottom: 16px;
    }
    .progress-line span {
      display: block;
      height: 100%;
      border-radius: 999px;
      background: linear-gradient(135deg, var(--primary), var(--primary-2));
    }

    .legal-card .legal-item {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      padding: 16px 0;
      border-bottom: 1px dashed rgba(255,255,255,.08);
    }
    .legal-card .legal-item:last-child { border-bottom: none; }

    .footer-cta {
      padding: 26px;
      border-radius: 24px;
      background: linear-gradient(135deg, rgba(200,169,107,.16), rgba(255,255,255,.04));
      border: 1px solid rgba(200,169,107,.18);
      margin-bottom: 28px;
    }

    .testimonial {
      text-align: center;
      padding: 34px 24px;
    }
    .testimonial .avatar {
      width: 82px;
      height: 82px;
      border-radius: 50%;
      overflow: hidden;
      margin: 0 auto 16px;
      border: 3px solid rgba(200,169,107,.22);
    }
    .testimonial .avatar img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .testimonial small {
      color: var(--primary);
      display: block;
      margin-bottom: 12px;
    }
    .testimonial p { color: var(--muted); margin-bottom: 0; }

    .faq .accordion-item {
      background: rgba(255,255,255,.03);
      border: 1px solid rgba(255,255,255,.06);
      border-radius: 18px !important;
      overflow: hidden;
      margin-bottom: 14px;
    }
    .faq .accordion-button {
      background: transparent;
      color: #fff;
      font-weight: 600;
      box-shadow: none !important;
      padding: 20px 22px;
    }
    .faq .accordion-button:not(.collapsed) {
      background: rgba(200,169,107,.08);
      color: #fff;
    }
    .faq .accordion-body { color: var(--muted); padding: 0 22px 20px; }

    .lead-box {
      background: linear-gradient(135deg, rgba(200,169,107,.16), rgba(255,255,255,.04));
      border: 1px solid rgba(200,169,107,.18);
      border-radius: 30px;
      padding: 38px;
      box-shadow: var(--shadow);
    }

    #tin-tuc .section-heading {
      margin-bottom: 32px;
    }
    #tin-tuc .section-heading h2 {
      margin-bottom: 10px;
    }
    #tin-tuc .section-heading p {
      max-width: 640px;
      margin-left: auto;
      margin-right: auto;
    }
    .news-card .news-thumb {
      height: auto;
      aspect-ratio: 16 / 10;
      max-height: 176px;
      overflow: hidden;
      border-radius: 14px;
      margin-bottom: 12px;
    }
    .news-card .news-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: .4s ease;
    }
    .news-card:hover .news-thumb img { transform: scale(1.04); }
    .news-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px 14px;
      font-size: 12px;
      color: var(--muted);
      margin-bottom: 8px;
      line-height: 1.3;
    }
    .news-card {
      padding: 16px 18px;
      border-radius: 20px;
    }
    .news-card h5 {
      font-size: 1.05rem;
      line-height: 1.35;
      margin-bottom: 8px;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
      overflow: hidden;
    }
    .news-card p {
      font-size: 0.9rem;
      line-height: 1.55;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 3;
      overflow: hidden;
    }

    .article-page .breadcrumb,
    .tin-tuc-page .breadcrumb,
    .bang-hang-page .breadcrumb {
      --bs-breadcrumb-divider-color: rgba(255,255,255,.35);
    }
    .article-page .breadcrumb-item a,
    .tin-tuc-page .breadcrumb-item a,
    .bang-hang-page .breadcrumb-item a {
      color: var(--primary);
      text-decoration: none;
    }
    .article-page .breadcrumb-item a:hover,
    .tin-tuc-page .breadcrumb-item a:hover,
    .bang-hang-page .breadcrumb-item a:hover {
      text-decoration: underline;
    }
    .article-page .breadcrumb-item.active,
    .tin-tuc-page .breadcrumb-item.active,
    .bang-hang-page .breadcrumb-item.active {
      color: rgba(255,255,255,.75);
    }

    .article-reading-progress {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      height: 3px;
      z-index: 1090;
      background: linear-gradient(90deg, rgba(200, 169, 107, 0.95), rgba(235, 207, 154, 0.9));
      transform: scaleX(0);
      transform-origin: left center;
      pointer-events: none;
    }
    .article-page-inner {
      /* max-width: 1140px; */
    }
    .article-title {
      font-size: clamp(1.35rem, 2.5vw, 2rem);
      line-height: 1.3;
      letter-spacing: -0.02em;
    }
    .article-cat-badge {
      background: rgba(200, 169, 107, 0.14);
      border: 1px solid rgba(200, 169, 107, 0.35);
      color: var(--primary-2);
      font-weight: 600;
      font-size: 0.8rem;
      padding: 0.35rem 0.75rem;
    }
    .article-cat-badge:hover {
      background: rgba(200, 169, 107, 0.22);
      color: #f0e6d4;
    }
    .article-meta-bar time,
    .article-meta-bar span {
      color: rgba(203, 212, 222, 0.92);
    }
    .article-share-label {
      display: inline-block;
      vertical-align: middle;
    }
    .article-lead {
      font-size: 1.12rem;
      line-height: 1.65;
      font-weight: 500;
      padding: 1rem 1.1rem;
      border-radius: 14px;
      background: rgba(255, 255, 255, 0.04);
      border: 1px solid rgba(255, 255, 255, 0.07);
      border-left: 3px solid rgba(200, 169, 107, 0.65);
    }
    .article-hero {
      border-radius: 18px;
    }
    .article-hero-thumb {
      position: relative;
      aspect-ratio: 16 / 9;
      background: rgba(0, 0, 0, 0.25);
    }
    .article-hero-thumb img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .article-sidebar {
      top: 92px;
    }
    .article-sidebar-card {
      border-radius: 18px;
      padding: 18px 18px 16px;
    }
    .article-sidebar-card-h {
      font-size: 0.95rem;
      font-weight: 700;
      color: #fff;
      margin-bottom: 12px;
      padding-bottom: 10px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }
    .article-sidebar-item + .article-sidebar-item {
      margin-top: 12px;
      padding-top: 12px;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
    }
    .article-sidebar-thumb {
      width: 72px;
      height: 48px;
      background: rgba(0, 0, 0, 0.2);
    }
    .article-sidebar-item-title {
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 2;
      overflow: hidden;
      line-height: 1.35;
    }
    .article-sidebar-list a:hover .article-sidebar-item-title {
      color: var(--primary-2) !important;
    }
    .article-toc-list {
      color: rgba(203, 212, 222, 0.95);
    }
    .article-toc-list a {
      color: rgba(203, 212, 222, 0.95);
      text-decoration: none;
    }
    .article-toc-list a:hover {
      color: var(--primary-2);
      text-decoration: underline;
    }
    .article-related-card {
      background: rgba(255, 255, 255, 0.03);
      border: 1px solid rgba(255, 255, 255, 0.06);
      transition: background 0.2s ease, border-color 0.2s ease;
    }
    .article-related-card:hover {
      background: rgba(255, 255, 255, 0.06);
      border-color: rgba(200, 169, 107, 0.25);
    }
    .article-related-card:hover .article-related-title {
      color: var(--primary-2) !important;
    }
    .article-related-thumb {
      width: 112px;
      height: 72px;
      background: rgba(0, 0, 0, 0.2);
    }
    .article-related-thumb img {
      object-fit: cover;
    }
    .uc-icon-zalo--btn {
      width: 14px;
      height: 14px;
      vertical-align: -0.2em;
      flex-shrink: 0;
    }
    .uc-icon-zalo--btn path {
      fill: currentColor;
    }

    .tin-tuc-header .sub {
      display: inline-block;
      color: var(--primary);
      text-transform: uppercase;
      letter-spacing: 0.16em;
      font-size: 0.82rem;
      font-weight: 800;
    }
    .tin-tuc-page .tin-tuc-lead {
      max-width: 42rem;
      font-size: 1.05rem;
    }
    .ratio-tin-tuc-thumb {
      --bs-aspect-ratio: 62.5%;
    }
    .tin-tuc-page .tin-tuc-card {
      background: linear-gradient(180deg, rgba(23, 28, 37, 0.96) 0%, rgba(17, 22, 29, 0.96) 100%);
      border: 1px solid rgba(255, 255, 255, 0.08) !important;
      border-radius: 1.25rem;
      transition: transform 0.22s ease, box-shadow 0.22s ease;
    }
    .tin-tuc-page .tin-tuc-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 24px 48px rgba(0, 0, 0, 0.28) !important;
    }
    .tin-tuc-card-thumb {
      background: rgba(0, 0, 0, 0.25);
      border-radius: 1.25rem 1.25rem 0 0;
      overflow: hidden;
    }
    .tin-tuc-card-thumb img {
      object-fit: cover;
      transition: transform 0.35s ease;
    }
    .tin-tuc-card:hover .tin-tuc-card-thumb img {
      transform: scale(1.04);
    }
    .tin-tuc-card-title-link:hover {
      color: var(--primary-2) !important;
    }
    .tin-tuc-card-excerpt {
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 3;
      overflow: hidden;
    }
    .tin-tuc-page .tin-tuc-empty {
      --bs-alert-bg: rgba(255, 255, 255, 0.06);
      --bs-alert-border-color: rgba(255, 255, 255, 0.12);
      --bs-alert-color: rgba(203, 212, 222, 0.95);
      border-radius: 1rem;
    }

    .uc-article-prose {
      font-size: 1.05rem;
      line-height: 1.75;
    }
    .uc-article-prose p { margin-bottom: 1rem; }
    .uc-article-prose h2, .uc-article-prose h3, .uc-article-prose h4 {
      color: #fff;
      margin-top: 1.5rem;
      margin-bottom: 0.75rem;
      font-weight: 700;
      scroll-margin-top: 96px;
    }
    .uc-article-prose img {
      max-width: 100%;
      height: auto;
      border-radius: 16px;
      margin: 0.5rem 0 1rem;
    }
    .uc-article-prose ul, .uc-article-prose ol {
      padding-left: 1.25rem;
      margin-bottom: 1rem;
    }
    .uc-article-prose a {
      color: var(--primary);
    }

    /*
     * Chế độ tối (mặc định): HTML copy từ WP hay có inline color (#333, rgb…) trên p/span/div
     * khiến chữ gần như trùng nền — ghi đè bằng màu theme. Chế độ sáng giữ nguyên (data-theme="light").
     */
    body:not([data-theme="light"]) .article-page .uc-article-prose {
      color: var(--text);
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose p,
    body:not([data-theme="light"]) .article-page .uc-article-prose li,
    body:not([data-theme="light"]) .article-page .uc-article-prose td,
    body:not([data-theme="light"]) .article-page .uc-article-prose th,
    body:not([data-theme="light"]) .article-page .uc-article-prose blockquote {
      color: var(--text) !important;
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose h2,
    body:not([data-theme="light"]) .article-page .uc-article-prose h3,
    body:not([data-theme="light"]) .article-page .uc-article-prose h4,
    body:not([data-theme="light"]) .article-page .uc-article-prose h5,
    body:not([data-theme="light"]) .article-page .uc-article-prose h6 {
      color: #fff !important;
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose figcaption,
    body:not([data-theme="light"]) .article-page .uc-article-prose .wp-element-caption {
      color: var(--muted) !important;
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose a {
      color: var(--primary) !important;
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose a:hover {
      color: var(--primary-2) !important;
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose a span {
      color: inherit !important;
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose div[style*="color"],
    body:not([data-theme="light"]) .article-page .uc-article-prose span[style*="color"] {
      color: var(--text) !important;
    }
    body:not([data-theme="light"]) .article-page .uc-article-prose a span[style*="color"] {
      color: inherit !important;
    }

    .footer {
      padding: 40px 0 52px;
      border-top: 1px solid rgba(255,255,255,.08);
      background: #0a0d12;
      color: #a9b0bc;
    }
    .footer-title {
      color: #fff;
      font-weight: 700;
      margin-bottom: 14px;
    }
    .footer ul {
      list-style: none;
      padding: 0;
      margin: 0;
    }
    .footer ul li { margin-bottom: 10px; }
    .footer ul.footer-link-list a {
      display: inline-flex;
      align-items: center;
    }
    .footer ul.footer-link-list a i {
      flex-shrink: 0;
      width: 1.1em;
      text-align: center;
    }
    .footer a { color: #c7d0dc; }
    .footer a:hover { color: var(--primary-2); }
    /* Footer / CTA: nút vàng cần chữ tối — .footer a không được phủ màu link lên nền vàng */
    .footer a.btn.btn-gold,
    .footer-cta a.btn.btn-gold,
    .sticky-mobile-cta a.btn.btn-gold {
      color: #141210 !important;
    }
    .footer a.btn.btn-gold:hover,
    .footer-cta a.btn.btn-gold:hover,
    .sticky-mobile-cta a.btn.btn-gold:hover {
      color: #0a0908 !important;
    }

    .sticky-mobile-cta {
      position: fixed;
      left: 0;
      right: 0;
      bottom: 0;
      z-index: 1060;
      display: none;
      background: rgba(12,15,20,.95);
      border-top: 1px solid rgba(255,255,255,.08);
      padding: 10px 14px;
      backdrop-filter: blur(12px);
    }
    body[data-theme="light"] {
      background: var(--dark);
      color: var(--text);
    }
    body[data-theme="light"] .topbar {
      background: rgba(255,255,255,.92);
      color: #475569;
      border-bottom: 1px solid rgba(15,23,42,.08);
    }
    body[data-theme="light"] .navbar {
      background: rgba(255,255,255,.90);
      border-bottom: 1px solid rgba(15,23,42,.08);
      box-shadow: 0 10px 30px rgba(15,23,42,.06);
    }
    body[data-theme="light"] .navbar-brand {
      background: transparent;
      border: 0;
      box-shadow: none;
    }
    body[data-theme="light"] .navbar .nav-link {
      color: #243041;
    }
    body[data-theme="light"] .navbar .nav-link:hover,
    body[data-theme="light"] .navbar .nav-link.active {
      color: #8b6a2d;
      background: transparent;
      box-shadow: none;
    }
    body[data-theme="light"] .navbar .nav-link:not(.dropdown-toggle)::after {
      background: rgba(200,169,107,.92);
    }
    body[data-theme="light"] .nav-compact {
      background: transparent;
      box-shadow: none;
    }
    body[data-theme="light"] .btn-outline-light-custom,
    body[data-theme="light"] .theme-toggle {
      border-color: rgba(15,23,42,.10);
      background: transparent;
      color: #1f2c3a;
    }
    body[data-theme="light"] .btn-outline-light-custom:hover,
    body[data-theme="light"] .theme-toggle:hover {
      background: rgba(200,169,107,.10);
      color: #8b6a2d;
    }
    body[data-theme="light"] .section-dark,
    body[data-theme="light"] .section-soft,
    body[data-theme="light"] .footer {
      background: linear-gradient(180deg, #ffffff 0%, #f5f7fb 100%);
    }
    body[data-theme="light"] .stats-wrap {
      background: linear-gradient(180deg, #eef2f7 0%, #e2e8f0 55%, #f0f4f8 100%);
      border-bottom-color: rgba(15, 23, 42, 0.08);
    }
    body[data-theme="light"] .tong-quan-deck,
    body[data-theme="light"] .tong-quan-intro {
      color: #4f5f72 !important;
    }
    body[data-theme="light"] .tong-quan-spec-list {
      background: rgba(255, 255, 255, 0.82);
      border-color: rgba(15, 23, 42, 0.1);
    }
    body[data-theme="light"] .tong-quan-spec-row {
      border-bottom-color: rgba(15, 23, 42, 0.08);
    }
    body[data-theme="light"] .tong-quan-spec-value {
      color: #334155 !important;
    }
    body[data-theme="light"] .topbar .item,
    body[data-theme="light"] .topbar .item a.topbar-contact-link,
    body[data-theme="light"] p,
    body[data-theme="light"] .section-heading p,
    body[data-theme="light"] .project-info-item span,
    body[data-theme="light"] .feature-card p,
    body[data-theme="light"] .timeline-item p,
    body[data-theme="light"] .policy-card .policy-row p,
    body[data-theme="light"] .legal-card .legal-item p,
    body[data-theme="light"] .testimonial p,
    body[data-theme="light"] .faq .accordion-body,
    body[data-theme="light"] .footer,
    body[data-theme="light"] .hero-form p,
    body[data-theme="light"] .hero-mini-contact,
    body[data-theme="light"] .news-meta,
    body[data-theme="light"] .news-card p,
    body[data-theme="light"] .stat-card p,
    body[data-theme="light"] .product-body p,
    body[data-theme="light"] .inventory-card p {
      color: #4f5f72 !important;
    }
    body[data-theme="light"] .text-white,
    body[data-theme="light"] h1,
    body[data-theme="light"] h2,
    body[data-theme="light"] h3,
    body[data-theme="light"] h4,
    body[data-theme="light"] h5,
    body[data-theme="light"] h6,
    body[data-theme="light"] .footer-title,
    body[data-theme="light"] .mega-menu .mega-title,
    body[data-theme="light"] .hero-form h5,
    body[data-theme="light"] .project-info-item strong,
    body[data-theme="light"] .timeline-item h6,
    body[data-theme="light"] .price-card .price,
    body[data-theme="light"] .detail-price,
    body[data-theme="light"] .inventory-card .price,
    body[data-theme="light"] .stat-card h3,
    body[data-theme="light"] .article-page .article-title,
    body[data-theme="light"] .article-page .article-sidebar-card-h,
    body[data-theme="light"] .article-page .article-related-title,
    body[data-theme="light"] .article-page .article-sidebar-item-title,
    body[data-theme="light"] .uc-article-prose h2,
    body[data-theme="light"] .uc-article-prose h3,
    body[data-theme="light"] .uc-article-prose h4 {
      color: #16212f !important;
    }
    body[data-theme="light"] .article-page .article-lead {
      background: rgba(15, 23, 42, 0.04);
      border-color: rgba(15, 23, 42, 0.08);
      color: #4f5f72 !important;
    }
    body[data-theme="light"] .article-page .article-related-card {
      background: rgba(255, 255, 255, 0.65);
      border-color: rgba(15, 23, 42, 0.08);
    }
    body[data-theme="light"] .article-page .article-toc-list,
    body[data-theme="light"] .article-page .article-toc-list a {
      color: #4f5f72 !important;
    }
    body[data-theme="light"] .article-reading-progress {
      background: linear-gradient(90deg, #c8a96b, #e0c989);
    }
    body[data-theme="light"] .tin-tuc-page .tin-tuc-header h1,
    body[data-theme="light"] .tin-tuc-page .tin-tuc-header .display-6 {
      color: #16212f !important;
    }
    body[data-theme="light"] .tin-tuc-page .tin-tuc-empty {
      --bs-alert-bg: rgba(15, 23, 42, 0.06);
      --bs-alert-border-color: rgba(15, 23, 42, 0.12);
      --bs-alert-color: #4f5f72;
    }
    body[data-theme="light"] .tin-tuc-page .tin-tuc-card .card-title,
    body[data-theme="light"] .tin-tuc-page .tin-tuc-card .tin-tuc-card-title-link {
      color: #16212f !important;
    }
    body[data-theme="light"] .tin-tuc-page .tin-tuc-card .card-text {
      color: #4f5f72 !important;
    }
    body[data-theme="light"] .tin-tuc-page .tin-tuc-lead {
      color: #4f5f72 !important;
    }
    body[data-theme="light"] .bang-hang-panel {
      background: linear-gradient(165deg, rgba(255, 252, 248, 0.98) 0%, rgba(245, 238, 228, 0.96) 100%);
      border-color: rgba(139, 105, 40, 0.14);
      box-shadow: 0 18px 44px rgba(90, 70, 40, 0.08);
    }
    body[data-theme="light"] .bang-hang-panel::before {
      opacity: 0.85;
    }
    body[data-theme="light"] .bang-hang-panel__bar {
      border-bottom-color: rgba(15, 23, 42, 0.08);
    }
    body[data-theme="light"] .bang-hang-page .breadcrumb-item a {
      color: #9a7328 !important;
    }
    body[data-theme="light"] .bang-hang-page .breadcrumb-item.active {
      color: #64748b !important;
    }
    body[data-theme="light"] .bang-hang-title {
      color: #16212f !important;
      text-shadow: none;
    }
    body[data-theme="light"] .bang-hang-lead {
      color: #4f5f72 !important;
    }
    body[data-theme="light"] .bang-hang-stat__inner {
      background: rgba(255, 255, 255, 0.88);
      border-color: rgba(139, 105, 40, 0.2);
      color: #334155;
    }
    body[data-theme="light"] .bang-hang-stat__inner strong {
      color: #8b6918;
    }
    body[data-theme="light"] .bang-hang-controls {
      background: rgba(255, 255, 255, 0.94);
      border-color: rgba(15, 23, 42, 0.08);
      box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06);
    }
    body[data-theme="light"] .bang-hang-controls__head {
      background: rgba(248, 243, 235, 0.75);
      border-bottom-color: rgba(139, 105, 40, 0.12);
    }
    body[data-theme="light"] .bang-hang-controls__hint {
      color: #64748b;
    }
    body[data-theme="light"] .bang-hang-types {
      background: rgba(250, 247, 242, 0.65);
      border-top-color: rgba(15, 23, 42, 0.06);
    }
    body[data-theme="light"] .bang-hang-types__label {
      color: rgba(107, 78, 24, 0.85);
    }
    body[data-theme="light"] .bang-hang-page .bang-hang-search-box.inventory-search-box {
      background: rgba(255, 255, 255, 0.97);
      border-color: rgba(15, 23, 42, 0.1);
      box-shadow: none;
    }
    body[data-theme="light"] .bang-hang-page .bang-hang-toolbar .inventory-filter {
      border-color: rgba(15, 23, 42, 0.1);
      color: #334155;
    }
    body[data-theme="light"] .bang-hang-page .bang-hang-toolbar .inventory-filter.active {
      color: #141210;
    }
    body[data-theme="light"] .news-card h5,
    body[data-theme="light"] .testimonial h6,
    body[data-theme="light"] .product-body h4,
    body[data-theme="light"] .detail-body h3,
    body[data-theme="light"] .hero .lead {
      color: #16212f !important;
    }
    body[data-theme="light"] .tin-tuc-page .tin-tuc-card,
    body[data-theme="light"] .stat-card,
    body[data-theme="light"] .glass-card,
    body[data-theme="light"] .inventory-search-box,
    body[data-theme="light"] .project-info-item,
    body[data-theme="light"] .mega-menu,
    body[data-theme="light"] .project-float-box,
    body[data-theme="light"] .footer-cta,
    body[data-theme="light"] .lead-box,
    body[data-theme="light"] .faq .accordion-item,
    body[data-theme="light"] #priceModal .modal-content {
      background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(242,246,251,.98) 100%) !important;
      border-color: rgba(15,23,42,.10) !important;
      box-shadow: 0 24px 60px rgba(15,23,42,.10);
    }
    body[data-theme="light"] #priceModal .price-modal-visual-overlay {
      background: linear-gradient(180deg, rgba(7,12,20,.10) 0%, rgba(7,12,20,.26) 38%, rgba(7,12,20,.80) 100%) !important;
    }
    body[data-theme="light"] #priceModal .price-modal-visual-copy .chip {
      background: rgba(255,255,255,.18);
      border-color: rgba(255,255,255,.24);
      color: #fff4d8;
    }
    body[data-theme="light"] #priceModal .price-modal-visual-copy h4,
    body[data-theme="light"] #priceModal .price-modal-visual-copy .text-white {
      color: #ffffff !important;
    }
    body[data-theme="light"] #priceModal .price-modal-visual-copy p,
    body[data-theme="light"] #priceModal .price-modal-visual-copy .text-light {
      color: rgba(247,249,252,.96) !important;
    }
    body[data-theme="light"] #priceModal .price-modal-form-pane {
      background: rgba(255,255,255,.98);
    }
    body[data-theme="light"] #priceModal .price-modal-head h3,
    body[data-theme="light"] #priceModal .price-modal-head .text-white {
      color: #16212f !important;
    }
    body[data-theme="light"] #priceModal .price-modal-head p,
    body[data-theme="light"] #priceModal .price-modal-head .text-light-emphasis {
      color: #4b5e72 !important;
    }
    body[data-theme="light"] #priceModal .btn-close {
      filter: none;
    }
    body[data-theme="light"] .inventory-meta.inventory-meta--on-image span {
      background: rgba(255, 255, 255, 0.92) !important;
      color: #2f4154 !important;
      border-color: rgba(15, 23, 42, 0.1) !important;
      box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    }
    body[data-theme="light"] .product-meta span,
    body[data-theme="light"] .inventory-meta span,
    body[data-theme="light"] .chip,
    body[data-theme="light"] .status-badge {
      background: rgba(15,23,42,.05);
      border-color: rgba(15,23,42,.08);
      color: #2f4154;
    }
    body[data-theme="light"] .status-chip {
      box-shadow: 0 6px 16px rgba(15,23,42,.08);
    }
    body[data-theme="light"] .status-available {
      background: rgba(35,196,131,.16);
      color: #0d7a52;
      border-color: rgba(35,196,131,.30);
    }
    body[data-theme="light"] .status-hot {
      background: rgba(255,107,107,.16);
      color: #b93333;
      border-color: rgba(255,107,107,.28);
    }
    body[data-theme="light"] .status-booking {
      background: rgba(200,169,107,.22);
      color: #8a6420;
      border-color: rgba(200,169,107,.32);
    }
    body[data-theme="light"] .status-sold {
      background: rgba(100,116,139,.14);
      color: #475569;
      border-color: rgba(100,116,139,.28);
    }
    body[data-theme="light"] .policy-summary span {
      background: rgba(15,23,42,.04);
      border-color: rgba(15,23,42,.08);
      color: #33475b;
    }
    body[data-theme="light"] .feature-card::before {
      background: radial-gradient(circle, rgba(200,169,107,.18) 0%, rgba(200,169,107,0) 72%);
    }
    body[data-theme="light"] .feature-media {
      background: linear-gradient(180deg, rgba(200,169,107,.30) 0%, rgba(200,169,107,.12) 100%);
      box-shadow: 0 16px 30px rgba(15,23,42,.08);
    }
    body[data-theme="light"] .feature-media img {
      border-color: rgba(255,255,255,.75);
    }
    body[data-theme="light"] .feature-icon {
      background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(242,246,251,.96));
      border-color: rgba(200,169,107,.26);
      color: #9d742c;
      box-shadow: 0 12px 24px rgba(15,23,42,.10);
    }
    body[data-theme="light"] .price-card-kicker {
      background: rgba(200,169,107,.18);
      border-color: rgba(200,169,107,.26);
      color: #8b6a2d !important;
    }
    body[data-theme="light"] .price-card-media {
      border-color: rgba(15,23,42,.10);
      box-shadow: 0 16px 32px rgba(15,23,42,.06);
    }
    body[data-theme="light"] .price-card-media::after {
      background: linear-gradient(180deg, rgba(255,255,255,.03) 0%, rgba(255,255,255,.08) 34%, rgba(15,23,42,.72) 100%);
    }
    body[data-theme="light"] .section-card-carousel .owl-dots .owl-dot span {
      background: rgba(15,23,42,.14);
    }
    body[data-theme="light"] .detail-list li,
    body[data-theme="light"] .price-list li {
      color: #495a6d;
      border-bottom-color: rgba(15,23,42,.10);
    }
    body[data-theme="light"] .detail-list li i,
    body[data-theme="light"] .price-list li i {
      color: #c49a49;
    }
    body[data-theme="light"] .form-control,
    body[data-theme="light"] .form-select {
      background: rgba(255,255,255,.94);
      border-color: rgba(15,23,42,.16);
      color: #16212f;
    }
    body[data-theme="light"] .form-control::placeholder {
      color: #66758a;
    }
    body[data-theme="light"] .form-control:focus,
    body[data-theme="light"] .form-select:focus {
      background: #ffffff;
      color: #16212f;
    }
    body[data-theme="light"] .hero-form {
      background: linear-gradient(180deg, rgba(255,255,255,.84) 0%, rgba(255,255,255,.92) 100%) !important;
      border: 1px solid rgba(15,23,42,.12) !important;
      box-shadow: 0 22px 52px rgba(15,23,42,.12) !important;
    }
    body[data-theme="light"] .hero-content {
      background: transparent;
      border: 0;
      box-shadow: none;
      backdrop-filter: none;
    }
    body[data-theme="light"] .hero-slide::before {
      background: linear-gradient(90deg, rgba(255,255,255,.72) 0%, rgba(255,255,255,.44) 42%, rgba(255,255,255,.18) 100%);
    }
    body[data-theme="light"] .hero-slide::after {
      background: linear-gradient(180deg, rgba(255,255,255,.02) 0%, rgba(255,255,255,.10) 65%, rgba(255,255,255,.18) 100%);
    }
    body[data-theme="light"] .hero-badge {
      background: rgba(255,255,255,.36);
      color: #7a5a1d;
      box-shadow: 0 10px 24px rgba(15,23,42,.07);
    }
    body[data-theme="light"] .hero .lead,
    body[data-theme="light"] .hero-trust,
    body[data-theme="light"] .hero-highlights .item,
    body[data-theme="light"] .hero-highlights strong {
      color: #16212f;
    }
    body[data-theme="light"] .hero h1,
    body[data-theme="light"] .hero h2.hero-heading {
      text-shadow: 0 4px 18px rgba(255,255,255,.45);
    }
    body[data-theme="light"] .hero .lead {
      color: #31475a !important;
      font-weight: 500;
      text-shadow: none;
    }
    body[data-theme="light"] .hero-highlights .item {
      background: linear-gradient(180deg, rgba(255,255,255,.72) 0%, rgba(255,255,255,.48) 100%);
      border: 0;
      backdrop-filter: blur(8px);
      box-shadow: 0 14px 28px rgba(15,23,42,.06);
    }
    body[data-theme="light"] .hero-highlights .item::after {
      display: none;
    }
    body[data-theme="light"] .hero-form p,
    body[data-theme="light"] .hero-mini-contact,
    body[data-theme="light"] .text-light-emphasis {
      color: #485a6d !important;
    }
    body[data-theme="light"] .text-light {
      color: #44576a !important;
    }
    body[data-theme="light"] .project-float-box p {
      color: #48596c !important;
    }
    body[data-theme="light"] .hero-trust,
    body[data-theme="light"] .hero-highlights span {
      color: #314356 !important;
    }
    body[data-theme="light"] .hero-trust .trust-item {
      padding: 10px 16px;
      border-radius: 999px;
      background: rgba(255,255,255,.68);
      border: 0;
      box-shadow: 0 10px 22px rgba(15,23,42,.05);
    }
    body[data-theme="light"] .hero-badge i,
    body[data-theme="light"] .hero-trust .trust-item i {
      background: rgba(200,169,107,.18);
    }
    body[data-theme="light"] .brand-logo {
      filter: brightness(1.02) saturate(1.06) contrast(1.04) drop-shadow(0 6px 16px rgba(201,164,87,.12));
    }
    body[data-theme="light"] .nav-actions {
      background: transparent;
      box-shadow: none;
    }
    @media (min-width: 992px) {
      .hero-slide .col-lg-7,
      .hero-slide .col-lg-8,
      .hero-slide .col-lg-5 {
        display: flex;
      }
      .hero-slide .col-lg-7,
      .hero-slide .col-lg-8 {
        align-items: flex-start;
      }
      .hero-slide .col-lg-5 {
        justify-content: flex-end;
      }
      .navbar .dropdown > .dropdown-menu {
        display: block;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity .18s ease, visibility .18s ease, transform .18s ease;
      }
      .navbar .dropdown > .mega-menu {
        transform: translateY(6px) !important;
      }
      .navbar .dropdown > .nav-dropdown-menu {
        transform: translateX(-50%) translateY(6px) !important;
      }
      .navbar .dropdown:hover > .dropdown-menu,
      .navbar .dropdown:focus-within > .dropdown-menu,
      .navbar .dropdown > .dropdown-menu.show {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
      }
      .navbar .dropdown:hover > .mega-menu,
      .navbar .dropdown:focus-within > .mega-menu,
      .navbar .dropdown > .mega-menu.show {
        transform: translateY(0) !important;
      }
      .navbar .dropdown:hover > .nav-dropdown-menu,
      .navbar .dropdown:focus-within > .nav-dropdown-menu,
      .navbar .dropdown > .nav-dropdown-menu.show {
        transform: translateX(-50%) translateY(0) !important;
      }
      .navbar .navbar-nav:has(.dropdown:hover) .dropdown:not(:hover) > .mega-menu,
      .navbar .navbar-nav:has(.dropdown:hover) .dropdown:not(:hover) > .nav-dropdown-menu,
      .navbar .navbar-nav:has(.dropdown:hover) .dropdown:not(:hover) > .dropdown-menu {
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
      }
      .navbar .navbar-nav:has(.dropdown:hover) .dropdown:not(:hover) > .mega-menu {
        transform: translateY(6px) !important;
      }
      .navbar .navbar-nav:has(.dropdown:hover) .dropdown:not(:hover) > .nav-dropdown-menu {
        transform: translateX(-50%) translateY(6px) !important;
      }
    }
    body[data-theme="light"] .mega-menu .dropdown-item {
      color: #334155;
    }
    body[data-theme="light"] .mega-menu .dropdown-item:hover {
      background: rgba(15,23,42,.05);
      color: #16212f;
    }
    body[data-theme="light"] .nav-dropdown-menu {
      background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(242,246,251,.98) 100%);
      border-color: rgba(15,23,42,.10);
      box-shadow: 0 20px 48px rgba(15,23,42,.10);
    }
    body[data-theme="light"] .nav-dropdown-menu .dropdown-item {
      color: #334155;
    }
    body[data-theme="light"] .nav-dropdown-menu .dropdown-item:hover {
      background: rgba(15,23,42,.05);
      color: #16212f;
    }
    body[data-theme="light"] .mega-label {
      color: #16212f;
    }
    body[data-theme="light"] .mega-icon {
      background: linear-gradient(180deg, rgba(200,169,107,.20) 0%, rgba(200,169,107,.10) 100%);
      border-color: rgba(200,169,107,.24);
      color: #a57b2f;
    }
    body[data-theme="light"] .mega-highlight-card {
      background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(244,247,251,.98) 100%);
      border-color: rgba(15,23,42,.10);
      box-shadow: 0 14px 34px rgba(15,23,42,.08);
    }
    body[data-theme="light"] .mega-highlight .chip {
      background: rgba(15,23,42,.05);
      border-color: rgba(15,23,42,.08);
      color: #334155;
    }
    body[data-theme="light"] .mega-highlight-kicker {
      background: rgba(15,23,42,.06);
      color: #334155;
    }
    body[data-theme="light"] .mega-highlight-card p,
    body[data-theme="light"] .mega-highlight-points span {
      color: #475569;
    }
    body[data-theme="light"] .mega-highlight-points span {
      background: rgba(255,255,255,.72);
      border-color: rgba(15,23,42,.08);
    }
    body[data-theme="light"] .footer a,
    body[data-theme="light"] .accordion-button,
    body[data-theme="light"] .navbar-toggler .text-white {
      color: #243041 !important;
    }
    body[data-theme="light"] .footer a.btn.btn-gold,
    body[data-theme="light"] .footer-cta a.btn.btn-gold,
    body[data-theme="light"] .sticky-mobile-cta a.btn.btn-gold {
      color: #141210 !important;
    }
    body[data-theme="light"] .footer a.btn.btn-gold:hover,
    body[data-theme="light"] .footer-cta a.btn.btn-gold:hover,
    body[data-theme="light"] .sticky-mobile-cta a.btn.btn-gold:hover {
      color: #0a0908 !important;
    }
    body[data-theme="light"] .sticky-mobile-cta {
      background: rgba(255,255,255,.94);
      border-top: 1px solid rgba(15,23,42,.08);
    }
    body[data-theme="light"] .floating-contact a {
      border-color: rgba(15,23,42,.08);
      box-shadow: 0 16px 36px rgba(15,23,42,.12);
    }
    body[data-theme="light"] .floating-contact .back-to-top {
      background: linear-gradient(135deg, #dbe4f0, #94a3b8);
      color: #16212f;
    }

    @media (max-width: 991.98px) {
      .hero .container {
        padding-left: 20px;
        padding-right: 20px;
      }
      .brand-logo {
        width: 190px;
      }
      .topbar-right {
        margin-left: 0;
      }
      .nav-compact {
        gap: 0;
        align-items: stretch;
        display: flex;
        padding: 0;
        border-radius: 0;
        background: transparent;
        border: 0;
        box-shadow: none;
      }
      .hero .owl-carousel,
      .hero .owl-stage-outer,
      .hero .owl-stage,
      .hero .owl-item,
      .hero-slide {
        height: auto;
        min-height: min(520px, 56vh);
      }
      .hero-slide { padding: 76px 0 36px; }
      .hero-content {
        max-width: none;
        padding: 8px 0 4px;
      }
      .policy-intro,
      .policy-intro h2,
      .policy-intro p {
        max-width: none;
      }
      .hero-form { margin-top: 20px; max-width: none; }
      .stats-wrap { margin-top: 0; padding-top: 30px; }
      .project-visual { min-height: 420px; margin-top: 26px; }
      .owl-nav button.owl-prev { left: 10px; }
      .owl-nav button.owl-next { right: 10px; }
    }

    @media (max-width: 991.98px) {
      #priceModal .price-modal-form-pane {
        background: inherit;
      }
      .mega-menu {
        position: static !important;
        transform: none;
        inset: auto !important;
        width: 100%;
        margin-top: 12px;
      }
      .mega-menu::before,
      .nav-dropdown-menu::before {
        display: none;
      }
      .nav-dropdown-menu {
        position: static !important;
        transform: none !important;
        inset: auto !important;
        width: 100%;
        margin-top: 12px !important;
      }
      .nav-actions {
        margin-top: 14px;
        padding: 0;
        border-radius: 0;
        background: transparent;
        border: 0;
        box-shadow: none;
      }
    }

    @media (max-width: 767.98px) {
      #priceModal .modal-dialog {
        margin: 1rem;
      }
      .section-padding { padding: 72px 0; }
      .topbar { display: none; }
      .hero .container {
        padding-left: 16px;
        padding-right: 16px;
      }
      .brand-logo {
        width: 168px;
      }
      .hero h1,
      .hero h2.hero-heading { font-size: 1.85rem; }
      .hero-content {
        padding: 4px 0;
      }
      .hero-highlights {
        gap: 10px 12px;
        grid-template-columns: 1fr 1fr;
      }
      .hero-highlights .item {
        width: auto;
        min-width: unset;
        min-height: 66px;
        padding: 11px 12px;
      }
      .hero-trust .trust-item {
        width: 100%;
        justify-content: flex-start;
      }
      .hero-highlights .item::after { display: none; }
      .floating-contact { right: 12px; bottom: 80px; }
      .sticky-mobile-cta { display: block; }
      .footer { padding-bottom: 96px; }
      .navbar .btn-gold { display: inline-flex; justify-content: center; }
      .lead-box { padding: 26px; }
      .inventory-search-box { padding: 14px; }
      .detail-thumb { height: 240px; }
      .policy-card,
      .price-card {
        padding: 22px;
      }
      .policy-summary {
        flex-wrap: wrap;
        gap: 8px;
      }
      .feature-media {
        width: 120px;
        height: 120px;
        margin-bottom: 18px;
      }
      .policy-summary span {
        width: 100%;
        flex: 1 1 100%;
        justify-content: flex-start;
      }
      .price-card-media,
      .price-card-media img {
        min-height: 150px;
        height: 150px;
      }
    }

    /* --- Trang 404 (khối nội dung trong layout, không dùng full HTML riêng) --- */
    .page-404 {
      position: relative;
      min-height: 48vh;
    }
    .page-404::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse 75% 55% at 50% 0%, rgba(200, 169, 107, 0.14) 0%, transparent 58%);
      pointer-events: none;
    }
    .page-404 .container {
      position: relative;
      z-index: 1;
    }
    .page-404 .page-404__code {
      font-size: clamp(3.25rem, 14vw, 7rem);
      font-weight: 800;
      line-height: 1;
      letter-spacing: -0.04em;
      color: var(--primary);
      text-shadow: 0 0 48px rgba(200, 169, 107, 0.35);
      user-select: none;
    }
    .page-404 .page-404__card {
      max-width: 520px;
      margin-left: auto;
      margin-right: auto;
      padding: 2rem 1.5rem;
      border-radius: var(--radius-lg);
      border: 1px solid var(--line);
      background: linear-gradient(180deg, rgba(23, 28, 37, 0.88) 0%, rgba(17, 22, 29, 0.95) 100%);
      box-shadow: var(--shadow);
    }
    .page-404 .page-404__card .sub {
      display: inline-block;
      color: var(--primary);
      text-transform: uppercase;
      letter-spacing: 0.16em;
      font-size: 0.82rem;
      font-weight: 800;
    }
    body[data-theme="light"] .page-404 .page-404__card {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(245, 247, 251, 0.98) 100%);
      border-color: var(--line);
    }
    body[data-theme="light"] .page-404 .page-404__code {
      text-shadow: none;
    }