/* Custom CSS for Cotlas Travel Child Theme */

body,
button,
input,
select,
textarea {
    font-family: var(--gp-font--nunito-sans);
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--gp-font--nunito-sans);
}

/* Text elements */
p, span, a, li, td, th, label, figcaption, blockquote, cite {
    font-family: var(--gp-font--nunito-sans);
}

/* Form elements (already covered in base, but being explicit) */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
textarea,
select {
    font-family: var(--gp-font--nunito-sans);
}

/* WordPress/GeneratePress specific classes */
.site-title,
.site-description,
.entry-title,
.widget-title,
.main-navigation a,
.menu-toggle,
.post-meta,
.comment-meta,
.comment-author,
.wp-block-button__link,
.wp-block-search__input,
.wp-block-quote,
.wp-block-pullquote,
.wp-block-table,
.wp-block-verse,
.wp-block-preformatted {
    font-family: var(--gp-font--nunito-sans);
}

/* Additional common elements */
strong, b, em, i, u, mark, code, pre, small, sub, sup {
    font-family: var(--gp-font--nunito-sans);
}

/* Links (already covered but being explicit) */
a:link,
a:visited,
a:hover,
a:active,
a:focus {
    font-family: var(--gp-font--nunito-sans);
}

/* Breadcrumbs */
.breadcrumbs,
.woocommerce-breadcrumb {
    font-family: var(--gp-font--nunito-sans);
}

/* Footer elements */
.site-info,
.footer-widgets {
    font-family: var(--gp-font--nunito-sans);
}

/* Ensure proper inheritance for pseudo-elements */
::placeholder,
::-webkit-input-placeholder,
::-moz-placeholder,
:-ms-input-placeholder,
:-moz-placeholder {
    font-family: var(--gp-font--nunito-sans);
}

/* For any dynamically added content */
* {
    font-family: inherit;
}
.cotlas-social-links {
    display: inline-block;
}
.cotlas-social-links .social-icons-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 12px;
    align-items: center;
}
.cotlas-social-links .social-link {
    margin: 0;
    padding: 0;
    line-height: 1;
}
.cotlas-social-links .social-link a {
    display: block;
    padding: 0;
    margin: 0;
    background: 0 0;
    border: none;
    border-radius: 0;
    text-decoration: none;
    color: currentColor;
    transition: opacity .2s;
}
.cotlas-social-links .social-link svg {
    display: block;
    fill: currentColor;
}
.cotlas-social-links .social-link a:hover {
    opacity: .7;
    background: 0 0;
    border: none;
}
.footer.cotlas-social-links {
    display: inline-block;
}
.footer.cotlas-social-links .social-icons-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 12px;
    align-items: center;
}
.footer.cotlas-social-links .social-link {
    margin: 0;
    padding: 0;
    line-height: 1;
}
.footer.cotlas-social-links .social-link a {
    display: block;
    padding: 0;
    margin: 0;
    background: 0 0;
    border: none;
    border-radius: 0;
    text-decoration: none;
    color: var(--base-3);
    transition: opacity .2s;
}
.footer.cotlas-social-links .social-link svg {
    display: block;
    fill: var(--white);
}
.footer.cotlas-social-links .social-link a:hover {
    opacity: .7;
    background: 0 0;
    border: none;
}
@media (max-width: 1024px) {
    .footer.cotlas-social-links .social-link svg {
        width: 20px;
        height: 20px;
    }
}
.cotlas-search {
    width: 260px;
}
.ofc-row-top .cotlas-search {
    width: 225px;
}
.cotlas-search .wp-block-search__inside-wrapper {
    border: 1px solid #ecebeb !important;
    padding: 0 !important;
    border-radius: 50px !important;
    background-color: #f7f5f5;
    max-width: 100%;
    display: flex;
    align-items: center;
}
.cotlas-search input[type=search] {
    background-color: #ffffff00;
    border-color: #ffffff00;
    color: #292929;
    background-color: #ffffff00;
    border-color: #ffffff00;
    border: 0;
    border-radius: 0;
    padding: 5px 15px;
    max-width: 100%;
    width: 100%;
    min-width: 0;
    flex: 1;
    font-size: 18px;
    line-height: 2;
}
.cotlas-search .wp-block-search__button.has-icon {
    background-color: #55555e00;
    line-height: 0;
    color: #292929;
    background-color: #55555e00;
    padding: 5px;
    border: none;
    cursor: pointer;
}
.cotlas-search svg {
    display: block;
    fill: currentColor;
    width: 30px;
    height: 30px;
}
.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    word-wrap: normal;
    border: 1px solid red !important;
}

