﻿:root {
  --color-primary: #1380ae;
  --color-primary-dark: #1d89b5;
  --color-bg-blue-soft: #f2fbffa8;
  --color-border-blue: #b7e6ff;
  --color-sky: #a1c6e7;
  --color-sky-hover: #6fbad7;
  --color-text-nav: #504e61;
  --color-text-body: #4c4f56;
  --color-text-strong: #414042;
  --color-text-near-black: #242239;
  --color-icon-muted: #beb8c4;
  --color-contact-bg: #e7f7ff;
  --color-promo-bg: #f3fdff;
  --color-white: #ffffff;
  --color-divider: #efefef;
  --color-error: #d32f2f;
  --color-success: #2e7d32;
  --tour-accent: #9f5b2d;
  --tour-accent-soft: #fff6ed;
  --tour-line: #e9edf2;
  --tour-shadow: 0 16px 36px rgba(36,34,57,.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; background: #fff; color: var(--color-text-body); font-family: "DM Sans", "Helvetica Neue", Arial, sans-serif; font-size: 16px; line-height: 1.6; -webkit-font-smoothing: antialiased; }
h1,h2,h3,h4,h5,h6 { color: var(--color-text-strong); font-family: "Poppins", "Helvetica Neue", Arial, sans-serif; line-height: 1.3; font-weight: 600; margin: 0 0 16px; letter-spacing: 0; }
h1 { font-size: 2.5rem; } h2 { font-size: 2rem; } h3 { font-size: 1.5rem; }
p { margin: 0 0 16px; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
.container { max-width: 1170px; margin: 0 auto; padding-inline: 80px; }
.section { padding: 4em 0; }
.center { text-align: center; }
.lead { font-size: 1.1rem; max-width: 760px; }
.font-quote { font-family: "Merriweather", Georgia, serif; font-style: italic; }
.skip-link { position: absolute; top: -48px; left: 16px; z-index: 10000; padding: 12px 24px; border-radius: 0 0 8px 8px; color: #fff; background: var(--color-primary); font-size: 14px; font-weight: 600; transition: top .3s ease, opacity .3s ease; opacity: 0; }
.skip-link:focus { top: 0; opacity: 1; outline: 2px solid #fff; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 12px 28px; border: 0; border-radius: 1rem; cursor: pointer; font-weight: 600; transition: all .3s ease; }
.btn-primary { background: var(--color-primary); color: #fff; }
.btn-primary:hover { background: var(--color-primary-dark); color: #fff; }
.btn-outline { border: 1px solid var(--color-border-blue); border-radius: 12px; padding: 8px 16px; color: var(--color-primary); background: transparent; }
.btn-outline:hover { background: #eef9ff; }
.btn-lg { padding: 16px 36px; font-size: 18px; }
.form-control { width: 100%; padding: 12px 16px; border: 1px solid var(--color-divider); border-radius: 8px; color: var(--color-text-body); background: #fff; }
.form-control:focus { outline: 0; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(19,128,174,.1); }
.form-select { appearance: none; }
.validation-message, .form-error { color: var(--color-error); font-size: 13px; }
.eyebrow { display: inline-block; color: var(--tour-accent); font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin-bottom: 8px; }
.breadcrumbs { padding: 16px 0; color: var(--color-text-body); font-size: 14px; }
.breadcrumbs a:hover { color: var(--color-primary); text-decoration: underline; }
.breadcrumbs__separator { margin: 0 8px; color: var(--color-icon-muted); }

.site-header { position: sticky; top: 0; z-index: 1000; height: 72px; background: #fff; transition: all .3s ease; }
.is-scrolled .site-header { height: 64px; background: rgba(255,255,255,.95); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(0,0,0,.06); box-shadow: 0 2px 12px rgba(0,0,0,.08); }
.site-header__desktop { height: 100%; display: flex; align-items: center; gap: 32px; }
.site-header__brand img { width: 32px; }
.is-scrolled .site-header__brand img { width: 28px; }
.site-header__nav { display: flex; align-items: center; gap: 24px; flex: 1; }
.site-header__nav a, .site-header__nav button, .site-header__phone { color: var(--color-text-nav); background: none; border: 0; font-size: 15px; font-weight: 500; cursor: pointer; }
.site-header__nav a:hover, .site-header__nav button:hover, .site-header__phone:hover { color: var(--color-primary); }
.site-header__phone { color: var(--color-primary); font-weight: 600; font-size: 14px; }
.site-header__dropdown { position: relative; }
.site-header__panel { position: absolute; top: 100%; left: 50%; transform: translateX(-50%); margin-top: 8px; min-width: 540px; padding: 20px; border-radius: 16px; background: #fff; box-shadow: 0 12px 40px rgba(0,0,0,.15); display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.site-header__continents, .site-header__destinations { display: grid; gap: 10px; }
.site-header__continent { border: 2px solid transparent; border-radius: 12px; padding: 8px; background: transparent; color: var(--color-text-strong); text-align: left; cursor: pointer; }
.site-header__continent:hover { background: #f5f5f5; }
.site-header__continent--active { border-color: var(--color-border-blue); background: var(--color-bg-blue-soft); color: var(--color-primary); font-weight: 600; }
.site-header__continent img { aspect-ratio: 16 / 11; width: 100%; object-fit: cover; border-radius: 8px; margin-bottom: 6px; }
.site-header__dest-link { padding: 10px 14px; border-radius: 8px; font-size: 14px; color: var(--color-text-body); }
.site-header__dest-link:hover { background: var(--color-contact-bg); color: var(--color-primary); }
.site-header__mobile, .mobile-bottom, .mobile-overlay, .mobile-panel { display: none; }

.hero { position: relative; height: 85vh; min-height: 500px; max-height: 800px; overflow: hidden; }
.hero__slides { position: absolute; inset: 0; }
.hero__slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1s ease; }
.hero__slide--active { opacity: 1; }
.hero__image { width: 100%; height: 100%; object-fit: cover; }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.3) 0%, rgba(0,0,0,.6) 100%); }
.hero__content { position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 0 20px; }
.hero__title { max-width: 700px; color: #fff; font-size: 3rem; font-weight: 700; text-shadow: 0 2px 8px rgba(0,0,0,.3); transition: opacity .4s ease; }
.hero__dots { display: flex; gap: 10px; margin-top: 32px; }
.hero__dot { width: 12px; height: 12px; padding: 0; border: 2px solid rgba(255,255,255,.6); border-radius: 50%; background: transparent; cursor: pointer; transition: background .3s ease, border-color .3s ease; }
.hero__dot--active { background: #fff; border-color: #fff; }
.explore__heading { text-align: center; font-size: 2rem; margin-bottom: 12px; }
.explore__subtitle { max-width: 600px; margin: 0 auto 32px; color: var(--color-text-body); text-align: center; }
.explore__tabs { display: flex; gap: 14px; overflow-x: auto; padding-bottom: 12px; margin-bottom: 40px; scrollbar-width: none; }
.explore__tabs::-webkit-scrollbar { display: none; }
.explore__tab { position: relative; display: flex; flex-direction: column; align-items: center; gap: 10px; flex-shrink: 0; min-width: 140px; padding: 10px; border: 2px solid transparent; border-radius: 14px; background: #f5f5f5; color: var(--color-text-strong); cursor: pointer; font-family: "DM Sans", "Helvetica Neue", Arial, sans-serif; white-space: nowrap; transition: all .25s ease; }
.explore__tab:hover { background: #eee; }
.explore__tab:hover .explore__tab-icon { transform: scale(1.03); }
.explore__tab:focus-visible { outline: 3px solid rgba(19,128,174,.22); outline-offset: 3px; }
.explore__tab--active { border-color: var(--color-border-blue); background: var(--color-bg-blue-soft); }
.explore__tab--active::after { content: ""; position: absolute; bottom: -2px; left: 20%; right: 20%; height: 3px; border-radius: 999px; background: var(--color-primary); }
.explore__tab--active .explore__tab-icon { opacity: 1; box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.explore__tab--active .explore__tab-label { color: var(--color-primary); font-weight: 600; }
.explore__tab-icon { display: block; width: 120px; height: 82.5px; aspect-ratio: 16 / 11; object-fit: cover; border-radius: 10px; opacity: .55; transition: all .25s ease; }
.explore__tab-icon--empty { background: linear-gradient(135deg,#f0f4f8 0%,#e2e8f0 100%); }
.explore__tab-label { color: var(--color-text-nav); font-size: 13px; font-weight: 500; line-height: 1.3; text-align: center; transition: all .25s ease; }
.explore__group { margin-top: 32px; }
.explore__group-title { font-size: 1.25rem; margin-bottom: 18px; }
.explore__cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.tour-results__grid, .blog-page__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: 24px; }
.explore__empty { grid-column: 1 / -1; padding: 60px 20px; color: var(--color-text-body); font-size: 16px; text-align: center; }
.empty-box { grid-column: 1 / -1; padding: 42px 24px; border: 1px solid rgba(159,91,45,.2); border-radius: 16px; background: var(--tour-accent-soft); text-align: center; color: var(--color-text-body); }
.youtube { background: #f8f9fa; }
.youtube__wrapper { aspect-ratio: 16 / 9; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,.1); }
.youtube__iframe { width: 100%; height: 100%; border: 0; }
.promo { background: var(--color-promo-bg); padding: 72px 0; }
.promo__inner { display: flex; align-items: center; gap: 60px; }
.promo__content { flex: 1; }
.promo__image-wrap { flex: 1; border-radius: 16px; overflow: hidden; }
.promo__image { width: 100%; height: 360px; object-fit: cover; }

.tour-card, .dest-card, .blog-card { overflow: hidden; border-radius: 16px; background: #fff; box-shadow: 0 0 4px rgba(81,51,148,.20); transition: all .3s ease; }
.tour-card:hover, .dest-card:hover, .blog-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(81,51,148,.15); }
.tour-card__image-wrap, .dest-card__image-wrap, .blog-card__image-wrap { position: relative; height: 220px; display: block; overflow: hidden; }
.dest-card__image-wrap { height: 256px; }
.blog-card__image-wrap { height: 220px; }
.tour-card__image, .dest-card__image, .blog-card__image { width: 100%; height: 100%; object-fit: cover; }
.tour-card__save { position: absolute; top: 12px; left: 12px; padding: 4px 10px; border-radius: 20px; color: #fff; background: var(--color-error); font-size: 12px; font-weight: 600; }
.tour-card__style { position: absolute; top: 12px; right: 12px; padding: 4px 10px; border-radius: 20px; background: rgba(255,255,255,.9); color: var(--color-text-strong); font-size: 12px; }
.tour-card__body, .dest-card__body, .blog-card__body { padding: 20px; }
.tour-card__duration { color: var(--color-primary); font-size: 13px; font-weight: 500; }
.tour-card__title { font-size: 16px; font-weight: 700; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tour-card__location, .tour-card__meta { color: var(--color-text-body); font-size: 13px; }
.tour-card__meta { display: flex; gap: 12px; padding-top: 10px; border-top: 1px solid var(--color-divider); }
.tour-card__price-current { color: var(--color-primary); font-size: 22px; font-weight: 700; }
.dest-card__count { color: var(--color-text-nav); font-size: 10px; text-transform: uppercase; letter-spacing: 1px; }
.dest-card__title { font-size: 16px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.asset-placeholder { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; padding: 12px; border-radius: 8px; background: linear-gradient(135deg,#f0f4f8 0%,#e2e8f0 100%); color: #94a3b8; text-align: center; font-size: 14px; }

.tours-hero__inner { display: flex; justify-content: space-between; align-items: end; gap: 32px; }
.tours-hero h1 { font-size: clamp(2.25rem, 5vw, 4.4rem); line-height: .98; }
.popular-tours { background: linear-gradient(135deg, rgba(19,128,174,.1), rgba(255,246,237,.78)), #f8fbfd; }
.popular-tours__rail { display: flex; gap: 24px; overflow-x: auto; padding: 10px 0; }
.popular-tours__rail > * { min-width: min(340px, 82vw); }
.tour-finder__layout { display: grid; grid-template-columns: minmax(260px,310px) 1fr; gap: 32px; }
.filters { position: sticky; top: 92px; align-self: start; display: grid; gap: 18px; padding: 22px; border: 1px solid var(--tour-line); border-radius: 16px; background: #fff; box-shadow: var(--tour-shadow); }
.filters label { display: grid; gap: 6px; font-weight: 500; color: var(--color-text-strong); }
.filters__split { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.filters__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.filters__chips button { min-height: 40px; padding: 8px 14px; border: 1px solid var(--tour-line); border-radius: 999px; background: #fff; cursor: pointer; }
.filters__chips button.active { background: #eef8fd; border-color: rgba(19,128,174,.2); color: var(--color-primary); }
.tour-results__header { display: flex; align-items: end; justify-content: space-between; gap: 24px; margin-bottom: 20px; }
.trustpilot { display: flex; align-items: center; gap: 12px; padding: 12px 0; color: var(--color-text-body); font-size: 14px; }
.trustpilot__stars { color: #00b67a; letter-spacing: 2px; }
.offers-page__grid, .visa-page__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.offer-card, .visa-page__grid article { padding: 24px; border: 1px solid var(--tour-line); border-radius: 16px; background: #fff; box-shadow: var(--tour-shadow); }
.offer-card h2, .visa-page__grid h2 { font-size: 1.25rem; }

.tour-detail__header { display: flex; gap: 40px; align-items: center; margin-bottom: 40px; }
.tour-detail__header > div { flex: 1; }
.tour-detail__header img { width: 44%; max-height: 400px; object-fit: cover; border-radius: 16px; }
.tour-detail__grid { display: grid; grid-template-columns: 1fr 380px; gap: 40px; }
.tour-detail__content section { margin-bottom: 40px; }
.tour-detail__content h2 { display: inline-block; padding-bottom: 8px; border-bottom: 2px solid var(--color-primary); }
.check-list li::marker { color: var(--color-primary); }
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.gallery img { height: 180px; object-fit: cover; border-radius: 12px; }
.itinerary-day { padding: 20px 0; border-bottom: 1px solid var(--color-divider); }
.itinerary-day span { display: inline-block; padding: 4px 12px; border-radius: 20px; background: var(--color-primary); color: #fff; font-size: 13px; font-weight: 600; }
.inclusions { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.price-box { position: sticky; top: 92px; padding: 24px; border-radius: 16px; background: #f8f9fa; text-align: center; }
.price-box strong { display: block; color: var(--color-primary); font-size: 2rem; margin-bottom: 18px; }

.destination-page h1 { margin-top: 24px; }
.requirements { background: var(--color-bg-blue-soft); padding: 48px 0; }
.requirements__inner { display: flex; align-items: center; gap: 48px; }
.requirements img { width: 42%; border-radius: 16px; }
.instagram-widget { padding: 60px 0; background: #1a1a2e; color: #fff; text-align: center; }
.instagram-widget h2 { color: #fff; font-size: 1.5rem; }
.instagram-widget__placeholder { max-width: 800px; margin: 24px auto 0; padding: 40px; border: 1px dashed rgba(255,255,255,.2); border-radius: 16px; color: rgba(255,255,255,.5); }

.blog-page__header { text-align: center; margin-bottom: 32px; }
.blog-card h2 { font-size: 1.1rem; font-weight: 700; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.blog-card p { font-size: 14px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.blog-card__date { color: var(--color-icon-muted); font-size: 13px; }
.blog-article__container { max-width: 800px; margin: 0 auto; padding: 0 20px; }
.blog-article h1 { font-size: 2.25rem; line-height: 1.2; }
.blog-article__meta { display: flex; gap: 16px; color: var(--color-icon-muted); font-size: 14px; }
.blog-article__cover { width: 100%; border-radius: 16px; margin: 32px 0 40px; }
.blog-article__body { font-size: 16px; line-height: 1.8; }
.blog-article__body h2 { font-size: 1.5rem; margin: 32px 0 16px; }

.about-hero { position: relative; min-height: 300px; padding: 120px 80px; display: flex; align-items: center; }
.about-hero__bg-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.about-hero__overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(19,128,174,.85), rgba(36,34,57,.8)); }
.about-hero__content { position: relative; z-index: 1; }
.about-hero h1 { color: #fff; font-size: 3rem; }
.about-intro__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.about-intro h2 { color: var(--color-primary); font-size: 1.5rem; padding-bottom: 8px; border-bottom: 2px solid var(--color-border-blue); }
.about-intro p { line-height: 1.8; }
.about-team { background: #f8f9fa; }
.about-team h2 { text-align: center; margin-bottom: 40px; }
.about-team__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px; }
.team-card { display: flex; gap: 24px; padding: 24px; border-radius: 16px; background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,.06); }
.team-card__image-wrap { flex: 0 0 120px; height: 120px; border-radius: 50%; overflow: hidden; }
.team-card__image-wrap img { width: 100%; height: 100%; object-fit: cover; }
.team-card h3 { font-size: 1.1rem; font-weight: 700; margin-bottom: 4px; }
.team-card span { display: block; color: var(--color-primary); font-size: 13px; font-weight: 500; margin-bottom: 8px; }
.team-card p, .team-card li { font-size: 14px; }

.contact-hero { background: var(--color-contact-bg); padding: 90px 0 60px; }
.contact-hero__content { max-width: 75rem; margin: 0 auto; padding: 0 80px; display: flex; gap: 40px; }
.contact-hero__left { flex: 1; }
.contact-hero h1 { color: var(--color-primary); font-size: 2.5rem; }
.contact-hero__cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-bottom: 32px; }
.contact-hero__cards > div { padding: 24px; border-radius: 16px; background: #fff; text-align: center; box-shadow: 0 2px 8px rgba(0,0,0,.06); }
.contact-hero__cards img { width: 48px; height: 48px; object-fit: contain; margin: 0 auto; }
.contact-hero__cards a { color: var(--color-primary); font-size: 18px; font-weight: 600; }
.contact-hero__right { flex: 0 0 350px; }
.contact-hero__right img { width: 100%; height: 400px; object-fit: cover; border-radius: 16px; }
.contact-form { max-width: 700px; margin: 0 auto; display: grid; gap: 16px; }
.contact-form h2, .contact-faq h2 { text-align: center; font-size: 1.5rem; }
.contact-form__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.contact-form label { display: grid; gap: 6px; font-weight: 500; color: var(--color-text-strong); }
.contact-form__success { color: var(--color-success); text-align: center; font-weight: 500; }
.contact-form__error { color: var(--color-error); text-align: center; }
.honeypot { display: none; }

.faq--background { background: var(--color-bg-blue-soft); padding: 40px 20px; }
.faq__item { max-width: 800px; margin: 0 auto; border-bottom: 1px solid var(--color-divider); }
.faq__trigger { width: 100%; padding: 20px 0; border: 0; background: transparent; display: flex; align-items: center; justify-content: space-between; color: var(--color-text-strong); font-weight: 600; cursor: pointer; list-style: none; }
.faq__trigger::-webkit-details-marker { display: none; }
.faq__trigger:focus { outline: 2px solid var(--color-primary); outline-offset: 2px; border-radius: 4px; }
.faq__icon { font-size: 24px; transition: transform .3s ease; }
.faq__item[open] .faq__icon { transform: rotate(45deg); }
.faq__content { overflow: hidden; }
.not-found { min-height: 60vh; display: grid; place-items: center; align-content: center; text-align: center; padding: 40px 20px; }
.not-found h1 { color: var(--color-primary); font-size: 6rem; }

@media (max-width: 979px) {
  .container { padding-inline: 40px; }
  .site-header__desktop { display: none; }
  .site-header { position: fixed; height: 56px; left: 0; right: 0; border-bottom: 1px solid var(--color-divider); }
  .is-scrolled .site-header { height: 48px; }
  .is-scroll-hidden .site-header { transform: translateY(-100%); }
  .site-header__mobile { height: 100%; display: flex; align-items: center; justify-content: space-between; padding: 0 15px; background: rgba(255,255,255,.95); }
  .site-header__menu-btn { width: 40px; height: 40px; border: 0; background: transparent; font-size: 24px; }
  .mobile-bottom { position: fixed; left: 0; right: 0; bottom: 0; z-index: 1000; display: grid; grid-template-columns: repeat(4, 1fr); height: 60px; background: rgba(255,255,255,.95); backdrop-filter: blur(10px); border-top: 1px solid rgba(0,0,0,.06); }
  .mobile-bottom a, .mobile-bottom button { display: grid; place-items: center; border: 0; background: transparent; color: var(--color-text-nav); font-size: 11px; }
  .mobile-bottom a:hover, .mobile-bottom button:hover { color: var(--color-primary); }
  .mobile-overlay { display: block; position: fixed; inset: 0; z-index: 1001; background: rgba(0,0,0,.5); }
  .mobile-panel { display: block; position: fixed; top: 56px; left: 0; right: 0; bottom: 60px; z-index: 1002; overflow-y: auto; background: #fff; padding: 16px 20px; }
  .mobile-panel header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
  .mobile-panel header button { width: 36px; height: 36px; border: 0; border-radius: 50%; background: #f5f5f5; font-size: 24px; }
  .mobile-panel a, .mobile-panel__links a, .mobile-panel__tabs button { display: block; width: 100%; padding: 12px 10px; border: 0; border-radius: 8px; background: transparent; color: var(--color-text-strong); text-align: left; }
  .mobile-panel__tabs button.active { background: var(--color-bg-blue-soft); color: var(--color-primary); }
  .promo__inner, .tour-detail__header, .requirements__inner, .contact-hero__content { flex-direction: column; }
  .explore__cards { grid-template-columns: repeat(2, 1fr); }
  .tour-finder__layout, .tour-detail__grid { grid-template-columns: 1fr; }
  .filters, .price-box { position: static; }
  .tour-detail__header img, .requirements img { width: 100%; }
}

@media (max-width: 768px) {
  .container { padding-inline: 15px; }
  .section { padding: 3em 0; }
  .hero__title { font-size: 1.75rem; }
  .explore__cards, .tour-results__grid, .blog-page__grid, .about-team__grid, .about-intro__grid, .contact-form__grid, .contact-hero__cards, .inclusions, .offers-page__grid, .visa-page__grid { grid-template-columns: 1fr; }
  .about-hero { padding: 120px 15px; }
  .about-hero h1 { font-size: 2rem; }
  .team-card { flex-direction: column; align-items: center; text-align: center; }
  .contact-hero__content { padding: 0 15px; }
  .contact-hero__right { display: none; }
}

/* ===== Tour booking modal ===== */
.booking-modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 16px; }
.booking-modal__backdrop { position: absolute; inset: 0; background: rgba(36,34,57,.55); animation: booking-fade .2s ease-out; }
.booking-modal__dialog { position: relative; width: 100%; max-width: 620px; max-height: calc(100dvh - 32px); display: flex; flex-direction: column; background: #fff; border-radius: 16px; box-shadow: var(--tour-shadow); overflow: hidden; animation: booking-pop .24s cubic-bezier(.16,1,.3,1); }
.booking-modal__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 20px 24px; border-bottom: 1px solid var(--color-divider); }
.booking-modal__header h2 { margin: 0; font-size: 1.25rem; color: var(--color-text-strong); }
.booking-modal__close { flex: 0 0 auto; min-width: 44px; min-height: 44px; display: inline-flex; align-items: center; justify-content: center; border: none; border-radius: 8px; background: transparent; color: var(--color-text-body); font-size: 18px; cursor: pointer; transition: background .15s ease, color .15s ease; }
.booking-modal__close:hover { background: var(--tour-accent-soft); color: var(--tour-accent); }
.booking-modal__close:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }
.booking-modal__body { padding: 20px 24px 24px; overflow-y: auto; }

.booking-form { display: grid; gap: 16px; }
.booking-form__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.booking-form label { display: grid; gap: 6px; font-weight: 500; color: var(--color-text-strong); }
.booking-form .form-control { min-height: 44px; }
.booking-form .btn { width: 100%; min-height: 48px; }
.booking-form .req { color: var(--tour-accent); }

.booking-success { display: grid; gap: 8px; justify-items: center; text-align: center; padding: 24px 8px; }
.booking-success__sub { color: var(--color-text-body); font-size: 14px; }
.booking-success .btn { min-height: 44px; padding-inline: 28px; }

/* When the modal is open, stop the background page from scrolling. */
body.booking-modal--open { overflow: hidden; }

@media (max-width: 560px) {
  .booking-modal { padding: 0; align-items: stretch; }
  .booking-modal__dialog { max-width: 100%; max-height: 100dvh; border-radius: 0; }
  .booking-form__grid { grid-template-columns: 1fr; }
}

@keyframes booking-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes booking-pop { from { opacity: 0; transform: translateY(12px) scale(.98); } to { opacity: 1; transform: translateY(0) scale(1); } }

@media (prefers-reduced-motion: reduce) {
  .booking-modal__backdrop, .booking-modal__dialog { animation: none; }
}
