/*
  DosoTravel Clean Code Final
  Main production stylesheet for Desktop + Mobile.
  Container standard: 1170px.
  Search V2 includes single travel date range picker and budget dropdown.
*/
:root { --red: #c8192e; --red-dark: #9c1021; --navy: #111b33; --navy-soft: #172643; --gold: #d8a74a; --cream: #fbf7ef; --paper: #ffffff; --ink: #182033; --muted: #6b7280; --line: rgba(17, 27, 51, 0.10); --shadow: 0 24px 70px rgba(17, 27, 51, 0.13); --radius: 24px; --container: 1170px; --doso-card-radius: 8px; }
* { box-sizing: border-box; font-family: 'Noto Sans Thai', sans-serif; color: var(--color-txtg); }
:root { --font-bai-jamjuree: 'Bai Jamjuree', sans-serif; --font-barlow-semi: 'Barlow Semi Condensed', sans-serif; --font-noto-sans: 'Noto Sans Thai', sans-serif; --font-noto-prompt: 'Prompt', sans-serif; }
html { scroll-behavior: smooth; }
body { margin: 0; background: linear-gradient(180deg, #fff 0%, #fbf7ef 45%, #fff 100%); }
a { color: inherit; text-decoration: none; }
button, input, select { font-family: inherit; }
.container { width: min(var(--container), calc(100% - 40px)); margin: 0 auto; }
.topbar { background: var(--navy); color: rgba(255,255,255,.84); font-size: 13px; }
.topbar-inner, .main-header-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.topbar-inner { min-height: 42px; }
.topbar-left, .topbar-right { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.topbar a:hover { color: #fff; }
.main-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.92); backdrop-filter: blur(18px); border-bottom: 1px solid var(--line); }
.main-header-inner { min-height: 92px; }
.brand { display: flex; align-items: center; gap: 14px; min-width: 236px; }
.brand-logo { display: block; width: auto; height: 88px; max-width: 100%; object-fit: contain; }
.main-nav { display: flex; align-items: center; gap: 6px; }
.main-nav > a, .nav-dropdown > a { display: inline-flex; align-items: center; min-height: 46px; padding: 0 12px; border-radius: 999px; font-size: 14px; font-weight: 700; color: var(--navy); }
.main-nav > a:hover, .nav-dropdown:hover > a, .main-nav > a.active { background: rgba(200,25,46,.08); color: var(--red); }
.nav-dropdown { position: relative; }
.mobile-toggle { display: none; width: 46px; height: 46px; border: 0; border-radius: 14px; background: var(--red); padding: 11px; }
.mobile-toggle span { display: block; height: 2px; margin: 5px 0; background: #fff; border-radius: 99px; }
.mobile-search-trigger { display: none; }
.mobile-quick-search, .mobile-country-action, .mobile-shortcut-menu, .country-thumb, .mobile-all-countries { display: none; }
.hero { position: relative; min-height: 690px; overflow: hidden; background: var(--navy); }
.hero-slider { position: absolute; inset: 0; }
.hero-slide { position: absolute; inset: 0; opacity: 0; background-position: center; background-size: cover; background-repeat: no-repeat; animation: heroSlide 18s infinite; }
.hero-slide::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(17,27,51,.92) 0%, rgba(17,27,51,.76) 43%, rgba(17,27,51,.28) 100%); z-index: 1; }
.hero-slide .hero-inner { z-index: 2; }
@keyframes heroSlide { 0% { opacity: 1; transform: scale(1.02); } 30% { opacity: 1; transform: scale(1); } 33.333% { opacity: 0; transform: scale(1); } 100% { opacity: 0; transform: scale(1.02); } }
.hero-slider-dots { position: absolute; left: 50%; bottom: 22px; z-index: 3; display: flex; gap: 9px; transform: translateX(-50%); }
.hero-slider-dots span { width: 30px; height: 4px; border-radius: 999px; background: rgba(255,255,255,.38); box-shadow: 0 0 0 1px rgba(255,255,255,.12); }
.hero-slider-dots span:nth-child(1) { animation: dotActive 18s infinite; }
.hero-slider-dots span:nth-child(2) { animation: dotActive 18s infinite 6s; }
.hero-slider-dots span:nth-child(3) { animation: dotActive 18s infinite 12s; }
@keyframes dotActive { 0%, 35% { background: #f4512a; width: 42px; } 36%, 100% { background: rgba(255,255,255,.38); width: 30px; } }
.hero::after { content: ""; position: absolute; right: -140px; top: 70px; width: 520px; height: 520px; border-radius: 50%; border: 1px solid rgba(216,167,74,.34); box-shadow: inset 0 0 0 60px rgba(216,167,74,.05); z-index: 2; pointer-events: none; }
.hero-inner { position: relative; z-index: 2; min-height: 690px; display: grid; grid-template-columns: 1fr 380px; align-items: center; gap: 56px; color: #fff; }
.eyebrow, .section-heading span { display: inline-block; color: var(--gold); font-weight: 800; letter-spacing: .12em; text-transform: uppercase; font-size: 12px; margin-bottom: 10px; }
.hero h1 { margin: 0 0 20px; font-size: clamp(42px, 5vw, 68px); line-height: 1.12; letter-spacing: -1.5px; }
.hero p { max-width: 630px; margin: 0; color: rgba(255,255,255,.82); font-size: 19px; line-height: 1.9; }
.hero-actions { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
.btn { display: inline-flex; justify-content: center; align-items: center; min-height: 52px; padding: 0 26px; border-radius: 999px; font-weight: 800; transition: .25s ease; }
.btn-primary { background: var(--red); color: #fff; box-shadow: 0 18px 38px rgba(200,25,46,.36); }
.btn-primary:hover { transform: translateY(-2px); background: #dd2037; }
.btn-ghost { color: #fff; border: 1px solid rgba(255,255,255,.36); }
.btn-ghost:hover { background: rgba(255,255,255,.10); }
.hero-card { align-self: end; margin-bottom: 74px; padding: 30px; border-radius: 28px; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.22); backdrop-filter: blur(18px); box-shadow: 0 30px 80px rgba(0,0,0,.25); }
.card-label { color: var(--gold); font-size: 13px; font-weight: 800; }
.hero-card h3 { font-size: 26px; margin: 12px 0 8px; }
.hero-card p { font-size: 15px; line-height: 1.7; }
.hero-card-meta { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-top: 22px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.18); }
.hero-card-meta strong { color: #fff; font-size: 20px; }
.search-panel-wrap { margin-top: -58px; position: relative; z-index: 5; }
.search-panel { display: grid; grid-template-columns: 1.05fr 1.7fr 1.05fr 1fr auto; gap: 14px; padding: 18px; border-radius: 28px; background: #fff; box-shadow: var(--shadow); border: 1px solid rgba(216,167,74,.22); }
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { color: var(--muted); font-size: 13px; font-weight: 700; }
.field input, .field select { height: 52px; border: 1px solid var(--line); border-radius: 16px; padding: 0 16px; color: var(--ink); background: #fbfbfd; outline: none; }
.field input:focus, .field select:focus { border-color: rgba(200,25,46,.5); box-shadow: 0 0 0 4px rgba(200,25,46,.08); }
.btn-search { align-self: end; height: 52px; border: 0; border-radius: 16px; padding: 0 24px; background: var(--red); color: #fff; font-weight: 800; cursor: pointer; }
.section { padding: 86px 0; }
.section-heading { margin-bottom: 34px; }
.section-heading.center { text-align: center; max-width: 720px; margin-left: auto; margin-right: auto; }
.section-heading.split { display: flex; justify-content: space-between; align-items: end; gap: 20px; }
.section-heading h2 { margin: 0; font-size: clamp(30px, 4vw, 44px); color: var(--navy); letter-spacing: -.5px; }
.section-heading p { margin: 10px 0 0; color: var(--muted); line-height: 1.8; }
.view-all { color: var(--red); font-weight: 800; }
.popular-countries { background: linear-gradient(180deg, #fff 0%, #fffaf4 62%, var(--cream) 100%); padding-bottom: 58px; }
.country-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.country-card { min-height: 160px; display: flex; flex-direction: column; justify-content: end; padding: 20px; border-radius: 24px; color: #fff; overflow: hidden; position: relative; box-shadow: 0 18px 44px rgba(17,27,51,.14); background: var(--navy); }
.country-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(17,27,51,.1), rgba(17,27,51,.75)); }
.country-card strong, .country-card span { position: relative; }
.country-card strong { font-size: 23px; }
.country-card span { opacity: .82; }
.desktop-promo-section { position: relative; overflow: hidden; background: radial-gradient(ellipse at 50% 45%, rgba(82, 91, 204, .10) 0%, rgba(82, 91, 204, 0) 46%),
    radial-gradient(ellipse at 34% 46%, rgba(244, 81, 42, .08) 0%, rgba(244, 81, 42, 0) 34%),
    linear-gradient(180deg, var(--cream) 0%, #fffaf4 48%, var(--cream) 100%); padding: 36px 0; }
.desktop-promo-section::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(90deg, rgba(255,255,255,.70), rgba(255,255,255,0) 18%, rgba(255,255,255,0) 82%, rgba(255,255,255,.70)),
    linear-gradient(180deg, rgba(255,255,255,.40), rgba(255,255,255,0) 30%, rgba(255,255,255,.22)); }
.desktop-promo-section > .container { position: relative; z-index: 1; }
.desktop-promo-banner { display: block; overflow: hidden; background: #f4f6fb; border: 1px solid rgba(255,255,255,.65); box-shadow: 0 28px 70px rgba(17,27,51,.10),
    0 0 0 10px rgba(255,255,255,.22); transition: transform .28s ease, box-shadow .28s ease, filter .28s ease; }
.desktop-promo-banner img { display: block; width: 100%; height: auto; }
.desktop-promo-banner:hover { transform: translateY(-4px); filter: saturate(1.03) contrast(1.02); box-shadow: 0 34px 86px rgba(17,27,51,.15),
    0 0 0 10px rgba(255,255,255,.28); }
.tour-section { background: #fff; }
.tour-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.tour-card { border-radius: var(--doso-card-radius); overflow: hidden; background: #fff; border: 1px solid var(--line); box-shadow: 0 16px 45px rgba(17,27,51,.08); transition: .25s ease; }
.tour-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.tour-card.premium { border-color: rgba(216,167,74,.45); }
.tour-image { min-height: 230px; position: relative; display: flex; align-items: start; justify-content: end; padding: 16px; background: var(--navy) center/cover no-repeat; border-radius: var(--doso-card-radius) var(--doso-card-radius) 0 0; }
.tour-image span { padding: 8px 14px; border-radius: 999px; background: rgba(255,255,255,.92); color: var(--red); font-size: 13px; font-weight: 800; }
.tour-body { padding: 22px; }
.tour-topline { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.tour-topline { color: var(--muted); font-size: 13px; margin-bottom: 10px; }
.tour-topline strong { color: var(--gold); }
.tour-card h3 { margin: 0 0 10px; font-size: 20px; line-height: 1.45; color: var(--navy); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.tour-card p { margin: 0 0 18px; color: var(--muted); line-height: 1.75; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
@media (min-width: 901px) {
  .tour-grid { gap: 28px; align-items: stretch; }
  .tour-card { display: flex; flex-direction: column; }
  .tour-image { aspect-ratio: 1 / 1; min-height: 0; display: block; padding: 0; border-bottom: 1px solid rgba(17,27,51,.06); }
  .tour-image span { display: none; }
  .tour-body { display: flex; flex: 1; flex-direction: column; }
}
.doso-route { background: linear-gradient(180deg, var(--cream) 0%, #fbf7ef 100%); }
.past-work-section { position: relative; overflow: hidden; background: #fff; padding-top: 74px; padding-bottom: 64px; }
.work-heading { max-width: 760px; margin-bottom: 30px; }
.work-heading h2 { font-size: clamp(26px, 3.2vw, 34px); }
.work-heading h2 strong { color: var(--red); }
.work-heading p { margin-top: 8px; color: #6f7480; font-size: 16px; }
.past-work-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.past-work-card { position: relative; overflow: hidden; display: block; border-radius: var(--doso-card-radius); background: #fff; color: var(--ink); border: 1px solid rgba(17,27,51,.10); box-shadow: 0 12px 24px rgba(17,27,51,.08); }
.past-work-thumb { position: relative; aspect-ratio: 1.42 / 1; overflow: hidden; background: var(--navy); }
.past-work-thumb img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .28s ease, filter .28s ease; }
.past-work-thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,15,29,.06) 0%, rgba(8,15,29,.22) 45%, rgba(8,15,29,.58) 100%); }
.past-work-thumb span { position: absolute; left: 12px; right: 12px; bottom: 12px; z-index: 2; display: block; padding: 8px 12px 9px; border-radius: 16px; background: rgba(51, 157, 173, .94); color: #fff; border: 2px solid rgba(255,255,255,.62); box-shadow: 0 10px 18px rgba(17,27,51,.20); font-size: 19px; font-weight: 800; line-height: 1.2; text-align: center; text-shadow: 0 2px 4px rgba(17,27,51,.24); }
.past-work-card p { margin: 0; padding: 9px 11px 11px; color: #6b7280; font-size: 13px; line-height: 1.45; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; border-top: 1px solid rgba(17,27,51,.07); }
.past-work-card:hover .past-work-thumb img { transform: scale(1.06); filter: saturate(1.08) contrast(1.03); }
.past-work-action { margin-top: 22px; text-align: center; }
.past-work-more { display: inline-flex; align-items: center; min-height: 38px; padding: 0 18px; border-radius: 5px; background: #fff; border: 1px solid rgba(17,27,51,.22); color: #4b5563; font-size: 14px; font-weight: 700; box-shadow: 0 8px 18px rgba(17,27,51,.06); transition: background-color .22s ease, color .22s ease, border-color .22s ease, transform .22s ease; }
.past-work-more:hover { transform: translateY(-2px); background: var(--red); border-color: var(--red); color: #fff; }
.past-work-section + .places-section { padding-top: 74px; }
.past-work-section + .places-section::before { content: ""; display: block; width: min(760px, calc(100% - 40px)); height: 1px; margin: 0 auto 64px; background: linear-gradient(90deg, transparent, rgba(17,27,51,.13), rgba(244,81,42,.42), rgba(17,27,51,.13), transparent); }
.places-section { background: #fff; }
.article-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.article-card { overflow: hidden; border: 1px solid var(--line); border-radius: var(--doso-card-radius); background: linear-gradient(180deg, #fff, #fff8f3); box-shadow: 0 14px 36px rgba(17,27,51,.07); }
.article-thumb { aspect-ratio: 16 / 10; overflow: hidden; background: #f4f0e8; }
.article-thumb img { display: block; width: 100%; height: 100%; object-fit: cover; transition: transform .34s ease, filter .34s ease; }
.article-card:hover .article-thumb img { transform: scale(1.045); filter: saturate(1.06) contrast(1.03); }
.article-body { padding: 22px 24px 24px; }
.article-card span { color: var(--gold); font-weight: 800; font-size: 13px; }
.article-card h3 { margin: 12px 0; color: var(--navy); line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.article-card p { margin: 0; color: var(--muted); line-height: 1.8; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.site-footer { position: relative; overflow: hidden; background: radial-gradient(circle at 18% 12%, rgba(255,255,255,.14), transparent 26%),
    radial-gradient(circle at 78% 8%, rgba(255,92,64,.16), transparent 24%),
    linear-gradient(180deg, #e60000 0%, #d80000 48%, #c80000 100%); color: rgba(255,255,255,.9); padding: 70px 0 34px; }
.site-footer::before { display: none; }
.social-icon-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.footer-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(260px, 1.35fr) minmax(140px, .7fr) minmax(160px, .85fr) minmax(260px, 1.1fr); gap: 54px; align-items: start; }
.footer-brand, .footer-col, .footer-contact { min-width: 0; }
.footer-main-logo { display: block; width: 190px; max-width: 100%; margin: 0 0 20px; filter: drop-shadow(0 14px 22px rgba(105,0,0,.32)); }
.footer-company-name { margin: 0 0 12px; color: #fff; font-size: 18px; line-height: 1.5; }
.footer-brand p, .site-footer p { margin: 0 0 12px; line-height: 1.82; }
.site-footer h4 { color: #fff; margin: 0 0 16px; font-size: 18px; line-height: 1.35; }
.footer-col a { display: block; margin-bottom: 9px; color: rgba(255,255,255,.86); font-weight: 600; transition: color .2s ease, transform .2s ease; }
.footer-col a:hover { color: #fff; transform: translateX(3px); }
.footer-contact-list { display: grid; gap: 11px; list-style: none; padding: 0; margin: 0 0 20px; }
.footer-contact-list li { display: flex; align-items: center; gap: 12px; line-height: 1.55; color: rgba(255,255,255,.9); }
.footer-contact-icon { position: relative; flex: 0 0 20px; width: 20px; height: 20px; border-radius: 50%; background: rgba(255,255,255,.96); }
.footer-contact-icon.fa-clock::before, .footer-contact-icon.fa-square-phone::before, .footer-contact-icon.fa-envelope::before { content: ""; position: absolute; inset: 4px; background: #d70000; }
.footer-contact-icon.fa-clock::before { inset: 4px; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d70000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='8'/%3E%3Cpath d='M12 7v5l3 2'/%3E%3C/svg%3E") center / contain no-repeat; }
.footer-contact-icon.fa-square-phone::before { -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.6 2.8 4.1 4.1c-.9.5-1.4 1.6-1 2.7 2.1 6.4 7.1 11.4 13.4 13.5 1.1.4 2.2-.1 2.7-1l1.3-2.5c.4-.8.2-1.8-.5-2.4l-2.8-2.1c-.7-.5-1.6-.5-2.3 0l-1.3 1c-1.9-1-3.4-2.5-4.4-4.4l1-1.3c.5-.7.5-1.6 0-2.3L8.9 3.3c-.6-.8-1.6-1-2.3-.5Z'/%3E%3C/svg%3E") center / contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.6 2.8 4.1 4.1c-.9.5-1.4 1.6-1 2.7 2.1 6.4 7.1 11.4 13.4 13.5 1.1.4 2.2-.1 2.7-1l1.3-2.5c.4-.8.2-1.8-.5-2.4l-2.8-2.1c-.7-.5-1.6-.5-2.3 0l-1.3 1c-1.9-1-3.4-2.5-4.4-4.4l1-1.3c.5-.7.5-1.6 0-2.3L8.9 3.3c-.6-.8-1.6-1-2.3-.5Z'/%3E%3C/svg%3E") center / contain no-repeat; }
.footer-contact-icon.fa-envelope::before { inset: 5px 4px; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M3 5h18v14H3V5Zm2.4 2 6.6 4.35L18.6 7H5.4ZM19 9.2l-6.45 4.25a1 1 0 0 1-1.1 0L5 9.2V17h14V9.2Z'/%3E%3C/svg%3E") center / contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M3 5h18v14H3V5Zm2.4 2 6.6 4.35L18.6 7H5.4ZM19 9.2l-6.45 4.25a1 1 0 0 1-1.1 0L5 9.2V17h14V9.2Z'/%3E%3C/svg%3E") center / contain no-repeat; }
.footer-social { display: flex; flex-wrap: wrap; gap: 12px; }
.footer-social-button { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border: 1px solid rgba(255,255,255,.2); border-radius: 12px; color: #fff; font-size: 0; font-weight: 900; box-shadow: 0 16px 24px rgba(86,0,0,.24), 0 1px 0 rgba(255,255,255,.2) inset; transition: transform .2s ease, filter .2s ease, box-shadow .2s ease; }
.footer-social-button:hover { transform: translateY(-2px); filter: saturate(1.08) brightness(1.04); box-shadow: 0 16px 26px rgba(86,0,0,.24), 0 1px 0 rgba(255,255,255,.22) inset; }
.footer-social-button svg { width: 24px; height: 24px; display: block; fill: currentColor; stroke: none; }
.footer-social-button.instagram svg { fill: none; stroke: currentColor; stroke-width: 2; }
.footer-social-button.line svg path:first-child { fill: currentColor; }
.footer-social-button.line svg path:last-child { stroke: #06c755; }
.footer-social-button.facebook { background: #1877f2; color: #fff; }
.footer-social-button.instagram { background: radial-gradient(circle at 28% 108%, #fdf497 0 18%, #fd5949 42%, #d6249f 65%, #285aeb 100%); color: #fff; }
.footer-social-button.x { background: #0f1117; color: #fff; }
.footer-social-button.line { background: #06c755; color: #fff; }
.footer-social-button.tiktok { background: #08090d; color: #fff; }
.footer-social-button.facebook, .footer-social-button.instagram, .footer-social-button.x, .footer-social-button.line, .footer-social-button.tiktok { overflow: hidden; padding: 0; border-color: transparent; background: transparent; }
.footer-social-button img { display: block; width: 100%; height: 100%; border-radius: inherit; object-fit: cover; }
.footer-mobile-actions { display: none; }
.footer-line-card { position: fixed; right: clamp(18px, 2.2vw, 34px); top: 78%; z-index: 120; display: grid; justify-items: center; width: 184px; max-width: calc(100vw - 32px); padding: 16px 12px 38px; border: 1px solid rgba(255,255,255,.28); border-radius: 24px; background: radial-gradient(circle at 28% 0%, rgba(255,255,255,.34), transparent 24%),
    linear-gradient(160deg, #16d63a 0%, #07ae25 52%, #03851e 100%); color: #fff; text-align: center; box-shadow: 0 26px 55px rgba(2,66,20,.34),
    0 0 0 1px rgba(255,255,255,.18) inset; opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(-38%) translateX(54px) scale(.68); transform-origin: right bottom; filter: blur(3px) saturate(.96); transition: opacity .32s ease,
    visibility .32s ease,
    transform .42s cubic-bezier(.18,.9,.26,1.12),
    filter .32s ease; }
.footer-line-card::before { content: ""; position: absolute; inset: 8px; border-radius: 18px; pointer-events: none; box-shadow: 0 1px 0 rgba(255,255,255,.28) inset; }
.footer-line-card.is-open { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(-50%) translateX(0) scale(1); filter: blur(0) saturate(1); animation: lineCardReveal .48s cubic-bezier(.16,.96,.28,1.12) both; }
.footer-line-card.is-open:hover { filter: brightness(1.02); transform: translateY(-50%) translateX(-2px); }
.footer-line-card[hidden], .line-widget-launcher[hidden] { display: none !important; }
@keyframes lineCardReveal { 0% { opacity: 0; transform: translateY(-34%) translateX(64px) scale(.55); filter: blur(5px) saturate(.9); } 64% { opacity: 1; transform: translateY(-50%) translateX(-4px) scale(1.035); filter: blur(0) saturate(1.03); } 100% { opacity: 1; transform: translateY(-50%) translateX(0) scale(1); filter: blur(0) saturate(1); } }
.footer-line-head { display: inline-flex; align-items: center; gap: 7px; margin-bottom: 8px; font-weight: 900; }
.footer-line-icon { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 9px; background: #fff; color: #05b800; font-size: 8px; font-weight: 900; }
.footer-line-card p { margin: 0; font-size: 11px; line-height: 1.55; color: rgba(255,255,255,.88); }
.footer-qr { position: relative; width: 96px; height: 96px; margin: 12px auto 8px; border: 6px solid #fff; border-radius: 13px; background: linear-gradient(90deg, #111 10px, transparent 10px 18px, #111 18px 25px, transparent 25px 32px, #111 32px 40px, transparent 40px),
    linear-gradient(#111 9px, transparent 9px 17px, #111 17px 23px, transparent 23px 31px, #111 31px 38px, transparent 38px),
    #fff; background-size: 42px 42px, 36px 36px, auto; box-shadow: 0 16px 28px rgba(0,77,18,.24); }
/* .footer-qr::after { content: "LINE"; position: absolute; inset: 32px 17px; display: grid; place-items: center; border-radius: 8px; background: #fff; color: #111; font-size: 12px; font-weight: 900; } */
.footer-qr {
  font-size: 0;
  background: #fff;
}
.footer-qr img {
  width: 100%;
  height: auto;
}
.footer-line-id { display: block; margin-bottom: 9px; font-size: 11px; }
.footer-line-actions { display: grid; gap: 2px; width: 100%; padding-top: 9px; border-top: 1px solid rgba(255,255,255,.28); font-weight: 800; font-size: 11px; }
.footer-line-card small { display: block; margin-top: 9px; line-height: 1.45; color: rgba(255,255,255,.9); }
.footer-line-social { display: flex; justify-content: center; gap: 7px; margin-top: 12px; width: 100%; }
.footer-line-social span { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border: 0; border-radius: 8px; background-color: rgba(255,255,255,.12); background-position: center; background-size: cover; background-repeat: no-repeat; color: #fff; font-size: 0; font-weight: 900; box-shadow: 0 10px 16px rgba(0,88,17,.22), 0 0 0 1px rgba(255,255,255,.18) inset; }
.footer-line-social svg { display: none; }
.footer-line-social .facebook { background-image: url("/assets/fbsq.png"); }
.footer-line-social .instagram { background-image: url("/assets/igsq.png"); }
.footer-line-social .x { background-image: url("/assets/twsq.png"); }
.footer-line-social .line { background-image: url("/assets/lnsq.png"); }
.footer-line-social .tiktok { background-image: url("/assets/ttsq.png"); }
.footer-line-close { position: absolute; right: -10px; bottom: -20px; display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border: 0; border-radius: 50%; background: linear-gradient(180deg, #ff4b3f, #e71913); color: #fff; font-size: 27px; line-height: 1; z-index: 3; box-shadow: 0 16px 26px rgba(100,0,0,.34), 0 0 0 5px rgba(255,255,255,.18); cursor: pointer; }
.line-widget-launcher { position: fixed; right: clamp(18px, 2.2vw, 34px); bottom: 28px; z-index: 120; display: inline-flex; align-items: center; justify-content: center; width: 58px; height: 58px; border: 0; border-radius: 50%; background: linear-gradient(180deg, #18d83b, #02ad20); color: #fff; box-shadow: 0 14px 28px rgba(0,95,18,.28), 0 0 0 5px rgba(255,255,255,.94); cursor: pointer; isolation: isolate; animation: lineLauncherPulse 1.65s ease-out infinite; }
.line-widget-launcher::before { content: ""; position: absolute; z-index: 2; width: 32px; height: 32px; background: #fff; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M20 3H4a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h2v4l4.7-4H20a2 2 0 0 0 2-2V5a2 2 0 0 0-2-2Z'/%3E%3C/svg%3E") center / contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M20 3H4a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h2v4l4.7-4H20a2 2 0 0 0 2-2V5a2 2 0 0 0-2-2Z'/%3E%3C/svg%3E") center / contain no-repeat; }
.line-widget-launcher::after { content: ""; position: absolute; z-index: 3; width: 17px; height: 13px; background: linear-gradient(#03b820 0 0) 0 0 / 18px 3px no-repeat,
    linear-gradient(#03b820 0 0) 0 5px / 14px 3px no-repeat,
    linear-gradient(#03b820 0 0) 0 10px / 10px 3px no-repeat; transform: translate(1px, -4px); }
.line-widget-launcher span { position: absolute; right: calc(100% + 16px); top: 50%; z-index: 1; width: max-content; max-width: min(270px, calc(100vw - 104px)); padding: 15px 28px; border-radius: 999px; background: #f4f6fb; color: #172033; font-size: 18px; font-weight: 800; line-height: 1.2; box-shadow: 0 16px 36px rgba(17,27,51,.12); transform: translateY(-50%); pointer-events: none; }
.line-widget-launcher span::after { content: ""; position: absolute; right: -14px; top: 50%; width: 28px; height: 22px; background: #f4f6fb; clip-path: polygon(0 0, 100% 50%, 0 100%); transform: translateY(-50%); }
@keyframes lineLauncherPulse { 0% { box-shadow: 0 14px 28px rgba(0,95,18,.28), 0 0 0 5px rgba(255,255,255,.94), 0 0 0 0 rgba(4,199,51,.5); transform: scale(1); } 58% { box-shadow: 0 16px 34px rgba(0,95,18,.32), 0 0 0 5px rgba(255,255,255,.94), 0 0 0 17px rgba(4,199,51,0); transform: scale(1.045); } 100% { box-shadow: 0 14px 28px rgba(0,95,18,.28), 0 0 0 5px rgba(255,255,255,.94), 0 0 0 0 rgba(4,199,51,0); transform: scale(1); } }
.footer-bottom { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr auto 1fr; align-items: end; min-height: 118px; margin-top: 58px; padding-top: 56px; color: rgba(255,255,255,.86); }
.footer-bottom::before, .footer-bottom::after { content: ""; position: absolute; top: 0; height: 2px; background: rgba(255,255,255,.76); box-shadow: 0 1px 0 rgba(255,255,255,.08); }
.footer-bottom::before { left: calc((100vw - 100%) / -2); right: calc(50% + 104px); }
.footer-bottom::after { left: calc(50% + 104px); right: calc((100vw - 100%) / -2); }
.footer-legal { grid-column: 1 / 4; display: grid; justify-items: center; gap: 11px; margin-top: 2px; text-align: center; }
.footer-powered { display: inline-flex; align-items: center; gap: 6px; color: rgba(255,255,255,.78); font-size: 13px; }
.footer-powered strong { color: #fff; font-size: 18px; letter-spacing: .2px; }
.footer-visitor { position: absolute; left: 50%; top: -28px; transform: translateX(-50%); display: grid; justify-items: center; gap: 4px; min-width: 132px; padding: 9px 18px; border: 1px solid rgba(255,255,255,.55); border-radius: 10px; background: linear-gradient(180deg, rgba(226,0,0,.94), rgba(194,0,0,.94)); color: #fff; font-weight: 800; box-shadow: 0 16px 28px rgba(86,0,0,.2), 0 1px 0 rgba(255,255,255,.16) inset; }
.footer-visitor span { display: inline-flex; align-items: center; justify-content: center; gap: 6px; font-size: 13px; }
.footer-visitor span::before { content: ""; width: 18px; height: 18px; flex: 0 0 18px; background: currentColor; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10Zm9 10a9 9 0 0 0-18 0h18Z'/%3E%3C/svg%3E") center / contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10Zm9 10a9 9 0 0 0-18 0h18Z'/%3E%3C/svg%3E") center / contain no-repeat; }
.footer-visitor strong { font-size: 20px; }
.footer-top-link { position: absolute; top: 30px; right: 0; display: inline-flex; align-items: center; gap: 6px; z-index: 2; padding: 8px 16px; border: 1px solid rgba(255,255,255,.38); border-radius: 999px; background: linear-gradient(180deg, #e50000, #c70000); color: #fff; font-size: 14px; font-weight: 700; box-shadow: 0 12px 22px rgba(86,0,0,.2), 0 1px 0 rgba(255,255,255,.18) inset; transition: transform .2s ease, background .2s ease; }
.footer-top-link:hover { transform: translateY(-2px); background: linear-gradient(180deg, rgba(239,0,0,.98), rgba(205,0,0,.98)); }
.footer-top-link span { display: grid; place-items: center; width: 19px; height: 19px; border-radius: 50%; background: #fff; color: #d70000; font-size: 0; font-weight: 900; }
.footer-top-link span::before { content: ""; display: block; width: 7px; height: 7px; border-top: 2px solid currentColor; border-left: 2px solid currentColor; transform: translateY(2px) rotate(45deg); }
@media (max-width: 1080px) {
  .mobile-toggle { display: block; }
  .main-nav { position: fixed; left: 20px; right: 20px; top: 148px; flex-direction: column; align-items: stretch; gap: 4px; padding: 18px; border-radius: 22px; background: #fff; box-shadow: var(--shadow); opacity: 0; visibility: hidden; transform: translateY(-10px); transition: .22s ease; }
  .menu-open .main-nav { opacity: 1; visibility: visible; transform: translateY(0); }
  .search-panel { grid-template-columns: repeat(2, 1fr); }
  .btn-search { grid-column: span 2; }
  .country-grid, .tour-grid, .article-grid { grid-template-columns: repeat(2, 1fr); }
  .past-work-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-inner { grid-template-columns: 1fr; }
  .hero-card { align-self: auto; margin-bottom: 80px; max-width: 420px; }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-line-card { right: 16px; width: 162px; }
}
@media (max-width: 680px) {
  .container { width: min(100% - 28px, var(--container)); }
  .topbar-left { display: none; }
  .topbar-right { font-size: 12px; gap: 10px; }
  .brand-logo { height: 58px; }
  .footer-main-logo { width: 174px; }
  .main-header-inner { min-height: 78px; }
  .hero, .hero-inner { min-height: 640px; }
  .hero-inner { gap: 24px; padding: 60px 0 90px; }
  .hero p { font-size: 16px; }
  .hero-card { margin-bottom: 0; }
  .search-panel { grid-template-columns: 1fr; margin-top: 0; }
  .btn-search { grid-column: auto; }
  .section { padding: 64px 0; }
  .section-heading.split { align-items: start; flex-direction: column; }
  .country-grid, .tour-grid, .article-grid, .footer-grid { grid-template-columns: 1fr; }
  .past-work-grid { grid-template-columns: 1fr; }
  .past-work-thumb span { font-size: 17px; }
  .past-work-section + .places-section::before { margin-bottom: 46px; }
  .site-footer { padding: 48px 0 28px; }
  .site-footer::before { bottom: 118px; }
  .footer-grid { gap: 30px; text-align: center; }
  .footer-main-logo { margin-left: auto; margin-right: auto; }
  .footer-contact-list li { justify-content: center; }
  .footer-social { justify-content: center; }
  .footer-bottom { display: block; min-height: auto; margin-top: 66px; padding-top: 64px; text-align: center; }
  .footer-legal { display: grid; }
  .footer-visitor { top: -38px; }
  .footer-top-link { position: static; justify-content: center; margin-top: 20px; }
  .footer-line-card { right: 12px; top: auto; bottom: 74px; width: 172px; padding: 13px 12px 32px; border-radius: 18px; transform: none; }
  .footer-line-card.is-open { transform: none; animation: none; }
  .footer-line-card:hover { transform: none; }
  .footer-line-head { gap: 6px; font-size: 12px; }
  .footer-line-icon { width: 24px; height: 24px; }
  .footer-line-card p, .footer-line-actions, .footer-line-id, .footer-line-card small { font-size: 10px; }
  .footer-qr { width: 86px; height: 86px; border-width: 5px; }
  .footer-qr::after { inset: 28px 14px; font-size: 10px; }
  .footer-line-social { gap: 6px; margin-top: 10px; }
  .footer-line-social span { width: 24px; height: 24px; border-radius: 7px; }
  .footer-line-close { right: -10px; bottom: -20px; width: 34px; height: 34px; font-size: 24px; }
  .line-widget-launcher { right: 14px; bottom: 18px; width: 54px; height: 54px; }
  .line-widget-launcher span { display: none; }
}
.site-header { position: relative; z-index: 80; background: #fff; }
.topbar { background: linear-gradient(90deg, #b40012 0%, #ed1c24 50%, #ff5a2a 100%); color: #fff; font-size: 13px; }
.topbar-inner { min-height: 34px; }
.topbar-left, .topbar-right { gap: 16px; }
.topbar a { color: rgba(255,255,255,.94); font-weight: 600; }
.topbar-menu a + a { position: relative; }
.topbar-menu a + a::before { content: ""; position: absolute; left: -8px; top: 50%; width: 1px; height: 14px; background: rgba(255,255,255,.55); transform: translateY(-50%); }
.contact-header { background: #fff; border-bottom: 1px solid rgba(17,27,51,.08); }
.contact-header-inner { min-height: 112px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.talad-brand { min-width: 260px; }
.header-info-list { display: flex; align-items: center; justify-content: flex-end; gap: 0; }
.header-info-item { display: flex; align-items: center; gap: 12px; min-height: 62px; padding: 0 24px; border-left: 1px solid rgba(17,27,51,.08); color: #4b5563; }
.header-info-item strong { display: block; color: #374151; font-size: 14px; line-height: 1.35; }
.header-info-item small { display: block; color: #6b7280; font-size: 13px; line-height: 1.45; }
.info-icon { display: inline-grid; place-items: center; width: 32px; height: 32px; border-radius: 50%; color: #ed1c24; background: #fff1f2; font-weight: 800; }
.line-badge { display: inline-grid; place-items: center; width: 42px; height: 34px; border-radius: 10px; background: #06c755; color: #fff; font-size: 11px; font-weight: 900; }
.line-info strong { color: #00a83b; }
.main-header { position: sticky; top: 0; z-index: 90; background: #fff; backdrop-filter: none; border-bottom: 1px solid rgba(17,27,51,.10); box-shadow: 0 8px 20px rgba(17,27,51,.04); }
.main-header-inner.nav-only { min-height: 58px; justify-content: center; }
.main-nav { gap: 0; width: 100%; justify-content: center; }
.main-nav > a, .nav-dropdown > a { min-height: 58px; padding: 0 22px; border-radius: 0; font-size: 16px; font-weight: 800; line-height: 1.15; white-space: nowrap; color: #303540; border-bottom: 3px solid transparent; }
.main-nav > a:hover, .nav-dropdown:hover > a, .main-nav > a.active { background: #fff; color: #f4512a; border-bottom-color: #f4512a; }
.nav-dropdown { position: relative; }
.mega-zones { position: absolute; top: 58px; left: 50%; width: min(1320px, calc(100vw - 60px)); transform: translate(-50%, 8px); display: grid; grid-template-columns: 1.05fr 1.05fr 1.1fr 1.1fr 1.15fr 1.15fr; gap: 0; padding: 0; background: #fff; border: 1px solid rgba(17,27,51,.10); border-top: 3px solid #f4512a; border-radius: 0 0 8px 8px; box-shadow: 0 24px 70px rgba(17,27,51,.18); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .18s ease, transform .18s ease, visibility .18s ease; }
.nav-zone:hover .mega-zones { opacity: 1; visibility: visible; pointer-events: auto; transform: translate(-50%, 0); }
.zone-panel { padding: 16px 18px 18px; min-height: 430px; border-right: 1px solid rgba(17,27,51,.08); }
.zone-panel:last-child { border-right: 0; }
.zone-panel h4 { margin: 0 0 10px; text-align: center; color: #424851; font-size: 16px; font-weight: 800; }
.zone-mixed h4 { margin-top: 14px; padding-top: 10px; border-top: 1px solid rgba(17,27,51,.08); }
.zone-mixed h4:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.zone-panel a { min-height: 31px; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 4px 0; color: #4b5563; font-size: 14px; font-weight: 500; }
.zone-panel a:hover { color: #f4512a; }
.zone-panel a span { white-space: nowrap; }
.zone-panel a b { min-width: 28px; height: 24px; display: inline-grid; place-items: center; border-radius: 6px; background: #f4512a; color: #fff; font-size: 12px; line-height: 1; }
.compact-mega { width: min(720px, calc(100vw - 60px)); grid-template-columns: repeat(3, 1fr); }
.compact-mega .zone-panel { min-height: 180px; }
.search-panel-wrap { margin-top: -66px; position: relative; z-index: 10; }
.search-panel.search-panel-full { grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; padding: 24px 24px 26px; border-radius: 22px; border: 1px solid rgba(244,81,42,.12); box-shadow: 0 28px 78px rgba(17,27,51,.14); }
.search-title-row { grid-column: 1 / -1; display: flex; align-items: end; justify-content: space-between; gap: 20px; padding: 0 4px 4px; }
.search-title-row h2 { margin: 0; color: #ed1c24; font-size: 26px; }
.search-title-row p { margin: 0; color: #6b7280; font-size: 13px; }
.search-panel-full .field input, .search-panel-full .field select { height: 52px; border-radius: 12px; background: #fbfcff; }
.search-panel-full .field label { color: #374151; font-weight: 800; font-size: 13px; }
.search-panel-full .btn-search { align-self: end; min-width: 150px; height: 56px; border-radius: 12px; background: #f4512a; font-size: 20px; }
@media (max-width: 1180px) {
  .header-info-list { display: none; }
  .talad-brand { min-width: 0; }
  .main-nav { justify-content: flex-start; overflow-x: auto; }
  .main-nav > a, .nav-dropdown > a { white-space: nowrap; padding: 0 16px; }
  .mega-zones { left: 0; transform: translateY(8px); width: min(1040px, calc(100vw - 40px)); grid-template-columns: repeat(3, 1fr); }
  .nav-zone:hover .mega-zones { transform: translateY(0); }
}
@media (max-width: 900px) {
  .contact-header-inner { min-height: 82px; }
  .main-header-inner.nav-only { justify-content: flex-start; }
  .main-nav { display: flex; flex-direction: column; align-items: stretch; position: fixed; left: 20px; right: 20px; top: 94px; background: #fff; border-radius: 18px; padding: 12px; box-shadow: var(--shadow); opacity: 0; visibility: hidden; transform: translateY(-8px); }
  .menu-open .main-nav { opacity: 1; visibility: visible; transform: translateY(0); }
  .main-nav > a, .nav-dropdown > a { min-height: 46px; border-bottom: 0; border-radius: 12px; }
  .mega-zones, .compact-mega { position: static; width: 100%; grid-template-columns: 1fr; transform: none; border-radius: 14px; display: none; box-shadow: none; max-height: 360px; overflow: auto; }
  .nav-zone:hover .mega-zones { display: grid; transform: none; }
  .zone-panel { min-height: auto; border-right: 0; border-bottom: 1px solid rgba(17,27,51,.08); }
  .search-panel.search-panel-full { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .search-title-row { display: block; }
}
@media (max-width: 640px) {
  .topbar-left { display: none; }
  .topbar-menu { gap: 10px; font-size: 11px; }
  .brand-logo { height: 58px; }
  .search-panel.search-panel-full { grid-template-columns: 1fr; padding: 18px; }
  .search-title-row h2 { font-size: 22px; }
  .search-title-row p { margin-top: 6px; }
  .search-panel-full .btn-search { width: 100%; }
}
.main-header-inner.nav-only { position: relative; }
.main-header-inner.nav-only .nav-zone, .main-header-inner.nav-only .nav-dropdown { position: static; }
.main-header-inner.nav-only .mega-zones { left: 50%; right: auto; width: min(var(--container), calc(100vw - 40px)); max-width: var(--container); transform: translate(-50%, 8px); grid-template-columns: 1.02fr 1.02fr 1.08fr 1.08fr 1.1fr 1.1fr; overflow: hidden; }
.main-header-inner.nav-only .nav-zone:hover .mega-zones { transform: translate(-50%, 0); }
.main-header-inner.nav-only .compact-mega { width: min(760px, calc(100vw - 40px)); max-width: 760px; grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1200px) {
  .main-header-inner.nav-only .mega-zones { width: calc(100vw - 40px); grid-template-columns: repeat(4, minmax(0, 1fr)); max-height: 72vh; overflow: auto; }
}
@media (max-width: 760px) {
  .main-header-inner.nav-only .nav-zone, .main-header-inner.nav-only .nav-dropdown { position: relative; }
  .main-header-inner.nav-only .mega-zones, .main-header-inner.nav-only .compact-mega { position: static; width: 100%; max-width: 100%; transform: none; grid-template-columns: 1fr; overflow: auto; }
  .main-header-inner.nav-only .nav-zone:hover .mega-zones { transform: none; }
}
.tour-detail-list { display: grid; gap: 7px; margin: 16px 0 18px; padding: 14px 0 16px; border-top: 1px dashed rgba(17,27,51,.14); border-bottom: 1px dashed rgba(17,27,51,.14); }
.tour-detail-item { display: flex; align-items: center; gap: 10px; color: #6b7280; font-size: 17px; font-weight: 600; line-height: 1.35; }
.tour-icon { width: 24px; display: inline-flex; justify-content: center; color: #f5a400; font-size: 20px; line-height: 1; }
.tour-price-block { display: grid; grid-template-columns: 1fr auto; align-items: end; gap: 14px; margin-top: 12px; }
.airline-logo { min-height: 58px; width: 132px; display: inline-flex; align-items: center; justify-content: flex-start; padding: 4px 0; }
.airline-logo img { display: block; width: 132px; max-width: 100%; max-height: 52px; object-fit: contain; object-position: left center; }
.tour-price-box { text-align: right; min-width: 128px; }
.tour-price-box span { display: block; color: #7b8190; font-size: 16px; line-height: 1.1; margin-bottom: 4px; }
.tour-price-box strong { display: block; color: #f00000; font-size: 36px; font-weight: 900; line-height: 1; letter-spacing: -.8px; }
.tour-price-box em { display: block; color: #7b8190; font-size: 17px; font-style: normal; margin-top: 4px; }
.tour-detail-btn { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; margin-top: 18px; padding: 0 18px; border-radius: 999px; background: rgba(200,25,46,.08); color: var(--red); font-weight: 800; transition: .2s ease; }
.tour-detail-btn:hover { background: var(--red); color: #fff; }
@media (max-width: 680px) {
  .tour-price-block { grid-template-columns: 1fr; align-items: start; }
  .tour-price-box { text-align: left; }
  .airline-logo { min-height: 42px; }
  .airline-logo img { max-height: 40px; }
  .tour-price-box strong { font-size: 32px; }
}
.main-header-inner.nav-only .mega-zones { border-top: 3px solid #f4512a; border-left: 1px solid #d9dee8; border-right: 1px solid #d9dee8; border-bottom: 1px solid #d9dee8; }
.main-header-inner.nav-only .zone-panel { position: relative; border-right: 1px solid #d9dee8; box-shadow: inset -1px 0 0 rgba(17, 27, 51, 0.045); }
.main-header-inner.nav-only .zone-panel:last-child { border-right: 0; box-shadow: none; }
.main-header-inner.nav-only .zone-panel h4 { margin-bottom: 12px; padding-bottom: 9px; border-bottom: 1px solid #e0e4ec; }
.main-header-inner.nav-only .zone-panel-no-title h4 { border-bottom-color: transparent; }
.main-header-inner.nav-only .zone-mixed h4 { margin-top: 16px; padding-top: 14px; padding-bottom: 9px; border-top: 1px solid #d9dee8; border-bottom: 1px solid #e0e4ec; }
.main-header-inner.nav-only .zone-mixed h4:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.main-header-inner.nav-only .zone-panel a { border-radius: 8px; padding-left: 4px; padding-right: 4px; }
.main-header-inner.nav-only .zone-panel a:hover { background: rgba(244, 81, 42, 0.055); }
@media (max-width: 760px) {
  .main-header-inner.nav-only .zone-panel { border-right: 0; border-bottom: 1px solid #d9dee8; box-shadow: none; }
  .main-header-inner.nav-only .zone-panel:last-child { border-bottom: 0; }
}
.main-header-inner.nav-only .mega-zones { border-left: 1px solid #dfe3ea !important; border-right: 1px solid #dfe3ea !important; border-bottom: 1px solid #dfe3ea !important; }
.main-header-inner.nav-only .mega-zones .zone-panel { position: relative; border-right: 2px solid #dfe3ea !important; box-shadow: inset -1px 0 0 #f7f8fa; }
.main-header-inner.nav-only .mega-zones .zone-panel:last-child { border-right: 0 !important; box-shadow: none; }
.main-header-inner.nav-only .mega-zones .zone-panel h4 { padding-bottom: 10px; margin-bottom: 12px; border-bottom: 1px solid #e5e8ee !important; }
.main-header-inner.nav-only .mega-zones .zone-panel.zone-panel-no-title h4 { border-bottom-color: #edf0f4 !important; }
.main-header-inner.nav-only .mega-zones .zone-mixed h4:not(:first-child) { margin-top: 18px; padding-top: 14px; border-top: 2px solid #dfe3ea !important; border-bottom: 1px solid #e5e8ee !important; }
.main-header-inner.nav-only .mega-zones .zone-panel a + a { border-top: 1px solid rgba(223, 227, 234, 0.45); }
@media (max-width: 900px) {
  .main-header-inner.nav-only .mega-zones .zone-panel { border-right: 0 !important; border-bottom: 2px solid #dfe3ea !important; }
  .main-header-inner.nav-only .mega-zones .zone-panel:last-child { border-bottom: 0 !important; }
}
.mega-zones .zone-panel { border-right: 2px solid rgba(17, 27, 51, 0.12); }
.mega-zones .zone-panel:last-child { border-right: 0; }
.mega-zones .zone-panel h4 { padding-bottom: 10px; margin-bottom: 12px; border-bottom: 1px solid rgba(17, 27, 51, 0.14); }
.mega-zones .zone-mixed h4:not(:first-child) { margin-top: 18px; padding-top: 14px; border-top: 1px solid rgba(17, 27, 51, 0.16); }
.mega-zones .zone-panel a { min-height: 34px; padding: 5px 0; }
.mega-zones .country-name { display: inline-flex; align-items: center; gap: 9px; min-width: 0; white-space: nowrap; }
.mega-zones .flag-img { width: 24px; height: 24px; flex: 0 0 24px; border-radius: 50%; object-fit: cover; display: inline-block; box-shadow: 0 0 0 1px rgba(17, 27, 51, 0.12); background: #fff; }
:root { --container: 1170px; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) { width: min(var(--container), calc(100vw - 40px)) !important; max-width: var(--container) !important; background: #fff !important; border-top: 3px solid #f4512a !important; border-left: 2px solid #d6dce6 !important; border-right: 2px solid #d6dce6 !important; border-bottom: 2px solid #d6dce6 !important; overflow: hidden !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel { position: relative !important; padding: 16px 14px 18px !important; border-right: 2px solid #d6dce6 !important; box-shadow: inset -1px 0 0 rgba(255, 255, 255, .85) !important; background: #fff !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel::after { content: ""; position: absolute; top: 0; right: -2px; width: 2px; height: 100%; background: #d6dce6; pointer-events: none; z-index: 2; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel:last-child { border-right: 0 !important; box-shadow: none !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel:last-child::after { display: none !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel h4 { margin: 0 0 12px !important; padding: 0 0 10px !important; text-align: center !important; color: #303540 !important; font-size: 16px !important; font-weight: 900 !important; border-bottom: 2px solid #e1e6ee !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel-no-title h4 { color: transparent !important; border-bottom: 2px solid #e1e6ee !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-mixed h4:not(:first-child) { margin-top: 18px !important; padding-top: 14px !important; border-top: 2px solid #d6dce6 !important; border-bottom: 2px solid #e1e6ee !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel a { display: grid !important; grid-template-columns: minmax(0, 1fr) auto !important; align-items: center !important; gap: 8px !important; min-height: 33px !important; padding: 4px 3px !important; border-top: 0 !important; border-radius: 7px !important; color: #48505c !important; font-size: 13.5px !important; font-weight: 500 !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel a:hover { background: rgba(244, 81, 42, 0.07) !important; color: #f4512a !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .country-name { display: flex !important; align-items: center !important; gap: 8px !important; min-width: 0 !important; overflow: hidden !important; white-space: nowrap !important; text-overflow: ellipsis !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .flag-img { width: 23px !important; height: 23px !important; flex: 0 0 23px !important; border-radius: 50% !important; object-fit: cover !important; display: inline-block !important; background: #fff !important; box-shadow: 0 0 0 1px rgba(17, 27, 51, 0.16) !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel a b { min-width: 28px !important; height: 24px !important; padding: 0 6px !important; display: inline-grid !important; place-items: center !important; border-radius: 6px !important; background: #f4512a !important; color: #fff !important; font-size: 12px !important; font-weight: 800 !important; line-height: 1 !important; }
@media (max-width: 1200px) {
  .main-header-inner.nav-only .mega-zones:not(.compact-mega) { width: calc(100vw - 40px) !important; max-height: 72vh !important; overflow: auto !important; }
}
@media (max-width: 900px) {
  .main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel { border-right: 0 !important; border-bottom: 2px solid #d6dce6 !important; }
  .main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel::after { display: none !important; }
  .main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel:last-child { border-bottom: 0 !important; }
}
.search-panel-wrap { margin-top: -70px; position: relative; z-index: 10; }
.search-panel.search-panel-full { position: relative; overflow: hidden; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; padding: 26px 28px 28px; border-radius: 26px; background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(255,250,246,.96) 100%); border: 1px solid rgba(244,81,42,.18); box-shadow: 0 34px 90px rgba(17,27,51,.16),
    0 0 0 1px rgba(255,255,255,.70) inset; }
.search-panel.search-panel-full::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: linear-gradient(90deg, #c8192e 0%, #f4512a 55%, #d8a74a 100%); }
.search-panel.search-panel-full::after { content: ""; position: absolute; right: -120px; top: -120px; width: 260px; height: 260px; border-radius: 50%; background: radial-gradient(circle, rgba(244,81,42,.13) 0%, rgba(244,81,42,0) 68%); pointer-events: none; }
.search-title-row { grid-column: 1 / -1; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 18px; padding: 4px 4px 8px; position: relative; z-index: 1; }
.search-title-main { display: inline-flex; align-items: center; gap: 12px; min-width: max-content; }
.search-title-icon { position: relative; display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 13px; background: linear-gradient(145deg, #fff1ec, #fff8f5); border: 1px solid rgba(244,81,42,.18); box-shadow: 0 12px 28px rgba(244,81,42,.12); }
.search-title-icon::before { content: ""; width: 15px; height: 15px; border: 3px solid #f4512a; border-radius: 50%; transform: translate(-2px, -1px); }
.search-title-icon::after { content: ""; position: absolute; width: 10px; height: 3px; border-radius: 999px; background: #f4512a; transform: rotate(45deg); right: 9px; bottom: 10px; }
.search-title-row h2 { margin: 0; color: #ed1c24; font-size: 28px; line-height: 1.15; letter-spacing: -.2px; }
.search-title-row p { margin: 0; color: #737b88; font-size: 13px; line-height: 1.6; text-align: right; }
.search-badge { justify-self: end; white-space: nowrap; display: inline-flex; align-items: center; min-height: 32px; padding: 0 16px; border-radius: 999px; color: #b97a22; background: #fff7ed; border: 1px solid rgba(216,167,74,.28); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.search-panel-full .field { position: relative; z-index: 1; }
.search-panel-full .field label { color: #303540; font-weight: 900; font-size: 13px; line-height: 1; }
.search-panel-full .field input, .search-panel-full .field select { height: 54px; border-radius: 14px; border: 1px solid rgba(17,27,51,.11); background: linear-gradient(180deg, #fff 0%, #fbfcff 100%); color: #333b49; box-shadow: 0 9px 22px rgba(17,27,51,.045),
    0 0 0 1px rgba(255,255,255,.72) inset; transition: border-color .2s ease, box-shadow .2s ease, background .2s ease; }
.search-panel-full .field input::placeholder { color: #9aa2af; }
.search-panel-full .field input:focus, .search-panel-full .field select:focus { border-color: rgba(244,81,42,.58); background: #fff; box-shadow: 0 14px 28px rgba(244,81,42,.09),
    0 0 0 4px rgba(244,81,42,.09); }
.search-panel-full .icon-field input, .search-panel-full .icon-field select { padding-left: 44px; }
.field-icon { position: absolute; left: 15px; bottom: 16px; width: 22px; height: 22px; color: #f4512a; opacity: .95; pointer-events: none; }
.icon-search .field-icon::before { content: ""; position: absolute; width: 12px; height: 12px; left: 1px; top: 1px; border: 2px solid currentColor; border-radius: 50%; }
.icon-search .field-icon::after { content: ""; position: absolute; width: 9px; height: 2px; right: 2px; bottom: 4px; border-radius: 999px; background: currentColor; transform: rotate(45deg); }
.icon-flag .field-icon::before { content: ""; position: absolute; left: 4px; top: 2px; width: 2px; height: 18px; border-radius: 999px; background: currentColor; }
.icon-flag .field-icon::after { content: ""; position: absolute; left: 7px; top: 3px; width: 13px; height: 9px; border-radius: 2px 6px 6px 2px; background: currentColor; }
.icon-pin .field-icon::before { content: ""; position: absolute; left: 4px; top: 1px; width: 14px; height: 14px; border-radius: 50% 50% 50% 4px; border: 2px solid currentColor; transform: rotate(-45deg); }
.icon-pin .field-icon::after { content: ""; position: absolute; left: 9px; top: 6px; width: 4px; height: 4px; border-radius: 50%; background: currentColor; }
.icon-plane .field-icon::before { content: ""; position: absolute; left: 2px; top: 10px; width: 18px; height: 3px; border-radius: 999px; background: currentColor; transform: rotate(-28deg); }
.icon-plane .field-icon::after { content: ""; position: absolute; right: 2px; top: 4px; width: 8px; height: 8px; border-top: 3px solid currentColor; border-right: 3px solid currentColor; transform: rotate(18deg); }
.icon-calendar .field-icon { border: 2px solid currentColor; border-radius: 6px; }
.icon-calendar .field-icon::before { content: ""; position: absolute; left: 3px; right: 3px; top: 6px; height: 2px; background: currentColor; }
.icon-calendar .field-icon::after { content: ""; position: absolute; left: 5px; top: -4px; width: 10px; height: 6px; border-left: 2px solid currentColor; border-right: 2px solid currentColor; }
.icon-month .field-icon { border: 2px solid currentColor; border-radius: 50%; }
.icon-month .field-icon::before { content: ""; position: absolute; left: 10px; top: 3px; width: 2px; height: 8px; border-radius: 999px; background: currentColor; }
.icon-month .field-icon::after { content: ""; position: absolute; left: 10px; top: 10px; width: 7px; height: 2px; border-radius: 999px; background: currentColor; transform: rotate(30deg); transform-origin: left center; }
.icon-festival .field-icon::before, .icon-festival .field-icon::after { content: ""; position: absolute; left: 10px; top: 2px; width: 2px; height: 18px; border-radius: 999px; background: currentColor; }
.icon-festival .field-icon::after { transform: rotate(90deg); }
.icon-festival .field-icon { transform: rotate(45deg); }
.search-panel-full .btn-search { align-self: end; display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-width: 150px; height: 58px; border: 0; border-radius: 16px; background: linear-gradient(135deg, #ed1c24 0%, #f4512a 100%); color: #fff; font-size: 20px; font-weight: 900; box-shadow: 0 18px 36px rgba(237,28,36,.27); transition: transform .2s ease, box-shadow .2s ease, filter .2s ease; }
.search-panel-full .btn-search:hover { transform: translateY(-2px); box-shadow: 0 24px 46px rgba(237,28,36,.34); filter: saturate(1.05); }
.btn-search-icon { position: relative; width: 20px; height: 20px; display: inline-block; }
.btn-search-icon::before { content: ""; position: absolute; width: 11px; height: 11px; left: 1px; top: 1px; border: 3px solid #fff; border-radius: 50%; }
.btn-search-icon::after { content: ""; position: absolute; width: 9px; height: 3px; right: 0; bottom: 3px; border-radius: 999px; background: #fff; transform: rotate(45deg); }
@media (max-width: 900px) {
  .search-title-row { grid-template-columns: 1fr; gap: 8px; }
  .search-title-row p { text-align: left; }
  .search-badge { justify-self: start; }
  .search-panel.search-panel-full { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .search-panel.search-panel-full { grid-template-columns: 1fr; padding: 20px; border-radius: 22px; }
  .search-title-row h2 { font-size: 23px; }
  .search-title-main { min-width: 0; }
  .search-panel-full .btn-search { width: 100%; }
}
.search-panel.search-panel-full { gap: 16px; padding: 30px 30px 30px; border-radius: 28px; border-color: rgba(244,81,42,.22); box-shadow: 0 38px 96px rgba(17,27,51,.17),
    0 0 0 1px rgba(255,255,255,.78) inset; }
.search-title-row { padding: 6px 4px 10px; gap: 20px; }
.search-title-icon { width: 42px; height: 42px; border-radius: 15px; }
.search-title-row h2 { font-size: 30px; }
.search-title-row p { font-size: 13.5px; color: #697283; }
.search-badge { min-height: 34px; padding: 0 18px; font-size: 12.5px; border-color: rgba(216,167,74,.36); box-shadow: 0 10px 24px rgba(216,167,74,.10); }
.search-panel-full .field { gap: 8px; }
.search-panel-full .field label { font-size: 14px; letter-spacing: -.05px; }
.search-panel-full .field input, .search-panel-full .field select { height: 58px; border-radius: 15px; font-size: 14.5px; border-color: rgba(17,27,51,.13); }
.search-panel-full .icon-field input, .search-panel-full .icon-field select { padding-left: 48px; }
.field-icon { left: 16px; bottom: 18px; width: 23px; height: 23px; }
.search-panel-full .btn-search { min-width: 180px; height: 62px; border-radius: 17px; font-size: 21px; }
@media (min-width: 901px) {
  .search-panel-full .btn-search { grid-column: 3 / span 1; justify-self: start; }
}
@media (max-width: 640px) {
  .search-panel.search-panel-full { padding: 22px; }
}
.search-panel-wrap { margin-top: -72px; position: relative; z-index: 10; }
.search-panel.search-panel-full.priority-search-panel { width: 100%; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 18px 14px; padding: 28px 30px 30px; border-radius: 30px; background: linear-gradient(180deg, #ffffff 0%, #fffdfb 58%, #fff8f4 100%); border: 1px solid rgba(244, 81, 42, .18); box-shadow: 0 30px 82px rgba(17, 27, 51, .16); overflow: hidden; }
.search-panel.search-panel-full.priority-search-panel::before { height: 5px; background: linear-gradient(90deg, var(--red), #f4512a, var(--gold)); }
.priority-search-panel .search-title-row { grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 0 4px 2px; }
.priority-search-panel .search-title-main { display: flex; align-items: center; gap: 14px; }
.priority-search-panel .search-title-main h2 { margin: 0; color: #ed1c24; font-size: 31px; line-height: 1.15; }
.priority-search-panel .search-title-main p { margin: 5px 0 0; color: #6b7280; font-size: 14px; line-height: 1.6; }
.priority-search-panel .search-badge { flex: 0 0 auto; min-height: 34px; display: inline-flex; align-items: center; justify-content: center; padding: 0 18px; border-radius: 999px; background: #fff8ef; border: 1px solid rgba(216, 167, 74, .42); color: #b87b17; font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.priority-search-panel .keyword-field { grid-column: span 4; }
.priority-search-panel .priority-search-btn { grid-column: span 1; align-self: end; width: 100%; min-width: 0; height: 60px; border-radius: 16px; font-size: 23px; }
.priority-search-panel .field { gap: 7px; }
.priority-search-panel .field label { color: #263044; font-size: 13.5px; font-weight: 900; }
.priority-search-panel .field input, .priority-search-panel .field select { height: 60px; border-radius: 15px; padding-left: 48px; padding-right: 14px; border-color: rgba(17, 27, 51, .12); background: #fbfcff; font-size: 14px; font-weight: 600; color: #3c4352; }
.priority-search-panel .keyword-field input { font-size: 15px; letter-spacing: .01em; }
.priority-search-panel .field-icon { top: 42px; left: 17px; width: 22px; height: 22px; }
@media (max-width: 1180px) {
  .search-panel.search-panel-full.priority-search-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .priority-search-panel .keyword-field, .priority-search-panel .priority-search-btn { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .search-panel.search-panel-full.priority-search-panel { grid-template-columns: 1fr; padding: 20px; border-radius: 24px; }
  .priority-search-panel .search-title-row { align-items: flex-start; flex-direction: column; gap: 12px; }
  .priority-search-panel .search-title-main h2 { font-size: 24px; }
  .priority-search-panel .field input, .priority-search-panel .field select, .priority-search-panel .priority-search-btn { height: 56px; }
}
.hero.hero-slider-section { min-height: 0; aspect-ratio: 1920 / 596; background: #fff; }
.hero.hero-slider-section .hero-slide { width: 100%; height: 100%; background-position: center; background-size: cover; background-repeat: no-repeat; }
.hero-slide-media, .hero-slide-img { display: block; width: 100%; height: 100%; }
.hero-slide-img { object-fit: cover; object-position: center; }
.hero.hero-slider-section .hero-inner, .hero.hero-slider-section .hero-slide::before, .hero.hero-slider-section::after, .hero.hero-slider-section .hero-slider-dots { display: none !important; }
.search-panel-wrap { margin-top: 34px !important; }
:root { --container: 1170px; }
.main-header { background: #fff !important; border-top: 1px solid rgba(17, 27, 51, .05) !important; border-bottom: 1px solid rgba(17, 27, 51, .08) !important; box-shadow: none !important; }
.main-header-inner.nav-only { position: relative !important; min-height: 64px !important; width: min(var(--container), calc(100% - 40px)) !important; max-width: var(--container) !important; padding: 0 !important; justify-content: center !important; }
.main-header-inner.nav-only .main-nav { width: 100% !important; display: flex !important; align-items: stretch !important; justify-content: space-between !important; gap: 16px !important; overflow: visible !important; }
.main-header-inner.nav-only .main-nav > a, .main-header-inner.nav-only .nav-dropdown > a { position: relative !important; min-height: 64px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; padding: 0 !important; border: 0 !important; border-radius: 0 !important; background: transparent !important; color: #2f3540 !important; font-size: 15.5px !important; font-weight: 900 !important; line-height: 1.15 !important; white-space: nowrap !important; }
.main-header-inner.nav-only .main-nav > a::after, .main-header-inner.nav-only .nav-dropdown > a::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: #f4512a; opacity: 0; }
.main-header-inner.nav-only .main-nav > a:hover, .main-header-inner.nav-only .nav-dropdown:hover > a, .main-header-inner.nav-only .main-nav > a.active { color: #f4512a !important; }
.main-header-inner.nav-only .main-nav > a:hover::after, .main-header-inner.nav-only .nav-dropdown:hover > a::after, .main-header-inner.nav-only .main-nav > a.active::after { opacity: 1; }
.main-header-inner.nav-only .nav-zone, .main-header-inner.nav-only .nav-dropdown { position: static !important; }
.main-header-inner.nav-only .mega-zones, .main-header-inner.nav-only .compact-mega { top: 64px !important; left: 0 !important; right: auto !important; width: 100% !important; max-width: var(--container) !important; transform: translateY(8px) !important; }
.main-header-inner.nav-only .nav-zone:hover .mega-zones { transform: translateY(0) !important; }
.main-header-inner.nav-only .mega-zones:not(.compact-mega) { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }
.main-header-inner.nav-only .compact-mega { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
@media (max-width: 1180px) {
  .main-header-inner.nav-only .main-nav { justify-content: flex-start !important; gap: 18px !important; overflow-x: auto !important; }
  .main-header-inner.nav-only .main-nav > a, .main-header-inner.nav-only .nav-dropdown > a { flex: 0 0 auto !important; }
  .main-header-inner.nav-only .mega-zones, .main-header-inner.nav-only .compact-mega { width: calc(100vw - 40px) !important; max-width: calc(100vw - 40px) !important; grid-template-columns: repeat(3, minmax(0, 1fr)) !important; max-height: 72vh !important; overflow: auto !important; }
}
@media (max-width: 900px) {
  .main-header-inner.nav-only { min-height: 0 !important; }
  .main-header-inner.nav-only .main-nav { align-items: stretch !important; justify-content: flex-start !important; gap: 0 !important; overflow: visible !important; }
  .main-header-inner.nav-only .main-nav > a, .main-header-inner.nav-only .nav-dropdown > a { min-height: 46px !important; justify-content: flex-start !important; padding: 0 14px !important; font-size: 15px !important; }
  .main-header-inner.nav-only .mega-zones, .main-header-inner.nav-only .compact-mega { position: static !important; width: 100% !important; max-width: 100% !important; grid-template-columns: 1fr !important; transform: none !important; }
}
.section { position: relative; isolation: isolate; transition: background-color .28s ease; }
.section > .container { position: relative; z-index: 1; }
.section::before { content: ""; position: absolute; inset: 22px 0; z-index: 0; background: radial-gradient(circle at 50% 0%, rgba(244, 81, 42, .07), rgba(244, 81, 42, 0) 34%),
    linear-gradient(90deg, rgba(216, 167, 74, 0), rgba(216, 167, 74, .09), rgba(216, 167, 74, 0)); opacity: 0; pointer-events: none; transform: translateY(10px); transition: opacity .35s ease, transform .35s ease; }
.section:hover::before { opacity: 1; transform: translateY(0); }
.section-heading h2, .section-heading span, .section-heading p, .view-all { transition: color .24s ease, transform .24s ease, text-shadow .24s ease; }
.section:hover .section-heading h2 { color: #101a33; transform: translateX(4px); text-shadow: 0 14px 34px rgba(17, 27, 51, .12); }
.section:hover .section-heading span { color: #f4512a; }
.section:hover .view-all { transform: translateX(4px); }
.tour-card, .country-card, .past-work-card, .article-card { will-change: transform, box-shadow; transition: transform .28s ease,
    box-shadow .28s ease,
    border-color .28s ease,
    filter .28s ease; }
.section:hover .tour-card:hover, .section:hover .country-card:hover, .section:hover .past-work-card:hover, .section:hover .article-card:hover { transform: translateY(-10px); border-color: rgba(244, 81, 42, .28); box-shadow: 0 28px 70px rgba(17, 27, 51, .16),
    0 0 0 1px rgba(244, 81, 42, .06); }
.tour-image, .past-work-card { transition: filter .28s ease, transform .28s ease; }
.tour-card:hover .tour-image, .past-work-card:hover { filter: saturate(1.08) contrast(1.03); }
.tour-detail-btn { transition: background-color .24s ease, color .24s ease, transform .24s ease, box-shadow .24s ease; }
.tour-card:hover .tour-detail-btn { transform: translateY(-2px); background: #f4512a; color: #fff; box-shadow: 0 14px 30px rgba(244, 81, 42, .22); }
.monthly-tour-section { position: relative; padding-top: 126px; }
.monthly-tour-section > .container::before { content: ""; position: absolute; left: 50%; top: -58px; width: min(760px, calc(100vw - 72px)); height: 1px; transform: translateX(-50%); background: linear-gradient(90deg, rgba(216, 167, 74, 0), rgba(216, 167, 74, .55), rgba(244, 81, 42, .45), rgba(216, 167, 74, .55), rgba(216, 167, 74, 0)); box-shadow: 0 16px 42px rgba(216, 167, 74, .18); }
.monthly-tour-section > .container::after { content: ""; position: absolute; left: 50%; top: -60px; width: 94px; height: 5px; border-radius: 999px; transform: translateX(-50%); background: linear-gradient(90deg, #c8192e, #f4512a, #d8a74a); box-shadow: 0 10px 28px rgba(244, 81, 42, .32),
    0 0 0 7px rgba(255, 255, 255, .88); }
@media (max-width: 680px) {
  .section:hover .section-heading h2, .section:hover .view-all { transform: none; }
  .monthly-tour-section { padding-top: 96px; }
  .monthly-tour-section > .container::before { top: -42px; width: calc(100vw - 48px); }
  .monthly-tour-section > .container::after { top: -44px; width: 76px; }
}
.main-header-inner.nav-only .service-dropdown { position: relative !important; }
.main-header-inner.nav-only .service-dropdown > a { padding-right: 16px !important; }
.main-header-inner.nav-only .service-dropdown > a::before { content: ""; position: absolute; right: 0; top: 50%; width: 0; height: 0; margin-top: -1px; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 0; border-bottom: 6px solid rgba(47, 53, 64, .28); transition: border-bottom-color .2s ease, transform .2s ease; }
.main-header-inner.nav-only .service-dropdown:hover > a::before { border-bottom-color: #f4512a; transform: translateY(-2px); }
.service-menu { position: absolute; top: 64px; right: 0; z-index: 95; width: 300px; padding: 14px 0; background: #fff; border-top: 3px solid #e60012; border-radius: 0 0 8px 8px; box-shadow: 0 26px 68px rgba(17, 27, 51, .18); opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(10px); transition: opacity .2s ease, transform .2s ease, visibility .2s ease; }
.service-menu::before { content: ""; position: absolute; top: -11px; right: 74px; width: 0; height: 0; border-left: 10px solid transparent; border-right: 10px solid transparent; border-bottom: 10px solid #e60012; }
.service-dropdown:hover .service-menu { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
.service-menu a { display: flex; align-items: center; gap: 14px; min-height: 52px; padding: 8px 26px; color: #3a414d; font-size: 20px; font-weight: 700; transition: background-color .18s ease, color .18s ease, transform .18s ease; }
.service-menu a:hover { background: linear-gradient(90deg, rgba(244, 81, 42, .08), rgba(244, 81, 42, 0)); color: #e60012; transform: translateX(4px); }
.service-icon { width: 38px; height: 38px; display: inline-grid; place-items: center; flex: 0 0 38px; border-radius: 999px; background: linear-gradient(180deg, #fff7ee, #fff); box-shadow: 0 8px 18px rgba(17, 27, 51, .12); font-size: 22px; }
@media (max-width: 900px) {
  .main-header-inner.nav-only .service-dropdown { position: relative !important; }
  .service-menu { position: static; width: 100%; margin: 4px 0 8px; border: 1px solid rgba(17, 27, 51, .08); border-top: 3px solid #e60012; border-radius: 14px; box-shadow: none; display: none; opacity: 1; visibility: visible; pointer-events: auto; transform: none; }
  .service-menu::before { display: none; }
  .service-dropdown:hover .service-menu { display: block; transform: none; }
  .service-menu a { min-height: 46px; padding: 8px 14px; font-size: 16px; }
  .service-icon { width: 32px; height: 32px; flex-basis: 32px; font-size: 18px; }
}
@media (max-width: 900px) {
  .topbar { display: none !important; }
  .site-header { position: relative; z-index: 120; }
  .contact-header { position: sticky; top: 0; z-index: 125; background: #fff; border-bottom: 1px solid rgba(17, 27, 51, .08); box-shadow: 0 10px 24px rgba(17, 27, 51, .06); }
  .contact-header-inner { display: grid !important; grid-template-columns: 58px minmax(0, 1fr) 58px; align-items: center; min-height: 92px !important; gap: 0 !important; padding: 0 !important; }
  .header-info-list { display: none !important; }
  .talad-brand { grid-column: 2; grid-row: 1; justify-self: center; justify-content: center; min-width: 0 !important; width: auto; }
  .talad-brand .brand-logo, .brand-logo { height: 66px !important; max-width: min(190px, 48vw); object-fit: contain; }
  .mobile-toggle { grid-column: 1; grid-row: 1; justify-self: start; display: inline-grid !important; place-items: center; width: 54px; height: 54px; padding: 0; border-radius: 18px; background: linear-gradient(145deg, var(--red), #ef3e28); box-shadow: 0 14px 28px rgba(200, 25, 46, .22); cursor: pointer; }
  .mobile-toggle span { width: 28px; height: 3px; margin: 3px 0; background: #fff; }
  .mobile-search-trigger { grid-column: 3; grid-row: 1; justify-self: end; display: inline-grid !important; place-items: center; position: relative; width: 54px; height: 54px; border-radius: 18px; background: #fff; border: 2px solid rgba(200, 25, 46, .18); box-shadow: 0 12px 26px rgba(17, 27, 51, .08); }
  .mobile-search-trigger span { position: relative; width: 25px; height: 25px; border: 4px solid var(--red); border-radius: 50%; }
  .mobile-search-trigger span::after { content: ""; position: absolute; right: -9px; bottom: -7px; width: 13px; height: 4px; border-radius: 999px; background: var(--red); transform: rotate(45deg); transform-origin: center; }
  .main-header { height: 0 !important; min-height: 0 !important; border: 0 !important; box-shadow: none !important; overflow: visible !important; background: transparent !important; }
  .main-header-inner.nav-only { min-height: 0 !important; width: 100% !important; max-width: none !important; }
  .main-header-inner.nav-only .main-nav { position: fixed !important; top: 104px !important; left: 14px !important; right: 14px !important; z-index: 130 !important; width: auto !important; max-height: calc(100vh - 124px); flex-direction: column !important; align-items: stretch !important; justify-content: flex-start !important; gap: 0 !important; padding: 12px !important; border-radius: 20px !important; background: rgba(255, 255, 255, .98) !important; border: 1px solid rgba(17, 27, 51, .08); box-shadow: 0 26px 70px rgba(17, 27, 51, .20) !important; overflow: auto !important; opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(-8px); transition: opacity .22s ease, transform .22s ease, visibility .22s ease; }
  .menu-open .main-header-inner.nav-only .main-nav { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
}
@media (max-width: 480px) {
  .contact-header-inner { grid-template-columns: 54px minmax(0, 1fr) 54px; min-height: 84px !important; }
  .talad-brand .brand-logo, .brand-logo { height: 58px !important; max-width: min(170px, 48vw); }
  .mobile-toggle, .mobile-search-trigger { width: 50px; height: 50px; border-radius: 16px; }
  .main-header-inner.nav-only .main-nav { top: 94px !important; max-height: calc(100vh - 110px); }
}
.mobile-menu-backdrop, .mobile-drawer { display: none; }
@media (max-width: 900px) {
  body.menu-open { overflow: hidden; }
  .menu-open .main-header-inner.nav-only .main-nav, .main-header-inner.nav-only .main-nav { display: none !important; }
  .mobile-menu-backdrop { position: fixed; inset: 0; z-index: 198; display: block; background: rgba(17, 27, 51, .48); opacity: 0; pointer-events: none; transition: opacity .24s ease; }
  .menu-open .mobile-menu-backdrop { opacity: 1; pointer-events: auto; }
  .mobile-drawer { position: fixed; inset: 0 auto 0 0; z-index: 199; display: flex; width: min(100vw, 440px); max-width: 100vw; flex-direction: column; background: #fff; box-shadow: 32px 0 80px rgba(17, 27, 51, .20); transform: translateX(-100%); transition: transform .28s ease; }
  .menu-open .mobile-drawer { transform: translateX(0); }
  .mobile-drawer-head { position: sticky; top: 0; z-index: 2; display: flex; align-items: center; justify-content: space-between; min-height: 112px; padding: 22px 28px 18px; background: rgba(255, 255, 255, .98); border-bottom: 1px solid rgba(200, 25, 46, .14); }
  .mobile-drawer-brand { display: inline-flex; align-items: center; }
  .mobile-drawer-brand img { display: block; width: 136px; max-width: 42vw; height: auto; }
  .mobile-drawer-close { width: 46px; height: 46px; border: 0; border-radius: 999px; background: rgba(200, 25, 46, .08); color: var(--red); font-size: 34px; font-weight: 500; line-height: 1; cursor: pointer; }
  .mobile-drawer-nav { flex: 1; overflow-y: auto; padding: 26px 28px 44px; -webkit-overflow-scrolling: touch; }
  .mobile-drawer-nav > a, .mobile-menu-group > summary { min-height: 54px; display: flex; align-items: center; justify-content: space-between; padding: 0 16px; border-bottom: 1px solid rgba(200, 25, 46, .22); color: #4b4f58; font-size: 23px; font-weight: 500; letter-spacing: 0; }
  .mobile-drawer-nav > a:hover, .mobile-menu-group > summary:hover { color: var(--red); }
  .mobile-menu-group { border: 0; }
  .mobile-menu-group > summary { cursor: pointer; list-style: none; }
  .mobile-menu-group > summary::-webkit-details-marker { display: none; }
  .mobile-menu-group > summary::after { content: ""; width: 0; height: 0; border-left: 7px solid transparent; border-right: 7px solid transparent; border-top: 8px solid rgba(47, 53, 64, .28); transition: transform .2s ease, border-top-color .2s ease; }
  .mobile-menu-group[open] > summary { background: rgba(200, 25, 46, .055); color: #a80719; }
  .mobile-menu-group[open] > summary::after { border-top-color: rgba(47, 53, 64, .22); transform: rotate(180deg); }
  .mobile-submenu { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); column-gap: 20px; row-gap: 14px; padding: 18px 20px 22px; border-bottom: 1px solid rgba(200, 25, 46, .18); }
  .mobile-submenu a { display: inline-flex; align-items: center; gap: 10px; min-width: 0; color: #4b4f58; font-size: 19px; font-weight: 500; line-height: 1.25; }
  .mobile-submenu a:hover { color: var(--red); }
  .mobile-submenu-flags img, .drawer-thumb { width: 28px; height: 28px; flex: 0 0 28px; border-radius: 50%; object-fit: cover; background-size: cover; background-position: center; box-shadow: 0 4px 12px rgba(17, 27, 51, .12); }
}
@media (max-width: 480px) {
  .mobile-drawer-head { min-height: 104px; padding: 20px 24px 16px; }
  .mobile-drawer-brand img { width: 126px; }
  .mobile-drawer-nav { padding: 22px 18px 40px; }
  .mobile-drawer-nav > a, .mobile-menu-group > summary { min-height: 50px; padding: 0 14px; font-size: 21px; }
  .mobile-submenu { column-gap: 16px; row-gap: 12px; padding: 16px 14px 20px; }
  .mobile-submenu a { gap: 9px; font-size: 17px; }
  .mobile-submenu-flags img, .drawer-thumb { width: 25px; height: 25px; flex-basis: 25px; }
}
@media (max-width: 900px) {
  body { background: #eef5f8; }
  .contact-header { box-shadow: none !important; }
  .contact-header-inner { min-height: 82px !important; }
  .talad-brand .brand-logo, .brand-logo { height: 56px !important; max-width: min(178px, 48vw); }
  .mobile-toggle { width: 40px !important; height: 40px !important; padding: 0 !important; background: transparent !important; box-shadow: none !important; border-radius: 0 !important; }
  .mobile-toggle span { width: 26px !important; height: 3px !important; margin: 3px 0 !important; background: var(--red) !important; }
  .mobile-search-trigger { width: 40px !important; height: 40px !important; border: 0 !important; border-radius: 0 !important; background: transparent !important; box-shadow: none !important; }
  .mobile-search-trigger span { width: 23px !important; height: 23px !important; border-width: 4px !important; }
  .mobile-search-trigger span::after { right: -9px !important; bottom: -7px !important; width: 13px !important; height: 4px !important; }
  .hero.hero-slider-section { aspect-ratio: 2172 / 724; min-height: 0 !important; background: #fff; }
  .hero.hero-slider-section .hero-slide { animation: heroSlide 18s infinite !important; transform: scale(1.02); opacity: 0; background-size: cover; background-position: center; }
  .hero.hero-slider-section .hero-slider-dots { display: flex !important; bottom: 7px; gap: 5px; }
  .hero.hero-slider-section .hero-slider-dots span { width: 10px; height: 5px; background: rgba(255,255,255,.75); box-shadow: none; }
  .hero.hero-slider-section .hero-slider-dots span:nth-child(1) { animation: dotActive 18s infinite !important; }
  .hero.hero-slider-section .hero-slider-dots span:nth-child(2) { animation: dotActive 18s infinite 6s !important; }
  .hero.hero-slider-section .hero-slider-dots span:nth-child(3) { animation: dotActive 18s infinite 12s !important; }
  .hero.hero-slider-section .hero-slider-dots span:nth-child(1) { width: 34px; background: var(--red); }
  .search-panel-wrap { margin-top: 0 !important; padding: 26px 0 0; background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0) 30%),
      linear-gradient(180deg, #d9051e 0%, #c90e29 72%, #b70722 100%); z-index: 1; }
  .search-panel-wrap > .container, .popular-countries > .container { width: 100%; padding-left: 28px; padding-right: 28px; }
  .mobile-quick-search { display: grid; grid-template-columns: 32px minmax(0, 1fr) 38px; align-items: center; gap: 14px; min-height: 78px; padding: 0 18px; border-radius: 12px; background: linear-gradient(180deg, #fff 0%, #fffafa 100%); color: #9aa2af; box-shadow: 0 20px 46px rgba(70,0,12,.20),
      0 0 0 1px rgba(255,255,255,.78) inset; }
  .mobile-quick-search strong { font-size: clamp(24px, 6.8vw, 32px); font-weight: 700; line-height: 1; }
  .mobile-pin-icon, .mobile-mini-search-icon { position: relative; display: inline-block; color: var(--red); }
  .mobile-pin-icon { width: 32px; height: 34px; justify-self: center; background: transparent; transform: none; }
  .mobile-pin-icon::before { content: ""; position: absolute; left: 50%; top: 4px; width: 22px; height: 22px; border: 4px solid var(--red); border-radius: 50% 50% 50% 0; background: #fff; box-sizing: border-box; transform: translateX(-50%) rotate(-45deg); }
  .mobile-pin-icon::after { content: ""; position: absolute; left: 50%; top: 12px; width: 7px; height: 7px; border-radius: 50%; background: var(--red); transform: translateX(-50%); }
  .mobile-mini-search-icon { width: 28px; height: 28px; justify-self: end; border: 4px solid var(--red); border-radius: 50%; }
  .mobile-mini-search-icon::after { content: ""; position: absolute; right: -11px; bottom: -7px; width: 15px; height: 4px; border-radius: 99px; background: var(--red); transform: rotate(45deg); }
  .search-panel.search-panel-full.priority-search-panel { max-height: 0; margin-top: 0 !important; padding-top: 0 !important; padding-bottom: 0 !important; border-width: 0 !important; border-color: transparent; box-shadow: none; opacity: 0; pointer-events: none; transform: translateY(-10px); transition: max-height .45s ease,
      margin-top .28s ease,
      padding-top .28s ease,
      padding-bottom .28s ease,
      opacity .25s ease,
      transform .28s ease; }
  body.search-open .search-panel.search-panel-full.priority-search-panel { max-height: 1900px; margin-top: 22px !important; padding-top: 20px !important; padding-bottom: 20px !important; border-width: 1px !important; border-color: rgba(244,81,42,.18); box-shadow: 0 34px 90px rgba(17,27,51,.16),
      0 0 0 1px rgba(255,255,255,.70) inset; opacity: 1; pointer-events: auto; transform: translateY(0); }
  .popular-countries { position: relative; overflow: hidden; margin-top: 0; padding: 30px 0 46px; background: linear-gradient(180deg, #d9051e 0%, #c90e29 70%, #b70722 100%); }
  .popular-countries::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 48px; background: #f4f6f8; clip-path: polygon(0 68%, 100% 44%, 100% 100%, 0 100%); pointer-events: none; }
  .popular-countries > .container { position: relative; z-index: 1; }
  .popular-countries .section-heading { display: none; }
  .popular-countries .country-grid { display: flex; grid-template-columns: none; gap: 22px; overflow-x: auto; overflow-y: hidden; padding: 0 0 4px; scroll-snap-type: x proximity; scrollbar-width: none; }
  .popular-countries .country-grid::-webkit-scrollbar { display: none; }
  .popular-countries .country-card { flex: 0 0 108px; min-height: 0; padding: 0; border-radius: 0; overflow: visible; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; background: transparent !important; box-shadow: none; color: #fff; scroll-snap-align: start; }
  .popular-countries .country-card::before { display: none; }
  .popular-countries .country-thumb { display: block; width: 104px; height: 104px; border-radius: 14px; border: 5px solid rgba(255,255,255,.94); background-size: cover; background-position: center; box-shadow: 0 16px 30px rgba(70,0,8,.24),
      0 0 0 1px rgba(255,255,255,.22) inset; }
  .popular-countries .country-card strong { margin-top: 11px; color: #fff; font-size: 21px; line-height: 1.25; text-align: center; text-shadow: 0 8px 18px rgba(70,0,8,.24); }
  .popular-countries .country-card > span:not(.country-thumb) { display: none; }
  .mobile-country-action { display: block; position: relative; z-index: 2; margin-top: 22px; margin-bottom: -24px; text-align: center; }
  .mobile-country-action a { display: inline-flex; align-items: center; min-height: 56px; padding: 0 36px; border-radius: 999px; background: linear-gradient(135deg, #ff9a94 0%, #ee2d2d 44%, #d60012 100%); color: #fff; font-size: 23px; font-weight: 800; box-shadow: 0 18px 36px rgba(70,0,8,.30),
      0 0 0 1px rgba(255,255,255,.22) inset; }
  .mobile-shortcut-menu { display: block; position: relative; z-index: 4; margin-top: -12px; padding: 0 0 34px; background: #f4f6f8; }
  .mobile-shortcut-menu > .container { width: 100%; padding-left: 28px; padding-right: 28px; }
  .shortcut-card { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0; overflow: hidden; padding: 18px 12px 16px; border-radius: 13px; background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.94)),
      radial-gradient(circle at 50% 0%, rgba(244,81,42,.12), transparent 44%); border: 1px solid rgba(17,27,51,.06); box-shadow: 0 26px 60px rgba(17,27,51,.14),
      0 0 0 1px rgba(255,255,255,.80) inset; }
  .shortcut-item { position: relative; display: grid; justify-items: center; align-content: start; gap: 9px; min-height: 94px; padding: 8px 5px; color: #3f4651; text-align: center; transition: transform .2s ease, color .2s ease; }
  .shortcut-item:nth-child(-n + 4) { border-bottom: 1px solid rgba(17,27,51,.08); }
  .shortcut-item:not(:nth-child(4n)):not(:last-child) { border-right: 1px solid rgba(17,27,51,.08); }
  .shortcut-item:hover { color: var(--red); transform: translateY(-2px); }
  .shortcut-item strong { font-size: 13px; font-weight: 800; line-height: 1.28; }
  .shortcut-icon { position: relative; display: inline-grid; place-items: center; width: 44px; height: 44px; border-radius: 15px; background: linear-gradient(180deg, #fff, var(--shortcut-bg, #fff7f7)); color: var(--shortcut-color, var(--red)); box-shadow: 0 12px 24px var(--shortcut-shadow, rgba(200,25,46,.13)),
      0 0 0 1px rgba(17,27,51,.05) inset; }
  .shortcut-icon svg { width: 28px; height: 28px; fill: none; stroke: currentColor; stroke-width: 1.85; stroke-linecap: round; stroke-linejoin: round; }
  .shortcut-route { --shortcut-color: #c8192e; --shortcut-bg: #fff3f5; --shortcut-shadow: rgba(200,25,46,.14); }
  .shortcut-foreign { --shortcut-color: #172643; --shortcut-bg: #f3f6fb; --shortcut-shadow: rgba(23,38,67,.12); }
  .shortcut-domestic { --shortcut-color: #c7922a; --shortcut-bg: #fff8e8; --shortcut-shadow: rgba(199,146,42,.15); }
  .shortcut-flash { --shortcut-color: #f4512a; --shortcut-bg: #fff2ee; --shortcut-shadow: rgba(244,81,42,.14); }
  .shortcut-package { --shortcut-color: #b78020; --shortcut-bg: #fff7e6; --shortcut-shadow: rgba(183,128,32,.14); }
  .shortcut-free { --shortcut-color: #172643; --shortcut-bg: #f3f6fb; --shortcut-shadow: rgba(23,38,67,.12); }
  .shortcut-cruise { --shortcut-color: #31445f; --shortcut-bg: #f4f7fb; --shortcut-shadow: rgba(49,68,95,.12); }
  .shortcut-all { --shortcut-color: #9c1021; --shortcut-bg: #fff3f5; --shortcut-shadow: rgba(156,16,33,.14); }
  body.countries-open { background: #fff; }
  body.countries-open main > :not(.mobile-all-countries) { display: none !important; }
  body.countries-open .site-footer { display: none; }
  body.countries-open .mobile-search-trigger { visibility: hidden; pointer-events: none; }
  body.countries-open .contact-header { border-bottom-color: rgba(17,27,51,.12); box-shadow: 0 2px 10px rgba(17,27,51,.08) !important; }
  .mobile-all-countries { display: none; scroll-margin-top: 86px; padding: 30px 0 10px; background: #fff; }
  body.countries-open .mobile-all-countries { display: block; }
  .mobile-all-countries > .container { width: 100%; padding-left: 30px; padding-right: 30px; }
  .all-countries-heading { display: none; }
  .all-countries-heading span { display: block; margin-bottom: 8px; color: var(--red); font-size: 11px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
  .all-countries-heading h2 { margin: 0; color: #303743; font-size: 30px; line-height: 1.15; }
  .all-countries-heading p { margin: 8px auto 0; max-width: 300px; color: #7a8290; font-size: 15px; line-height: 1.7; }
  .all-country-region { padding: 0 0 34px; }
  .all-country-region + .all-country-region { padding-top: 0; }
  .all-country-region h3 { display: block; margin: 0 0 18px; padding-bottom: 14px; border-bottom: 1px solid rgba(17,27,51,.12); color: #464b54; font-size: 24px; font-weight: 900; line-height: 1.25; text-align: center; }
  .all-country-region h3::before, .all-country-region h3::after { display: none; }
  .all-country-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px 24px; }
  .all-country-grid a { display: flex; align-items: center; min-width: 0; gap: 12px; color: #4b515d; font-size: 20px; font-weight: 600; line-height: 1.35; }
  .all-country-grid a:hover { color: var(--red); }
  .all-country-grid img { width: 46px; height: 46px; flex: 0 0 46px; border-radius: 999px; object-fit: cover; background: #f4f5f7; box-shadow: 0 8px 18px rgba(17,27,51,.10),
      0 0 0 1px rgba(17,27,51,.05) inset; }
  .desktop-promo-section { display: none; }
  .doso-route { padding-top: 30px; background: #f4f6f8; }
  .doso-route .section-heading { display: block; padding: 20px 22px; border-radius: 12px; background: #fff; box-shadow: 0 14px 34px rgba(17,27,51,.08),
      0 0 0 1px rgba(17,27,51,.035); }
  .doso-route .section-heading span, .doso-route .section-heading p, .doso-route .section-heading .view-all { display: none; }
  .doso-route .section-heading h2 { font-size: 26px; color: #3f4651; }
}
@media (max-width: 480px) {
  .contact-header-inner { min-height: 74px !important; }
  .talad-brand .brand-logo, .brand-logo { height: 50px !important; max-width: min(158px, 46vw); }
  .mobile-toggle, .mobile-search-trigger { width: 36px !important; height: 36px !important; }
  .mobile-toggle span { width: 24px !important; }
  .mobile-search-trigger span { width: 21px !important; height: 21px !important; border-width: 3px !important; }
  .search-panel-wrap > .container, .popular-countries > .container { padding-left: 16px; padding-right: 16px; }
  .mobile-quick-search { min-height: 66px; grid-template-columns: 32px minmax(0, 1fr) 32px; gap: 10px; padding: 0 16px; }
  .mobile-quick-search strong { font-size: 27px; }
  .popular-countries .country-grid { gap: 18px; }
  .popular-countries .country-card { flex-basis: 100px; }
  .popular-countries .country-thumb { width: 96px; height: 96px; border-radius: 12px; }
  .popular-countries .country-card strong { font-size: 21px; }
  .mobile-country-action { margin-top: 20px; margin-bottom: -22px; }
  .mobile-country-action a { min-height: 54px; padding: 0 30px; font-size: 22px; }
  .mobile-shortcut-menu { margin-top: -8px; padding-bottom: 26px; }
  .mobile-shortcut-menu > .container { padding-left: 16px; padding-right: 16px; }
  .shortcut-card { padding: 14px 8px 12px; border-radius: 12px; }
  .shortcut-item { min-height: 86px; gap: 7px; padding: 7px 4px; }
  .shortcut-item strong { font-size: 12px; }
  .shortcut-icon { width: 34px; height: 34px; transform: scale(.92); }
  .mobile-all-countries { scroll-margin-top: 74px; padding-top: 26px; }
  .mobile-all-countries > .container { padding-left: 26px; padding-right: 26px; }
  .all-countries-heading h2 { font-size: 28px; }
  .all-countries-heading p { font-size: 14px; }
  .all-country-region { padding-bottom: 32px; }
  .all-country-region h3 { font-size: 22px; }
  .all-country-grid { gap: 16px 18px; }
  .all-country-grid a { gap: 10px; font-size: 18px; }
  .all-country-grid img { width: 42px; height: 42px; flex-basis: 42px; }
}
@media (max-width: 680px) {
  body.countries-open .site-footer { display: block; }
  .site-footer { overflow: hidden; padding: 30px 0 22px; background: radial-gradient(circle at 50% 0%, rgba(255,255,255,.16), transparent 34%),
      linear-gradient(180deg, #e60000 0%, #d90000 58%, #c90000 100%); text-align: center; }
  .site-footer .container { width: min(100% - 32px, var(--container)); }
  .footer-grid { display: block; text-align: center; }
  .footer-grid > .footer-col:not(.footer-contact) { display: none; }
  .footer-main-logo { width: min(190px, 56vw); margin: 0 auto 12px; filter: drop-shadow(0 12px 18px rgba(88,0,0,.3)); }
  .site-footer .footer-company-name { margin: 0 0 10px; color: #fff; font-size: clamp(17px, 4.7vw, 22px); line-height: 1.36; }
  .footer-brand p, .site-footer p { margin: 0 0 10px; color: #fff; font-size: clamp(13px, 3.8vw, 16px); line-height: 1.55; }
  .footer-mobile-actions { display: grid; gap: 9px; margin: 18px auto 24px; width: min(100%, 560px); }
  .footer-mobile-action { display: grid; grid-template-columns: 58px 1fr; align-items: center; min-height: 48px; overflow: hidden; border: 1px solid rgba(255,255,255,.72); border-radius: 9px; color: #fff; font-size: clamp(18px, 4.9vw, 22px); line-height: 1; text-decoration: none; box-shadow: 0 12px 22px rgba(91,0,0,.16), 0 1px 0 rgba(255,255,255,.2) inset; }
  .footer-mobile-action strong { font-weight: 500; }
  .footer-mobile-action.phone { background: rgba(255,255,255,.035); }
  .footer-mobile-action.line { border-color: rgba(255,255,255,.24); background: linear-gradient(180deg, #07d10c 0%, #00bd07 100%); }
  .footer-mobile-action-icon { position: relative; display: grid; place-items: center; justify-self: stretch; width: 100%; height: 100%; border-right: 1px dashed rgba(255,255,255,.5); }
  .footer-mobile-action-icon.fa-square-phone::before, .footer-mobile-action-icon.fa-line::before { content: ""; position: absolute; left: 50%; top: 50%; width: 30px; height: 30px; border-radius: 8px; background: linear-gradient(180deg, #fff, #f6f8fb); transform: translate(-50%, -50%); }
  .footer-mobile-action-icon.fa-square-phone::before { box-shadow: 0 8px 16px rgba(92,0,0,.2), 0 1px 0 rgba(255,255,255,.9) inset; }
  .footer-mobile-action-icon.fa-line::before { box-shadow: 0 8px 16px rgba(0,90,16,.18), 0 1px 0 rgba(255,255,255,.9) inset; }
  .footer-mobile-action-icon.fa-square-phone::after, .footer-mobile-action-icon.fa-line::after { content: ""; position: absolute; left: 50%; top: 50%; z-index: 1; width: 17px; height: 17px; transform: translate(-50%, -50%); }
  .footer-mobile-action-icon.fa-square-phone::after { background: #d90000; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.6 2.8 4.1 4.1c-.9.5-1.4 1.6-1 2.7 2.1 6.4 7.1 11.4 13.4 13.5 1.1.4 2.2-.1 2.7-1l1.3-2.5c.4-.8.2-1.8-.5-2.4l-2.8-2.1c-.7-.5-1.6-.5-2.3 0l-1.3 1c-1.9-1-3.4-2.5-4.4-4.4l1-1.3c.5-.7.5-1.6 0-2.3L8.9 3.3c-.6-.8-1.6-1-2.3-.5Z'/%3E%3C/svg%3E") center / 17px 17px no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.6 2.8 4.1 4.1c-.9.5-1.4 1.6-1 2.7 2.1 6.4 7.1 11.4 13.4 13.5 1.1.4 2.2-.1 2.7-1l1.3-2.5c.4-.8.2-1.8-.5-2.4l-2.8-2.1c-.7-.5-1.6-.5-2.3 0l-1.3 1c-1.9-1-3.4-2.5-4.4-4.4l1-1.3c.5-.7.5-1.6 0-2.3L8.9 3.3c-.6-.8-1.6-1-2.3-.5Z'/%3E%3C/svg%3E") center / 17px 17px no-repeat; }
  .footer-mobile-action-icon.fa-line::after { content: ""; position: absolute; left: 50%; top: 50%; z-index: 1; width: auto; height: auto; background: none; color: #06c755; font-family: "Font Awesome 6 Brands"; font-size: 21px; font-weight: 400; line-height: 1; transform: translate(-50%, -50%); }
  .footer-mobile-action-icon.fa-line { color: #06c755; font-size: 0; background: transparent; }
  .footer-mobile-action-icon.fa-line::before { content: ""; position: absolute; left: 50%; top: 50%; z-index: 0; width: 30px; height: 30px; border-radius: 8px; background: linear-gradient(180deg, #fff, #f6f8fb); box-shadow: 0 8px 16px rgba(0,90,16,.18), 0 1px 0 rgba(255,255,255,.9) inset; transform: translate(-50%, -50%); }
  .footer-contact { margin-top: 0; }
  .site-footer .footer-contact h4 { position: relative; margin: 0 0 22px; font-size: clamp(20px, 5.2vw, 25px); line-height: 1.25; }
  .site-footer .footer-contact h4::after { content: ""; position: absolute; left: 50%; bottom: -9px; width: 34px; height: 3px; border-radius: 99px; background: #fff; transform: translateX(-50%); }
  .footer-contact-list { width: min(100%, 320px); margin: 0 auto 22px; gap: 10px; justify-items: stretch; }
  .footer-contact-list li { display: grid; grid-template-columns: 24px minmax(0, 1fr); justify-content: start; align-items: center; gap: 10px; width: 100%; max-width: 100%; color: #fff; font-size: clamp(14px, 3.9vw, 18px); line-height: 1.4; text-align: left; }
  .footer-contact-list li strong { font-size: clamp(17px, 4.6vw, 22px); }
  .footer-contact-icon { flex: 0 0 24px; width: 24px; height: 24px; border-radius: 7px; background: linear-gradient(180deg, #fff, #f5f7fb); box-shadow: 0 8px 16px rgba(84,0,0,.18), 0 1px 0 rgba(255,255,255,.9) inset; }
  .footer-social { justify-content: center; gap: 9px; margin-top: 16px; }
  .footer-social-button { width: 39px; height: 39px; border-radius: 9px; border-color: rgba(255,255,255,.24); box-shadow: 0 10px 18px rgba(70,0,0,.2), 0 1px 0 rgba(255,255,255,.22) inset; }
  .footer-social-button svg { width: 22px; height: 22px; }
  .footer-bottom { display: grid; grid-template-columns: 1fr; justify-items: center; min-height: 0; margin-top: 40px; padding-top: 42px; text-align: center; }
  .footer-bottom::before { left: calc((100vw - 100%) / -2); right: calc(50% + 112px); }
  .footer-bottom::after { left: calc(50% + 112px); right: calc((100vw - 100%) / -2); }
  .footer-visitor { top: -32px; min-width: 170px; padding: 8px 14px; border-radius: 8px; gap: 2px; }
  .footer-visitor span { font-size: 14px; }
  .footer-visitor span::before { width: 15px; height: 15px; flex-basis: 15px; }
  .footer-visitor strong { font-size: 20px; }
  .footer-legal { grid-column: 1; justify-self: center; width: 100%; max-width: 270px; gap: 8px; margin: 0; color: #fff; font-size: clamp(13px, 3.6vw, 16px); line-height: 1.48; }
  .footer-legal > span { max-width: 100%; }
  .footer-powered { font-size: 13px; justify-content: center; }
  .footer-powered strong { font-size: 20px; }
  .footer-top-link { position: absolute; right: 0; bottom: 14px; width: 30px; height: 30px; display: grid; place-items: center; margin: 0; padding: 0; border: 0; border-radius: 50%; background: #fff; color: #d70000; font-size: 0; box-shadow: 0 16px 28px rgba(86,0,0,.18); }
  .footer-top-link span { width: 100%; height: 100%; background: transparent; color: #d70000; font-size: 0; }
  .footer-top-link span::before { width: 9px; height: 9px; border-top: 3px solid currentColor; border-left: 3px solid currentColor; transform: translateY(-3px) rotate(45deg); }
  .line-widget-launcher { right: 12px; bottom: 14px; width: 50px; height: 50px; }
  .line-widget-launcher::before { width: 28px; height: 28px; }
}
.tour-card .tour-image { aspect-ratio: 1 / 1; min-height: 0; }
@media (max-width: 680px) {
  .doso-route, #tours.tour-section, .monthly-tour-section { position: relative; overflow: hidden; padding: 48px 0 56px; background: radial-gradient(circle at 15% 12%, rgba(255, 255, 255, .96), transparent 32%),
      linear-gradient(180deg, #f5f9fc 0%, #eef4f8 100%); }
  #tours.tour-section { background: radial-gradient(circle at 80% 8%, rgba(255, 248, 238, .92), transparent 30%),
      linear-gradient(180deg, #fff 0%, #f7fafc 100%); }
  .monthly-tour-section { padding-top: 58px; background: radial-gradient(circle at 50% 0%, rgba(255, 239, 210, .92), transparent 36%),
      linear-gradient(180deg, #fffaf2 0%, #f8fbfd 100%); }
  .doso-route::before, #tours.tour-section::before, .monthly-tour-section::before { content: ""; position: absolute; inset: 0 0 auto; height: 160px; background: linear-gradient(180deg, rgba(208, 0, 0, .08), transparent); pointer-events: none; }
  .tour-section .container { position: relative; z-index: 1; width: 100%; padding-right: 0; padding-left: 28px; }
  .tour-section .section-heading.split, .doso-route .section-heading { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: end; gap: 12px; margin: 0 0 18px; padding: 0 28px 0 0; border: 0; border-radius: 0; background: transparent; box-shadow: none; text-align: left; }
  .tour-section .section-heading.split > div, .doso-route .section-heading > div { min-width: 0; }
  .tour-section .section-heading span, .doso-route .section-heading span { display: block; margin-bottom: 6px; color: var(--red); font-size: 11px; font-weight: 900; letter-spacing: 1.5px; text-transform: uppercase; }
  .monthly-tour-section .section-heading span { color: #c58b20; }
  .tour-section .section-heading h2, .doso-route .section-heading h2 { margin: 0; color: var(--navy); font-size: clamp(25px, 7vw, 31px); line-height: 1.14; letter-spacing: 0; }
  .tour-section .section-heading p, .doso-route .section-heading p { display: none; }
  .tour-section .view-all, .doso-route .section-heading .view-all { display: inline-flex; align-items: center; justify-content: flex-end; align-self: center; white-space: nowrap; color: var(--red); font-size: 13px; font-weight: 900; }
  .monthly-tour-section .view-all { color: #b9831b; }
  .tour-grid { display: flex !important; grid-template-columns: none !important; gap: 18px; overflow-x: auto; overflow-y: visible; padding: 4px 28px 18px 0; scroll-padding-left: 28px; scroll-snap-type: x mandatory; scrollbar-width: none; }
  .tour-grid::-webkit-scrollbar { display: none; }
  .tour-card { flex: 0 0 min(80vw, 326px); overflow: hidden; border: 1px solid rgba(17, 27, 51, .08); border-radius: 22px; background: rgba(255, 255, 255, .97); box-shadow: 0 24px 55px rgba(20, 34, 61, .14); scroll-snap-align: start; transform: none; }
  .tour-card:hover { transform: translateY(-4px); box-shadow: 0 28px 62px rgba(20, 34, 61, .18); }
  .tour-card.premium { border-color: rgba(216, 167, 74, .52); box-shadow: 0 24px 58px rgba(190, 128, 30, .18); }
  .tour-image { width: 100%; aspect-ratio: 1 / 1; min-height: 0; display: flex; align-items: flex-start; justify-content: flex-end; padding: 12px; border-radius: 22px 22px 0 0; background-size: cover; background-position: center; }
  .tour-image::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(4, 12, 26, .04) 35%, rgba(4, 12, 26, .2) 100%); pointer-events: none; }
  .tour-image span { position: relative; z-index: 1; padding: 7px 11px; border: 1px solid rgba(255, 255, 255, .75); border-radius: 999px; background: rgba(255, 255, 255, .94); box-shadow: 0 10px 22px rgba(17, 27, 51, .12); color: var(--red); font-size: 11px; line-height: 1; }
  .tour-body { padding: 16px; }
  .tour-topline { gap: 8px; margin-bottom: 8px; font-size: 11px; }
  .tour-card h3 { display: -webkit-box; min-height: 42px; margin-bottom: 9px; overflow: hidden; color: var(--navy); font-size: 17px; line-height: 1.25; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
  .tour-card p { display: -webkit-box; min-height: 41px; margin-bottom: 12px; overflow: hidden; font-size: 13px; line-height: 1.55; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
  .tour-detail-list { gap: 6px; margin: 0 0 12px; padding: 11px 0 12px; }
  .tour-detail-item { gap: 8px; font-size: 12.5px; }
  .tour-icon { width: 15px; height: 15px; }
  .tour-price-block { display: grid; grid-template-columns: 90px minmax(0, 1fr); align-items: end; gap: 10px; margin-bottom: 14px; }
  .airline-logo { width: 90px; min-height: 34px; justify-content: flex-start; }
  .airline-logo img { width: 84px; max-height: 32px; }
  .tour-price-box { min-width: 0; text-align: right; }
  .tour-price-box span { font-size: 11px; }
  .tour-price-box strong { font-size: 28px; letter-spacing: 0; }
  .tour-price-box em { font-size: 12px; }
  .tour-detail-btn { min-height: 38px; padding: 9px 16px; border-radius: 999px; font-size: 13px; box-shadow: 0 12px 24px rgba(207, 0, 18, .08); }
  .doso-route > .container::after, #tours > .container::after, .monthly-tour-section > .container::after { content: ""; position: static; display: block; width: 66px; height: 8px; margin: 0 auto; border: 0; border-radius: 999px; background: radial-gradient(circle at 62px 50%, rgba(201, 211, 224, .85) 0 4px, transparent 5px),
      radial-gradient(circle at 48px 50%, rgba(201, 211, 224, .85) 0 4px, transparent 5px),
      linear-gradient(90deg, var(--red) 0 30px, transparent 30px); box-shadow: none; transform: none; }
  .monthly-tour-section > .container::after { background: radial-gradient(circle at 62px 50%, rgba(216, 196, 160, .9) 0 4px, transparent 5px),
      radial-gradient(circle at 48px 50%, rgba(216, 196, 160, .9) 0 4px, transparent 5px),
      linear-gradient(90deg, #c58b20 0 30px, transparent 30px); }
  .monthly-tour-section > .container::before { display: none; }
}
@media (max-width: 480px) {
  .tour-section .container { padding-left: 26px; }
  .tour-section .section-heading.split, .doso-route .section-heading { padding-right: 26px; }
  .tour-grid { gap: 16px; padding-right: 26px; scroll-padding-left: 26px; }
  .tour-card { flex-basis: min(80vw, 306px); border-radius: 20px; }
  .tour-image { border-radius: 20px 20px 0 0; }
  .tour-body { padding: 14px; }
  .tour-card h3 { font-size: 16px; }
  .tour-price-box strong { font-size: 26px; }
}
@media (max-width: 680px) {
  .doso-route, #tours.tour-section, .monthly-tour-section { padding: 42px 0 46px; }
  .tour-section .section-heading.split, .doso-route .section-heading { margin-bottom: 14px; }
  .tour-section .section-heading h2, .doso-route .section-heading h2 { max-width: 210px; font-size: clamp(23px, 6.5vw, 29px); }
  .tour-grid { gap: 14px; padding-bottom: 14px; }
  .tour-card { position: relative; display: grid; grid-template-columns: minmax(144px, 46%) minmax(0, 1fr); flex: 0 0 min(88vw, 430px); min-height: 0; border-radius: 18px; box-shadow: 0 20px 44px rgba(20, 34, 61, .13); }
  .tour-card:hover { transform: translateY(-3px); }
  .tour-image { align-self: stretch; width: 100%; aspect-ratio: 1 / 1; height: auto; min-height: 0; padding: 8px; border-radius: 18px 0 0 18px; }
  .tour-image span { padding: 6px 9px; font-size: 10px; }
  .tour-body { position: relative; display: grid; grid-template-rows: auto auto auto 1fr; min-width: 0; min-height: 0; padding: 12px 12px 12px 13px; }
  .tour-topline { margin-bottom: 5px; font-size: 10px; }
  .tour-topline strong { font-size: 10px; }
  .tour-card h3 { min-height: 0; margin-bottom: 7px; font-size: 15px; line-height: 1.22; -webkit-line-clamp: 2; }
  .tour-card p { display: none; }
  .tour-detail-list { gap: 4px; margin: 0; padding: 0 0 8px; border: 0; }
  .tour-detail-item { gap: 6px; font-size: 10.5px; line-height: 1.2; }
  .tour-detail-item:nth-child(3) { display: none; }
  .tour-icon { width: 12px; height: 12px; }
  .tour-price-block { align-self: end; display: grid; grid-template-columns: 58px minmax(0, 1fr); gap: 7px; margin: 0; padding-right: 76px; }
  .airline-logo { width: 58px; min-height: 22px; }
  .airline-logo img { width: 54px; max-height: 22px; }
  .tour-price-box { text-align: right; }
  .tour-price-box span { font-size: 9px; }
  .tour-price-box strong { font-size: 22px; line-height: 1; }
  .tour-price-box em { font-size: 10px; }
  .tour-detail-btn { position: absolute; right: 12px; bottom: 12px; min-height: 28px; padding: 6px 11px; font-size: 11px; box-shadow: 0 10px 20px rgba(207, 0, 18, .12); }
  .doso-route > .container::after, #tours > .container::after, .monthly-tour-section > .container::after { margin-top: 2px; }
}
@media (max-width: 480px) {
  .tour-card { grid-template-columns: minmax(138px, 46%) minmax(0, 1fr); flex-basis: min(88vw, 340px); }
  .tour-body { padding: 11px 11px 11px 12px; }
  .tour-card h3 { font-size: 14px; }
  .tour-price-block { grid-template-columns: 52px minmax(0, 1fr); padding-right: 70px; }
  .airline-logo { width: 52px; }
  .airline-logo img { width: 50px; }
  .tour-price-box strong { font-size: 20px; }
  .tour-detail-btn { right: 10px; bottom: 10px; padding: 6px 10px; }
}
@media (max-width: 680px) {
  .tour-card { grid-template-columns: minmax(148px, 46%) minmax(178px, 1fr); flex-basis: min(90vw, 440px); }
  .tour-topline { display: none; }
  .tour-body { grid-template-rows: auto auto 1fr auto; padding: 14px 13px 13px 14px; }
  .tour-card h3 { margin-bottom: 8px; font-size: 15.5px; line-height: 1.24; }
  .tour-detail-list { margin-bottom: 8px; }
  .tour-price-block { grid-template-columns: 58px minmax(100px, 1fr); align-items: end; gap: 8px; padding-right: 0; }
  .tour-price-box { display: grid; justify-items: end; gap: 1px; line-height: 1; }
  .tour-price-box strong { font-size: 24px; line-height: 1; white-space: nowrap; }
  .tour-price-box em { display: block; white-space: nowrap; }
  .tour-detail-btn { position: static; justify-self: end; min-height: 30px; margin-top: 10px; padding: 7px 13px; font-size: 11px; }
}
@media (max-width: 480px) {
  .tour-card { grid-template-columns: minmax(140px, 45%) minmax(166px, 1fr); flex-basis: min(91vw, 360px); }
  .tour-body { padding: 13px 12px 12px; }
  .tour-price-block { grid-template-columns: 52px minmax(96px, 1fr); gap: 7px; }
  .tour-price-box strong { font-size: 23px; }
  .tour-detail-btn { margin-top: 9px; }
}
@media (max-width: 680px) {
  .tour-section .tour-card { grid-template-columns: minmax(148px, 45%) minmax(178px, 1fr); flex-basis: min(91vw, 442px); overflow: hidden; border-color: rgba(216, 167, 74, .26); box-shadow: 0 20px 46px rgba(20, 34, 61, .14); }
  .tour-section .tour-body { grid-template-rows: auto 1fr auto auto; padding: 15px 14px 13px; }
  .tour-section .tour-topline { display: none !important; }
  .tour-section .tour-card h3 { margin-bottom: 8px; font-size: 15.5px; line-height: 1.24; }
  .tour-section .tour-detail-list { align-self: start; gap: 5px; padding-bottom: 8px; }
  .tour-section .tour-price-block { grid-template-columns: 56px minmax(0, 1fr); align-items: end; gap: 8px; width: 100%; margin-top: 3px; padding: 8px 0 0; border-top: 1px solid rgba(17, 27, 51, .07); }
  .tour-section .airline-logo { align-self: end; width: 56px; min-width: 0; }
  .tour-section .airline-logo img { width: 54px; }
  .tour-section .tour-price-box { min-width: 0; text-align: right; }
  .tour-section .tour-price-box span, .tour-section .tour-price-box em { display: block; white-space: nowrap; }
  .tour-section .tour-price-box strong { display: block; font-size: 23px; line-height: 1.03; white-space: nowrap; }
  .tour-section .tour-detail-btn { position: static; justify-self: end; min-height: 29px; margin-top: 8px; padding: 7px 13px; border-radius: 999px; font-size: 11px; }
}
@media (max-width: 480px) {
  .tour-section .tour-card { grid-template-columns: minmax(140px, 45%) minmax(164px, 1fr); flex-basis: min(91vw, 360px); }
  .tour-section .tour-body { padding: 13px 12px 12px; }
  .tour-section .tour-price-block { grid-template-columns: 50px minmax(0, 1fr); gap: 7px; }
  .tour-section .airline-logo { width: 50px; }
  .tour-section .airline-logo img { width: 48px; }
  .tour-section .tour-price-box strong { font-size: 21px; }
}
@media (max-width: 380px) {
  .tour-section .tour-card { grid-template-columns: minmax(132px, 44%) minmax(150px, 1fr); }
  .tour-section .tour-price-block { grid-template-columns: 1fr; }
  .tour-section .airline-logo { display: none; }
}
.tour-detail-item .tour-icon i { display: block; line-height: 1; }
@media (max-width: 680px) {
  .tour-section .tour-detail-item { color: #5c6678; font-weight: 700; }
  .tour-section .tour-icon { flex: 0 0 18px; width: 18px; height: 18px; align-items: center; justify-content: center; color: #f2a100; font-size: 15px; }
  .tour-section .tour-price-block { grid-template-columns: 74px minmax(0, 1fr); gap: 10px; padding-top: 10px; }
  .tour-section .airline-logo { display: inline-flex; width: 74px; min-height: 30px; align-self: end; align-items: center; justify-content: flex-start; padding: 0; }
  .tour-section .airline-logo img { width: 72px; max-height: 30px; filter: drop-shadow(0 4px 7px rgba(17, 27, 51, .10)); }
  .tour-section .tour-price-box strong { font-size: 24px; }
}
@media (max-width: 480px) {
  .tour-section .tour-price-block { grid-template-columns: 66px minmax(0, 1fr); gap: 9px; }
  .tour-section .airline-logo { display: inline-flex; width: 66px; }
  .tour-section .airline-logo img { width: 64px; max-height: 28px; }
}
@media (max-width: 380px) {
  .tour-section .tour-price-block { grid-template-columns: 60px minmax(0, 1fr); }
  .tour-section .airline-logo { display: inline-flex; width: 60px; }
  .tour-section .airline-logo img { width: 58px; max-height: 26px; }
}
@media (max-width: 680px) {
  .tour-section .tour-card { grid-template-columns: minmax(140px, 42%) minmax(0, 1fr); flex-basis: min(92vw, 452px); }
  .tour-section .tour-body { padding: 14px 14px 12px; }
  .tour-section .tour-detail-list { gap: 5px; margin: 0 0 6px; padding: 0 0 8px; border-bottom: 1px solid rgba(17, 27, 51, .08); }
  .tour-section .tour-detail-item, .tour-section .tour-detail-item:nth-child(3) { display: flex !important; }
  .tour-section .tour-detail-item { min-width: 0; color: #667184; font-size: 12px; font-weight: 700; line-height: 1.22; }
  .tour-section .tour-detail-item span:last-child { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .tour-section .tour-icon { flex: 0 0 18px; width: 18px; height: 18px; font-size: 14px; }
  .tour-section .tour-price-block { margin-top: 2px; padding-top: 8px; }
}
@media (max-width: 480px) {
  .tour-section .tour-card { grid-template-columns: minmax(134px, 42%) minmax(0, 1fr); flex-basis: min(93vw, 370px); }
  .tour-section .tour-body { padding: 12px 12px 11px; }
  .tour-section .tour-detail-list { gap: 4px; padding-bottom: 7px; }
  .tour-section .tour-detail-item { font-size: 11.25px; }
  .tour-section .tour-icon { flex-basis: 16px; width: 16px; height: 16px; font-size: 13px; }
}
.past-work-section { background: radial-gradient(circle at 50% 0%, rgba(255, 240, 220, .72), transparent 36%),
    linear-gradient(180deg, #fff 0%, #fffaf5 100%); }
.past-work-section .work-heading { margin-inline: auto; text-align: center; }
.past-work-section .work-heading h2, .places-section .section-heading h2 { letter-spacing: 0; }
.past-work-section .work-heading h2::after, .places-section .section-heading h2::after { content: ""; display: block; width: 86px; height: 2px; margin: 10px auto 0; border-radius: 999px; background: linear-gradient(90deg, transparent, rgba(212, 0, 0, .85), rgba(17, 27, 51, .28), transparent); }
.past-work-section .work-heading p { max-width: 680px; margin-inline: auto; }
.past-work-grid { gap: 18px; }
.past-work-card { border-radius: var(--doso-card-radius); border: 1px solid rgba(17, 27, 51, .08); box-shadow: 0 18px 40px rgba(17, 27, 51, .08); }
.past-work-thumb { aspect-ratio: 1.36 / 1; }
.past-work-thumb span { left: 0; right: 0; bottom: 0; padding: 11px 14px 12px; border: 0; border-radius: 0; background: linear-gradient(90deg, rgba(255,255,255,.88), rgba(255,255,255,.70)); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px); color: #3f4652; font-size: 16px; line-height: 1.35; text-align: center; text-shadow: none; box-shadow: none; }
.past-work-card p { padding: 12px 14px 14px; background: linear-gradient(180deg, #fff, #fff9f4); }
.past-work-more { min-height: 44px; padding: 0 22px; border-radius: 999px; color: #3f4652; }
.places-section { background: radial-gradient(circle at 26% 10%, rgba(255, 245, 231, .78), transparent 32%),
    linear-gradient(180deg, #fff 0%, #f8fbff 100%); }
.places-section .section-heading.split { align-items: end; }
.places-section .article-grid { gap: 22px; }
.places-section .article-card { border-color: rgba(216, 167, 74, .18); border-radius: var(--doso-card-radius); background: linear-gradient(180deg, #fff, #fff8f2); box-shadow: 0 18px 42px rgba(17, 27, 51, .075); }
.places-section .article-thumb { aspect-ratio: 16 / 9; }
.places-section .article-body { padding: 20px 22px 22px; }
.places-section .article-card h3 { color: #17213a; }
@media (max-width: 680px) {
  .past-work-section { padding: 54px 0 56px; background: radial-gradient(circle at 50% 8%, rgba(255, 237, 225, .82), transparent 42%),
      linear-gradient(180deg, #fff 0%, #f7fbff 100%); }
  .past-work-section .container, .places-section .container { width: min(100% - 28px, var(--container)); }
  .past-work-section .work-heading { margin-bottom: 24px; }
  .past-work-section .work-heading h2 { font-size: 25px; line-height: 1.35; }
  .past-work-section .work-heading p { font-size: 16px; line-height: 1.65; }
  .past-work-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
  .past-work-card { border-radius: 9px; box-shadow: 0 14px 28px rgba(17, 27, 51, .12); }
  .past-work-thumb { aspect-ratio: 1.16 / 1; }
  .past-work-thumb::after { background: linear-gradient(180deg, rgba(8, 15, 29, .04), rgba(8, 15, 29, .26) 58%, rgba(8, 15, 29, .44)); }
  .past-work-thumb span { padding: 9px 8px 10px; color: #434b56; font-size: 14.5px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .past-work-card p { display: none; }
  .past-work-action { margin-top: 24px; }
  .past-work-more { min-height: 46px; padding: 0 22px; border-color: rgba(17, 27, 51, .34); font-size: 16px; box-shadow: 0 14px 26px rgba(17, 27, 51, .10); }
  .past-work-section + .places-section { padding-top: 58px; }
  .past-work-section + .places-section::before { width: min(320px, calc(100% - 64px)); margin-bottom: 46px; }
  .places-section { padding: 58px 0 64px; background: radial-gradient(circle at 50% 0%, rgba(255, 239, 226, .72), transparent 36%),
      linear-gradient(180deg, #fff 0%, #f7fbff 100%); }
  .places-section .section-heading.split { align-items: center; gap: 12px; margin-bottom: 24px; text-align: center; }
  .places-section .section-heading span { color: #ff4d2d; }
  .places-section .section-heading h2 { font-size: 27px; }
  .places-section .view-all { margin-top: 0; color: #d60000; font-size: 14px; }
  .places-section .article-grid { display: grid; grid-template-columns: 1fr; gap: 0; }
  .places-section .article-card { display: grid; grid-template-columns: 122px minmax(0, 1fr); gap: 14px; align-items: center; padding: 16px 0; border: 0; border-bottom: 1px dashed rgba(17, 27, 51, .14); border-radius: 0; background: transparent; box-shadow: none; }
  .places-section .article-card:last-child { border-bottom: 0; }
  .places-section .article-thumb { aspect-ratio: 1 / 1; border-radius: 15px; box-shadow: 0 12px 22px rgba(17, 27, 51, .13); }
  .places-section .article-body { min-width: 0; padding: 0; }
  .places-section .article-card span { display: block; margin-bottom: 4px; color: #9aa1ad; font-size: 12.5px; }
  .places-section .article-card span::before { content: "Updated : "; color: #8f96a3; font-weight: 700; }
  .places-section .article-card h3 { margin: 0 0 5px; color: #ef4b2a; font-size: 18px; line-height: 1.45; -webkit-line-clamp: 2; }
  .places-section .article-card p { color: #6b7280; font-size: 14px; line-height: 1.65; -webkit-line-clamp: 2; }
}
@media (max-width: 390px) {
  .past-work-grid { gap: 10px; }
  .past-work-thumb span { font-size: 13px; }
  .places-section .article-card { grid-template-columns: 106px minmax(0, 1fr); gap: 12px; }
  .places-section .article-card h3 { font-size: 16px; }
  .places-section .article-card p { font-size: 13px; }
}
.priority-search-panel .icon-field input, .priority-search-panel .icon-field select { padding-left: 64px; }
.priority-search-panel .field-icon { top: auto; bottom: 13px; left: 15px; width: 34px; height: 34px; display: inline-grid; place-items: center; border-radius: 12px; color: #f4512a; opacity: 1; background: radial-gradient(circle at 28% 20%, rgba(255,255,255,.98), rgba(255,247,241,.88) 68%),
    linear-gradient(145deg, rgba(255,255,255,.96), rgba(255,242,235,.88)); border: 1px solid rgba(244,81,42,.16); box-shadow: 0 12px 24px rgba(244,81,42,.12),
    0 0 0 1px rgba(255,255,255,.78) inset; transform: none; }
.priority-search-panel .icon-flag .field-icon, .priority-search-panel .icon-pin .field-icon, .priority-search-panel .icon-plane .field-icon { bottom: 111px; }
@media (min-width: 641px) {
  .priority-search-panel .icon-calendar .field-icon, .priority-search-panel .icon-month .field-icon, .priority-search-panel .icon-festival .field-icon { bottom: 13px; }
}
.priority-search-panel .field-icon::before, .priority-search-panel .field-icon::after { content: none !important; }
.priority-search-panel .field-icon i { display: block; font-size: 18px; line-height: 1; filter: drop-shadow(0 5px 8px rgba(244,81,42,.16)); }
.priority-search-panel .icon-calendar .field-icon, .priority-search-panel .icon-month .field-icon, .priority-search-panel .icon-festival .field-icon { color: #f05a2a; }
.priority-search-panel input[type="date"]::-webkit-calendar-picker-indicator { width: 18px; height: 18px; opacity: .58; filter: grayscale(1) brightness(.58); cursor: pointer; }
.priority-search-panel input[type="date"]:focus::-webkit-calendar-picker-indicator { opacity: .9; filter: none; }
@media (max-width: 640px) {
  .priority-search-panel .icon-field input, .priority-search-panel .icon-field select { padding-left: 62px; }
  .priority-search-panel .field-icon { bottom: 15px; width: 32px; height: 32px; border-radius: 11px; }
  .priority-search-panel .icon-flag .field-icon, .priority-search-panel .icon-pin .field-icon, .priority-search-panel .icon-plane .field-icon { bottom: 13px; }
  .priority-search-panel .field-icon i { font-size: 17px; }
}
@media (min-width: 901px) {
  .main-header-inner.nav-only .service-menu a { min-height: 48px; padding: 7px 24px; font-size: 12.75px; font-weight: 500; line-height: 1.35; }
  .main-header-inner.nav-only .service-icon { width: 34px; height: 34px; flex-basis: 34px; font-size: 19px; }
  .main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel a { min-height: 31px !important; font-size: 12.75px !important; line-height: 1.25 !important; }
  .main-header-inner.nav-only .mega-zones:not(.compact-mega) .zone-panel h4 { font-size: 15px !important; }
  .main-header-inner.nav-only .mega-zones:not(.compact-mega) { left: 50% !important; right: auto !important; width: min(1280px, calc(100vw - 48px)) !important; max-width: calc(100vw - 48px) !important; transform: translate(-50%, 8px) !important; }
  .main-header-inner.nav-only .nav-zone:hover .mega-zones:not(.compact-mega) { transform: translate(-50%, 0) !important; }
}
.search-panel.search-panel-full.priority-search-panel { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 24px 18px !important; padding: 32px 30px 34px !important; }
.priority-search-panel .keyword-field { grid-column: span 3 !important; }
.priority-search-panel .priority-search-btn { grid-column: span 1 !important; }
.priority-search-panel .country-field, .priority-search-panel .city-field { grid-column: span 1 !important; }
.priority-search-panel .airline-field { grid-column: span 2 !important; }
.priority-search-panel .travel-date-range-field, .priority-search-panel .icon-month, .priority-search-panel .icon-festival, .priority-search-panel .budget-select-field { grid-column: span 1 !important; }
.priority-search-panel .field input, .priority-search-panel .field select { appearance: none; -webkit-appearance: none; width: 100%; cursor: pointer; }
.priority-search-panel .field input[readonly] { cursor: pointer; }
.priority-search-panel .field-icon { top: auto !important; bottom: 14px !important; }
.priority-search-panel .keyword-field .field-icon { bottom: 19px !important; }
.priority-search-panel .budget-select-field select, .priority-search-panel .travel-date-range-field input { font-weight: 700; }
.icon-price .field-icon { border-radius: 50%; }
.icon-price .field-icon::before { content: ""; position: absolute; left: 4px; top: 3px; width: 14px; height: 14px; border: 2px solid currentColor; border-radius: 50%; box-shadow: 0 4px 0 -2px currentColor, 0 8px 0 -2px currentColor; }
.icon-price .field-icon::after { content: ""; position: absolute; left: 8px; top: 7px; width: 6px; height: 2px; border-radius: 999px; background: currentColor; box-shadow: 0 4px 0 currentColor; }
.priority-search-panel .field select { background-image: linear-gradient(45deg, transparent 50%, #263044 50%),
    linear-gradient(135deg, #263044 50%, transparent 50%),
    linear-gradient(180deg, #fff 0%, #fbfcff 100%) !important; background-position: calc(100% - 22px) calc(50% + 2px),
    calc(100% - 16px) calc(50% + 2px),
    0 0 !important; background-size: 6px 6px, 6px 6px, 100% 100% !important; background-repeat: no-repeat !important; padding-right: 42px !important; }
.priority-search-panel .travel-date-range-field input { padding-right: 42px !important; }
.priority-search-panel .travel-date-range-field::after { content: ""; position: absolute; right: 16px; bottom: 19px; width: 11px; height: 11px; border-right: 2px solid #263044; border-bottom: 2px solid #263044; transform: rotate(45deg); opacity: .88; pointer-events: none; }
.doso-date-picker-open { overflow: hidden; }
.doso-date-picker { position: fixed; inset: 0; z-index: 999; display: grid; place-items: center; padding: 24px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .24s ease, visibility .24s ease; }
.doso-date-picker.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.doso-date-picker-backdrop { position: absolute; inset: 0; background: rgba(17, 27, 51, .22); backdrop-filter: blur(6px); }
.doso-date-picker-panel { position: relative; z-index: 1; width: min(1050px, calc(100vw - 42px)); max-height: calc(100vh - 48px); overflow: auto; padding: 26px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,250,246,.98)); border: 1px solid rgba(244, 81, 42, .20); box-shadow: 0 36px 90px rgba(17, 27, 51, .22),
    0 0 0 1px rgba(255,255,255,.84) inset; transform: translateY(18px) scale(.98); transition: transform .24s ease; }
.doso-date-picker.is-open .doso-date-picker-panel { transform: translateY(0) scale(1); }
.doso-picker-head { display: grid; grid-template-columns: 58px 1fr 58px; align-items: center; gap: 18px; margin-bottom: 18px; }
.doso-picker-title { text-align: center; }
.doso-picker-title strong { display: block; color: #c8192e; font-size: 28px; font-weight: 900; line-height: 1.2; }
.doso-picker-title span { display: block; margin-top: 3px; color: #697283; font-size: 15px; font-weight: 700; }
.doso-picker-nav { width: 54px; height: 54px; display: inline-grid; place-items: center; border: 1px solid rgba(244, 81, 42, .20); border-radius: 18px; background: #fff8f5; color: #f4512a; font-size: 42px; line-height: 1; cursor: pointer; box-shadow: 0 12px 24px rgba(244, 81, 42, .08); transition: transform .2s ease, background-color .2s ease; }
.doso-picker-nav:hover { transform: translateY(-2px); background: #fff1ec; }
.doso-picker-status { display: grid; place-items: center; min-height: 54px; margin-bottom: 18px; border-radius: 16px; background: #fff6f2; border: 1px solid rgba(244, 81, 42, .16); color: #c8192e; font-size: 17px; font-weight: 900; }
.doso-picker-status.has-value { background: linear-gradient(135deg, rgba(244, 81, 42, .10), rgba(216, 167, 74, .13)); border-color: rgba(244, 81, 42, .26); }
.doso-picker-months { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.doso-picker-month { overflow: hidden; border: 1px solid rgba(17, 27, 51, .09); border-radius: 22px; background: #fff; box-shadow: 0 16px 34px rgba(17, 27, 51, .06); }
.doso-picker-month h3 { margin: 0; padding: 18px 16px; background: linear-gradient(135deg, #c8192e 0%, #f4512a 100%); color: #fff; font-size: 22px; font-weight: 900; line-height: 1.2; text-align: center; }
.doso-picker-weekdays, .doso-picker-days { display: grid; grid-template-columns: repeat(7, 1fr); }
.doso-picker-weekdays { background: #fff3ee; color: #303540; font-weight: 900; }
.doso-picker-weekdays span { display: grid; place-items: center; min-height: 48px; font-size: 16px; }
.doso-picker-days { padding: 18px; gap: 8px; }
.doso-picker-days .is-empty { min-height: 44px; }
.doso-day { position: relative; min-height: 44px; border: 0; border-radius: 14px; background: transparent; color: #172033; font-size: 18px; font-weight: 800; cursor: pointer; transition: background-color .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease; }
.doso-day:hover { background: rgba(244, 81, 42, .10); color: #c8192e; transform: translateY(-1px); }
.doso-day.is-today { box-shadow: inset 0 0 0 1px rgba(244, 81, 42, .65); }
.doso-day.is-in-range { background: rgba(244, 81, 42, .10); color: #c8192e; }
.doso-day.is-selected, .doso-day.is-start, .doso-day.is-end { background: linear-gradient(135deg, #ed1c24, #f4512a); color: #fff; box-shadow: 0 10px 22px rgba(237, 28, 36, .24); }
.doso-picker-actions { display: flex; justify-content: flex-end; gap: 12px; margin-top: 22px; }
.doso-picker-btn { min-width: 112px; min-height: 50px; padding: 0 20px; border: 1px solid rgba(17, 27, 51, .10); border-radius: 14px; background: #fff; color: #697283; font-size: 16px; font-weight: 900; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, color .18s ease; }
.doso-picker-btn:hover { transform: translateY(-1px); color: #c8192e; box-shadow: 0 12px 24px rgba(17, 27, 51, .08); }
.doso-picker-confirm { border-color: transparent; background: linear-gradient(135deg, #ed1c24, #f4512a); color: #fff; box-shadow: 0 16px 30px rgba(237, 28, 36, .24); }
.doso-picker-confirm:hover { color: #fff; }
@media (max-width: 1180px) {
  .search-panel.search-panel-full.priority-search-panel { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .priority-search-panel .keyword-field, .priority-search-panel .priority-search-btn, .priority-search-panel .airline-field, .priority-search-panel .country-field, .priority-search-panel .city-field, .priority-search-panel .travel-date-range-field, .priority-search-panel .icon-month, .priority-search-panel .icon-festival, .priority-search-panel .budget-select-field { grid-column: span 1 !important; }
  .priority-search-panel .keyword-field, .priority-search-panel .priority-search-btn { grid-column: 1 / -1 !important; }
}
@media (max-width: 720px) {
  .doso-date-picker { align-items: end; padding: 14px; }
  .doso-date-picker-panel { width: 100%; max-height: calc(100vh - 28px); padding: 18px; border-radius: 24px 24px 18px 18px; }
  .doso-picker-head { grid-template-columns: 48px 1fr 48px; gap: 10px; }
  .doso-picker-title strong { font-size: 22px; }
  .doso-picker-title span { font-size: 13px; }
  .doso-picker-nav { width: 46px; height: 46px; border-radius: 15px; font-size: 34px; }
  .doso-picker-months { grid-template-columns: 1fr; }
  .doso-picker-month h3 { font-size: 20px; padding: 16px; }
  .doso-picker-weekdays span { min-height: 42px; font-size: 14px; }
  .doso-picker-days { padding: 14px; gap: 6px; }
  .doso-day { min-height: 40px; border-radius: 12px; font-size: 16px; }
  .doso-picker-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .doso-picker-btn { min-width: 0; min-height: 46px; padding: 0 10px; font-size: 14px; }
}
@media (max-width: 640px) {
  .search-panel.search-panel-full.priority-search-panel { grid-template-columns: 1fr !important; gap: 14px !important; }
  .priority-search-panel .keyword-field, .priority-search-panel .priority-search-btn, .priority-search-panel .airline-field, .priority-search-panel .country-field, .priority-search-panel .city-field, .priority-search-panel .travel-date-range-field, .priority-search-panel .icon-month, .priority-search-panel .icon-festival, .priority-search-panel .budget-select-field { grid-column: 1 / -1 !important; }
}

/* Mobile final: slanted red-to-light divider like Doso reference */
@media (max-width: 900px) {
  .popular-countries {
    overflow: hidden;
    padding-bottom: 78px;
  }

  .popular-countries::after {
    left: 0;
    right: 0;
    bottom: -1px;
    z-index: 1;
    height: 86px;
    background: #f4f6f8;
    clip-path: polygon(0 72%, 100% 24%, 100% 100%, 0 100%);
  }

  .popular-countries > .container {
    position: relative;
    z-index: 2;
  }

  .mobile-country-action {
    z-index: 3;
    margin-top: 26px;
    margin-bottom: -48px;
  }

  .mobile-country-action a {
    min-height: 58px;
    padding: 0 40px;
    border: 1px solid rgba(255, 255, 255, .38);
    background: linear-gradient(135deg, #ff8580 0%, #ef232d 46%, #d60012 100%);
    box-shadow:
      0 20px 42px rgba(80, 0, 10, .30),
      0 0 0 1px rgba(255, 255, 255, .22) inset;
  }

  .mobile-shortcut-menu {
    margin-top: 0;
    padding-top: 40px;
    background: #f4f6f8;
  }
}

@media (max-width: 480px) {
  .popular-countries {
    padding-bottom: 72px;
  }

  .popular-countries::after {
    height: 78px;
    clip-path: polygon(0 74%, 100% 34%, 100% 100%, 0 100%);
  }

  .mobile-country-action {
    margin-top: 22px;
    margin-bottom: -42px;
  }

  .mobile-country-action a {
    min-height: 54px;
    padding: 0 32px;
    font-size: 22px;
  }

  .mobile-shortcut-menu {
    padding-top: 34px;
  }
}

/* Mobile refinement: cleaner slanted divider, softer bottom shadow, shortcut menu closer to divider */
@media (max-width: 900px) {
  .popular-countries::after {
    filter: drop-shadow(0 8px 14px rgba(17, 27, 51, .055));
    box-shadow: none !important;
  }

  .mobile-shortcut-menu {
    padding-top: 20px !important;
  }

  .shortcut-card {
    box-shadow:
      0 16px 38px rgba(17, 27, 51, .10),
      0 0 0 1px rgba(255,255,255,.82) inset !important;
  }
}

@media (max-width: 480px) {
  .popular-countries::after {
    filter: drop-shadow(0 7px 12px rgba(17, 27, 51, .05));
  }

  .mobile-shortcut-menu {
    padding-top: 16px !important;
  }
}

/* Mobile refinement: keep the soft shadow close to the country button and remove the distant grey shadow. */
@media (max-width: 900px) {
  .popular-countries::after {
    filter: none !important;
    box-shadow: none !important;
  }

  .mobile-country-action a {
    box-shadow:
      0 9px 18px rgba(80, 0, 10, .18),
      0 2px 4px rgba(255, 255, 255, .28) inset,
      0 0 0 1px rgba(255, 255, 255, .22) inset !important;
  }

  .mobile-shortcut-menu {
    padding-top: 14px !important;
  }
}

@media (max-width: 480px) {
  .mobile-country-action a {
    box-shadow:
      0 8px 15px rgba(80, 0, 10, .16),
      0 2px 4px rgba(255, 255, 255, .26) inset,
      0 0 0 1px rgba(255, 255, 255, .20) inset !important;
  }

  .mobile-shortcut-menu {
    margin-top: -10px !important;
    padding-top: 4px !important;
  }
}

/* Doso desktop card radius alignment: match the live dosotravel.com card corners. */
@media (min-width: 681px) {
  .tour-card,
  .past-work-card,
  .article-card,
  .places-section .article-card {
    border-radius: var(--doso-card-radius);
  }

  .tour-image,
  .past-work-thumb,
  .article-thumb,
  .places-section .article-thumb {
    border-radius: var(--doso-card-radius) var(--doso-card-radius) 0 0;
  }
}

/* Doso mobile card radius alignment: match the live dosotravel.com mobile cards. */
@media (max-width: 680px) {
  .tour-section .tour-card,
  .tour-card,
  .past-work-card,
  .article-card,
  .places-section .article-card {
    border-radius: var(--doso-card-radius) !important;
  }

  .tour-section .tour-image,
  .tour-image {
    border-radius: var(--doso-card-radius) 0 0 var(--doso-card-radius) !important;
  }

  .past-work-thumb,
  .article-thumb,
  .places-section .article-thumb {
    border-radius: var(--doso-card-radius) var(--doso-card-radius) 0 0 !important;
  }

  .tour-section .tour-card.premium,
  .tour-card.premium {
    border-radius: var(--doso-card-radius) !important;
  }
}

/* Final radius unification: use the same Doso live-site 8px card corner on Desktop and Mobile. */
:root {
  --doso-card-radius: 8px;
}

.tour-card,
.past-work-card,
.article-card,
.places-section .article-card {
  border-radius: var(--doso-card-radius) !important;
}

.tour-image,
.past-work-thumb,
.article-thumb,
.places-section .article-thumb {
  border-radius: var(--doso-card-radius) var(--doso-card-radius) 0 0 !important;
}

@media (max-width: 680px) {
  .tour-card,
  .tour-section .tour-card,
  .tour-card.premium,
  .tour-section .tour-card.premium,
  .past-work-card,
  .article-card {
    border-radius: var(--doso-card-radius) !important;
  }

  .tour-image,
  .tour-section .tour-image {
    border-radius: var(--doso-card-radius) 0 0 var(--doso-card-radius) !important;
  }

  .past-work-thumb,
  .article-thumb {
    border-radius: var(--doso-card-radius) var(--doso-card-radius) 0 0 !important;
  }

  .shortcut-card {
    border-radius: var(--doso-card-radius) !important;
  }
}

/* Mobile premium background refinement: remove heavy grey bands behind tour carousels. */
@media (max-width: 680px) {
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    background: #fff !important;
  }

  .doso-route::before,
  #tours.tour-section::before,
  .monthly-tour-section::before {
    display: none !important;
  }

  .doso-route {
    padding-top: 44px !important;
  }

  #tours.tour-section {
    padding-top: 50px !important;
  }

  .monthly-tour-section {
    padding-top: 50px !important;
    background: linear-gradient(180deg, #fffdf8 0%, #fff 34%, #fff 100%) !important;
  }

  .tour-grid {
    padding-top: 2px !important;
    padding-bottom: 10px !important;
  }

  .tour-section .tour-card,
  .tour-card {
    background: #fff !important;
    box-shadow: 0 12px 28px rgba(20, 34, 61, .095) !important;
  }

  .tour-section .tour-card:hover,
  .tour-card:hover {
    box-shadow: 0 16px 34px rgba(20, 34, 61, .12) !important;
  }

  .doso-route > .container::after,
  #tours > .container::after,
  .monthly-tour-section > .container::after {
    margin-top: 8px !important;
  }
}

@media (max-width: 480px) {
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    padding-bottom: 44px !important;
  }

  .doso-route {
    padding-top: 40px !important;
  }

  #tours.tour-section,
  .monthly-tour-section {
    padding-top: 46px !important;
  }
}

/* Mobile no-background premium tour sections: keep the page clean and let cards carry the visual weight. */
@media (max-width: 680px) {
  body,
  main,
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    background: #fff !important;
  }

  .doso-route::before,
  .doso-route::after,
  #tours.tour-section::before,
  #tours.tour-section::after,
  .monthly-tour-section::before,
  .monthly-tour-section::after,
  .section::before {
    display: none !important;
    opacity: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    filter: none !important;
  }

  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    overflow: hidden !important;
    padding-top: 46px !important;
    padding-bottom: 48px !important;
  }

  .doso-route + #tours.tour-section,
  #tours.tour-section + .monthly-tour-section {
    border-top: 1px solid rgba(17, 27, 51, .045);
  }

  .tour-grid {
    background: transparent !important;
    padding-top: 2px !important;
    padding-bottom: 14px !important;
  }

  .tour-section .tour-card,
  .tour-card,
  .tour-card.premium,
  .tour-section .tour-card.premium {
    background: #fff !important;
    border-color: rgba(17, 27, 51, .075) !important;
    box-shadow: 0 10px 24px rgba(17, 27, 51, .075) !important;
  }

  .tour-section .tour-card:hover,
  .tour-card:hover {
    box-shadow: 0 14px 30px rgba(17, 27, 51, .095) !important;
  }

  .tour-section .section-heading.split,
  .doso-route .section-heading {
    background: transparent !important;
    box-shadow: none !important;
  }

  .doso-route > .container::after,
  #tours > .container::after,
  .monthly-tour-section > .container::after {
    margin-top: 8px !important;
    box-shadow: none !important;
  }
}

@media (max-width: 480px) {
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    padding-top: 42px !important;
    padding-bottom: 44px !important;
  }
}

/* === FINAL Mobile Tour Sections Premium Cleanup
   Keep Doso card design, remove visible grey section/background bands,
   and use subtle hover-only Doso accent. === */
@media (max-width: 680px) {
  body,
  main,
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    background: #fff !important;
  }

  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    position: relative !important;
    overflow: hidden !important;
    padding-top: 42px !important;
    padding-bottom: 42px !important;
    isolation: isolate !important;
  }

  .doso-route::before,
  .doso-route::after,
  #tours.tour-section::before,
  #tours.tour-section::after,
  .monthly-tour-section::before,
  .monthly-tour-section::after,
  .section::before {
    display: none !important;
    content: none !important;
    opacity: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    filter: none !important;
  }

  .doso-route > .container,
  #tours.tour-section > .container,
  .monthly-tour-section > .container,
  .tour-section .container {
    background: transparent !important;
    box-shadow: none !important;
  }

  .doso-route + #tours.tour-section,
  #tours.tour-section + .monthly-tour-section {
    border-top: 1px solid rgba(17, 27, 51, .035) !important;
  }

  .tour-section .section-heading.split,
  .doso-route .section-heading {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    margin-bottom: 18px !important;
  }

  .tour-grid {
    background: transparent !important;
    box-shadow: none !important;
    padding-top: 0 !important;
    padding-bottom: 10px !important;
  }

  .tour-section .tour-card,
  .tour-card,
  .tour-section .tour-card.premium,
  .tour-card.premium {
    border-radius: var(--doso-card-radius) !important;
    border: 1px solid rgba(17, 27, 51, .075) !important;
    background: #fff !important;
    box-shadow: 0 6px 18px rgba(17, 27, 51, .055) !important;
    transition:
      transform .22s ease,
      border-color .22s ease,
      box-shadow .22s ease,
      filter .22s ease !important;
  }

  .tour-section .tour-image,
  .tour-image {
    border-radius: var(--doso-card-radius) 0 0 var(--doso-card-radius) !important;
  }

  .tour-section .tour-card:hover,
  .tour-card:hover {
    transform: translateY(-2px) !important;
    border-color: rgba(244, 81, 42, .48) !important;
    box-shadow: 0 10px 24px rgba(244, 81, 42, .10) !important;
  }

  .tour-section .tour-card:hover .tour-image,
  .tour-card:hover .tour-image {
    filter: saturate(1.04) contrast(1.02) !important;
  }

  .tour-section .tour-detail-btn,
  .tour-detail-btn {
    transition:
      background-color .22s ease,
      color .22s ease,
      box-shadow .22s ease,
      transform .22s ease !important;
  }

  .tour-section .tour-card:hover .tour-detail-btn,
  .tour-card:hover .tour-detail-btn {
    background: rgba(244, 81, 42, .10) !important;
    color: #c8192e !important;
    box-shadow: 0 8px 18px rgba(244, 81, 42, .10) !important;
  }

  .doso-route > .container::after,
  #tours > .container::after,
  .monthly-tour-section > .container::after {
    margin-top: 8px !important;
    box-shadow: none !important;
    filter: none !important;
  }
}

@media (max-width: 480px) {
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    padding-top: 38px !important;
    padding-bottom: 40px !important;
  }
}

@media (hover: none) and (max-width: 680px) {
  .tour-section .tour-card:hover,
  .tour-card:hover {
    transform: none !important;
    border-color: rgba(17, 27, 51, .075) !important;
    box-shadow: 0 6px 18px rgba(17, 27, 51, .055) !important;
  }
}

/* === FINAL Mobile: zero visible carousel background, premium clean cards === */
@media (max-width: 680px) {
  body,
  main,
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section,
  .tour-section,
  .tour-section .container,
  .doso-route > .container,
  #tours > .container,
  .monthly-tour-section > .container,
  .tour-grid {
    background: #fff !important;
    background-image: none !important;
    box-shadow: none !important;
    filter: none !important;
  }

  .doso-route::before,
  .doso-route::after,
  #tours.tour-section::before,
  #tours.tour-section::after,
  .monthly-tour-section::before,
  .monthly-tour-section::after,
  .tour-section::before,
  .tour-section::after,
  .section::before,
  .section::after,
  .tour-section .container::before,
  .tour-section .container::after,
  .doso-route > .container::before,
  .doso-route > .container::after,
  #tours > .container::before,
  #tours > .container::after,
  .monthly-tour-section > .container::before,
  .monthly-tour-section > .container::after {
    display: none !important;
    content: none !important;
    background: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
    filter: none !important;
    opacity: 0 !important;
  }

  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    border-top: 0 !important;
    padding-top: 38px !important;
    padding-bottom: 38px !important;
  }

  .tour-section .section-heading.split,
  .doso-route .section-heading {
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
  }

  .tour-grid {
    padding-top: 0 !important;
    padding-bottom: 6px !important;
    overflow-y: visible !important;
  }

  .tour-section .tour-card,
  .tour-card,
  .tour-section .tour-card.premium,
  .tour-card.premium {
    background: #fff !important;
    border: 1px solid rgba(17, 27, 51, .08) !important;
    box-shadow: 0 4px 12px rgba(17, 27, 51, .045) !important;
  }

  .tour-section .tour-card:hover,
  .tour-card:hover,
  .tour-section .tour-card.is-active,
  .tour-card.is-active {
    border-color: rgba(244, 81, 42, .55) !important;
    box-shadow: 0 8px 18px rgba(244, 81, 42, .08) !important;
    transform: translateY(-1px) !important;
  }
}

@media (max-width: 480px) {
  .doso-route,
  #tours.tour-section,
  .monthly-tour-section {
    padding-top: 34px !important;
    padding-bottom: 36px !important;
  }
}

/* === FINAL Mobile card interaction: clean default, Doso accent only on hover/tap === */
@media (max-width: 680px) {
  .tour-section .tour-card,
  .tour-card,
  .tour-section .tour-card.premium,
  .tour-card.premium {
    position: relative !important;
    border-color: rgba(17, 27, 51, .075) !important;
    box-shadow: 0 4px 12px rgba(17, 27, 51, .045) !important;
    overflow: hidden !important;
  }

  .tour-section .tour-card::after,
  .tour-card::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 3;
    border: 1.5px solid #f4512a;
    border-radius: inherit;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease, box-shadow .2s ease;
  }

  .tour-section .tour-card:hover,
  .tour-card:hover,
  .tour-section .tour-card:active,
  .tour-card:active,
  .tour-section .tour-card:focus-within,
  .tour-card:focus-within,
  .tour-section .tour-card.is-active,
  .tour-card.is-active {
    transform: translateY(-1px) !important;
    border-color: rgba(244, 81, 42, .18) !important;
    box-shadow: 0 8px 20px rgba(244, 81, 42, .08) !important;
  }

  .tour-section .tour-card:hover::after,
  .tour-card:hover::after,
  .tour-section .tour-card:active::after,
  .tour-card:active::after,
  .tour-section .tour-card:focus-within::after,
  .tour-card:focus-within::after,
  .tour-section .tour-card.is-active::after,
  .tour-card.is-active::after {
    opacity: 1;
    box-shadow: 0 0 0 1px rgba(244, 81, 42, .08) inset;
  }

  .tour-section .tour-card:hover .tour-detail-btn,
  .tour-card:hover .tour-detail-btn,
  .tour-section .tour-card:active .tour-detail-btn,
  .tour-card:active .tour-detail-btn,
  .tour-section .tour-card:focus-within .tour-detail-btn,
  .tour-card:focus-within .tour-detail-btn {
    background: rgba(244, 81, 42, .12) !important;
    color: #c8192e !important;
    box-shadow: 0 8px 18px rgba(244, 81, 42, .10) !important;
  }
}

@media (hover: hover) and (pointer: fine) {
  .tour-card {
    position: relative;
    overflow: hidden;
  }

  .tour-card::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 3;
    border: 1.5px solid #f4512a;
    border-radius: inherit;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease, box-shadow .2s ease;
  }

  .tour-card:hover::after,
  .tour-card:focus-within::after {
    opacity: 1;
    box-shadow: 0 0 0 1px rgba(244, 81, 42, .08) inset;
  }
}

/* === FINAL FIX: visible Doso hover/tap accent for tour cards ===
   The accent is applied directly to the card border/box-shadow so it works
   even when browser hover emulation or older pseudo-element rules are inconsistent. */
.tour-card,
.tour-section .tour-card {
  transition:
    transform .22s ease,
    border-color .22s ease,
    box-shadow .22s ease,
    filter .22s ease !important;
}

body .tour-section .tour-card:hover,
body .tour-card:hover,
body .tour-section .tour-card.card-hover,
body .tour-card.card-hover,
body .tour-section .tour-card:focus-within,
body .tour-card:focus-within,
body .tour-section .tour-card:active,
body .tour-card:active {
  border-color: #f4512a !important;
  box-shadow:
    inset 0 0 0 1px rgba(244, 81, 42, .72),
    0 12px 28px rgba(244, 81, 42, .13),
    0 8px 18px rgba(17, 27, 51, .065) !important;
  transform: translateY(-2px) !important;
}

body .tour-section .tour-card:hover::after,
body .tour-card:hover::after,
body .tour-section .tour-card.card-hover::after,
body .tour-card.card-hover::after,
body .tour-section .tour-card:focus-within::after,
body .tour-card:focus-within::after,
body .tour-section .tour-card:active::after,
body .tour-card:active::after {
  opacity: 1 !important;
  border-color: #f4512a !important;
  box-shadow: 0 0 0 1px rgba(244, 81, 42, .10) inset !important;
}

body .tour-section .tour-card:hover .tour-image,
body .tour-card:hover .tour-image,
body .tour-section .tour-card.card-hover .tour-image,
body .tour-card.card-hover .tour-image {
  filter: saturate(1.045) contrast(1.02) !important;
}

body .tour-section .tour-card:hover .tour-detail-btn,
body .tour-card:hover .tour-detail-btn,
body .tour-section .tour-card.card-hover .tour-detail-btn,
body .tour-card.card-hover .tour-detail-btn,
body .tour-section .tour-card:focus-within .tour-detail-btn,
body .tour-card:focus-within .tour-detail-btn,
body .tour-section .tour-card:active .tour-detail-btn,
body .tour-card:active .tour-detail-btn {
  background: rgba(244, 81, 42, .13) !important;
  color: #c8192e !important;
  box-shadow: 0 8px 18px rgba(244, 81, 42, .12) !important;
}

@media (max-width: 680px) {
  body .tour-section .tour-card:hover,
  body .tour-card:hover,
  body .tour-section .tour-card.card-hover,
  body .tour-card.card-hover,
  body .tour-section .tour-card:focus-within,
  body .tour-card:focus-within,
  body .tour-section .tour-card:active,
  body .tour-card:active {
    border-color: #f4512a !important;
    box-shadow:
      inset 0 0 0 1px rgba(244, 81, 42, .72),
      0 10px 22px rgba(244, 81, 42, .115),
      0 6px 14px rgba(17, 27, 51, .05) !important;
    transform: translateY(-1px) !important;
  }
}

/* === FINAL REAL HOVER FIX: card accent appears immediately on mouse over === */
.tour-card {
  cursor: pointer;
}

body .tour-card:hover,
body .tour-card.card-hover,
body .tour-card:focus-within,
body .tour-card:active,
body .tour-section .tour-card:hover,
body .tour-section .tour-card.card-hover,
body .tour-section .tour-card:focus-within,
body .tour-section .tour-card:active {
  border-color: #f4512a !important;
  box-shadow:
    inset 0 0 0 1px rgba(244, 81, 42, .78),
    0 12px 28px rgba(244, 81, 42, .12),
    0 6px 16px rgba(17, 27, 51, .055) !important;
  transform: translateY(-2px) !important;
}

body .tour-card:hover::after,
body .tour-card.card-hover::after,
body .tour-card:focus-within::after,
body .tour-card:active::after,
body .tour-section .tour-card:hover::after,
body .tour-section .tour-card.card-hover::after,
body .tour-section .tour-card:focus-within::after,
body .tour-section .tour-card:active::after {
  opacity: 1 !important;
  border-color: #f4512a !important;
}

body .tour-card:hover .tour-image,
body .tour-card.card-hover .tour-image,
body .tour-section .tour-card:hover .tour-image,
body .tour-section .tour-card.card-hover .tour-image {
  filter: saturate(1.045) contrast(1.02) !important;
}

body .tour-card:hover .tour-detail-btn,
body .tour-card.card-hover .tour-detail-btn,
body .tour-card:focus-within .tour-detail-btn,
body .tour-card:active .tour-detail-btn,
body .tour-section .tour-card:hover .tour-detail-btn,
body .tour-section .tour-card.card-hover .tour-detail-btn,
body .tour-section .tour-card:focus-within .tour-detail-btn,
body .tour-section .tour-card:active .tour-detail-btn {
  background: rgba(244, 81, 42, .13) !important;
  color: #c8192e !important;
  box-shadow: 0 8px 18px rgba(244, 81, 42, .12) !important;
}

/* === FINAL FIX: Premium visible card border + overlay accent border ===
   1) Default card border is slightly clearer on white mobile sections.
   2) Hover/tap accent uses an overlay pseudo-element so the top line will not disappear. */
.tour-card,
.tour-section .tour-card,
.tour-card.premium,
.tour-section .tour-card.premium {
  position: relative !important;
  border: 1px solid rgba(17, 27, 51, .16) !important;
  box-shadow: 0 6px 16px rgba(17, 27, 51, .055) !important;
  overflow: hidden !important;
}

.tour-card::after,
.tour-section .tour-card::after,
.tour-card.premium::after,
.tour-section .tour-card.premium::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 30 !important;
  box-sizing: border-box !important;
  border: 1.5px solid transparent !important;
  border-radius: inherit !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .18s ease, border-color .18s ease, box-shadow .18s ease !important;
}

.tour-card:hover,
.tour-section .tour-card:hover,
.tour-card.card-hover,
.tour-section .tour-card.card-hover,
.tour-card:focus-within,
.tour-section .tour-card:focus-within,
.tour-card:active,
.tour-section .tour-card:active {
  border-color: rgba(17, 27, 51, .16) !important;
  box-shadow: 0 10px 24px rgba(244, 81, 42, .10), 0 6px 16px rgba(17, 27, 51, .055) !important;
}

.tour-card:hover::after,
.tour-section .tour-card:hover::after,
.tour-card.card-hover::after,
.tour-section .tour-card.card-hover::after,
.tour-card:focus-within::after,
.tour-section .tour-card:focus-within::after,
.tour-card:active::after,
.tour-section .tour-card:active::after {
  opacity: 1 !important;
  border-color: #f4512a !important;
  box-shadow: 0 0 0 1px rgba(244, 81, 42, .08) inset !important;
}

@media (hover: hover) and (pointer: fine) {
  .tour-card:hover,
  .tour-section .tour-card:hover,
  .tour-card.card-hover,
  .tour-section .tour-card.card-hover {
    transform: translateY(-2px) !important;
  }
}

@media (max-width: 680px) {
  .tour-grid {
    overflow-y: visible !important;
    padding-top: 4px !important;
  }

  .tour-card,
  .tour-section .tour-card,
  .tour-card.premium,
  .tour-section .tour-card.premium {
    border-color: rgba(17, 27, 51, .16) !important;
    box-shadow: 0 5px 14px rgba(17, 27, 51, .052) !important;
  }

  .tour-card:hover,
  .tour-section .tour-card:hover,
  .tour-card.card-hover,
  .tour-section .tour-card.card-hover,
  .tour-card:focus-within,
  .tour-section .tour-card:focus-within,
  .tour-card:active,
  .tour-section .tour-card:active {
    transform: none !important;
    border-color: rgba(17, 27, 51, .16) !important;
    box-shadow: 0 8px 20px rgba(244, 81, 42, .085), 0 5px 14px rgba(17, 27, 51, .052) !important;
  }
}

/* === FINAL Doso equal corner/border system ===
   Align all main cards/tiles with the live DosoTravel visual language.
   Keep pill buttons circular, but normalize content cards to the same 8px radius. */
:root {
  --doso-card-radius: 8px;
  --doso-panel-radius: 24px;
  --doso-control-radius: 8px;
  --doso-card-border: rgba(17, 27, 51, .16);
  --doso-card-border-soft: rgba(17, 27, 51, .12);
}

/* Main content cards and visual tiles */
.tour-card,
.tour-section .tour-card,
.tour-card.premium,
.tour-section .tour-card.premium,
.country-card,
.past-work-card,
.article-card,
.places-section .article-card,
.all-country-card,
.promo-card,
.member-card {
  border-radius: var(--doso-card-radius) !important;
}

/* Images inside cards follow the same 8px system */
.tour-image,
.tour-section .tour-image,
.country-thumb,
.past-work-thumb,
.article-thumb,
.places-section .article-thumb,
.promo-thumb,
.member-thumb {
  border-radius: var(--doso-card-radius) !important;
}

/* Horizontal mobile tour cards: image uses only the left card corners */
@media (max-width: 680px) {
  .tour-card,
  .tour-section .tour-card,
  .tour-card.premium,
  .tour-section .tour-card.premium {
    border-radius: var(--doso-card-radius) !important;
    border: 1px solid var(--doso-card-border) !important;
  }

  .tour-image,
  .tour-section .tour-image {
    border-radius: var(--doso-card-radius) 0 0 var(--doso-card-radius) !important;
  }

  .popular-countries .country-card {
    border-radius: 0 !important;
  }

  .popular-countries .country-thumb {
    border-radius: var(--doso-card-radius) !important;
  }

  .shortcut-card {
    border-radius: var(--doso-card-radius) !important;
  }
}

/* Desktop cards and destination tiles */
@media (min-width: 681px) {
  .tour-card,
  .tour-section .tour-card,
  .tour-card.premium,
  .tour-section .tour-card.premium,
  .country-card,
  .past-work-card,
  .article-card,
  .places-section .article-card {
    border-radius: var(--doso-card-radius) !important;
    border-color: var(--doso-card-border-soft) !important;
  }

  .tour-image,
  .tour-section .tour-image,
  .past-work-thumb,
  .article-thumb,
  .places-section .article-thumb {
    border-radius: var(--doso-card-radius) var(--doso-card-radius) 0 0 !important;
  }
}

/* Search V2 is a large panel, so keep it premium but reduce over-rounded corners. */
.search-panel.search-panel-full.priority-search-panel {
  border-radius: var(--doso-panel-radius) !important;
}

.priority-search-panel .field input,
.priority-search-panel .field select,
.search-panel-full .field input,
.search-panel-full .field select {
  border-radius: var(--doso-control-radius) !important;
}

/* Keep the overlay hover/tap accent above the card so every edge remains visible. */
.tour-card::after,
.tour-section .tour-card::after,
.tour-card.premium::after,
.tour-section .tour-card.premium::after {
  border-radius: inherit !important;
}

/* === FINAL RESTORE: Mobile red section slanted divider + shortcut transition ===
   Keep the original Doso mobile slant under the country area while preserving
   the latest equal-radius card/border system. This block is intentionally last
   so cleanup rules that hide .section::after do not remove the slant. */
@media (max-width: 900px) {
  .popular-countries {
    position: relative !important;
    overflow: hidden !important;
    padding-bottom: 72px !important;
  }

  .popular-countries::after {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: -1px !important;
    z-index: 1 !important;
    height: 80px !important;
    background: #f4f6f8 !important;
    background-image: none !important;
    clip-path: polygon(0 72%, 100% 34%, 100% 100%, 0 100%) !important;
    box-shadow: none !important;
    filter: none !important;
    opacity: 1 !important;
    pointer-events: none !important;
  }

  .popular-countries > .container {
    position: relative !important;
    z-index: 2 !important;
  }

  .mobile-country-action {
    position: relative !important;
    z-index: 5 !important;
    margin-top: 22px !important;
    margin-bottom: -42px !important;
    text-align: center !important;
  }

  .mobile-country-action a {
    box-shadow:
      0 8px 15px rgba(80, 0, 10, .16),
      0 2px 4px rgba(255, 255, 255, .26) inset,
      0 0 0 1px rgba(255, 255, 255, .20) inset !important;
  }

  .mobile-shortcut-menu {
    position: relative !important;
    z-index: 4 !important;
    margin-top: -10px !important;
    padding-top: 4px !important;
    background: #f4f6f8 !important;
  }
}

@media (max-width: 480px) {
  .popular-countries {
    padding-bottom: 70px !important;
  }

  .popular-countries::after {
    height: 78px !important;
    clip-path: polygon(0 74%, 100% 36%, 100% 100%, 0 100%) !important;
  }

  .mobile-country-action {
    margin-bottom: -40px !important;
  }

  .mobile-shortcut-menu {
    margin-top: -10px !important;
    padding-top: 4px !important;
  }
}


/* === FINAL CLEAN CODE: content images live in HTML/data, not CSS background-image ===
   CSS below only controls presentation/cropping for <img> media. */
.hero-slide {
  background-image: none !important;
}
.hero-slide-media {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: 0;
}
.hero-slide-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.country-card .country-thumb {
  display: block;
  overflow: hidden;
}
.country-card .country-thumb img,
.tour-image img,
.drawer-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.country-grid .country-card .country-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: inherit;
  z-index: 0;
}
.country-grid .country-card::before {
  z-index: 1;
}
.country-grid .country-card strong,
.country-grid .country-card > span:not(.country-thumb) {
  position: relative;
  z-index: 2;
}
.tour-image {
  overflow: hidden;
  background: var(--navy);
}
.tour-image img {
  position: absolute;
  inset: 0;
  z-index: 0;
  transition: transform .28s ease, filter .28s ease;
}
.tour-image span {
  position: relative;
  z-index: 2;
}
.tour-card:hover .tour-image img,
.tour-card.card-hover .tour-image img,
.past-work-card:hover .past-work-thumb img {
  transform: scale(1.035);
  filter: saturate(1.08) contrast(1.03);
}
.drawer-thumb {
  overflow: hidden;
  background: #eef2f7;
}
@media (max-width: 900px) {
  .hero.hero-slider-section .hero-slide {
    background-image: none !important;
  }
  .popular-countries .country-thumb {
    position: relative !important;
    inset: auto !important;
    width: 104px !important;
    height: 104px !important;
    border: 5px solid rgba(255,255,255,.94) !important;
    border-radius: var(--doso-card-radius) !important;
    background: transparent !important;
  }
  .popular-countries .country-thumb img {
    border-radius: inherit;
  }
  .popular-countries .country-card strong {
    position: relative;
    z-index: 2;
  }
}
@media (max-width: 480px) {
  .popular-countries .country-thumb {
    width: 96px !important;
    height: 96px !important;
  }
}

/* === FINAL FIX: hero slider image timing after moving banner images into HTML ===
   Each slide needs its own animation delay. Without this, all slides can become
   transparent at the same time and leave a blank hero area. */
.hero.hero-slider-section .hero-slide {
  opacity: 0;
  animation: heroSlide 18s infinite !important;
}
.hero.hero-slider-section .hero-slide:nth-child(1) {
  animation-delay: 0s !important;
}
.hero.hero-slider-section .hero-slide:nth-child(2) {
  animation-delay: 6s !important;
}
.hero.hero-slider-section .hero-slide:nth-child(3) {
  animation-delay: 12s !important;
}
.hero.hero-slider-section .hero-slide-media,
.hero.hero-slider-section .hero-slide-img {
  display: block !important;
  width: 100%;
  height: 100%;
}
.hero.hero-slider-section .hero-slide-img {
  object-fit: cover;
  object-position: center;
}
@media (max-width: 900px) {
  .hero.hero-slider-section .hero-slide:nth-child(1) {
    animation-delay: 0s !important;
  }
  .hero.hero-slider-section .hero-slide:nth-child(2) {
    animation-delay: 6s !important;
  }
  .hero.hero-slider-section .hero-slide:nth-child(3) {
    animation-delay: 12s !important;
  }
}