.copy-footer {
    color: #ffffff;
    margin-bottom: 0px;
    font-size: 18px;
    font-weight: 600;
}
.copy-footer a{
    color: var(--global-color-9);
    text-decoration: none;
}
@media (max-width: 1024px) {
    .copy-footer {
        font-size: 16px;
    }
}
.footer-menu a {
    color: var(--white);
    text-decoration: none;
}
.site-header {
    background-color: #f7f8f908;
}
/* Desktop Sticky */
/* Desktop Sticky Header */
@media (min-width: 600px) {
    /* Default state - normal position */
    .site-header.is-sticky {
        position: relative;
        width: 100%;
        z-index: 100;
        transition: all 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    }
    
    /* Sticky active state - fixed at top */
    .site-header.is-sticky.is-sticky-active {
        position: fixed !important;
        top: 0;
        left: 0;
        right: 0;
        animation: slideDown 0.6s ease;
    }
    
    /* Slide down animation */
    @keyframes slideDown {
        0% {
            transform: translateY(-100%);
            opacity: 0.8;
        }
        100% {
            transform: translateY(0);
            opacity: 1;
        }
    }
    
    /* Add padding to body when header is sticky */
    body.has-sticky-active {
        padding-top: 80px; /* Adjust based on your header height */
    }
}

