/* ============================================================
   HanGo AI — Design System Overrides
   Loaded LAST to override HanGo Travel defaults.
   ============================================================ */

:root {
    --hg-radius-xs: 6px;
    --hg-radius-sm: 10px;
    --hg-radius-md: 14px;
    --hg-radius-lg: 20px;
    --hg-radius-xl: 28px;
    --hg-radius-full: 9999px;

    --hg-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
    --hg-shadow-md: 0 4px 14px rgba(0, 0, 0, 0.08), 0 2px 6px rgba(0, 0, 0, 0.04);
    --hg-shadow-lg: 0 10px 30px rgba(0, 0, 0, 0.10), 0 4px 10px rgba(0, 0, 0, 0.04);
    --hg-shadow-float: 0 8px 32px rgba(0, 0, 0, 0.10), 0 2px 8px rgba(0, 0, 0, 0.06);

    --hg-card-bg: #ffffff;
    --hg-page-bg: #ffffff;
    --hg-transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);

    --hg-primary: #CD2E3A;
    --hg-primary-hover: #b22630;
    --hg-primary-light: rgba(205, 46, 58, 0.1);
    --hg-secondary: #0047A0;
    --hg-secondary-hover: #003a85;
    --hg-secondary-light: rgba(0, 71, 160, 0.1);
    --hg-accent: #CD2E3A;
    --hg-accent-hover: #b22630;
    --hg-text-primary: #2d3748;
    --hg-text-secondary: #64748b;
}

body.frontend-page {
    background-color: var(--hg-page-bg) !important;
}

/* ---- Header Logo — constrained size ---- */
.bc_header .header-logo img,
.bc_header .logo-menu img {
    max-height: 45px !important;
    width: auto !important;
    object-fit: contain !important;
}

/* ---- Header Menu — Navy Blue ---- */
.bc_header .main-menu .navbar-nav > li > a {
    color: #0047A0 !important;
}
.bc_header .main-menu .navbar-nav > li > a:hover {
    color: var(--hg-primary) !important;
}

/* ===========================================================
   HERO SEARCH — ONE UNIFIED WHITE BLOCK
   =========================================================== */

/* Wrapper = the single white card */
.g-form-control {
    margin-top: 10px !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    background: var(--hg-card-bg) !important;
    border-radius: var(--hg-radius-lg) !important;
    box-shadow: var(--hg-shadow-lg) !important;
    overflow: visible !important;
    position: relative;
    z-index: 20;
}

/* ---- TABS: full-width, each tab stretches equally ---- */
.g-form-control > .nav-tabs {
    margin: 0 !important;
    border: none !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 0 !important;
    background: transparent !important;
    border-radius: var(--hg-radius-lg) var(--hg-radius-lg) 0 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    border-bottom: 1px solid #e8ecf1 !important;
}

.g-form-control .nav-tabs li {
    margin: 0 !important;
    list-style: none !important;
    flex: 1 1 0% !important;
    min-width: 0 !important;
}

.g-form-control .nav-tabs li a {
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: var(--hg-text-secondary) !important;
    padding: 12px 6px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    transition: background var(--hg-transition), color var(--hg-transition) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    white-space: nowrap !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    text-decoration: none !important;
    width: 100% !important;
    border-right: 1px solid #e8ecf1 !important;
}

.g-form-control .nav-tabs li:last-child a {
    border-right: none !important;
}

.g-form-control .nav-tabs li a:hover {
    background: #f1f5f9 !important;
    color: var(--hg-text-primary) !important;
}

/* Active tab — fills to the very top of the container */
.g-form-control .nav-tabs li a.active,
.g-form-control .nav-tabs li.active a {
    background: var(--hg-primary) !important;
    color: #fff !important;
    border-right-color: var(--hg-primary) !important;
}

/* Match container corner radius on first/last active tab */
.g-form-control .nav-tabs li:first-child a.active,
.g-form-control .nav-tabs li.active:first-child a {
    border-radius: var(--hg-radius-lg) 0 0 0 !important;
}
.g-form-control .nav-tabs li:last-child a.active,
.g-form-control .nav-tabs li.active:last-child a {
    border-radius: 0 var(--hg-radius-lg) 0 0 !important;
}

.g-form-control .nav-tabs li a i {
    font-size: 14px !important;
}

/* Tab content — transparent */
.g-form-control .tab-content {
    padding: 0 !important;
    background: transparent !important;
    overflow: visible !important;
}
.g-form-control .tab-content > .tab-pane {
    padding: 0 !important;
    overflow: visible !important;
}

/* ---- FORM BAR: transparent inside the wrapper ---- */
.g-form-control .bc_form,
.g-form-control form.bc_form,
.bc_wrap .g-form-control .bc_form {
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    border: none !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    overflow: visible !important;
    padding: 0 !important;
}

