/* ===================================
    Crafto - Travel agency
====================================== */
/* font */
@import url('https://fonts.googleapis.com/css2?family=Lusitana:wght@400;700&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');


/* variable */
:root {     
    --base-color: #D4AF37; 
    --light-gray: #E7E4DF;
    --red: #d03c3c;
    --very-light-gray:#F2EFEB;
    --alt-font: 'Lusitana', sans-serif;
    --primary-font: 'Montserrat', sans-serif;
}
/* reset */
body {
    color: #616161;
    font-size: 20px;
    line-height: 32px; 
}
section, footer {
    padding-top: 100px;
    padding-bottom: 100px;
}
section.big-section {
    padding-top: 120px;
    padding-bottom: 120px;
}
/* heading */
h1 { 
    line-height: 3.8rem;
}
/* header */
.navbar .navbar-nav .nav-link {
    font-size: 22px;
}
.header-icon .icon > a {
    font-size: 19px;
}
header .navbar-brand img {
    max-height: 60px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
    border-bottom: 1px solid var(--extra-medium-gray);
    padding: 16px 20px;
    font-weight: 500;
    font-size: 16px;
    color: var(--dark-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:hover img {
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(502%) contrast(502%);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a:hover{
    background-color: var(--base-color);
    color: var(--white);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li.active > a {
        color: var(--medium-gray);
    }
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu {
    width: 320px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li a {
    color: var(--dark-gray);
    font-size: 17px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li a p {
    line-height: 22px;
    font-size: 14px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li a img {
    width: 60px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li.active > a {
    color: var(--medium-gray);
}
.push-menu .close-menu {
    right: 30px;
    top: 30px;
}
/* bg color */
.bg-gradient-gulf-blue-sepia-brown {
    background-image: linear-gradient(to right, #33455B, #494954, #795244, #91563D, #97573B);
}
.bg-bay-of-many-blue {
    background-color: #363f6d;
}
.bg-gradient-gray-light-dark-transparent {
    background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(32, 35, 41, 1)), to(transparent));
    background-image: linear-gradient(to top, rgba(32, 35, 41, 1) 0%, transparent 70%);
}
.border-color-transparent-dark-very-light {
    border-color: rgba(35, 35, 35, 0.15) !important;
}
/* feature box */
.feature-box.feature-box-left-icon-middle .feature-box-icon {
    margin-right: 20px;
}
/* page title  */
.page-title-extra-large h1 {
    font-size: 4.375rem;
    line-height: 5rem;
}
.page-title-extra-large h2 {
    font-size: 16px;
    line-height: 16px;
    padding: 12px 25px;
    display: inline-block;
}
.page-title-button-style h1 {
    padding: 0;
    display: block;
}
.small-screen {
    height: 350px !important;
}
/* btn */
.btn.btn-extra-large {
    font-size: 18px;
    padding: 16px 36px 16px; 
}
.btn.btn-large {
    font-size: 17px;
    padding: 14px 32px;
}
.btn.btn-medium {
    font-size: 15px;
    padding: 12px 30px;
}
.btn.btn-small {
    font-size: 14px;
    padding: 10px 25px;
}
.btn.btn-very-small {
    font-size: 12px;
    padding: 8px 20px;
}
.btn.btn-link {
    padding: 0 0 2px;
}
.btn i {
    margin-left: 6px;
}
.team-style-01 figure figcaption .social-icon a {
    margin: 0 7px;
}
/* blog */
.blog-modern figure .post-content-wrapper {
    bottom: -50px;
}
/* top right bottom left */
.top-minus-75px {
    top: -75px;
}
/* footer */
footer .elements-social ul li:last-child {
    margin-right: 0;
}
.footer-navbar li a:hover {
    color: var(--medium-gray);
}
footer .nav-link {
    line-height: normal;
    color: var(--dark-gray);
}
footer .elements-social ul li {
    margin: 0;
}
/* Revolution slider jquery */
.erinyen .tp-tab-title {
    font-size: 66px !important; text-align: center !important; text-transform: inherit !important; line-height: 60px !important; font-family: 'Barlow Semi Condensed', sans-serif !important; font-weight: 600 !important; letter-spacing: -3.3px; color: #ffffff !important;
}
.rev_column {
    border-right: 1px solid rgba(255,255,255,0.3)
}
.rev_column:last-child {
    border-right: 0px solid rgba(255,255,255,0.3)
}
.hesperiden.tparrows { width: 45px; height: 45px;background: rgba(0,0,0,.4); -webkit-transition: all 300ms ease-in-out; transition: all 300ms ease-in-out}
.hesperiden.tparrows:hover {background: #fff; }
.hesperiden.tparrows:before {line-height: 45px;}
.hesperiden.tparrows.tp-rightarrow:hover:before, .hesperiden.tparrows.tp-leftarrow:hover:before {color: #000}
.hesperiden.tparrows.tp-leftarrow:before { content: "\f104";font-family: "Font Awesome 6 Free";font-size: 15px; font-weight: 900}
.hesperiden.tparrows.tp-rightarrow:before { content: "\f105";font-family: "Font Awesome 6 Free";font-size: 15px; font-weight: 900; margin-right: 0}
/* media query responsive */
@media (min-width: 2100px){
    .background-image-layer {max-width: 120%!important; width: 3000px!important; overflow-y: visible!important; }
    .extra-grass-layer {max-width: 120%!important; width: 3000px!important; bottom: -200px; }
}
@media (max-width: 1199px) and (min-width: 992px){
    .blog-modern figure .post-content-wrapper { width: 90%; }
    .blog-modern figure .post-content-wrapper .separator { margin: 0 9px; }
}
@media (max-width: 1200px) and (min-width: 1024px){
    .object-layer {max-width: 800px !important; width: 800px !important;min-width: 800px !important;}
    .blog-modern figure .post-content-wrapper { width: 90%; }
}
@media (max-width: 991px){
    section, footer {
        padding-top: 75px;
        padding-bottom: 75px;
    }
    section.big-section {
        padding-top: 95px;
        padding-bottom: 95px;
    }
    .navbar .navbar-nav .simple-dropdown .dropdown-menu {
        margin-top: 15px;
    }
    .navbar .navbar-nav .simple-dropdown .dropdown-menu li a {
        padding: 14px 0 15px;
    }
}
@media (max-width: 767px){
    section, footer {
        padding-top: 50px;
        padding-bottom: 50px;
    }
    section.big-section {
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .small-screen {
        height: 300px !important;
    }
    .sm-clear-both {
        clear: both
    }
}
@media (max-width: 777px){
    .tp-loop-wrap .tp-parallax-wrap:nth-child(4) {display: none}
    #travel-agency_wrapper { height: 700px !important;}
    .tp-fullwidth-forcer {height: 700px !important;}
    section, footer { padding-top: 50px; padding-bottom: 50px; }
}
@media (max-width: 479px){
    .rev_row .rev_column:nth-child(4) {display: none !important;}   
    .rev_row .rev_column:nth-child(2) {display: none !important;}   
    #travel-agency_wrapper { height: 700px !important;}
    .tp-fullwidth-forcer {height: 700px !important;}
}
@media (max-width: 991px) and (min-width: 800px) and (orientation: landscape) {
    #travel-agency-slider_forcefullwidth {height: 500px !important;}
    #travel-agency_wrapper {height: 500px !important;}
    .background-image-layer {display: none!important;}
    .extra-grass-layer {max-width: 100%!important; width: 1200px!important;}
    .object-layer {max-width: 600px !important; width: 600px !important;min-width: 600px !important;}
    .rev_row .rev_column:nth-child(4) {display: none !important;}
    .package-details .rev_column {padding-bottom: 20px!important;}
    #slide-02-layer-03, #slide-02-layer-01, #slide-02-layer-02, #slide-03-layer-05, #slide-03-layer-01, #slide-03-layer-02, #slide-03-layer-04, #slide-03-layer-06 {max-width: 1200px !important; width: 1200px !important;min-width: 1200px !important;}
    #slide-02-layer-05 { bottom: 60px !important;}
}

.tab-style-08 ul .nav-item .nav-link {
    color: #616161;    
}


h1, h2, h3, h4  {
    color: rgb(218,165,32); /*if no support for background-clip*/
    background: -webkit-linear-gradient(transparent, transparent), -webkit-linear-gradient(top, rgba(218,165,32,1) 0%, rgba(213,173,109,1) 26%, rgba(226,186,120,1) 35%, rgba(163,126,67,1) 45%, rgba(212,175,55,1) 61%, rgba(213,173,109,1) 100%);
    background: -o-linear-gradient(transparent, transparent);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}


.img-caballo {
    position: absolute;
    right: -100px; /* Ajusta esta distancia para que el caballo salga desde la derecha */
    top: 50%; /* Centrar verticalmente */
    transform: translateY(-50%) scale(1.5); /* Aumenta el tamaño y centra verticalmente */
    animation: entrar 1s forwards; /* Agrega una animación */
}

@keyframes entrar {
    from {
        right: -200px; /* Comienza fuera de la pantalla */
        opacity: 0; /* Comienza invisible */
    }
    to {
        right: 0; /* Termina en su posición normal */
        opacity: 1; /* Termina visible */
    }
}

.bg-dark-black{
    background-color: #1E1E1E;
}

.bg-white-grey{
    background-color: #F7F6F4
}

.bg-black-grey {
    background-color: #1E1E1E;
}

.bg-nero-grey {
    background-color: #161616;
}


/* Para letra colores en el fondo negro */
.alt-color-font{
    color: #686868
}

/* Pala colores en fondo blanco */
bg-white-grey-letter{
    color: #616161
}
/* Titulos en fondo blanco */
.white-grey-letter{
    color: #1e1e1e
}

footer .footer-logo img {
    max-height: 80px;
}
.swiper, .swiper-wrapper {
    position: static;
}

@media (max-width: 800px) {
    .login-button {
        position: relative!important; 
        text-align: center!important;
    }
}

/* ===================================
   Results Page — Layout
====================================== */

.results-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 24px;
    align-items: start;
}

.results-sidebar-sticky {
    position: sticky;
    top: 90px;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #ddd transparent;
}

.results-sidebar-sticky::-webkit-scrollbar {
    width: 4px;
}

.results-sidebar-sticky::-webkit-scrollbar-thumb {
    background: #ddd;
    border-radius: 4px;
}

/* Results Bar */
.results-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
    padding: 14px 20px;
    background: #fff;
    border-radius: 10px;
    border: 1px solid #eee;
}

.results-bar-title {
    font-family: var(--primary-font);
    font-size: 16px;
    font-weight: 700;
    color: #1e1e1e;
    margin: 0 0 2px;
    line-height: 1.3;
}

.results-bar-meta {
    font-family: var(--primary-font);
    font-size: 12px;
    color: #888;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
}

.results-bar-meta i {
    font-size: 11px;
    color: var(--base-color);
}

.results-bar-dot {
    color: #ccc;
}

.results-bar-right {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

.results-sort-label {
    font-family: var(--primary-font);
    font-size: 12px;
    color: #888;
    white-space: nowrap;
    font-weight: 500;
}

.results-sort-select {
    font-family: var(--primary-font);
    font-size: 13px;
    font-weight: 500;
    color: #333;
    border: 1px solid #e8e8e8;
    border-radius: 8px;
    padding: 7px 12px;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.2s ease;
    -webkit-appearance: auto;
}

.results-sort-select:focus {
    outline: none;
    border-color: var(--base-color);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.08);
}

/* Alert */
.results-alert {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px 20px;
    border-radius: 10px;
    font-size: 14px;
    font-family: var(--primary-font);
}

.results-alert i {
    font-size: 18px;
    flex-shrink: 0;
    margin-top: 2px;
}

.results-alert p {
    margin: 4px 0 0;
    font-size: 13px;
}

.results-alert-error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #991b1b;
}

.results-alert-error i {
    color: #dc2626;
}

/* Empty State */
.results-empty {
    text-align: center;
    padding: 64px 24px;
    background: #fff;
    border-radius: 12px;
    border: 1px solid #eee;
}

.results-empty > i {
    font-size: 3rem;
    color: #ddd;
    margin-bottom: 16px;
    display: block;
}

.results-empty h4 {
    font-family: var(--primary-font);
    font-size: 18px;
    font-weight: 700;
    color: #333;
    margin: 0 0 8px;
}

.results-empty p {
    font-size: 14px;
    color: #888;
    margin: 0 0 16px;
}

.results-empty-hint {
    display: inline-block;
    font-size: 13px;
    color: #666;
    background: #f9f9f9;
    padding: 6px 14px;
    border-radius: 6px;
    border: 1px solid #eee;
}

.results-empty-actions {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 16px;
}

.results-empty-link {
    font-size: 13px;
    font-weight: 600;
    color: #555;
    background: #f5f5f5;
    padding: 6px 16px;
    border-radius: 20px;
    text-decoration: none;
    transition: all 0.2s ease;
    border: 1px solid #eee;
}

.results-empty-link:hover {
    background: var(--base-color);
    color: #fff;
    border-color: var(--base-color);
}


/* ===================================
   Filters Sidebar
====================================== */

.filters-minimal {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
    overflow: hidden;
    border: 1px solid #eee;
}

.filters-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid #f0f0f0;
}

.filters-title {
    font-family: var(--primary-font);
    font-size: 13px;
    font-weight: 700;
    color: #1e1e1e;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin: 0;
}

.filters-header-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

.filter-loading-indicator {
    color: var(--base-color);
    font-size: 13px;
}

.filters-clear {
    font-family: var(--primary-font);
    font-size: 12px;
    color: #888;
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s ease;
}

.filters-clear:hover {
    color: var(--base-color);
}

.filters-content {
    padding: 20px;
}

.filter-item {
    margin-bottom: 28px;
}

.filter-item:last-child {
    margin-bottom: 0;
}

.filter-label {
    display: block;
    font-family: var(--primary-font);
    font-size: 11px;
    font-weight: 700;
    color: #555;
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Stars */
.stars-filter {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.star-option {
    display: flex;
    align-items: center;
    cursor: pointer;
    padding: 8px 10px;
    border-radius: 6px;
    transition: all 0.15s ease;
    border: 1px solid transparent;
    position: relative;
    user-select: none;
}

.star-option:hover {
    background: #fafafa;
    border-color: #eee;
}

.star-option input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.star-display {
    display: flex;
    gap: 2px;
    color: #d4af37;
    font-size: 12px;
    transition: color 0.15s ease;
}

.star-option.active {
    background: rgba(212, 175, 55, 0.06);
    border-color: var(--base-color);
}

.star-option.active .star-display {
    color: var(--base-color);
}

.filters-minimal,
.filters-minimal * {
    pointer-events: auto !important;
}

.filters-minimal input,
.filters-minimal label {
    cursor: pointer;
}

/* Price */
.price-filter { margin-top: 4px; }

.price-input-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
}

.price-input {
    flex: 1;
    padding: 8px 12px;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    font-family: var(--primary-font);
    font-size: 13px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background: #fff;
    min-width: 0;
}

.price-input:focus {
    outline: none;
    border-color: var(--base-color);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.08);
}

.price-separator {
    color: #ccc;
    font-size: 13px;
    flex-shrink: 0;
}

/* Refundable */
.filter-option {
    display: flex;
    align-items: center;
    cursor: pointer;
    padding: 10px;
    border-radius: 6px;
    transition: background 0.15s ease;
    border: 1px solid transparent;
}

.filter-option:hover {
    background: #fafafa;
}

.filter-option input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.filter-checkmark {
    width: 18px;
    height: 18px;
    border: 2px solid #ddd;
    border-radius: 4px;
    margin-right: 10px;
    position: relative;
    flex-shrink: 0;
    transition: all 0.15s ease;
    background: #fff;
}

.filter-option input[type="checkbox"]:checked + .filter-checkmark {
    background: var(--base-color);
    border-color: var(--base-color);
}

.filter-option input[type="checkbox"]:checked + .filter-checkmark::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 1px;
    width: 5px;
    height: 9px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.filter-text {
    font-family: var(--primary-font);
    font-size: 13px;
    color: #333;
    font-weight: 500;
}

.filter-option:hover .filter-text {
    color: var(--base-color);
}

/* Hotel Name Search */
.filter-search-wrapper {
    position: relative;
}

.filter-search-icon {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 12px;
    color: #bbb;
    pointer-events: none;
}

.filter-search-input {
    width: 100%;
    padding: 8px 12px 8px 32px;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    font-family: var(--primary-font);
    font-size: 13px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background: #fff;
}

.filter-search-input:focus {
    outline: none;
    border-color: var(--base-color);
    box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.08);
}

.filter-search-input::placeholder {
    color: #bbb;
}

/* Meal Type Segmented Control */
.meal-segment {
    display: flex;
    gap: 0;
    background: #f0f0f0;
    border-radius: 6px;
    padding: 3px;
}

.meal-segment-option {
    flex: 1;
    text-align: center;
    cursor: pointer;
    padding: 7px 4px;
    border-radius: 5px;
    font-family: var(--primary-font);
    font-size: 11px;
    font-weight: 600;
    color: #888;
    transition: all 0.15s ease;
    user-select: none;
    line-height: 1.3;
}

.meal-segment-option input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.meal-segment-option span {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    white-space: nowrap;
}

.meal-segment-option span i {
    font-size: 10px;
}

.meal-segment-option:hover {
    color: #555;
}

.meal-segment-option.active,
.meal-segment-option:has(input:checked) {
    background: #fff;
    color: #1e1e1e;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* More Filters — Collapsible */
.filter-more-toggle {
    display: none;
}

.filter-more-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    font-family: var(--primary-font);
    font-size: 12px;
    font-weight: 600;
    color: #888;
    padding: 6px 0;
    user-select: none;
    transition: color 0.15s ease;
}

.filter-more-label:hover {
    color: var(--base-color);
}

.filter-more-icon {
    font-size: 10px;
    transition: transform 0.2s ease;
}

.filter-more-toggle:checked ~ .filter-more-label .filter-more-icon {
    transform: rotate(180deg);
}

.filter-more-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.25s ease;
}

.filter-more-toggle:checked ~ .filter-more-content {
    max-height: 200px;
}

.filter-more-content .filter-option {
    margin-top: 6px;
}


/* ===================================
   Hotel Cards
====================================== */

.hotel-card {
    display: flex;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 14px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    border: 1px solid #eee;
    transition: box-shadow 0.2s ease, transform 0.15s ease;
}

.hotel-card:hover {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transform: translateY(-1px);
}

.hotel-card-image {
    display: block;
    width: 220px;
    min-width: 220px;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
    background: #f5f5f5;
}

.hotel-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.hotel-card:hover .hotel-card-image img {
    transform: scale(1.04);
}

.hotel-card-image-fallback {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ddd;
    font-size: 2rem;
    background: #f8f8f8;
    min-height: 160px;
}

.hotel-badge-premium {
    position: absolute;
    top: 10px;
    left: 10px;
    background: rgba(30, 30, 30, 0.85);
    color: var(--base-color);
    font-size: 10px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 4px;
    letter-spacing: 0.5px;
    backdrop-filter: blur(4px);
}

.hotel-card-body {
    display: flex;
    flex: 1;
    min-width: 0;
}

.hotel-card-info {
    flex: 1;
    padding: 16px 18px;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.hotel-card-name {
    font-family: var(--primary-font);
    font-size: 15px;
    font-weight: 700;
    color: #1e1e1e;
    text-decoration: none;
    line-height: 1.3;
    display: block;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hotel-card-name:hover {
    color: var(--base-color);
}

.hotel-card-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}

.hotel-stars {
    color: var(--base-color);
    font-size: 11px;
    display: flex;
    gap: 1px;
    flex-shrink: 0;
}

.hotel-address {
    font-size: 12px;
    color: #999;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 4px;
    min-width: 0;
}

.hotel-address i { color: #e74c3c; flex-shrink: 0; font-size: 10px; }
.hotel-address span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hotel-address:hover { color: var(--base-color); }

.hotel-card-room {
    margin-top: auto;
    border-top: 1px solid #f5f5f5;
    padding-top: 10px;
}

.hotel-room-name {
    font-family: var(--primary-font);
    font-size: 12px;
    font-weight: 600;
    color: #444;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.hotel-room-name i { color: #bbb; margin-right: 4px; font-size: 11px; }

.hotel-room-occupancy {
    font-size: 12px;
    color: #999;
    margin-bottom: 6px;
}

.hotel-room-occupancy i { margin-right: 2px; font-size: 10px; }
.hotel-room-occupancy .dot { margin: 0 4px; }

.hotel-room-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.tag {
    font-family: var(--primary-font);
    font-size: 11px;
    font-weight: 500;
    padding: 3px 8px;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    line-height: 1.4;
}

.tag i { font-size: 9px; }
.tag-green { background: #ecfdf5; color: #059669; }
.tag-red { background: #fef2f2; color: #dc2626; }
.tag-blue { background: #eff6ff; color: #2563eb; }
.tag-gray { background: #f5f5f5; color: #999; }
.tag-neutral { background: #f5f5f5; color: #666; border: 1px solid #e5e5e5; }
.tag-promo { background: #fffbeb; color: #b45309; }

.hotel-room-promo { margin-top: 5px; }
.hotel-room-promo span {
    font-size: 11px; color: #b45309; background: #fffbeb;
    padding: 2px 8px; border-radius: 4px;
}
.hotel-room-promo span i { font-size: 9px; margin-right: 2px; }

/* Price Column */
.hotel-card-price {
    width: 155px;
    min-width: 155px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    text-align: right;
    border-left: 1px solid #f0f0f0;
    background: #fafafa;
    flex-shrink: 0;
}

.price-label {
    font-family: var(--primary-font);
    font-size: 11px;
    color: #aaa;
    margin-bottom: 2px;
}

.price-amount {
    font-family: var(--primary-font);
    font-size: 22px;
    font-weight: 700;
    color: #1e1e1e;
    line-height: 1.2;
}

.price-amount small { font-size: 11px; font-weight: 400; color: #aaa; }

.price-tax {
    font-size: 10px;
    color: #bbb;
    margin-bottom: 10px;
}

.btn-reserve {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    width: 100%;
    padding: 9px 0;
    font-family: var(--primary-font);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.4px;
    color: #fff;
    background: var(--base-color);
    border-radius: 6px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.btn-reserve:hover {
    background: #c09800;
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 3px 10px rgba(212, 175, 55, 0.3);
}

.btn-reserve i { font-size: 10px; margin-left: 0; }

.price-inclusion {
    font-size: 10px;
    color: #059669;
    margin-top: 6px;
    text-align: right;
}

.price-inclusion i { margin-right: 2px; }


/* ===================================
   Results Page — Responsive
====================================== */

/* Tablet */
@media (max-width: 991px) {
    .results-layout {
        grid-template-columns: 1fr;
    }

    .results-sidebar {
        order: -1;
    }

    .results-sidebar-sticky {
        position: static;
        max-height: none;
    }

    .results-bar {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .hotel-card-image {
        width: 180px;
        min-width: 180px;
    }

    .hotel-card-price {
        width: 135px;
        min-width: 135px;
    }

    .price-amount { font-size: 18px; }
}

/* Mobile */
@media (max-width: 767px) {
    .results-page .results-wide {
        padding: 0 16px;
    }

    .results-bar {
        padding: 12px 16px;
    }

    .results-bar-title { font-size: 15px; }

    .results-sort-select {
        width: 100%;
    }

    .hotel-card {
        flex-direction: column;
    }

    .hotel-card-image {
        width: 100%;
        min-width: 100%;
        height: 180px;
    }

    .hotel-card-body {
        flex-direction: column;
    }

    .hotel-card-price {
        width: 100%;
        min-width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        border-left: none;
        border-top: 1px solid #f0f0f0;
        padding: 14px 16px;
        gap: 8px;
    }

    .btn-reserve {
        width: 100%;
        padding: 10px 0;
        font-size: 13px;
        order: 10;
    }

    .price-tax { margin-bottom: 0; }
    .price-inclusion { order: 11; width: 100%; text-align: center; }
}

/* =============================================
   Hotel Detail Page — Premium layout
   ============================================= */
.container-detail-wide {
    max-width: 1320px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 24px;
    padding-right: 24px;
}

.detail-hero {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 32px;
    align-items: start;
    margin-bottom: 40px;
}

.detail-hero-left { min-width: 0; }

/* Gallery */
.detail-gallery {
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
    border: 1px solid #eee;
    margin-bottom: 24px;
}

.detail-gallery-main {
    position: relative;
    aspect-ratio: 16/10;
    cursor: pointer;
    display: block;
    overflow: hidden;
}

.detail-gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.25s ease;
}

.detail-gallery-main:hover img { transform: scale(1.03); }

.detail-gallery-main:focus {
    outline: 2px solid var(--base-color);
    outline-offset: 2px;
}

.detail-gallery-placeholder {
    width: 100%;
    height: 100%;
    background: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    color: #ccc;
}

.detail-gallery-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    opacity: 0;
    transition: opacity 0.2s;
}

.detail-gallery-main:hover .detail-gallery-overlay { opacity: 1; }

.detail-gallery-badges {
    position: absolute;
    top: 12px;
    left: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    z-index: 1;
}

.detail-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

.detail-badge-green { background: #ecfdf5; color: #059669; }
.detail-badge-gold { background: rgba(212, 175, 55, 0.95); color: #fff; }
.detail-badge-premium { border: 1px solid var(--base-color); color: var(--base-color); }

.detail-gallery-thumbs {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
    padding: 8px;
}

.detail-gallery-thumb {
    aspect-ratio: 1;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    position: relative;
}

.detail-gallery-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.detail-gallery-thumb:focus { outline: 2px solid var(--base-color); outline-offset: 2px; }

.detail-gallery-thumb-more {
    background: #333;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 600;
}

.detail-gallery-thumb-more small { font-size: 11px; opacity: 0.9; }

/* Hotel info below gallery */
.detail-hotel-info { padding: 0 4px; }

.detail-hotel-name {
    font-family: var(--primary-font);
    font-size: 1.75rem;
    font-weight: 700;
    color: #1e1e1e;
    margin-bottom: 8px;
    line-height: 1.3;
}

.detail-hotel-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.detail-stars { color: var(--base-color); }

.detail-address {
    font-size: 14px;
    color: #666;
    margin-bottom: 16px;
}

.detail-address a {
    color: var(--base-color);
    text-decoration: none;
    margin-left: 8px;
}

.detail-address a:hover { text-decoration: underline; }

.detail-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.detail-highlight-chip {
    font-size: 12px;
    padding: 6px 12px;
    border-radius: 20px;
    background: #f8f8f8;
    color: #555;
    border: 1px solid #eee;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.detail-highlight-chip i { color: var(--base-color); }

/* Booking card sticky */
.detail-hero-right { position: relative; }

.detail-booking-card {
    position: sticky;
    top: 100px;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
    border: 1px solid #eee;
    padding: 24px;
}

.detail-booking-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: #1e1e1e;
    margin-bottom: 16px;
}

.detail-booking-dates {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.detail-booking-date-item {
    flex: 1;
    text-align: center;
    padding: 8px;
    background: #f8f8f8;
    border-radius: 8px;
}

.detail-booking-date-label,
.detail-booking-time { font-size: 11px; color: #888; display: block; }

.detail-booking-date-value { font-weight: 600; font-size: 14px; display: block; }

.detail-booking-arrow { color: #ccc; font-size: 12px; }

.detail-booking-guests { font-size: 13px; color: #555; margin-bottom: 16px; }

.detail-booking-hr { margin: 16px 0; border-color: #eee; }

.detail-booking-price-label { font-size: 12px; color: #888; display: block; }

.detail-booking-price-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: #1e1e1e;
}

.detail-booking-price-note { font-size: 11px; color: #888; display: block; margin-top: 4px; }

.btn-detail-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 14px 20px;
    margin-top: 16px;
    background: var(--base-color);
    color: #fff;
    font-weight: 600;
    border: none;
    border-radius: 12px;
    text-decoration: none;
    transition: background 0.2s, transform 0.15s;
}

.btn-detail-cta:hover { background: #c09800; color: #fff; transform: translateY(-1px); }

.btn-detail-cta:focus { outline: 2px solid var(--base-color); outline-offset: 2px; }

/* About section */
.detail-about {
    background: #fff;
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 32px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
    border: 1px solid #eee;
}

.detail-section-title {
    font-family: var(--primary-font);
    font-size: 1.25rem;
    font-weight: 700;
    color: #1e1e1e;
    margin-bottom: 16px;
}

.detail-about-text { font-size: 14px; line-height: 1.6; color: #555; }

.detail-read-more {
    color: var(--base-color);
    font-weight: 600;
    text-decoration: none;
    margin-left: 4px;
}

.detail-read-more:hover { text-decoration: underline; }

.detail-about-highlights {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #f0f0f0;
    font-size: 13px;
    color: #666;
}

.detail-about-highlights li { margin-bottom: 6px; }

.detail-about-highlights i { color: var(--base-color); margin-right: 8px; width: 18px; }

/* Rooms section */
.detail-rooms { margin-bottom: 40px; }

.detail-rooms-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
}

.detail-rooms-count { font-size: 0.9rem; font-weight: 500; color: #666; }

.detail-rooms-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-left: auto;
}

.detail-sort-label { font-size: 13px; color: #666; margin: 0; }

.detail-sort-select {
    width: auto;
    min-width: 180px;
    font-size: 13px;
    border-radius: 8px;
}

.detail-filter-chips { display: flex; flex-wrap: wrap; gap: 8px; }

.detail-filter-chip {
    font-size: 12px;
    padding: 6px 14px;
    border-radius: 20px;
    border: 1px solid #e0e0e0;
    background: #fff;
    color: #555;
    cursor: pointer;
    transition: all 0.2s;
}

.detail-filter-chip:hover { border-color: var(--base-color); color: var(--base-color); }

.detail-filter-chip.active {
    background: var(--base-color);
    border-color: var(--base-color);
    color: #fff;
}

.detail-filter-chip:focus { outline: 2px solid var(--base-color); outline-offset: 2px; }

/* Room card 3 zones */
.detail-room-card {
    display: grid;
    grid-template-columns: 180px 1fr 220px;
    gap: 0;
    background: #fff;
    border-radius: 16px;
    border: 1px solid #eee;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
    margin-bottom: 20px;
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.15s;
}

.detail-room-card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    transform: translateY(-2px);
}

.detail-room-card-image {
    min-height: 140px;
    background: #f5f5f5;
}

.detail-room-card-image-link {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 140px;
    position: relative;
    overflow: hidden;
}

.detail-room-card-image-link img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.detail-room-card-image-fallback {
    width: 100%;
    height: 100%;
    min-height: 140px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    color: #ccc;
}

.detail-room-card-quickview {
    position: absolute;
    bottom: 8px;
    left: 8px;
    font-size: 11px;
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    padding: 4px 8px;
    border-radius: 6px;
    opacity: 0;
    transition: opacity 0.2s;
}

.detail-room-card-image-link:hover .detail-room-card-quickview { opacity: 1; }

.detail-room-card-body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.detail-room-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: #1e1e1e;
    margin-bottom: 10px;
    line-height: 1.3;
}

.detail-room-card-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.detail-room-card-chips .tag { font-size: 11px; padding: 4px 8px; }

.detail-room-card-inclusion { font-size: 12px; }

.detail-room-card-price {
    padding: 20px;
    background: #fafafa;
    border-left: 1px solid #eee;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.detail-room-price-label { font-size: 11px; color: #888; display: block; }

.detail-room-price-amount { font-size: 1.25rem; font-weight: 700; color: #1e1e1e; display: block; margin: 4px 0; }

.detail-room-price-pernight,
.detail-room-price-tax { display: block; }

.btn-reserve-detail {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 12px 16px;
    margin-top: 12px;
    background: var(--base-color);
    color: #fff;
    font-weight: 600;
    border: none;
    border-radius: 10px;
    text-decoration: none;
    font-size: 14px;
    transition: background 0.2s;
}

.btn-reserve-detail:hover { background: #c09800; color: #fff; }

.detail-room-policy-btn { font-size: 12px; color: #666; text-decoration: underline; }

.detail-room-policy-box {
    background: #f8f8f8;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 12px;
    color: #555;
}

/* Amenities */
.detail-amenities-section { margin-bottom: 40px; }

.detail-amenities-search-wrapper {
    position: relative;
    max-width: 280px;
    margin-bottom: 20px;
}

.detail-amenities-search-wrapper i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #999;
    font-size: 14px;
}

.detail-amenities-search { padding-left: 36px; border-radius: 10px; }

.detail-amenity-category { margin-bottom: 20px; }

.detail-amenity-category-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 10px;
}

.detail-amenity-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px 24px;
}

.detail-amenity-item { font-size: 13px; color: #555; }

/* Mobile booking bar */
.detail-booking-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fff;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
    padding: 12px 16px;
    z-index: 1000;
    transform: translateY(100%);
    transition: transform 0.25s ease;
    display: none;
}

.detail-booking-bar.detail-booking-bar-visible {
    transform: translateY(0);
    display: block;
}

.detail-booking-bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1320px;
    margin: 0 auto;
    gap: 16px;
}

.detail-booking-bar-price { font-weight: 700; font-size: 1.1rem; color: #1e1e1e; }

.detail-booking-bar .btn-detail-cta { margin-top: 0; width: auto; min-width: 160px; }

/* Tablet */
@media (max-width: 1023px) {
    .detail-hero {
        grid-template-columns: 1fr;
    }

    .detail-booking-card { position: static; margin-bottom: 24px; }

    .detail-room-card {
        grid-template-columns: 140px 1fr 200px;
    }

    .detail-amenity-list { grid-template-columns: 1fr; }
}

/* Mobile */
@media (max-width: 767px) {
    .container-detail-wide { padding-left: 16px; padding-right: 16px; }

    .detail-gallery-thumbs { grid-template-columns: repeat(4, 1fr); }

    .detail-hotel-name { font-size: 1.4rem; }

    .detail-rooms-header { flex-direction: column; align-items: flex-start; }

    .detail-rooms-controls { margin-left: 0; width: 100%; }

    .detail-sort-select { width: 100%; min-width: 0; }

    .detail-room-card {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
    }

    .detail-room-card-image { min-height: 160px; }

    .detail-room-card-image-link { min-height: 160px; }

    .detail-room-card-body { padding: 16px; }

    .detail-room-card-price {
        border-left: none;
        border-top: 1px solid #eee;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
    }

    .detail-room-price-total { text-align: left; }

    .btn-reserve-detail { width: 100%; margin-top: 8px; order: 10; }

    .detail-booking-bar .btn-detail-cta { width: 100%; }
}