/* Mobile - disable sticky */
@media (max-width: 768px) {
    .site-header.is-sticky {
        position: relative !important;
        transform: none !important;
    }
    
    body.has-sticky-active {
        padding-top: 0 !important;
    }
}
@media (max-width: 1024px) {
  .footer-container {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important; /* Creates 2 equal columns */
    gap: 20px;
  }

  /* Order controls vertical position in grid */
  .about-us-footer { 
    order: 1; 
    grid-column: 1; /* First column */
  }
  .contact-footer { 
    order: 2; 
    grid-column: 2; /* Second column */
  }
  .menu-footer { 
    order: 3; 
    grid-column: 1 / span 2; /* Spans both columns (full width) */
    width: 100% !important;
  }
    .cotlas-search {
        width: 230px;
    }
}
/* Mobile Layout (768px and below) - 3 rows */
@media (max-width: 768px) {
  /* Order controls vertical position in grid */
  .about-us-footer { 
    order: 1; 
    grid-column: 1; /* First column */
  }
  .contact-footer { 
    order: 3; 
    grid-column: 2; /* Second column */
  }
  .menu-footer { 
    order: 2; 
    grid-column: 1 / span 2; /* Spans both columns (full width) */
    width: 100% !important;
  }
  .copy-footer {
        color: #ffffff;
        margin-bottom: 0px;
        font-size: 18px;
        font-weight: 600;
        text-align: center; /* This will center align the text */
    }
    .footer.cotlas-social-links .social-link svg {
        width: 30px;
        height: 30px;
    }
}
.menu-toggle {
    line-height: 0px!important;
}
.menu-toggle .gp-icon svg {
    height: 2em;
    width: 2em;
    fill: rgb(255 255 255);
}
.mobile-menu .menu-toggle .gp-icon svg {
    height: 2em;
    width: 2em;
    fill: rgb(0, 0, 0);
}
/* Animations */
.pulse {
    animation: pulse 1.5s infinite;
}
@keyframes pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.1); }
    100% { transform: scale(1); }
}
.blink {
    animation: blink 1s infinite;
}
@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}
.bounce {
    animation: bounce 1s infinite;
}
@keyframes bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}
.shake {
    animation: shake 0.5s infinite;
}
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-3px); }
    75% { transform: translateX(3px); }
}
.spin {
    animation: spin 2s linear infinite;
}
@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}
.glow {
    animation: glow 1.5s ease-in-out infinite;
}
@keyframes glow {
    0%, 100% { box-shadow: 0 0 5px #2A6E3F; }
    50% { box-shadow: 0 0 20px #D55B3E, 0 0 30px #D55B3E; }
}
.wiggle {
    animation: wiggle 0.8s infinite;
}
@keyframes wiggle {
    0%, 100% { transform: rotate(-3deg); }
    50% { transform: rotate(15deg); }
}
.color-flash {
    animation: color-flash 2s infinite;
}
@keyframes color-flash {
    0% { color: #2A6E3F; }
    50% { color: #D55B3E; }
    100% { color: #2A6E3F; }
}
.float {
    animation: float 3s ease-in-out infinite;
}
@keyframes float {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-10px); }
}
.heartbeat {
    animation: heartbeat 1.2s infinite;
}
@keyframes heartbeat {
    0% { transform: scale(1); }
    25% { transform: scale(1.1); }
    50% { transform: scale(1); }
    75% { transform: scale(1.15); }
    100% { transform: scale(1); }
}
.flash-bg {
    animation: flash-bg 0.8s infinite;
}
@keyframes flash-bg {
    0%, 100% { 
        background-color: #2A6E3F;
        color: white;
    }
    50% { 
        background-color: #D55B3E;
        color: white;
    }
}
.flash-db {
    animation: flash 0.8s infinite;
}
@keyframes flash {
    0%, 100% { color: #2A6E3F; }
    50% { color: #D55B3E; }
}
.flash-border {
    animation: flash-border 1s infinite;
}
@keyframes flash-border {
    0%, 100% { 
        border-color: #2A6E3F;
        box-shadow: 0 0 0 0 #2A6E3F;
    }
    50% { 
        border-color: #D55B3E;
        box-shadow: 0 0 0 3px #D55B3E;
    }
}
.ofc-row-middle a {
    font-size: 15px;
    font-weight: 600;
}
.copy-footer-ofc {
    color: var(--black);
    margin-bottom: 0px;
    font-size: 15px;
    line-height: 26px;
    font-weight: 600;
    white-space: normal; /* Prevents text wrapping */
}

.copy-footer-ofc a {
    color: var(--accent)!important;
    font-weight: 700;
    display: inline !important; /* Force inline display */
}
.book-now-button a{
    color: var(--white)!important;
    line-height: 15px;
}
@media (max-width: 768px) {
    .separate-containers .inside-article, .separate-containers .comments-area, .separate-containers .page-header, .separate-containers .paging-navigation, .one-container .site-content, .inside-page-header {
        padding: 10px 10px 10px 10px;
    }
}
@media (min-width: 1024px) {
    .main-content-wrapper {
        --tmp-sidebar-width: 28%;
    }
}
.sidebar {
    width: var(--tmp-sidebar-width);
}
.main-content {
    width: calc(100% - var(--tmp-sidebar-width));
}
.grid-container {
    margin-left: auto;
    margin-right: auto;
    max-width: 1200px !important;
}
.trip-fact-item {
    column-gap: 12px;
}
.trip-fact-item .fact-container {
    column-gap: 5px;
    row-gap: 5px;
}
.trip-fact-item .fact-item-name {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.2;
    color: var(--border-dark);
}
.trip-fact-item .fact-item-value {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.4;
    color: var(--black);
}
@media (max-width: 767px) {
        .trip-fact-item {
        column-gap: 12px;
    }
    .trip-fact-item .fact-container {
        column-gap: 5px;
        row-gap: 5px;
    }
    .trip-fact-item .fact-item-name {
        font-size: 14px;
        font-weight: 400;
        line-height: 1;
        color: var(--border-dark);
    }
    .trip-fact-item .fact-item-value {
        font-size: 14px;
        font-weight: 700;
        line-height: 1.2;
        color: var(--black);
    }
    .trip-facts-list {
        column-gap: 16px!important;
        row-gap: 20px!important;
    }
    .fact-image {
        width: 30px!important;
        height: 30px!important;
    }
}
.pricing-details .price {
    font-size: 27px !important;
    color: #027602;
    margin-bottom: 0;
}
.pricing-details .pricing-type {
    font-size: 18px !important;
    color: #111211;
}
.sidebar-enq {
    padding:10px;
}
.sidebar-enq .ctd-form-stack {
    display: flex;
    gap: 20px;
    align-content: flex-start;
    flex-direction: column;
    flex-wrap: wrap;
}
.sidebar-enq .ctd-field-name, .sidebar-enq .ctd-field-email, .sidebar-enq .ctd-field-mobile, .sidebar-enq .ctd-field-message {
    display: flex;
    gap: 7px;
    align-content: flex-start;
    flex-direction: column;
    flex-wrap: wrap;
    width:100%
}
.sidebar-enq .ctd-field-name .ctd-input, .sidebar-enq .ctd-field-email .ctd-input, .sidebar-enq .ctd-field-mobile .ctd-input, .sidebar-enq .ctd-field-message .ctd-input, .sidebar-enq .ctd-field-city .ctd-input {
    font-size: 18px;
    font-weight: 400;
    line-height: 1.4;
    color: var(--black);
    width: 100%;
    border-radius: 4px;
    border: 1px solid #e5e5e5;
}

.sidebar-enq .ctd-field-name .ctd-label {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8;
    color: var(--black);
}
.sidebar-enq .ctd-button {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8;
    color: var(--white);
    background-color: #05a306;
    border-radius: 34px;
    border: 1px solid #05a306;
    padding: 6px 20px;
}
.sidebar-enq .ctd-button:hover {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8;
    color: var(--black);
    background-color: var(--white);
    border-radius: 34px;
    border: 1px solid #05a306;
    padding: 6px 20px;
}
.page-enq {
    padding:20px;
    background-color: var(--white);
    border-radius:12px;
}
.page-enq .ctd-enquiry-grid {
    display: grid!important;
    grid-template-rows: auto auto auto auto!important;
    gap: 20px!important;
    align-content: flex-start!important;
    flex-direction: column!important;
    flex-wrap: wrap!important;
}
.page-enq .ctd-col-name, .page-enq .ctd-col-email, .page-enq .ctd-col-mobile, .page-enq .ctd-col-message {
    display: flex;
    gap: 7px;
    align-content: flex-start;
    flex-direction: column;
    flex-wrap: wrap;
}
.page-enq .ctd-col-name .ctd-input, .page-enq .ctd-col-email .ctd-input, .page-enq .ctd-col-mobile .ctd-input, .page-enq .ctd-col-message .ctd-textarea, .page-enq .ctd-col-city .ctd-input {
    font-size: 18px;
    font-weight: 400;
    line-height: 1.4;
    color: var(--black);
    width: 100%;
    border-radius: 4px;
    border: 1px solid #e5e5e5;
}
.page-enq .ctd-col-submit {
    display: flex;
    gap: 7px;
    align-content: flex-start;
    flex-direction: column;
    flex-wrap: wrap;
}
.page-enq .ctd-row-4 {
    display: flex!important;
    gap: 20px;
    align-content: flex-start;
    flex-direction: column;
    flex-wrap: wrap;
}
.page-enq .ctd-field-name .ctd-label {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8;
    color: var(--black);
}
.page-enq .ctd-button {
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    color: var(--white);
    background-color: var(--primary);
    border-radius: 34px;
    border: 1px solid var(--primary);
    padding: 8px 15px;
}
.page-enq .ctd-button:hover {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8;
    color: var(--black);
    background-color: #ffffff;
    border-radius: 34px;
    border: 1px solid var(--primary);
    padding: 6px 20px;
}
.sidebar .trip-pricing .pricing-section .pricing-container .price-wrapper .pricing-amount .gb-text.price {
    font-size: 20px!important;
    line-height: 1;
    font-weight: 700!important;
    color: var(--primary)!important;
    margin-bottom:0px;
}
.sidebar .trip-pricing .pricing-section .pricing-container .price-wrapper .pricing-amount .gb-text.price .pricing-type {
    display:none;
}
.download-section .downloads .trip-downloads .ctd-download-item {
    border-radius:34px;
    border: 1px solid var(--primary);
    color: var(--white);
    background-color: var(--primary);
    font-size: 18px;
    font-weight: 600;
    line-height: 1;
    padding: 8px 15px;
}
.download-section .downloads .trip-downloads .ctd-download-item:hover {
    border: 1px solid var(--primary);
    color: var(--primary);
    background-color: var(--white);
}
.download-section .downloads .trip-downloads .ctd-download-item .button {
    padding: 0;
    color: unset;
    background-color: unset;
}
@media (max-width: 767px) {
    .download-section .downloads .trip-downloads {
        align-items: center;
        display: flex;
        justify-content: center;
    }
    .page-enq .ctd-row-1, .page-enq .ctd-row-2, .page-enq .ctd-row-3, .page-enq .ctd-row-4 {
        grid-template-columns: 1fr!important;
    }
}
.hero-search-bar .hero-search-form .ctd-search-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    background: #ffffffa8;
    border-radius: 4px;
    padding: 6px 6px 6px 6px;
    box-shadow: 0px 1px 8px rgb(171 171 171 / 75%);
    position: relative;
    gap: 20px;
}
@media (max-width: 1024px) {
    .hero-search-bar .hero-search-form .ctd-search-bar {
        gap: 10px;
    }
    .ctd-search-submit {
        padding-left: 0px!important;
    }
}
    
.hero-search-bar .hero-search-form .ctd-search-field i {
    color: var(--primary-text);
    font-size: 18px;
    margin-right: 12px;
    width: 20px;
    text-align: center;
}
.hero-search-bar .hero-search-form .ctd-search-submit button {
    background: var(--accent);
    padding: 10px 25px;
    border-radius: 4px;
    font-weight: 700;
    font-size: 18px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: capitalize;
    letter-spacing: 0.5px;
}
@media (max-width: 767px) {
    .hero-search-bar .hero-search-form .ctd-search-bar {
        border-radius: 10px;
        padding-top: 20px;
        padding-bottom: 20px;
    }
}
.bg-fade-wrapper {
    position:relative;
    overflow:hidden;
}
.bg-fade {
    position:absolute;
    content: '';
    width: 100%;
    height: 100%;
    inset: 0;
    background-size:cover;
    background-position: center center;
    opacity: 0;
    animation-name: fade-zoom;
    animation-duration: 16s;
    animation-iteration-count: infinite;
}
.bg-fade-wrapper:hover .bg-fade {
    animation-play-state: paused;
}
.bg-fade:nth-child(2) {
    animation-delay: 0s;
}
.bg-fade:nth-child(3) {
    animation-delay: 4s;
}
.bg-fade:nth-child(4) { 
   animation-delay: 8s;
}
.bg-fade:nth-child(5) {
    animation-delay: 12s;
}
@keyframes fade-zoom {
    0% {
        opacity: 0;
        transform: scale(100%);
    }
    16.66% {
        opacity: 1;
    }
    33.33% {
        opacity: 1;
    }
    48.66% {
        opacity: 0;
    }
    100% {
        opacity: 0;
        transform : scale(110%);
    }
}
.archive .grid-container {
    margin-left: auto;
    margin-right: auto;
    max-width: 100% !important;
}
.cs-archive-trip-grid .ctd-trip-card {
    background: #fcfcfc;
    border: 1px solid #e6e5e5;
}
.ctd-sort-dropdown {
    width:180px;
}
/* Mobile Filter Panel Styles */
@media (max-width: 1024px) {
    .cs-sidebar-filter {
        position: fixed;
        top: 0;
        left: -100%; /* Hidden off-screen */
        width: 80% !important; /* 80% of screen width */
        max-width: 350px;
        height: 100vh;
        background: #fff;
        z-index: 99999;
        box-shadow: 2px 0 15px rgba(0,0,0,0.15);
        transition: left 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        overflow-y: auto;
        padding: 20px 15px;
        margin: 0 !important;
        display: block !important; /* Override the display: none */
    }
    
    /* When active, slide in */
    .cs-sidebar-filter.active {
        left: 0;
    }
    
    /* Overlay background */
    .cs-filter-overlay {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0,0,0,0.5);
        z-index: 99998;
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease;
    }
    
    .cs-filter-overlay.active {
        opacity: 1;
        visibility: visible;
    }
    
    /* Close button inside panel */
    .cs-filter-close {
        position: absolute;
        top: 15px;
        right: 15px;
        background: none;
        border: none;
        font-size: 24px;
        cursor: pointer;
        color: #333;
        width: 30px;
        height: 30px;
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 1;
    }
    
    /* Prevent body scroll when panel is open */
    body.filter-panel-open {
        overflow: hidden;
    }
    
    /* Make the button more visible */
    .cs-filter-button {
        background: #025033 !important;
        cursor: pointer;
        display: inline-flex !important;
        align-items: center;
    }
    
    .cs-filter-button:hover {
        background: #058e35 !important;
    }
}
/* ================================
   Base Animation Setup
================================ */
.anim {
    opacity: 0;
    transition: all 0.8s cubic-bezier(0.25,0.46,0.45,0.94);
    will-change: transform, opacity;
}

.anim.show {
    opacity: 1;
    transform: none;
}


/* ================================
   Slide Animations
================================ */

/* Left â†’ Right */
.anim-left { transform: translateX(-80px); }

/* Right â†’ Left */
.anim-right { transform: translateX(80px); }

/* Bottom â†’ Up */
.anim-up { transform: translateY(80px); }

/* Top â†’ Down */
.anim-down { transform: translateY(-80px); }

/* Blur reveal */
.anim-blur {
    transform: translateY(40px);
    filter: blur(6px);
}
.anim-blur.show {
    filter: blur(0);
}

/* Floating soft rise */
.anim-float {
    transform: translateY(30px) scale(0.95);
}

/* 3D pop */
.anim-pop {
    transform: scale(0.7) rotate(-5deg);
}


/* ================================
   Fade
================================ */
.anim-fade { transform: none; }


/* ================================
   Zoom
================================ */
.anim-zoom-in { transform: scale(0.8); }
.anim-zoom-out { transform: scale(1.2); }


/* ================================
   Rotate
================================ */
.anim-rotate { transform: rotate(-10deg) scale(0.9); }


/* ================================
   Flip
================================ */
.anim-flip-up {
    transform: rotateX(90deg);
    transform-origin: bottom;
}


/* ================================
   Delay Utilities (manual)
================================ */
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }
.delay-5 { transition-delay: 0.5s; }
.delay-6 { transition-delay: 0.6s; }
.delay-7 { transition-delay: 0.7s; }
.delay-8 { transition-delay: 0.8s; }
.delay-9 { transition-delay: 0.9s; }
.delay-10 { transition-delay: 1.0s; }

/* ================================
   Faster / Slower Speed
================================ */
.speed-fast { transition-duration: 0.5s; }
.speed-slow { transition-duration: 1.2s; }

/* ===== Universal Hover Base ===== */
.hover {
    transition: all 0.35s ease;
    will-change: transform, box-shadow, filter;
}

/* Lift */
.hover-lift:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 28px rgba(0,0,0,0.12);
}

/* Grow */
.hover-grow:hover {
    transform: scale(1.05);
}

/* Shrink */
.hover-shrink:hover {
    transform: scale(0.95);
}

/* Glow */
.hover-glow:hover {
    box-shadow: 0 0 20px rgba(0,123,255,0.45);
}

/* Rotate tiny */
.hover-tilt:hover {
    transform: rotate(-2deg) scale(1.03);
}

/* Image zoom inside card */
.hover-zoom-img img {
    transition: transform 0.5s ease;
}
.hover-zoom-img:hover img {
    transform: scale(1.12);
}

/* Underline slide */
.hover-underline {
    position: relative;
}
.hover-underline::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 0%;
    height: 2px;
    background: currentColor;
    transition: width 0.3s ease;
}
.hover-underline:hover::after {
    width: 100%;
}
/* Base button */
.btn-anim {
    transition: all 0.25s ease;
    position: relative;
    overflow: hidden;
}

