/* Botón flotante teléfono */
.floating-phone-btn {
    position: fixed;
    right: 20px;
    bottom: 100px;
    z-index: 1050;
    /* encima de casi todo en Bootstrap */

    width: 60px;
    height: 60px;
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;

    font-size: 26px;
    color: #fff;
    background-color: #198754;
    /* verde bootstrap */

    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
    transition: all 0.3s ease;
    text-decoration: none;
}

.floating-phone-btn:hover {
    transform: scale(1.1);
    background-color: #157347;
    color: #fff;
}

.img-100 {
    width: 100%;
}

.gallery-thumb {
    width: 100%;
    height: 200px;
    /* altura fija para que todas se vean parejas */
    object-fit: cover;
    /* recorta sin deformar */
}

.share-btn {
    position: fixed;
    bottom: 170px;
    right: 20px;
    width: 60px;
    height: 60px;
    background-color: #283a5a;
    border-color: #1d345a;
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    z-index: 999;
    text-decoration: none;
    transition: all 0.2s ease;
}

.share-btn:hover {
    transform: scale(1.08);
    background-color: #333;
}

.h3,
h3 {
    font-size: 1.5em;
}

.h2,
h2 {
    font-weight: bold;
}

.featured-tours .tour-card .tour-content p {
    margin-bottom: 0px;
    flex-grow: 0.7
}

.featured-tours .tour-card .tour-content .tour-highlights {
    margin-bottom: 20px
}

.header .logo img {
    max-height: 50px;
}

body,
.h1,
.h2,
h1,
h3,
a {
    font-family: "Josefin Sans", sans-serif !important;
}

.h4,
h4,
h2,
.h2 {
    font-family: 'Poppins', sans-serif
}

p {
    font-family: 'Poppins', sans-serif;
    font-size: 1.1em;
    line-height: 2em;
    color: #333333 !important;
}

.josefin-sans-b {
    font-family: "Josefin Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
}

.navmenu a,
.navmenu a:focus {
    font-size: 1.2em;
}

.btn-danger {
    background-color: #d27668;
    border-color: #d16858;
}

.btn-primary {
    background-color: #4c7281;
    border-color: #3d6e82;
}

.section-title div .description-title {
    color: #283a5a;
}

.bg-primary {
    background-color: #4c7281 !important;
    border-color: #3d6e82;
}

.travel-destinations .isotope-container .destination-tile .tile-image .overlay-content .destination-info .destination-stats .starting-price {
    color: #deca97;
}

.travel-destinations .isotope-container .destination-tile .tile-image .overlay-content .destination-tag.luxury {
    background-color: #dc9668;
}

.featured-tours .tour-card .tour-content .tour-action .btn-book {
    background-color: #4c7281 !important;
}

.travel-destination-details .cta-section {
    background: #283a5a;
}

.travel-destinations .isotope-container .destination-tile .tile-image .overlay-content .destination-info h4 {
    font-size: 20px;
}

.text-primary {
    color: #4c7281 !important;
}

.border-primary {
    border-color: #4c7281 !important;
}


.text-danger {
    color: #d27668 !important;
}

.border-danger {
    border-color: #d27668 !important;
}

.bg-danger {
    background-color: #d27668 !important;
}

.card-title {
    font-weight: bold !important;
}

.card-body ul {
    flex-grow: 1;
}
li {
    font-family: 'Poppins', sans-serif;
}

.h2, h2{
    font-size: 1.4em;
}

/* Header light variant */
.header.header-light {
    --default-color: #333333;
    --heading-color: #1c4b56;
    --surface-color: rgba(255, 255, 255, 0.95);
}

.scrolled .header.header-light {
    --surface-color: rgba(255, 255, 255, 0.97);
}

.header.header-light .navmenu a {
    color: #333333;
}

.header.header-light .navmenu a:hover,
.header.header-light .navmenu a.active {
    color: var(--accent-color);
}

/* Prices: trust strip + simple card badges (no brand assets) */
.payment-trust-strip {
    max-width: 100%;
}

.payment-card-badge {
    display: inline-block;
    padding: 0.25rem 0.5rem;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: #495057;
    background: #fff;
    border: 1px solid #dee2e6;
    border-radius: 4px;
    line-height: 1.2;
}

.payment-card-badge--sm {
    font-size: 0.62rem;
    padding: 0.15rem 0.35rem;
}