/* Standalone bc_form (outside g-form-control) */
.bc_wrap .bc_form:not(.g-form-control .bc_form) {
    background: var(--hg-card-bg) !important;
    border-radius: var(--hg-radius-lg) !important;
    box-shadow: var(--hg-shadow-lg) !important;
    border: none !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    overflow: visible !important;
    padding: 0 !important;
}

/* ---- SEARCH FIELDS — flex-grow, take remaining space ---- */
.bc_form .g-field-search {
    flex: 1 1 auto !important;
    max-width: none !important;
    padding: 0 !important;
    overflow: visible !important;
    min-width: 0 !important;
}

.bc_form .g-field-search > .row {
    margin: 0 !important;
    align-items: stretch !important;
    flex-wrap: nowrap !important;
}

.bc_form .g-field-search .border-right,
.bc_form .g-field-search [class*="col-md-"].border-right {
    border-right: 1px solid #e8ecf1 !important;
}
.bc_form .g-field-search [class*="col-md-"]:last-child {
    border-right: none !important;
}

/* ---- SEARCH BUTTON — FIXED RIGHT, can't be pushed ---- */
.bc_form .g-button-submit {
    flex: 0 0 auto !important;
    max-width: none !important;
    padding: 8px !important;
    display: flex !important;
    align-items: center !important;
    margin-left: auto !important;
    flex-shrink: 0 !important;
}

.bc_form .g-button-submit button {
    background: var(--hg-accent) !important;
    border: none !important;
    color: #fff !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    padding: 12px 28px !important;
    border-radius: var(--hg-radius-md) !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    box-shadow: 0 4px 14px rgba(205, 46, 58, 0.35) !important;
    transition: all var(--hg-transition) !important;
    white-space: nowrap !important;
    cursor: pointer !important;
    height: auto !important;
    width: auto !important;
    margin: 0 !important;
}

.bc_form .g-button-submit button:hover {
    background: var(--hg-primary-hover) !important;
    box-shadow: 0 6px 20px rgba(205, 46, 58, 0.45) !important;
    transform: translateY(-1px) !important;
}

/* ---- FORM GROUP (each field) ---- */
.bc_form .form-group {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 10px 14px !important;
    border: none !important;
    border-bottom: none !important;
    min-height: 58px !important;
}

.bc_form .form-group > .field-icon {
    font-size: 20px !important;
    color: var(--hg-primary) !important;
    opacity: 0.7 !important;
    flex-shrink: 0 !important;
    width: 22px !important;
    text-align: center !important;
    margin: 0 !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    float: none !important;
}

.bc_form .form-group > .form-content {
    flex: 1 !important;
    min-width: 0 !important;
    padding: 0 !important;
}

/* Field labels */
.bc_form .form-content label,
.bc_form .date-wrapper .check-in-wrapper > label,
.bc_form .wrapper-more > label {
    display: block !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: var(--hg-text-secondary) !important;
    margin-bottom: 1px !important;
    line-height: 1.3 !important;
}

/* ---- DATE FIELD — aligned with other fields ---- */
.hg-date-display {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 14px !important;
    white-space: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
}

.hg-date-display .render {
    font-size: 14px !important;
    color: var(--hg-primary) !important;
    font-weight: 500 !important;
    display: inline !important;
}

.hg-date-separator {
    color: var(--hg-text-secondary) !important;
    font-size: 12px !important;
    opacity: 0.5;
}