/* Press effect */
.btn-press:active {
    transform: scale(0.96);
}

/* Slide shine */
.btn-shine::before {
    content: "";
    position: absolute;
    top: 0;
    left: -120%;
    width: 100%;
    height: 100%;
    background: linear-gradient(120deg, transparent, rgba(255,255,255,0.5), transparent);
    transition: all 0.6s ease;
}
.btn-shine:hover::before {
    left: 120%;
}

/* Arrow move */
.btn-arrow span {
    display: inline-block;
    transition: transform 0.25s ease;
}
.btn-arrow:hover span {
    transform: translateX(6px);
}

/* Ripple click */
.btn-ripple {
    position: relative;
    overflow: hidden;
}
.btn-ripple:after {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    background: rgba(255,255,255,0.4);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    top: 50%;
    left: 50%;
    transition: width 0.4s ease, height 0.4s ease;
}
.btn-ripple:active:after {
    width: 220px;
    height: 220px;
}.text-reveal {
    overflow: hidden;
}

/* All animated words */
.text-reveal .tr-word {
    display: inline-block;
    transform: translateY(100%);
    opacity: 0;
    transition: transform 0.6s cubic-bezier(.2,.65,.3,1),
                opacity 0.6s cubic-bezier(.2,.65,.3,1),
                color 0.4s ease;
}

