:root {
  --blue: #076ca3;
  --blue-deep: #073b59;
  --blue-ink: #062d43;
  --coral: #f36b25;
  --coral-dark: #dd5310;
  --green: #6cab45;
  --ivory: #f7f4ec;
  --sand: #e8dfce;
  --paper: #fffdf8;
  --ink: #10252f;
  --muted: #66767d;
  --line: #dbe2e3;
  --white: #fff;
  --serif: Georgia, "Times New Roman", serif;
  --sans: Inter, "Segoe UI", Arial, sans-serif;
  --container: min(1180px, calc(100% - 40px));
  --shadow: 0 24px 60px rgba(5, 45, 67, .14);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); -webkit-font-smoothing: antialiased; }
body.modal-open { overflow: hidden; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { color: inherit; }
.container { width: var(--container); margin-inline: auto; }
.section { padding: 110px 0; }
.skip-link { position: fixed; z-index: 999; top: 12px; left: 12px; padding: 10px 16px; transform: translateY(-150%); background: var(--white); border-radius: 6px; }
.skip-link:focus { transform: none; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

.utility-bar { background: var(--blue-ink); color: rgba(255,255,255,.78); font-size: 12px; letter-spacing: .02em; }
.utility-inner { min-height: 34px; display: flex; align-items: center; justify-content: space-between; }
.utility-inner p { margin: 0; }
.utility-links { display: flex; gap: 12px; }
.utility-links a:hover { color: var(--white); }

.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,253,248,.95); border-bottom: 1px solid rgba(7,59,89,.08); backdrop-filter: blur(16px); transition: box-shadow .3s, transform .3s; }
.site-header.scrolled { box-shadow: 0 8px 30px rgba(6,45,67,.09); }
.nav-wrap { height: 84px; display: flex; align-items: center; gap: 34px; }
.brand { min-width: max-content; display: inline-flex; align-items: center; gap: 11px; }
.brand img { width: 56px; height: 56px; object-fit: cover; border-radius: 50%; box-shadow: 0 0 0 3px var(--white), 0 0 0 4px rgba(7,108,163,.16); }
.brand span { display: grid; gap: 1px; }
.brand strong { font-size: 18px; color: var(--blue); letter-spacing: .04em; }
.brand small { color: var(--coral); font-weight: 800; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.main-nav { margin-left: auto; display: flex; align-items: center; gap: 27px; }
.main-nav a { position: relative; font-weight: 650; font-size: 14px; }
.main-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 2px; background: var(--coral); transition: right .25s; }
.main-nav a:hover::after { right: 0; }
.nav-cta { display: inline-flex; align-items: center; gap: 9px; padding: 12px 16px; color: var(--white); background: var(--blue); font-size: 13px; font-weight: 750; border-radius: 5px; }
.nav-cta:hover { background: var(--blue-deep); }
.nav-cta-icon { color: #9cd9f4; font-size: 16px; }
.menu-toggle { display: none; width: 40px; height: 40px; border: 0; padding: 9px; background: transparent; cursor: pointer; }
.menu-toggle span { display: block; width: 100%; height: 2px; margin: 5px 0; background: var(--ink); transition: .25s; }

.hero { position: relative; min-height: 710px; color: var(--white); background: var(--blue-ink); }
.hero-media { position: absolute; inset: 0; background: url("public/hero-nice-tourist.png") center / cover no-repeat; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(4,31,46,.89) 0%, rgba(4,31,46,.57) 34%, rgba(4,31,46,.06) 69%), linear-gradient(0deg, rgba(4,31,46,.33), transparent 42%); }
.hero-content { position: relative; min-height: 620px; display: flex; align-items: center; justify-content: space-between; padding-bottom: 40px; }
.hero-copy { max-width: 660px; padding: 60px 0 95px; }
.eyebrow { margin: 0 0 20px; display: flex; align-items: center; gap: 10px; color: var(--blue); font-size: 12px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.eyebrow span { width: 32px; height: 2px; background: var(--coral); }
.eyebrow-light { color: #c5eafa; }
.hero h1, .section-head h2, .custom-content h2, .testimonial-intro h2, .newsletter h2, .consult-aside h2 { margin: 0; font-family: var(--serif); font-size: clamp(50px, 6.4vw, 90px); line-height: .98; letter-spacing: -.045em; font-weight: 400; }
h1 em, h2 em { color: var(--coral); font-weight: 400; }
.hero-lead { max-width: 600px; margin: 27px 0 0; color: rgba(255,255,255,.79); font-size: 18px; line-height: 1.65; }
.hero-actions { margin-top: 34px; display: flex; align-items: center; gap: 26px; }
.btn { min-height: 52px; padding: 0 22px; border: 0; border-radius: 5px; display: inline-flex; align-items: center; justify-content: center; gap: 18px; font-weight: 800; cursor: pointer; transition: transform .2s, background .2s; }
.btn:hover { transform: translateY(-2px); }
.btn-primary, .btn-coral { color: var(--white); background: var(--coral); }
.btn-primary:hover, .btn-coral:hover { background: var(--coral-dark); }
.btn-dark { color: var(--white); background: var(--blue-ink); }
.text-link { border: 0; padding: 8px 0; color: var(--white); background: transparent; border-bottom: 1px solid rgba(255,255,255,.35); font-weight: 700; cursor: pointer; }
.hero-stamp { width: 138px; height: 138px; margin: 0 35px 40px 20px; padding: 9px; border: 1px solid rgba(255,255,255,.55); border-radius: 50%; animation: float 5s ease-in-out infinite; }
.hero-stamp img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; }
@keyframes float { 50% { transform: translateY(-12px) rotate(2deg); } }

.finder-wrap { position: relative; z-index: 3; margin-top: -92px; }
.trip-finder { min-height: 128px; padding: 22px 22px 22px 28px; display: grid; grid-template-columns: 1.25fr 1fr .85fr 1fr auto; align-items: center; gap: 0; color: var(--ink); background: var(--white); box-shadow: var(--shadow); border-radius: 8px; }
.finder-heading { display: flex; align-items: center; gap: 13px; padding-right: 24px; }
.finder-compass { width: 42px; height: 42px; display: grid; place-items: center; flex: 0 0 auto; color: var(--white); background: var(--blue); border-radius: 50%; font-size: 20px; }
.finder-heading div { display: grid; gap: 4px; }
.finder-heading small { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .09em; }
.finder-heading strong { font-family: var(--serif); font-size: 20px; font-weight: 500; }
.trip-finder label { padding: 0 18px; border-left: 1px solid var(--line); display: grid; gap: 8px; }
.trip-finder label span { color: var(--muted); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .09em; }
.trip-finder select, .trip-finder input { width: 100%; height: 36px; padding: 0 22px 0 0; border: 0; outline: 0; color: var(--ink); background: transparent; font-weight: 700; font-size: 13px; }
.trip-finder input::placeholder { color: var(--ink); opacity: 1; }
.finder-submit { height: 58px; min-width: 126px; border: 0; border-radius: 5px; color: var(--white); background: var(--coral); font-weight: 800; cursor: pointer; }
.finder-submit:hover { background: var(--coral-dark); }

.trust-strip { padding-top: 58px; background: var(--paper); }
.trust-grid { padding: 30px 0; display: grid; grid-template-columns: repeat(4, 1fr); border-bottom: 1px solid var(--line); }
.trust-grid div { display: flex; align-items: center; justify-content: center; gap: 15px; border-right: 1px solid var(--line); }
.trust-grid div:last-child { border: 0; }
.trust-grid strong { color: var(--blue); font-family: var(--serif); font-size: 30px; font-weight: 500; }
.trust-grid span { max-width: 94px; color: var(--muted); font-size: 12px; line-height: 1.4; }

.section-head { margin-bottom: 50px; display: grid; grid-template-columns: 1.5fr .7fr; align-items: end; gap: 80px; }
.section-head h2, .custom-content h2, .testimonial-intro h2, .newsletter h2, .consult-aside h2 { font-size: clamp(42px, 5vw, 68px); color: var(--blue-ink); }
.section-intro { margin: 0 0 8px; color: var(--muted); font-size: 16px; line-height: 1.75; }

.destination-grid { height: 520px; display: grid; grid-template-columns: 1.25fr .75fr .75fr; grid-template-rows: 1fr 1fr; gap: 16px; }
.destination-card { position: relative; overflow: hidden; padding: 28px; border: 0; color: var(--white); background-image: linear-gradient(0deg, rgba(4,31,46,.75), rgba(4,31,46,.03) 60%), url("public/hero-nice-tourist.png"); background-size: auto, 1900px auto; text-align: left; cursor: pointer; }
.destination-card::after { content: ""; position: absolute; inset: 0; border: 1px solid rgba(255,255,255,.25); transition: inset .35s; }
.destination-card:hover::after { inset: 10px; }
.destination-card:hover .destination-copy { transform: translateY(-6px); }
.destination-vietnam { grid-row: 1 / 3; background-position: center, 53% center; }
.destination-asia { grid-column: 2 / 4; background-position: center, 16% 45%; }
.destination-europe { background-position: center, 76% 70%; }
.destination-america { background-position: center, 100% 48%; }
.destination-no { position: absolute; top: 22px; right: 22px; z-index: 1; font-size: 11px; letter-spacing: .14em; }
.destination-copy { position: absolute; z-index: 1; left: 28px; bottom: 27px; display: grid; transition: transform .3s; }
.destination-copy small { margin-bottom: 6px; color: rgba(255,255,255,.7); font-size: 11px; letter-spacing: .13em; text-transform: uppercase; }
.destination-copy strong { font-family: var(--serif); font-size: 34px; font-weight: 500; }
.destination-copy em { margin-top: 10px; color: #ffd0b6; font-style: normal; font-size: 12px; font-weight: 700; }

.journeys { background: #f0f4f3; }
.journeys-head { margin-bottom: 30px; }
.tour-tabs { display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }
.tour-tab { padding: 10px 13px; border: 1px solid #cbd7d8; border-radius: 4px; color: var(--muted); background: transparent; font-size: 12px; font-weight: 750; cursor: pointer; }
.tour-tab.active { border-color: var(--blue); color: var(--white); background: var(--blue); }
.tour-result-meta { min-height: 40px; display: flex; align-items: center; justify-content: space-between; color: var(--muted); font-size: 12px; }
.tour-result-meta p { margin: 0; }
.tour-result-meta strong { color: var(--ink); }
.tour-result-meta button { border: 0; color: var(--coral-dark); background: transparent; cursor: pointer; }
.tour-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.tour-card { position: relative; min-width: 0; background: var(--white); transition: transform .3s, box-shadow .3s; }
.tour-card:hover { transform: translateY(-6px); box-shadow: 0 18px 44px rgba(7,59,89,.13); }
.tour-image { position: relative; height: 250px; overflow: hidden; background-image: linear-gradient(0deg, rgba(4,31,46,.5), rgba(4,31,46,.04) 60%), url("public/hero-nice-tourist.png"); background-size: auto, 1900px auto; }
.tour-card[data-scene="vietnam"] .tour-image { background-position: center, 52% 51%; }
.tour-card[data-scene="asia"] .tour-image { background-position: center, 16% 44%; }
.tour-card[data-scene="europe"] .tour-image { background-position: center, 77% 62%; }
.tour-card[data-scene="america"] .tour-image { background-position: center, 100% 45%; }
.tour-badge { position: absolute; top: 16px; left: 16px; padding: 7px 10px; color: var(--blue-ink); background: rgba(255,255,255,.9); backdrop-filter: blur(8px); border-radius: 3px; font-size: 10px; font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.tour-index { position: absolute; right: 16px; bottom: 13px; color: var(--white); font-family: var(--serif); font-size: 42px; opacity: .8; }
.tour-body { padding: 22px; }
.tour-kicker { margin: 0 0 9px; color: var(--coral-dark); font-size: 10px; font-weight: 850; letter-spacing: .12em; text-transform: uppercase; }
.tour-body h3 { min-height: 51px; margin: 0; font-family: var(--serif); color: var(--blue-ink); font-size: 21px; line-height: 1.25; font-weight: 600; }
.tour-meta { margin: 19px 0; padding: 15px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 9px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.tour-meta span { color: var(--muted); font-size: 11px; }
.tour-meta strong { display: block; margin-top: 3px; color: var(--ink); font-size: 12px; }
.tour-foot { display: flex; align-items: end; justify-content: space-between; gap: 10px; }
.tour-price { display: grid; gap: 4px; }
.tour-price small { color: var(--muted); font-size: 10px; }
.tour-price strong { color: var(--coral); font-size: 18px; }
.tour-detail-btn { padding: 8px 0; border: 0; border-bottom: 1px solid var(--blue); color: var(--blue); background: transparent; font-size: 12px; font-weight: 800; cursor: pointer; }
.empty-state { padding: 70px 20px; text-align: center; background: var(--white); }
.empty-state span { color: var(--coral); font-size: 50px; }
.empty-state h3 { margin: 10px 0; font-family: var(--serif); font-size: 28px; }
.empty-state p { margin: 0 auto 24px; max-width: 520px; color: var(--muted); line-height: 1.6; }

.custom-tour { overflow: hidden; color: var(--white); background: var(--blue-ink); }
.custom-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 90px; align-items: center; }
.custom-visual { position: relative; min-height: 590px; background: linear-gradient(145deg, #0783bd, #06496d); overflow: hidden; }
.custom-visual::before { content: ""; position: absolute; inset: 0; opacity: .18; background-image: radial-gradient(circle at 20% 20%, #fff 1px, transparent 1px); background-size: 22px 22px; }
.custom-visual::after { content: "N"; position: absolute; right: -30px; bottom: -120px; color: rgba(255,255,255,.08); font-family: var(--serif); font-size: 480px; line-height: 1; }
.visual-label { position: absolute; z-index: 2; top: 25px; left: 28px; margin: 0; font-size: 11px; font-weight: 800; letter-spacing: .16em; }
.visual-quote { position: absolute; z-index: 2; top: 95px; left: 55px; width: 61%; }
.visual-quote span { color: #ffbe9b; font-family: var(--serif); font-size: 90px; line-height: .7; }
.visual-quote p { margin: 15px 0; font-family: var(--serif); font-size: 28px; line-height: 1.35; }
.visual-card { position: absolute; z-index: 3; right: 0; bottom: 0; width: 61%; padding: 34px; color: var(--ink); background: var(--ivory); }
.visual-card span { color: var(--coral-dark); font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.visual-card strong { display: block; margin-top: 14px; font-family: var(--serif); font-size: 34px; line-height: 1.1; font-weight: 500; }
.route-line { position: absolute; z-index: 1; left: 18%; bottom: 10%; width: 70%; height: 55%; border: 1px dashed rgba(255,255,255,.4); border-left-color: transparent; border-bottom-color: transparent; border-radius: 50%; transform: rotate(-15deg); }
.route-dot { position: absolute; width: 11px; height: 11px; border: 3px solid rgba(255,255,255,.5); background: var(--coral); border-radius: 50%; box-shadow: 0 0 0 6px rgba(243,107,37,.18); }
.route-a { left: 10%; bottom: 4%; }.route-b { left: 48%; top: -4%; }.route-c { right: 4%; bottom: 16%; }
.custom-content h2 { color: var(--white); }
.custom-content > p:not(.eyebrow) { margin: 27px 0 32px; color: rgba(255,255,255,.7); line-height: 1.75; }
.process-list { margin: 0 0 32px; padding: 0; list-style: none; }
.process-list li { padding: 16px 0; display: flex; gap: 18px; border-top: 1px solid rgba(255,255,255,.14); }
.process-list li > span { color: var(--coral); font-family: var(--serif); }
.process-list div { display: grid; gap: 5px; }
.process-list strong { font-family: var(--serif); font-size: 18px; font-weight: 500; }
.process-list small { color: rgba(255,255,255,.58); line-height: 1.5; }

.benefit-grid { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); }
.benefit { min-height: 310px; padding: 32px 27px; border-right: 1px solid var(--line); }
.benefit:last-child { border: 0; }
.benefit-icon { width: 47px; height: 47px; display: grid; place-items: center; color: var(--blue); background: #e7f3f7; border-radius: 50%; font-size: 22px; }
.benefit-no { margin: 36px 0 12px; color: var(--coral); font-size: 11px; font-weight: 800; }
.benefit h3 { margin: 0 0 13px; color: var(--blue-ink); font-family: var(--serif); font-size: 22px; }
.benefit > p:last-child { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.65; }

.testimonials { color: var(--white); background: #076996; }
.testimonial-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 80px; align-items: center; }
.testimonial-intro h2 { color: var(--white); }
.testimonial-intro h2 em { color: #ffb186; }
.testimonial-arrows { margin-top: 38px; display: flex; gap: 8px; }
.testimonial-arrows button { width: 46px; height: 46px; border: 1px solid rgba(255,255,255,.35); color: var(--white); background: transparent; cursor: pointer; }
.testimonial-arrows button:hover { background: rgba(255,255,255,.12); }
.testimonial-card { position: relative; min-height: 400px; padding: 50px; color: var(--ink); background: var(--white); }
.stars { color: var(--coral); letter-spacing: .12em; }
.testimonial-card blockquote { position: relative; z-index: 1; margin: 28px 0 42px; font-family: var(--serif); font-size: 29px; line-height: 1.5; }
.testimonial-person { display: flex; align-items: center; gap: 14px; }
.avatar { width: 48px; height: 48px; display: grid; place-items: center; color: var(--white); background: var(--blue); border-radius: 50%; font-weight: 800; }
.testimonial-person div:last-child { display: grid; gap: 4px; }
.testimonial-person small { color: var(--muted); }
.quote-mark { position: absolute; right: 28px; top: 10px; color: #edf3f3; font-family: var(--serif); font-size: 180px; line-height: 1; }

.newsletter { padding: 75px 0; background: var(--ivory); }
.newsletter-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; }
.newsletter h2 { font-size: 50px; }
.newsletter form { display: grid; grid-template-columns: 1fr auto; }
.newsletter input { min-width: 0; height: 58px; padding: 0 18px; border: 1px solid #cfd6d3; border-right: 0; background: var(--white); outline-color: var(--blue); }
.newsletter button { padding: 0 22px; border: 0; color: var(--white); background: var(--coral); font-weight: 800; cursor: pointer; }
.newsletter form small { grid-column: 1 / -1; margin-top: 10px; color: var(--muted); }

.site-footer { color: rgba(255,255,255,.7); background: var(--blue-ink); }
.footer-top { padding: 70px 0 55px; display: grid; grid-template-columns: 1.5fr .7fr .7fr 1fr; gap: 60px; }
.brand-footer strong { color: var(--white); }
.brand-footer img { box-shadow: 0 0 0 3px var(--blue-ink), 0 0 0 4px rgba(255,255,255,.3); }
.footer-brand > p { max-width: 310px; margin: 25px 0; font-size: 13px; line-height: 1.7; }
.socials { display: flex; gap: 8px; }
.socials a { width: 35px; height: 35px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.2); border-radius: 50%; color: var(--white); }
.footer-col { display: flex; flex-direction: column; gap: 13px; font-size: 13px; }
.footer-col h3 { margin: 5px 0 13px; color: var(--white); font-family: var(--serif); font-size: 17px; font-weight: 500; }
.footer-col a:hover { color: var(--white); }
.footer-contact a, .footer-contact p { display: grid; gap: 5px; margin: 0; color: var(--white); font-weight: 700; }
.footer-contact small { color: rgba(255,255,255,.45); font-weight: 400; }
.footer-bottom { min-height: 70px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.12); font-size: 11px; }

.floating-actions { position: fixed; z-index: 40; right: 20px; bottom: 20px; display: grid; gap: 8px; }
.floating-actions a, .floating-actions button { width: 44px; height: 44px; display: grid; place-items: center; border: 0; border-radius: 50%; color: var(--white); background: var(--coral); box-shadow: 0 8px 24px rgba(6,45,67,.2); cursor: pointer; }
.floating-actions button { opacity: 0; pointer-events: none; color: var(--blue-ink); background: var(--white); transition: opacity .25s; }
.floating-actions button.visible { opacity: 1; pointer-events: auto; }

dialog { padding: 0; border: 0; color: var(--ink); background: var(--white); box-shadow: 0 30px 90px rgba(0,0,0,.28); }
dialog::backdrop { background: rgba(2,24,36,.74); backdrop-filter: blur(4px); }
.tour-modal { width: min(900px, calc(100% - 30px)); max-height: min(860px, calc(100vh - 30px)); }
.modal-close { position: absolute; z-index: 5; top: 15px; right: 15px; width: 38px; height: 38px; border: 0; border-radius: 50%; color: var(--ink); background: rgba(255,255,255,.9); font-size: 25px; cursor: pointer; }
.modal-hero { min-height: 290px; padding: 42px; display: flex; align-items: end; color: var(--white); background-image: linear-gradient(0deg, rgba(4,31,46,.9), rgba(4,31,46,.05)), url("public/hero-nice-tourist.png"); background-size: auto, 1900px auto; }
.modal-hero[data-scene="vietnam"] { background-position: center, 52% 51%; }
.modal-hero[data-scene="asia"] { background-position: center, 16% 44%; }
.modal-hero[data-scene="europe"] { background-position: center, 77% 62%; }
.modal-hero[data-scene="america"] { background-position: center, 100% 45%; }
.modal-hero p { margin: 0 0 12px; color: #ffd0b6; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; }
.modal-hero h2 { max-width: 720px; margin: 0; font-family: var(--serif); font-size: 38px; line-height: 1.1; }
.modal-body { padding: 36px 42px 42px; }
.modal-info { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); }
.modal-info div { padding: 15px; border-right: 1px solid var(--line); }
.modal-info div:last-child { border: 0; }
.modal-info small { color: var(--muted); font-size: 10px; text-transform: uppercase; }
.modal-info strong { display: block; margin-top: 6px; font-size: 12px; }
.modal-columns { margin-top: 30px; display: grid; grid-template-columns: 1fr .8fr; gap: 45px; }
.modal-columns h3 { margin: 0 0 14px; font-family: var(--serif); font-size: 23px; }
.highlight-list { margin: 0; padding: 0; list-style: none; }
.highlight-list li { position: relative; padding: 9px 0 9px 22px; color: var(--muted); line-height: 1.5; border-bottom: 1px solid var(--line); }
.highlight-list li::before { content: "✦"; position: absolute; left: 0; color: var(--coral); }
.modal-note { padding: 22px; background: var(--ivory); }
.modal-note p { margin: 0 0 18px; color: var(--muted); font-size: 13px; line-height: 1.6; }
.modal-note .btn { width: 100%; }
.pdf-link { margin-top: 10px; display: block; color: var(--blue); text-align: center; font-size: 12px; font-weight: 700; }

.consult-modal { width: min(960px, calc(100% - 30px)); }
.consult-layout { display: grid; grid-template-columns: .85fr 1.15fr; }
.consult-aside { padding: 55px 45px; color: var(--white); background: var(--blue-ink); }
.consult-aside h2 { color: var(--white); font-size: 43px; }
.consult-aside > p:last-child { color: rgba(255,255,255,.65); line-height: 1.7; }
#consult-form { padding: 55px 45px; display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
#consult-form label { display: grid; gap: 8px; color: var(--muted); font-size: 12px; font-weight: 700; }
#consult-form input, #consult-form select, #consult-form textarea { width: 100%; padding: 12px; border: 1px solid var(--line); color: var(--ink); background: var(--paper); outline-color: var(--blue); resize: vertical; }
#consult-form .full { grid-column: 1 / -1; }

.toast { position: fixed; z-index: 100; left: 50%; bottom: 26px; max-width: calc(100% - 32px); padding: 14px 20px; color: var(--white); background: var(--blue-ink); border-left: 4px solid var(--green); box-shadow: var(--shadow); transform: translate(-50%, 140%); transition: transform .35s; }
.toast.show { transform: translate(-50%, 0); }
.reveal { opacity: 1; transform: none; }
.reveal.in-view { animation: soft-in .55s ease both; }
@keyframes soft-in {
  from { opacity: .86; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}

@media (max-width: 1050px) {
  .main-nav { gap: 17px; }
  .main-nav a { font-size: 13px; }
  .nav-cta { display: none; }
  .trip-finder { grid-template-columns: 1fr 1fr 1fr auto; }
  .finder-heading { display: none; }
  .tour-grid { grid-template-columns: repeat(2, 1fr); }
  .custom-grid { gap: 55px; }
  .footer-top { grid-template-columns: 1.3fr 1fr 1fr; }
  .footer-contact { grid-column: 2 / 4; }
}

@media (max-width: 800px) {
  :root { --container: min(100% - 28px, 650px); }
  .section { padding: 78px 0; }
  .utility-inner { justify-content: center; }
  .utility-inner > p { display: none; }
  .nav-wrap { height: 72px; }
  .brand img { width: 48px; height: 48px; }
  .brand strong { font-size: 16px; }
  .menu-toggle { display: block; margin-left: auto; }
  .menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle.open span:nth-child(2) { opacity: 0; }
  .menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .main-nav { position: absolute; top: 72px; left: 0; right: 0; margin: 0; padding: 14px; display: none; flex-direction: column; align-items: stretch; gap: 0; background: var(--paper); box-shadow: 0 20px 30px rgba(6,45,67,.12); }
  .main-nav.open { display: flex; }
  .main-nav a { padding: 15px; border-bottom: 1px solid var(--line); }
  .main-nav a::after { display: none; }
  .hero { min-height: 810px; }
  .hero-media { background-position: 45% center; }
  .hero-shade { background: linear-gradient(90deg, rgba(4,31,46,.88), rgba(4,31,46,.32)), linear-gradient(0deg, rgba(4,31,46,.5), transparent); }
  .hero-content { min-height: 560px; }
  .hero-copy { padding: 50px 0 130px; }
  .hero h1 { font-size: clamp(47px, 13vw, 68px); }
  .hero-lead { font-size: 16px; }
  .hero-stamp { display: none; }
  .finder-wrap { margin-top: -145px; }
  .trip-finder { padding: 19px; grid-template-columns: 1fr 1fr; gap: 14px; }
  .trip-finder label { padding: 0 10px 8px 0; border-left: 0; border-bottom: 1px solid var(--line); }
  .finder-submit { grid-column: 1 / -1; }
  .trust-strip { padding-top: 75px; }
  .trust-grid { grid-template-columns: 1fr 1fr; gap: 0; }
  .trust-grid div { padding: 18px 0; border-bottom: 1px solid var(--line); }
  .trust-grid div:nth-child(2) { border-right: 0; }
  .trust-grid div:nth-child(3), .trust-grid div:nth-child(4) { border-bottom: 0; }
  .section-head { grid-template-columns: 1fr; gap: 25px; }
  .destination-grid { height: auto; grid-template-columns: 1fr 1fr; grid-template-rows: 310px 240px 240px; }
  .destination-vietnam { grid-row: auto; grid-column: 1 / -1; }
  .destination-asia { grid-column: 1 / -1; }
  .journeys-head { align-items: start; }
  .tour-tabs { justify-content: flex-start; }
  .custom-grid, .testimonial-grid, .newsletter-inner { grid-template-columns: 1fr; }
  .custom-visual { min-height: 480px; }
  .custom-grid { gap: 60px; }
  .benefit-grid { grid-template-columns: 1fr 1fr; }
  .benefit:nth-child(2) { border-right: 0; }
  .benefit:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .testimonial-grid { gap: 45px; }
  .newsletter-inner { gap: 35px; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-contact { grid-column: auto; }
  .consult-layout { grid-template-columns: 1fr; max-height: calc(100vh - 30px); overflow: auto; }
  .consult-aside { padding: 40px 30px; }
  #consult-form { padding: 35px 30px; }
}

@media (max-width: 560px) {
  .hero-actions { align-items: stretch; flex-direction: column; gap: 13px; }
  .hero-actions .btn { width: 100%; }
  .text-link { align-self: center; }
  .trip-finder { grid-template-columns: 1fr; }
  .finder-submit { grid-column: auto; }
  .trust-grid div { padding: 15px 8px; gap: 9px; }
  .trust-grid strong { font-size: 24px; }
  .destination-grid { display: grid; grid-template-columns: 1fr; grid-template-rows: repeat(4, 250px); }
  .destination-card { grid-column: auto; }
  .tour-grid { grid-template-columns: 1fr; }
  .tour-image { height: 230px; }
  .custom-visual { min-height: 420px; }
  .visual-quote { left: 30px; width: 75%; }
  .visual-quote p { font-size: 23px; }
  .visual-card { width: 78%; }
  .benefit-grid { grid-template-columns: 1fr; }
  .benefit { min-height: 240px; border-right: 0; border-bottom: 1px solid var(--line); }
  .testimonial-card { min-height: 0; padding: 32px 25px; }
  .testimonial-card blockquote { font-size: 23px; }
  .newsletter form { grid-template-columns: 1fr; }
  .newsletter input { border-right: 1px solid #cfd6d3; }
  .newsletter button { min-height: 52px; }
  .newsletter form small { grid-column: auto; }
  .footer-top { grid-template-columns: 1fr; gap: 35px; }
  .footer-brand, .footer-contact { grid-column: auto; }
  .footer-bottom { padding: 20px 0; align-items: flex-start; flex-direction: column; justify-content: center; gap: 6px; }
  .modal-hero { min-height: 240px; padding: 30px 24px; }
  .modal-hero h2 { font-size: 29px; }
  .modal-body { padding: 26px 24px 32px; }
  .modal-info { grid-template-columns: 1fr 1fr; }
  .modal-info div:nth-child(2) { border-right: 0; }
  .modal-info div:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .modal-columns { grid-template-columns: 1fr; gap: 25px; }
  #consult-form { grid-template-columns: 1fr; }
  #consult-form .full { grid-column: auto; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
