@media (max-width: 1199px) {
    .header-shell {
        padding-left: 0;
        padding-right: 0;
    }

    .header-kicker {
        display: none;
    }

    .header-topbar {
        padding-left: 24px;
        padding-right: 24px;
    }

    .main-nav-panel {
        gap: 18px;
        padding: 0 24px 0 0;
    }

    .main-nav-panel:before {
        width: clamp(165px, 18vw, 220px);
    }

    .nav-colored-link {
        display: none;
    }

    .nav-links>.item>a {
        padding: 24px 12px;
        font-size: 0.74rem;
    }

    .nav-links>.item:last-child>a {
        padding-right: 12px;
    }

    .comment-slider-buttons {
        display: none;
    }

    .main-slider-buttons {
        display: none;
    }
}

@media (max-width: 991px) {
    html {
        font-size: var(--mobile-font-size);
    }

    .header-shell {
        padding-left: 0;
        padding-right: 0;
    }

    .nav-top {
        padding: 10px 0;
    }

    .header-topbar {
        flex-wrap: nowrap;
        justify-content: space-between;
        align-items: center;
        gap: 10px;
        padding-left: 20px;
        padding-right: 20px;
    }

    .header-topbar-left,
    .header-topbar-right {
        gap: 12px;
    }

    .header-topbar-left {
        flex: 1 1 auto;
        min-width: 0;
    }

    .header-topbar-right {
        margin-left: auto;
    }

    .nt-contact {
        white-space: nowrap;
    }

    .nt-contact>span {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .nav-links {
        display: none;
    }

    .main-nav {
        padding-top: 0;
    }

    .main-nav-panel {
        gap: 14px;
        padding: 0 18px 0 0;
        border-radius: var(--border-radius);
    }

    .main-nav-panel:before {
        width: 150px;
        border-radius: var(--border-radius);
    }

    .site-logo-wrap {
        min-width: auto;
    }

    .site-logo {
        min-height: 56px;
    }

    .site-logo a {
        min-height: 56px;
        padding: 6px 14px;
    }

    .site-logo img {
        width: auto;
        height: 48px;
        max-width: 190px;
    }

    .slider-bottom-destinations {
        display: none;
    }

    .section-sticker {
        text-align: center;
    }

    .badges-row>[class*="col-"]:not(:last-child)>.badge-item:after {
        content: none;
    }

    .badge-item>div {
        width: 100px;
    }

    .title-icon {
        display: none;
    }

    .sub-box {
        margin-top: var(--main-gap);
    }

    .slider-banner {
        padding-top: calc(3 / 4 * 100%);
    }

    .slider-desc-inner {
        width: min(100%, 780px);
        padding: 28px 30px;
    }

    .slider-desc-inner>.slide-title {
        font-size: 4rem;
    }

    .slider-desc-inner>.slide-desc {
        font-size: 1.08rem;
    }

    .mobile-nav-open {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 48px;
        height: 48px;
        border: none;
        border-radius: 4px;
        background: linear-gradient(135deg, #0f274d 0%, #173a69 100%);
        box-shadow: 0 14px 34px rgba(10, 28, 55, 0.24);
        color: #fff !important;
        font-size: 1.9rem;
        margin-right: 0;
    }

    .mobile-nav-close {
        display: inline-flex;
        justify-content: center;
        align-items: center;
        width: 46px;
        height: 46px;
        border: solid 1px rgba(15, 39, 77, 0.12);
        border-radius: 4px;
        background: rgba(255, 255, 255, 0.92);
        color: #0f274d !important;
        font-size: 1.9rem;
        margin-bottom: 0;
    }

    .mobile-nav>.mobile-nav-content {
        width: min(420px, 100%);
    }

    .page-banner {
        padding-top: calc(720/1280*100%);
    }

    .bcrumb-links {
        display: none;
    }

    .container-banner-media {
        padding: 0 20px 20px;
    }

    .container-banner-media .page-banner {
        min-height: 260px;
    }

    .listing-page-hero {
        padding: 42px 0 42px;
    }

    .listing-page-title {
        font-size: 2.5rem;
    }

    .listing-page-meta {
        max-width: 320px;
    }

    .hotel-filter-box {
        padding: 24px 22px;
    }

    .destination-showcase-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .destination-feature-card {
        min-height: 420px;
    }

    .destination-mini-card,
    .destination-rail-card {
        min-height: 220px;
    }

    .destination-grid-card {
        min-height: 220px;
    }

    .destination-card-title {
        font-size: 1.7rem;
    }

    .destination-mini-card .destination-card-title,
    .destination-rail-card .destination-card-title {
        font-size: 1.25rem;
    }

    .destination-grid-card .destination-card-title {
        font-size: 1.25rem;
    }

    .about-showcase-copy {
        padding: 28px 24px;
    }

    .about-showcase-media {
        padding: 0 20px 20px;
    }

    .about-showcase-frame {
        min-height: 320px;
    }

    .page-hero-copy {
        padding: 28px 24px;
    }

    .page-hero-media {
        padding: 0 20px 20px;
    }

    .page-hero-frame {
        min-height: 320px;
    }

    .page-content-panel,
    .page-side-panel {
        padding: 24px 22px;
    }

    .service-related-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .service-map-frame {
        padding-top: calc(620 / 1280 * 100%);
    }

    .hotel-showcase-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .hotel-feature-card {
        min-height: 420px;
    }

    .hotel-mini-card {
        min-height: 220px;
    }

    .hotel-grid-card {
        min-height: 220px;
    }

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

    .hotel-rail-media {
        min-width: 100%;
        width: 100%;
        min-height: 220px;
    }

    .hotel-rail-content {
        padding: 24px 22px;
    }

    .hotel-showcase-title {
        font-size: 1.65rem;
    }

    .hotel-mini-content .hotel-showcase-title {
        font-size: 1.2rem;
    }

    .gallery-showcase-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .gallery-showcase-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-auto-rows: 200px;
    }

    .gallery-card.is-featured {
        grid-column: span 2;
        grid-row: span 2;
    }

    .gallery-card.is-tall {
        grid-row: span 1;
    }

    .story-showcase-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .story-showcase-grid {
        row-gap: 20px;
    }

    .story-feature-content {
        min-height: 420px;
        padding: 28px 24px;
    }

    .story-grid-media {
        min-height: 200px;
    }

    .story-grid-content {
        padding: 22px 20px 20px;
    }

    .story-showcase-title {
        font-size: 1.7rem;
    }

    .story-mini-card {
        min-height: 150px;
    }

    .story-mini-content {
        padding: 20px 18px;
    }

    .story-showcase-title.dark {
        font-size: 1.1rem;
    }

    .footer-main {
        padding: 46px 0 20px;
    }

    .footer-brand-card {
        padding: 24px;
    }

    .footer-column {
        padding-top: 0;
    }
}

@media (max-width: 767px) {
    .header-shell {
        padding-left: 0;
        padding-right: 0;
    }

    .header-topbar {
        justify-content: space-between;
        align-items: center;
        padding-left: 16px;
        padding-right: 16px;
    }

    .header-topbar-left {
        flex-wrap: nowrap;
    }

    .nt-contact {
        font-size: 0.86rem;
    }

    .mobile-nav-contact {
        font-size: 0.86rem;
    }

    .about-showcase-copy {
        padding: 24px 20px;
    }

    .page-hero-copy {
        padding: 24px 20px;
    }

    .page-hero-media {
        padding: 0 20px 20px;
    }

    .page-hero-frame {
        min-height: 260px;
    }

    .page-content-panel,
    .page-side-panel {
        padding: 22px 20px;
    }

    .hotel-feature-content,
    .hotel-mini-content {
        padding: 24px 20px;
    }

    .gallery-showcase-grid {
        gap: 16px;
    }

    .story-mini-card {
        flex-direction: column;
    }

    .story-mini-media,
    .story-mini-content {
        width: 100%;
        min-width: 100%;
    }

    .story-mini-media {
        min-height: 180px;
    }

    .story-mini-content {
        padding: 20px;
    }

    .footer-contact-pills {
        gap: 10px;
    }

    .footer-contact-pill {
        width: 100%;
        justify-content: flex-start;
    }

    .footer-bottom-row {
        align-items: flex-start;
    }

    .listing-page-hero {
        padding: 34px 0 34px;
    }

    .listing-page-title {
        font-size: 2.15rem;
    }

    .listing-page-meta {
        padding: 20px 18px;
    }

    .hotel-filter-toggle {
        min-height: 50px;
        padding: 0 16px;
    }

    .hotel-filter-box {
        padding: 22px 20px;
    }

    .service-side-stack {
        gap: 16px;
    }

    .service-support-card {
        padding: 24px;
    }

    .tour-request-sidebar {
        position: static;
    }

    .hotel-detail-meta {
        gap: 10px;
    }

    .hotel-detail-meta-item {
        min-height: 38px;
        padding: 0 12px;
    }

    .hotel-gallery-shell .prd-thumbs-row > .prev,
    .hotel-gallery-shell .prd-thumbs-row > .next {
        min-width: 46px;
        width: 46px;
        height: 82px;
    }

    .hotel-gallery-shell .prd-thumbs-slider-container {
        width: calc(100% - 46px - 46px - 20px);
    }

    .service-summary-text,
    .service-side-text {
        font-size: 0.94rem;
    }

    .service-map-frame {
        padding-top: calc(680 / 1280 * 100%);
    }

    .destination-card-content {
        padding: 24px 20px;
    }

    .slider-desc-inner {
        width: min(100%, 640px);
        padding: 22px 24px;
    }

    .slider-desc-inner>.slide-kicker {
        margin-bottom: 12px;
        padding: 6px 12px;
        font-size: 0.74rem;
    }

    .slider-desc-inner>.slide-desc {
        font-size: 1rem;
        line-height: 1.6em;
    }

    .slider-cta-btn {
        min-height: 48px;
        padding: 0 20px;
    }

    .story-grid-media {
        min-height: 190px;
    }
}

@media (max-width: 575px) {
    .header-shell {
        padding-left: 0;
        padding-right: 0;
    }

    .header-topbar {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding-left: 14px;
        padding-right: 14px;
    }

    .header-topbar-left {
        flex: 1 1 auto;
        min-width: 0;
    }

    .header-topbar-right {
        width: auto;
        margin-left: auto;
    }

    .nt-lang-dd>a {
        width: auto;
        justify-content: flex-start;
    }

    .main-nav-panel {
        padding: 0 14px 0 0;
        border-radius: var(--border-radius);
    }

    .main-nav-panel:before {
        width: 124px;
        border-radius: var(--border-radius);
    }

    .site-logo img {
        height: 42px;
        max-width: 170px;
    }

    .site-logo a {
        min-height: 50px;
        padding: 5px 12px;
    }

    .mobile-nav>.mobile-nav-content {
        width: 100%;
    }

    .mobile-nav>.mobile-nav-content>.mobile-nav-inner {
        padding: 22px 16px;
    }

    .mobile-menu-links>.item>a {
        padding: 14px 16px;
    }

    .destination-feature-card {
        min-height: 340px;
    }

    .destination-mini-card,
    .destination-rail-card {
        min-height: 200px;
    }

    .destination-grid-card {
        min-height: 200px;
    }

    .destination-showcase-action {
        width: 100%;
    }

    .destination-showcase-action.main-btn {
        justify-content: center;
    }

    .destination-card-content {
        padding: 20px 16px;
    }

    .destination-card-title {
        font-size: 1.4rem;
    }

    .destination-card-text {
        font-size: 0.9rem;
    }

    .listing-page-hero {
        padding: 28px 0 28px;
    }

    .listing-page-links {
        gap: 8px;
        margin-bottom: 12px;
    }

    .listing-page-links>a {
        min-height: 30px;
        padding: 0 10px;
        font-size: 0.74rem;
    }

    .listing-page-title {
        font-size: 1.8rem;
    }

    .listing-page-meta {
        padding: 18px 16px;
    }

    .listing-page-meta-count {
        font-size: 2.35rem;
    }

    .hotel-filter-toggle {
        min-height: 48px;
        padding: 0 14px;
        font-size: 0.76rem;
    }

    .hotel-filter-box {
        padding: 20px 16px;
    }

    .slider-desc {
        top: auto;
        bottom: 32px;
        transform: none;
    }

    .slider-desc-inner {
        width: 100%;
        padding: 18px 16px;
    }

    .slider-desc-inner>.slide-kicker {
        margin-bottom: 10px;
        font-size: 0.68rem;
    }

    .slider-desc-inner>.slide-title {
        font-size: 22px;
        margin-bottom: 12px;
    }

    .slider-desc-inner>.slide-desc {
        font-size: 10px;
        line-height: 1.55em;
    }

    .slider-cta-btn {
            min-height: 30px;
            padding: 0 10px;
            gap: 8px;
        }

    .about-showcase-copy {
        padding: 22px 16px;
    }

    .about-showcase-text {
        font-size: 0.92rem;
    }

    .about-showcase-media {
        padding: 0 16px 16px;
    }

    .about-showcase-frame {
        min-height: 260px;
    }

    .page-hero-copy {
        padding: 22px 16px;
    }

    .page-hero-text {
        font-size: 0.92rem;
    }

    .page-hero-media {
        padding: 0 16px 16px;
    }

    .page-hero-frame {
        min-height: 240px;
    }

    .page-content-panel,
    .page-side-panel {
        padding: 20px 16px;
    }

    .service-detail-panel {
        padding-bottom: 24px;
    }

    .hotel-detail-panel {
        padding-bottom: 24px;
    }

    .hotel-detail-meta {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    .hotel-detail-meta-item {
        width: 100%;
        min-height: 40px;
        justify-content: flex-start;
    }

    .hotel-gallery-shell .prd-thumbs-row {
        gap: 8px;
    }

    .hotel-gallery-shell .prd-thumbs-row > .prev,
    .hotel-gallery-shell .prd-thumbs-row > .next {
        min-width: 40px;
        width: 40px;
        height: 72px;
    }

    .hotel-gallery-shell .prd-thumbs-slider-container {
        width: calc(100% - 40px - 40px - 16px);
    }

    .service-support-card {
        padding: 20px 16px;
    }

    .service-summary-text,
    .service-side-text {
        font-size: 0.9rem;
    }

    .service-map-frame {
        padding-top: calc(760 / 1280 * 100%);
    }

    .service-related-head {
        margin-bottom: 18px;
    }

    .service-card-title {
        min-height: auto;
    }

    .page-side-title {
        font-size: 1.18rem;
    }

    .hotel-showcase-action {
        width: 100%;
    }

    .hotel-showcase-action.main-btn {
        justify-content: center;
    }

    .hotel-feature-card {
        min-height: 340px;
    }

    .hotel-mini-card {
        min-height: 200px;
    }

    .hotel-grid-card {
        min-height: 200px;
    }

    .hotel-feature-content,
    .hotel-mini-content,
    .hotel-rail-content {
        padding: 20px 16px;
    }

    .hotel-showcase-title {
        font-size: 1.4rem;
    }

    .hotel-showcase-text,
    .hotel-mini-content .hotel-showcase-text,
    .hotel-showcase-text.dark {
        font-size: 0.9rem;
    }

    .gallery-showcase-action {
        width: 100%;
    }

    .gallery-showcase-action.main-btn {
        justify-content: center;
    }

    .gallery-showcase-grid {
        grid-template-columns: 1fr;
        grid-auto-rows: 220px;
        gap: 14px;
    }

    .gallery-card.is-featured,
    .gallery-card.is-tall {
        grid-column: span 1;
        grid-row: span 1;
    }

    .gallery-card-badge {
        top: 12px;
        left: 12px;
        min-height: 28px;
        padding: 0 10px;
        font-size: 0.68rem;
    }

    .gallery-card-icon {
        right: 12px;
        bottom: 12px;
        width: 40px;
        height: 40px;
    }

    .story-showcase-action {
        width: 100%;
    }

    .story-showcase-action.main-btn {
        justify-content: center;
    }

    .story-feature-content {
        min-height: 340px;
        padding: 22px 16px;
    }

    .story-grid-media {
        min-height: 180px;
    }

    .story-grid-content {
        padding: 18px 16px 16px;
    }

    .story-showcase-title {
        font-size: 1.42rem;
    }

    .story-showcase-text {
        font-size: 0.9rem;
    }

    .story-mini-media {
        min-height: 160px;
    }

    .story-mini-content {
        padding: 18px 16px;
    }

    .story-showcase-title.dark {
        font-size: 1rem;
    }

    .story-showcase-text.dark {
        font-size: 0.88rem;
    }

    .footer-main {
        padding: 40px 0 18px;
    }

    .footer-brand-card {
        padding: 20px 16px;
    }

    .footer-logo {
        min-height: 60px;
        padding: 8px 14px;
    }

    .footer-logo img {
        height: 44px;
        max-width: 190px;
    }

    .footer-kicker {
        font-size: 0.7rem;
    }

    .footer-section-title {
        margin-bottom: 14px;
    }

    .footer-cert-list .item {
        min-height: 58px;
        padding: 8px 10px;
    }

    .footer-cert-list .item>img {
        height: 36px;
    }

    .footer-copy {
        font-size: 0.78rem;
    }

    .blog-item>.content,
    .hotel-item .content {
        padding: 10px 15px;
    }

    .comment-item {
        padding: 15px;
    }

    .hotel-item .img>.location {
        bottom: 5px;
        left: 10px;
    }

    .main-title {
        font-size: 2rem;
    }

    .ftr-brands>.item>img {
        height: 40px;
    }
}

@media (max-width: 1199px) {
    .blog-featured-panel {
        top: 96px;
    }

    .blog-featured-media {
        min-width: 120px;
        width: 120px;
    }

    .blog-featured-content {
        width: calc(100% - 120px);
    }

    .destination-side-panel {
        top: 96px;
    }

    .destination-side-media {
        min-width: 120px;
        width: 120px;
    }

    .destination-side-content {
        width: calc(100% - 120px);
    }
}

@media (max-width: 991px) {
    .journal-featured-section {
        margin-bottom: 32px;
    }

    .journal-list-head {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }

    .blog-featured-panel {
        position: static;
    }

    .blog-detail-frame {
        padding-top: calc(760 / 1280 * 100%);
    }

    .destination-side-panel {
        position: static;
    }

    .destination-detail-frame {
        padding-top: calc(760 / 1280 * 100%);
    }

    .tour-request-sidebar {
        position: static;
    }
}

@media (max-width: 767px) {
    .journal-list-head {
        margin-bottom: 18px;
    }

    .blog-detail-meta {
        gap: 10px;
    }

    .blog-detail-meta-item {
        width: 100%;
        justify-content: flex-start;
    }

    .blog-featured-item {
        flex-direction: column;
    }

    .blog-featured-media,
    .blog-featured-content {
        width: 100%;
        min-width: 100%;
    }

    .blog-featured-media {
        min-height: 180px;
    }

    .blog-featured-content {
        padding: 18px 16px;
    }

    .destination-detail-meta {
        gap: 10px;
    }

    .destination-detail-meta-item {
        width: 100%;
        justify-content: flex-start;
    }

    .destination-side-item {
        flex-direction: column;
    }

    .destination-side-media,
    .destination-side-content {
        width: 100%;
        min-width: 100%;
    }

    .destination-side-media {
        min-height: 180px;
    }

    .destination-side-content {
        padding: 18px 16px;
    }

    .tour-request-fact {
        padding: 12px 14px;
    }

    .tour-request-contact-item {
        min-height: 48px;
        padding: 0 14px;
    }

    .tour-request-actions .g-recaptcha {
        transform: scale(0.92);
        transform-origin: left top;
    }

    .tour-request-submit-btn {
        min-height: 50px;
    }
}