/* During animation â†’ keep neutral color */
.text-reveal.animating .tr-word {
    color: inherit;
}

/* Final visible state */
.text-reveal.show .tr-word {
    transform: translateY(0);
    opacity: 1;
}
.destination-container {
    align-items: center;
    column-gap: 10px;
    display: flex;
    flex-direction: column;
    row-gap: 10px;
}
.destination-image {
    aspect-ratio: 4/3;
    height: auto;
    min-width: 100%;
    object-fit: cover;
    object-position: center center;
    width: 100%;
    border-radius: 12px;
}
.destination-name {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 16px;
    font-weight: 700;
    line-height: 20px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: center;
}

.destination-name {
    text-decoration: none;
}
.destination-name:hover, .destination-name:focus, .destination-name:active {
    color: #ff7c01!important;
}
.destination-count {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 700;
    line-height: 14px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: center;
}

.destination-count {
    text-decoration: none;
}
.destination-count:hover, .destination-count:focus, .destination-count:active {
    color: #ff7c01!important;
}
.destination-sub {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 16px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: center;
}

.destination-sub {
    text-decoration: none!important;
}
.destination-sub:hover, .destination-sub:focus, .destination-sub:active {
    color: #262626!important;
}
.destination-desc {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 16px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: center;
}

.destination-desc {
    text-decoration: none;
}
.mega-menu-destination-text.destination-container {
    align-items: flex-start;
    column-gap: 10px;
    display: flex;
    flex-direction: column;
    row-gap: 10px;
}
.mega-menu-destination-text .destination-name {
    color: var(--blue);
    font-family: var(--gp-font--nunito-sans);
    font-size: 15px;
    font-weight: 700;
    line-height: 15px;
    margin-bottom: 0px;
    text-decoration: none;
}