/* Date search container — position relative for invisible input overlay */
.bc_wrap .bc_form .form-group .form-content .form-date-search-hotel,
.bc_wrap .bc_form .form-group .form-content .form-date-search,
.bc_form .form-date-search-hotel,
.bc_form .form-date-search {
    position: relative !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Invisible daterangepicker trigger — high specificity to beat HanGo Travel */
.bc_wrap .bc_form .form-content .form-date-search .check-in-out,
.bc_wrap .bc_form .form-content .form-date-search-hotel .check-in-out,
.bc_form .check-in-out,
.bc_form .form-date-search-hotel .check-in-out,
.bc_form .form-date-search .check-in-out {
    position: absolute !important;
    opacity: 0 !important;
    width: 100% !important;
    height: 100% !important;
    top: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    right: auto !important;
    cursor: pointer !important;
    z-index: 5 !important;
}

.bc_form .form-date-search-hotel,
.bc_form .form-date-search {
    position: relative !important;
}

/* ---- SMART SEARCH (Location) ---- */
.bc_form .smart-search {
    position: relative !important;
    overflow: visible !important;
}

.bc_form .smart-search .parent_text,
.bc_form .smart-search .form-control {
    height: 22px !important;
    font-size: 14px !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    color: var(--hg-primary) !important;
    line-height: 22px !important;
    font-weight: 500 !important;
}

.bc_form .smart-search::after {
    top: 6px !important;
    right: 0 !important;
}

.bc_form .smart-search .search-items,
.smart-search .search-items {
    position: absolute !important;
    top: 100% !important;
    left: -14px !important;
    right: -14px !important;
    z-index: 9999 !important;
    background: var(--hg-card-bg) !important;
    border-radius: var(--hg-radius-sm) !important;
    box-shadow: var(--hg-shadow-lg) !important;
    border: 1px solid #e2e8f0 !important;
    max-height: 300px !important;
    overflow-y: auto !important;
    margin-top: 4px !important;
}

/* ---- GUEST FIELD ---- */
.bc_form .form-select-guests {
    overflow: visible !important;
}

.bc_form .form-select-guests .render {
    font-size: 14px !important;
    color: var(--hg-text-primary) !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 160px !important;
}

.bc_form .select-guests-dropdown,
.bc_form .dropdown-menu {
    z-index: 9999 !important;
    border-radius: var(--hg-radius-sm) !important;
    box-shadow: var(--hg-shadow-lg) !important;
    border: 1px solid #e2e8f0 !important;
    background: var(--hg-card-bg) !important;
    min-width: 220px !important;
    padding: 12px !important;
}

/* ---- FLIGHT-SPECIFIC spacing kills ---- */
.bc_form .item {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

.bc_form .dropdown-custom {
    margin-bottom: 0 !important;
    padding: 0 !important;
}

.bc_form .dropdown-custom > span {
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: var(--hg-text-secondary) !important;
}

.bc_form .flex-horizontal-center {
    border-bottom: none !important;
    padding: 2px 0 0 !important;
    margin: 0 !important;
}

.bc_form .height-40 {
    height: auto !important;
}

.bc_form .item .render {
    font-size: 14px !important;
    color: var(--hg-text-primary) !important;
    font-weight: 500 !important;
}

/* Daterangepicker popup */
.daterangepicker {
    border-radius: var(--hg-radius-md) !important;
    box-shadow: var(--hg-shadow-lg) !important;
    border: 1px solid #e2e8f0 !important;
    z-index: 9999 !important;
}

/* ---- RESPONSIVE: TABLET ---- */
@media (max-width: 991px) {
    .g-form-control > .nav-tabs {
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }
    .g-form-control .nav-tabs li {
        flex: 1 1 0% !important;
        min-width: 0 !important;
    }
    .g-form-control .nav-tabs li a {
        padding: 10px 12px !important;
        font-size: 12px !important;
    }
    .g-form-control .bc_form,
    .g-form-control form.bc_form,
    .bc_wrap .bc_form:not(.g-form-control .bc_form) {
        flex-wrap: wrap !important;
        flex-direction: column !important;
    }
    .bc_form .g-field-search {
        flex: 0 0 100% !important;
        width: 100% !important;
    }
    .bc_form .g-field-search > .row {
        flex-wrap: wrap !important;
        flex-direction: column !important;
    }
    .bc_form .g-field-search .border-right,
    .bc_form .g-field-search [class*="col-md-"].border-right,
    .bc_form .g-field-search [class*="col-"].border-right {
        border-right: none !important;
        border-bottom: 1px solid #e8ecf1 !important;
    }
    .bc_form .g-field-search [class*="col-md-"],
    .bc_form .g-field-search [class*="col-lg-"],
    .bc_form .g-field-search > .row > [class*="col"] {
        flex: 0 0 100% !important;
        max-width: 100% !important;
        width: 100% !important;
    }
    .bc_form .g-button-submit {
        flex: 0 0 100% !important;
        width: 100% !important;
        padding: 8px 14px 14px !important;
        margin-left: 0 !important;
    }
    .bc_form .g-button-submit button {
        width: 100% !important;
        padding: 14px 24px !important;
    }
}

/* ---- RESPONSIVE: MOBILE ---- */
@media (max-width: 767px) {
    .g-form-control {
        margin-top: 8px !important;
        border-radius: var(--hg-radius-md) !important;
    }
    .g-form-control > .nav-tabs {
        border-radius: var(--hg-radius-md) var(--hg-radius-md) 0 0 !important;
        gap: 0 !important;
    }
    .g-form-control .nav-tabs li a {
        padding: 8px 10px !important;
        font-size: 11px !important;
        gap: 3px !important;
    }
    .g-form-control .nav-tabs li a i {
        font-size: 12px !important;
    }
    .g-form-control .nav-tabs li:first-child a.active,
    .g-form-control .nav-tabs li.active:first-child a {
        border-radius: var(--hg-radius-md) 0 0 0 !important;
    }
    .g-form-control .nav-tabs li:last-child a.active,
    .g-form-control .nav-tabs li.active:last-child a {
        border-radius: 0 var(--hg-radius-md) 0 0 !important;
    }
    .bc_form .form-group {
        padding: 8px 12px !important;
        min-height: 48px !important;
        gap: 8px !important;
    }
    .bc_form .form-group > .field-icon {
        font-size: 18px !important;
        width: 20px !important;
    }
    .bc_form .smart-search .parent_text,
    .bc_form .smart-search .form-control {
        font-size: 13px !important;
    }
    .bc_form .form-content label,
    .bc_form .date-wrapper .check-in-wrapper > label,
    .bc_form .wrapper-more > label {
        font-size: 10px !important;
    }
    .hg-date-display {
        font-size: 13px !important;
    }
    .hg-date-display .render {
        font-size: 13px !important;
    }
    /* Flight form specifics */
    .bc_form .item {
        width: 100% !important;
    }
    .bc_form .dropdown-custom {
        width: 100% !important;
    }
    /* Guest dropdown */
    .bc_form .select-guests-dropdown,
    .bc_form .dropdown-menu {
        min-width: 200px !important;
        left: 0 !important;
        right: 0 !important;
    }
    .bc_form .g-button-submit {
        padding: 6px 12px 12px !important;
    }
    .bc_form .g-button-submit button {
        padding: 12px 20px !important;
        font-size: 13px !important;
        border-radius: var(--hg-radius-sm) !important;
    }
}

/* ===========================================================
   GLOBAL CARD STYLING
   =========================================================== */
.item-tour,
.item-loop,
.list-item .item-loop,
.list-item .item-tour,
.bravo-list-item .item-loop,
.bravo-list-item .item-tour,
.service-card,
.service-item {
    background: var(--hg-card-bg) !important;
    border-radius: var(--hg-radius-md) !important;
    box-shadow: var(--hg-shadow-md) !important;
    border: none !important;
    overflow: hidden !important;
    transition: transform var(--hg-transition), box-shadow var(--hg-transition) !important;
}

.item-tour:hover,
.item-loop:hover,
.list-item .item-loop:hover,
.list-item .item-tour:hover,
.bravo-list-item .item-loop:hover,
.bravo-list-item .item-tour:hover,
.service-card:hover,
.service-item:hover {
    transform: translateY(-6px) !important;
    box-shadow: var(--hg-shadow-float) !important;
}

.item-tour .thumb-image,
.item-loop .thumb-image,
.item-tour .featured-image,
.item-loop .featured-image,
.service-card .thumb-image {
    border-radius: var(--hg-radius-md) var(--hg-radius-md) 0 0 !important;
    overflow: hidden !important;
}

/* ----------------------------------------------------------
   Location / Destination Cards
   ---------------------------------------------------------- */
.bravo-list-locations .item-location,
.bravo-list-locations .list-item,
.destination-item,
.location-item {
    border-radius: var(--hg-radius-md) !important;
    overflow: hidden !important;
    box-shadow: var(--hg-shadow-sm) !important;
    transition: transform var(--hg-transition), box-shadow var(--hg-transition) !important;
}

.bravo-list-locations .item-location:hover,
.destination-item:hover,
.location-item:hover {
    transform: translateY(-4px) !important;
    box-shadow: var(--hg-shadow-lg) !important;
}

/* ----------------------------------------------------------
   Buttons
   ---------------------------------------------------------- */
.btn,
input[type="submit"],
input[type="button"],
.btn-primary,
.btn-info,
.btn-success,
.btn-warning,
.btn-danger,
.btn-secondary,
.btn-outline-primary,
.btn-outline-secondary {
    border-radius: var(--hg-radius-sm) !important;
    transition: all var(--hg-transition) !important;
}

.btn-lg {
    border-radius: var(--hg-radius-md) !important;
}

/* ----------------------------------------------------------
   Form Inputs
   ---------------------------------------------------------- */
.form-control,
.form-select,
textarea,
select,
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    border-radius: var(--hg-radius-sm) !important;
}

/* ----------------------------------------------------------
   Dropdowns & Menus
   ---------------------------------------------------------- */
.dropdown-menu,
.select2-dropdown {
    border-radius: var(--hg-radius-sm) !important;
    box-shadow: var(--hg-shadow-lg) !important;
    border: 1px solid #e2e8f0 !important;
    overflow: hidden !important;
}

/* ----------------------------------------------------------
   Modals
   ---------------------------------------------------------- */
.modal-content {
    border-radius: var(--hg-radius-lg) !important;
    box-shadow: var(--hg-shadow-float) !important;
    border: none !important;
    overflow: hidden !important;
}

.popover {
    border-radius: var(--hg-radius-md) !important;
    box-shadow: var(--hg-shadow-md) !important;
}

/* ----------------------------------------------------------
   Alerts
   ---------------------------------------------------------- */
.alert,
.notice,
.notification-item {
    border-radius: var(--hg-radius-sm) !important;
}

/* ----------------------------------------------------------
   Pagination
   ---------------------------------------------------------- */
.pagination .page-link,
.pagination .page-item .page-link {
    border-radius: var(--hg-radius-xs) !important;
}
.pagination {
    gap: 4px;
}

/* ----------------------------------------------------------
   Booking Sidebar
   ---------------------------------------------------------- */
.bravo_tour_book,
.bravo_single_book,
.bravo_single_book_wrap,
.bc_single_book,
.bc_single_book_wrap {
    border-radius: var(--hg-radius-md) !important;
    box-shadow: var(--hg-shadow-md) !important;
    border: none !important;
    overflow: visible !important;
    background: var(--hg-card-bg) !important;
}

/* ----------------------------------------------------------
   Review Box
   ---------------------------------------------------------- */
.review-box,
.bravo-reviews .review-box {
    border-radius: var(--hg-radius-md) !important;
    background: var(--hg-card-bg) !important;
    box-shadow: var(--hg-shadow-sm) !important;
}

/* ----------------------------------------------------------
   Tags & Badges
   ---------------------------------------------------------- */
.badge,
.tag,
.label,
.featured,
.sale_info {
    border-radius: var(--hg-radius-xs) !important;
}

/* ----------------------------------------------------------
   Tabs (generic)
   ---------------------------------------------------------- */
.nav-pills .nav-link {
    border-radius: var(--hg-radius-full) !important;
}

/* ----------------------------------------------------------
   Breadcrumbs
   ---------------------------------------------------------- */
.breadcrumb {
    border-radius: var(--hg-radius-sm) !important;
}

/* ----------------------------------------------------------
   Cards / Panels
   ---------------------------------------------------------- */
.panel,
.card,
.widget,
.sidebar-widget,
.bc-widget {
    background: var(--hg-card-bg) !important;
    border-radius: var(--hg-radius-md) !important;
    box-shadow: var(--hg-shadow-sm) !important;
    border: none !important;
}

/* ----------------------------------------------------------
   Images in cards
   ---------------------------------------------------------- */
.service-card img,
.item-tour .thumb-image img,
.item-loop .thumb-image img {
    border-radius: inherit !important;
}

/* ----------------------------------------------------------
   Wishlist Heart
   ---------------------------------------------------------- */
.service-wishlist {
    border-radius: var(--hg-radius-full) !important;
    background: rgba(255, 255, 255, 0.85) !important;
    backdrop-filter: blur(4px) !important;
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: var(--hg-shadow-sm) !important;
    transition: all var(--hg-transition) !important;
}

.service-wishlist:hover {
    background: rgba(255, 255, 255, 1) !important;
    transform: scale(1.1) !important;
    box-shadow: var(--hg-shadow-md) !important;
}

/* ----------------------------------------------------------
   Destination Images
   ---------------------------------------------------------- */
.bravo-list-locations .owl-item .item-location img,
.destination-item img {
    border-radius: var(--hg-radius-md) !important;
}

/* ----------------------------------------------------------
   User Dashboard
   ---------------------------------------------------------- */
.bravo_user_profile .user-content-wrap,
.bravo_user_profile .dashboard-card {
    border-radius: var(--hg-radius-md) !important;
    background: var(--hg-card-bg) !important;
    box-shadow: var(--hg-shadow-sm) !important;
}

/* ----------------------------------------------------------
   Tables
   ---------------------------------------------------------- */
.table,
.table-responsive {
    border-radius: var(--hg-radius-sm) !important;
    overflow: hidden !important;
}

/* ----------------------------------------------------------
   Vendor Sidebar
   ---------------------------------------------------------- */
.bravo_user_profile > .container-fluid > .row-eq-height > .col-md-3 {
    border-radius: 0 var(--hg-radius-lg) var(--hg-radius-lg) 0 !important;
}

/* ----------------------------------------------------------
   Footer
   ---------------------------------------------------------- */
.bc_footer {
    border-radius: var(--hg-radius-xl) var(--hg-radius-xl) 0 0 !important;
    overflow: hidden;
}

/* ----------------------------------------------------------
   Misc
   ---------------------------------------------------------- */
.tooltip-inner {
    border-radius: var(--hg-radius-xs) !important;
}

.owl-dots .owl-dot span {
    border-radius: var(--hg-radius-full) !important;
}

.bc_wrap .card,
.bc_wrap .panel,
.bc_wrap .well,
.bc_wrap .jumbotron,
.bc_wrap .list-group,
.bc_wrap .list-group-item:first-child,
.bc_wrap .list-group-item:last-child {
    border-radius: var(--hg-radius-sm) !important;
}

.card-img-top,
.card > img:first-child {
    border-radius: var(--hg-radius-md) var(--hg-radius-md) 0 0 !important;
}

.bc_wrap h2 {
    font-weight: 700 !important;
    color: var(--hg-text-primary) !important;
}

/* ===========================================================
   GLOBAL COLOR REBRAND — SAFE VERSION
   Primary: #CD2E3A (red)  |  Secondary: #0047A0 (blue)
   Only targets specific HanGo Travel components, NOT global tags.
   =========================================================== */

/* ---- Primary Buttons ---- */
.btn-primary,
.btn-info,
.bc_btn,
.bravo-pagination .active .page-link,
.page-item.active .page-link,
input[type="submit"].btn-primary {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
    color: #fff !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-info:hover,
.btn-info:focus,
.bc_btn:hover {
    background-color: var(--hg-primary-hover) !important;
    border-color: var(--hg-primary-hover) !important;
    color: #fff !important;
}

/* ---- Outline Primary ---- */
.btn-outline-primary {
    color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
    background: transparent !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
    color: #fff !important;
}

/* ---- Secondary Buttons ---- */
.btn-secondary {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

.btn-secondary:hover {
    background-color: var(--hg-primary-hover) !important;
    border-color: var(--hg-primary-hover) !important;
}

/* ---- Content Links (NOT header/footer/nav) ---- */
.bc_wrap .bravo_wrap a:not([class]),
.bc_wrap .page-content a:not([class]),
.bc_wrap .entry-content a:not([class]) {
    color: var(--hg-primary) !important;
}

.bc_wrap .bravo_wrap a:not([class]):hover,
.bc_wrap .page-content a:not([class]):hover {
    color: var(--hg-primary-hover) !important;
}

/* ---- Navbar Hover ---- */
.bc_header .main-menu .navbar-nav > li > a:hover,
.bc_header .main-menu .navbar-nav > li.active > a,
.bc_header .main-menu .dropdown-menu a:hover {
    color: var(--hg-primary) !important;
}

/* ---- Text Colors ---- */
.text-primary,
.text-info {
    color: var(--hg-primary) !important;
}

/* ---- Prices ---- */
.bc_wrap .price .text-lg,
.bc_wrap .price-wrapper .price,
.bc_wrap .sale-price,
.item-loop .price .text-price,
.item-tour .price .text-price,
.bravo_single_book .price .onsale,
.bravo_single_book .price .text-price {
    color: var(--hg-primary) !important;
}

/* ---- Backgrounds ---- */
.bg-primary,
.bg-info {
    background-color: var(--hg-primary) !important;
}

/* ---- Badges & Tags ---- */
.badge-primary,
.badge-info,
.badge.bg-primary,
.badge.bg-info {
    background-color: var(--hg-primary) !important;
    color: #fff !important;
}

.sale_info,
.featured {
    background-color: var(--hg-primary) !important;
    color: #fff !important;
}

/* ---- Form Focus ---- */
.form-control:focus,
.form-select:focus,
textarea:focus {
    border-color: var(--hg-primary) !important;
    box-shadow: 0 0 0 3px var(--hg-primary-light) !important;
}

/* ---- Selection ---- */
::selection {
    background: var(--hg-primary) !important;
    color: #fff !important;
}

/* ---- Booking Sidebar ---- */
.bravo_single_book .btn-primary,
.bravo_tour_book .btn-primary,
.booking_submit_btn {
    background: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

.bravo_single_book .btn-primary:hover,
.bravo_tour_book .btn-primary:hover {
    background: var(--hg-primary-hover) !important;
}

/* ---- Wishlist ---- */
.service-wishlist.active,
.service-wishlist .active {
    color: var(--hg-primary) !important;
}

/* ---- Progress / Scores ---- */
.progress-bar {
    background-color: var(--hg-primary) !important;
}

.review-score-value {
    background: var(--hg-primary) !important;
}

/* ---- Dropdown Active ---- */
.dropdown-item.active,
.dropdown-item:active {
    background-color: var(--hg-primary) !important;
}

/* ---- Border ---- */
.border-primary {
    border-color: var(--hg-primary) !important;
}

/* ---- Spinner ---- */
.spinner-border,
.loading-icon {
    color: var(--hg-primary) !important;
}

/* ---- Dashboard Sidebar ---- */
.bravo_user_profile .sidebar-menu li.active a,
.bravo_user_profile .sidebar-menu li a:hover {
    color: var(--hg-primary) !important;
}

.bravo_user_profile .sidebar-menu li.active {
    border-left-color: var(--hg-primary) !important;
}

/* ---- Tabs (non-search) ---- */
.nav-tabs .nav-link.active:not(.g-form-control .nav-tabs .nav-link) {
    color: var(--hg-primary) !important;
    border-bottom-color: var(--hg-primary) !important;
}

/* ---- Checkbox / Radio ---- */
input[type="checkbox"]:checked,
input[type="radio"]:checked {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}


/* Don't color nav links or white links */
.bc_header a,
.text-white a,
.bc_footer a,
[class*="nav"] a,
.breadcrumb a,
.item-loop a,
.item-tour a {
    color: inherit !important;
}

/* ---- Primary Buttons ---- */
.btn-primary,
.btn-info,
.bc_btn,
.bravo-pagination .active .page-link,
.page-item.active .page-link,
input[type="submit"].btn-primary {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
    color: #fff !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-info:hover,
.btn-info:focus,
.bc_btn:hover {
    background-color: var(--hg-primary-hover) !important;
    border-color: var(--hg-primary-hover) !important;
    color: #fff !important;
}

/* ---- Outline Primary ---- */
.btn-outline-primary {
    color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
    background: transparent !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
    color: #fff !important;
}

/* ---- Secondary Buttons ---- */
.btn-secondary {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

.btn-secondary:hover {
    background-color: var(--hg-primary-hover) !important;
    border-color: var(--hg-primary-hover) !important;
}

/* ---- Header / Navbar ---- */
.bc_header .main-menu .navbar-nav > li > a:hover,
.bc_header .main-menu .navbar-nav > li > a.active,
.bc_header .main-menu .dropdown-menu a:hover {
    color: var(--hg-primary) !important;
}

.bc_header .topbar-left a:hover {
    color: var(--hg-primary) !important;
}

/* ---- Text Color Overrides ---- */
.text-primary,
.text-info {
    color: var(--hg-primary) !important;
}

.text-secondary {
    color: var(--hg-primary) !important;
}

/* HanGo Travel specific blue text */
.bc_wrap .price .text-lg,
.bc_wrap .price-wrapper .price,
.bc_wrap .sale-price,
.item-loop .price .text-price,
.item-tour .price .text-price,
.bravo_single_book .price .onsale,
.bravo_single_book .price .text-price {
    color: var(--hg-primary) !important;
}

/* ---- Background Overrides ---- */
.bg-primary,
.bg-info {
    background-color: var(--hg-primary) !important;
}

/* HanGo Travel dark header (#CD2E3A) */
.bc_header .main-header,
.bc_header .top-header {
    background-color: #CD2E3A !important;
}

/* ---- Badges & Tags ---- */
.badge-primary,
.badge-info,
.badge.bg-primary,
.badge.bg-info {
    background-color: var(--hg-primary) !important;
    color: #fff !important;
}

.sale_info,
.featured {
    background-color: var(--hg-primary) !important;
    color: #fff !important;
}

/* ---- Stars / Ratings ---- */
.fa-star,
.icofont-star,
.star-rate .icofont-star,
.review-star i {
    color: #f59e0b !important;
}

/* ---- Form Focus States ---- */
.form-control:focus,
.form-select:focus,
textarea:focus,
input:focus {
    border-color: var(--hg-primary) !important;
    box-shadow: 0 0 0 3px var(--hg-primary-light) !important;
}

/* ---- Checkbox / Radio ---- */
input[type="checkbox"]:checked,
input[type="radio"]:checked {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

/* ---- Selection / Highlights ---- */
::selection {
    background: var(--hg-primary) !important;
    color: #fff !important;
}

/* ---- Icon Colors ---- */
.bc_form .form-group > .field-icon {
    color: var(--hg-primary) !important;
}

.bc_form .smart-search .parent_text,
.bc_form .smart-search .form-control {
    color: var(--hg-primary) !important;
}

.smart-search::after,
.input-search::after {
    color: var(--hg-primary) !important;
}

.smart-search:not(.normal-control) .parent_text,
.smart-search:not(.normal-control) .form-control,
.input-search:not(.normal-control) .parent_text,
.input-search:not(.normal-control) .form-control {
    color: var(--hg-primary) !important;
}

.smart-search:not(.normal-control) .parent_text::placeholder,
.smart-search:not(.normal-control) .form-control::placeholder,
.input-search:not(.normal-control) .parent_text::placeholder,
.input-search:not(.normal-control) .form-control::placeholder {
    color: var(--hg-primary) !important;
}

/* ---- HanGo Travel Specific Components ---- */
/* Tabs */
.nav-tabs .nav-link.active {
    color: var(--hg-primary) !important;
    border-bottom-color: var(--hg-primary) !important;
}

/* Booking sidebar button */
.bravo_single_book .btn-primary,
.bravo_tour_book .btn-primary,
.booking_submit_btn {
    background: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

.bravo_single_book .btn-primary:hover,
.bravo_tour_book .btn-primary:hover {
    background: var(--hg-primary-hover) !important;
}

/* Load more / Show more */
.btn-loadmore,
.show-more a {
    color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

.btn-loadmore:hover,
.show-more a:hover {
    background: var(--hg-primary) !important;
    color: #fff !important;
}

/* Wishlist active */
.service-wishlist.active,
.service-wishlist .active {
    color: var(--hg-primary) !important;
}

/* Progress bars */
.progress-bar {
    background-color: var(--hg-primary) !important;
}

/* Review score */
.review-score-value {
    background: var(--hg-primary) !important;
}

/* Map markers */
.marker-price {
    background: var(--hg-primary) !important;
}

/* Footer social icons */
.bc_footer .social-links a:hover {
    color: var(--hg-primary) !important;
}

/* Dropdown active */
.dropdown-item.active,
.dropdown-item:active {
    background-color: var(--hg-primary) !important;
}

/* Border accents */
.border-primary {
    border-color: var(--hg-primary) !important;
}

/* Loading spinner */
.spinner-border,
.loading-icon {
    color: var(--hg-primary) !important;
}

/* User dashboard sidebar active */
.bravo_user_profile .sidebar-menu li.active a,
.bravo_user_profile .sidebar-menu li a:hover {
    color: var(--hg-primary) !important;
}

.bravo_user_profile .sidebar-menu li.active {
    border-left-color: var(--hg-primary) !important;
}

/* Vendor register/login */
.bravo_form .btn-primary {
    background: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

/* Alert links */
.alert a {
    color: var(--hg-primary) !important;
}

/* Switch toggle */
.custom-switch .custom-control-input:checked ~ .custom-control-label::before {
    background-color: var(--hg-primary) !important;
    border-color: var(--hg-primary) !important;
}

/* ===========================================================
   ADDRESS AUTOCOMPLETE (Nominatim)
   =========================================================== */
.hg-address-autocomplete {
    position: relative !important;
}

.hg-address-suggestions {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 9999 !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: var(--hg-radius-sm) !important;
    box-shadow: var(--hg-shadow-lg) !important;
    list-style: none !important;
    padding: 4px 0 !important;
    margin: 4px 0 0 !important;
    max-height: 260px !important;
    overflow-y: auto !important;
}

.hg-address-suggestions li {
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    padding: 10px 14px !important;
    cursor: pointer !important;
    font-size: 13px !important;
    color: var(--hg-text-primary) !important;
    line-height: 1.4 !important;
    transition: background 0.15s ease !important;
}

.hg-address-suggestions li:hover {
    background: var(--hg-primary-light) !important;
}

.hg-address-suggestions li i {
    color: var(--hg-primary) !important;
    font-size: 14px !important;
    margin-top: 2px !important;
    flex-shrink: 0 !important;
}

.hg-address-suggestions li span {
    flex: 1 !important;
    word-break: break-word !important;
}

/* ----------------------------------------------------------
   Quick-Book Banner
   ---------------------------------------------------------- */
.hg-quick-book-banner {
    background: linear-gradient(135deg, #f8f9ff 0%, #eef1ff 50%, #f0f4ff 100%) !important;
    border: 1px solid rgba(79, 70, 229, 0.15) !important;
    border-radius: var(--hg-radius-md, 12px) !important;
    padding: 16px 20px !important;
    margin-bottom: 20px !important;
    box-shadow: 0 2px 8px rgba(79, 70, 229, 0.08) !important;
}

.hg-qb-inner {
    display: flex !important;
    align-items: center !important;
    gap: 20px !important;
    flex-wrap: wrap !important;
}

.hg-qb-info {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex: 1 !important;
    min-width: 200px !important;
}

.hg-qb-info > i {
    font-size: 22px !important;
    color: var(--hg-primary, #e12d2d) !important;
}

.hg-qb-details {
    display: flex !important;
    flex-direction: column !important;
}

.hg-qb-label {
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: #888 !important;
    font-weight: 600 !important;
}

.hg-qb-dates {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #1a1a2e !important;
}

.hg-qb-dates small {
    color: #888 !important;
    font-weight: 400 !important;
}

.hg-qb-guests {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 14px !important;
    color: #555 !important;
    padding: 0 16px !important;
    border-left: 1px solid rgba(0, 0, 0, 0.1) !important;
}

.hg-qb-guests i {
    color: var(--hg-primary, #e12d2d) !important;
    font-size: 16px !important;
}

.hg-qb-btn {
    white-space: nowrap !important;
    padding: 10px 20px !important;
    border-radius: var(--hg-radius-sm, 8px) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

.hg-qb-btn:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

@media (max-width: 767px) {
    .hg-quick-book-banner {
        padding: 12px 14px !important;
    }
    .hg-qb-inner {
        gap: 12px !important;
    }
    .hg-qb-guests {
        border-left: none !important;
        padding: 0 !important;
    }
    .hg-qb-btn {
        width: 100% !important;
        justify-content: center !important;
    }
}