.mega-menu-destination-text.destination-name {
    text-decoration: none;
}
.mega-menu-destination-text .destination-name:hover, .mega-menu-destination-text .destination-name:focus, .mega-menu-destination-text .destination-name:active {
    color: #ff7c01!important;
}
.mega-menu-destination-text .destination-count {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 700;
    line-height: 14px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: center;
}

.mega-menu-destination-text .destination-count {
    text-decoration: none;
}
.mega-menu-destination-text .destination-count:hover, .mega-menu-destination-text .destination-count:focus, .mega-menu-destination-text .destination-count:active {
    color: #ff7c01!important;
}
.mega-menu-destination-text .destination-sub {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
    margin-bottom: 0px;
    text-align: left;
}

.mega-menu-destination-text .destination-sub {
    text-decoration: none!important;
}
.mega-menu-destination-text .destination-sub:hover, .mega-menu-destination-text .destination-sub:focus, .mega-menu-destination-text .destination-sub:active {
    color: #262626!important;
}
.mega-menu-destination.destination-container {
    align-items: flex-start;
}
.mega-menu-destination .destination-image {
    aspect-ratio: 16/9;
}
.mega-menu-destination .destination-name {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 16px;
    line-height: 16px;
    text-align: left;
}
.mega-menu-destination .destination-name {
    text-decoration: none;
}
.mega-menu-destination .destination-name:hover, .mega-menu-destination .destination-name:focus, .mega-menu-destination .destination-name:active { 
    color: #ff7c01!important;
}
.mega-menu-destination.destination-count {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 16px;
    font-weight: 700;
    line-height: 20px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: center;
}

.mega-menu-destination .destination-count {
    text-decoration: none;
}
.mega-menu-destination .destination-count:hover, .mega-menu-destination .destination-count:focus, .mega-menu-destination .destination-count:active {
    color: #ff7c01!important;
}
.mega-menu-destination .destination-sub {
    font-size: 14px;
    line-height: 18px;
    text-align: left;
}
.mega-menu-destination .destination-sub {
    text-decoration: none!important;
}
.mega-menu-destination .destination-sub:hover, .mega-menu-destination .destination-sub:focus, .mega-menu-destination .destination-sub:active {
    color: #262626!important;
}
.mega-menu-destination .destination-desc {
    font-size: 14px;
    line-height: 16px;
    text-align: left;
}

.mega-menu-destination .destination-desc {
    text-decoration: none;
} 
.image-3isto4 .destination-image{
    aspect-ratio: 4/3;
}
@media (max-width: 1024px) {
    .destinations-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .tab-v {
        flex-direction: column!important;
    }
    .tab-menu-v {
        flex-direction: row!important;
    }
    .mega-section {
        width: 100%!important;
    }
}
.mega-menu-trip.destination-container {
    align-items: flex-start;
    column-gap: 5px;
    display: flex;
    flex-direction: column;
    row-gap: 5px;
}
.mega-menu-trip .destination-image {
    aspect-ratio: 16/9;
    height: auto;
    min-width: 100%;
    object-fit: cover;
    object-position: center center;
    width: 100%;
    border-radius: 12px;
}
.mega-menu-trip .destination-name {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 15px;
    font-weight: 700;
    line-height: 15px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: left;
}

.mega-menu-trip .destination-name {
    text-decoration: none;
}
.mega-menu-trip .destination-name:hover, .mega-menu-trip .destination-name:focus, .mega-menu-trip .destination-name:active {
    color: #ff7c01!important;
}
.mega-menu-trip .destination-count {
    color: var(--blue);
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 700;
    line-height: 14px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: left;
}

.mega-menu-trip .destination-count {
    text-decoration: none;
}
.mega-menu-trip .destination-count:hover, .mega-menu-trip .destination-count:focus, .mega-menu-trip .destination-count:active {
    color: #ff7c01!important;
}
.mega-menu-trip .destination-sub {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 16px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: left;
}

.mega-menu-trip .destination-sub {
    text-decoration: none!important;
}
.mega-menu-trip .destination-sub:hover, .mega-menu-trip .destination-sub:focus, .mega-menu-trip .destination-sub:active {
    color: #262626!important;
}
.mega-menu-trip .destination-desc {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 16px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: left;
}

.mega-menu-trip .destination-desc {
    text-decoration: none;
}
.mega-menu-activity.destination-container {
    align-items: flex-start;
    column-gap: 5px;
    display: flex;
    flex-direction: column;
    row-gap: 5px;
}
.mega-menu-activity .destination-image {
    aspect-ratio: 4/3;
    height: auto;
    min-width: 100%;
    object-fit: cover;
    object-position: center center;
    width: 100%;
    border-radius: 12px;
}
.mega-menu-activity .destination-name {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 15px;
    font-weight: 700;
    line-height: 16px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: left;
}

.mega-menu-activity .destination-name {
    text-decoration: none;
}
.mega-menu-activity .destination-name:hover, .mega-menu-activity .destination-name:focus, .mega-menu-activity .destination-name:active {
    color: #ff7c01!important;
}
.mega-menu-activity .destination-count {
    color: var(--blue);
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 700;
    line-height: 14px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: left;
}

.mega-menu-activity .destination-count {
    text-decoration: none;
}
.mega-menu-activity .destination-count:hover, .mega-menu-activity .destination-count:focus, .mega-menu-activity .destination-count:active {
    color: #ff7c01!important;
}
.mega-menu-activity .destination-sub {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: left;
}

.mega-menu-activity .destination-sub {
    text-decoration: none!important;
}
.destination-sub:hover, .destination-sub:focus, .destination-sub:active {
    color: #262626!important;
}
.mega-menu-activity .destination-desc {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: left;
}
.mega-menu-activity .destination-desc {
    text-decoration: none;
}
.mega-menu-activity-text.destination-container {
    align-items: flex-start;
    column-gap: 5px;
    display: flex;
    flex-direction: column;
    row-gap: 5px;
}
.mega-menu-activity-text .destination-image {
    aspect-ratio: 4/3;
    height: auto;
    min-width: 100%;
    object-fit: cover;
    object-position: center center;
    width: 100%;
    border-radius: 12px;
}
.mega-menu-activity-text .destination-name {
    color: var(--primary-text);
    font-family: var(--gp-font--nunito-sans);
    font-size: 15px;
    font-weight: 700;
    line-height: 16px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: left;
}

.mega-menu-activity-text .destination-name {
    text-decoration: none;
}
.mega-menu-activity-text .destination-name:hover, .mega-menu-activity-text .destination-name:focus, .mega-menu-activity-text .destination-name:active {
    color: #ff7c01!important;
}
.mega-menu-activity-text .destination-count {
    color: var(--blue);
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 700;
    line-height: 14px;
    margin-bottom: 0px;
    text-decoration: none;
    text-align: left;
}

.mega-menu-activity-text .destination-count {
    text-decoration: none;
}
.mega-menu-activity-text .destination-count:hover, .mega-menu-activity-text .destination-count:focus, .mega-menu-activity-text .destination-count:active {
    color: #ff7c01!important;
}
.mega-menu-activity-text .destination-sub {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: left;
}

.mega-menu-activity-text .destination-sub {
    text-decoration: none!important;
}
.destination-sub:hover, .destination-sub:focus, .destination-sub:active {
    color: #262626!important;
}
.mega-menu-activity-text .destination-desc {
    color: #262626;
    font-family: var(--gp-font--nunito-sans);
    font-size: 14px;
    font-weight: 400;
    line-height: 22px;
    margin-bottom: 0px;
    text-align: left;
}
.mega-menu-activity-text .destination-desc {
    text-decoration: none;
}
@media (max-width: 1024px) {
    .destinations-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .tab-v {
        flex-direction: column!important;
    }
    .tab-menu-v {
        flex-direction: row!important;
    }
    .mega-section {
        width: 100%!important;
    }
    .mega-menu-trip .destination-name {
        font-size: 14px;
    }
    .mega-menu-trip .destination-count {
        font-size: 14px;
    }
}