/* ==========================================================================
   UV Travel — bilingual tour module (Airbnb/Klook style)
   Scoped under .uvt so it can be dropped into an existing site safely.
   ========================================================================== */
.uvt {
  /* brand palette — from 趣环游 / MoreAhead Travel logo */
  --orange: #fc9c18;
  --accent: #f5841f;        /* primary action / price */
  --accent-dark: #e0710c;
  --accent-soft: #fff4e3;
  --blue: #189cf0;
  --blue-soft: #e8f5fe;
  --pink: #f04878;
  --pink-soft: #fdeaf0;
  --teal: #1fb6c4;
  --teal-soft: #e4f7f9;
  --ink: #34343d;
  --ink-2: #565660;
  --muted: #8a8a99;
  --line: #ececf1;
  --bg: #ffffff;
  --bg-2: #f7f8fa;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 1px 2px rgba(20,20,40,.04), 0 6px 20px rgba(20,20,40,.06);
  --shadow-hover: 0 8px 30px rgba(20,20,40,.13);
  --maxw: 1200px;
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC",
    "Hiragino Sans GB", "Microsoft YaHei", Roboto, Helvetica, Arial, sans-serif;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  font-size: 15px;
}
.uvt *, .uvt *::before, .uvt *::after { box-sizing: border-box; }
.uvt img { max-width: 100%; display: block; }
.uvt a { color: inherit; text-decoration: none; }
.uvt .wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }

/* lang visibility */
.uvt[data-lang="zh"] .lang-en { display: none; }
.uvt[data-lang="en"] .lang-zh { display: none; }

/* ---------- top bar ---------- */
.uvt-top {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.92); backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--line);
}
.uvt-top::after { content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 3px;
  background: linear-gradient(90deg, var(--pink) 0%, var(--orange) 33%, var(--teal) 66%, var(--blue) 100%); }
.uvt-top .wrap { display: flex; align-items: center; gap: 18px; height: 64px; }
.uvt-brand { display: flex; align-items: center; gap: 9px; }
.uvt-brand .brand-logo { height: 46px; width: auto; display: block; }
.uvt-brand .logo { width: 38px; height: 38px; object-fit: contain; }
.uvt-brand .bname { display: flex; flex-direction: column; line-height: 1.05; }
.uvt-brand .bname b { font-weight: 800; font-size: 19px; letter-spacing: 1px; color: var(--ink); }
.uvt-brand .bname small { font-size: 10px; font-weight: 600; letter-spacing: .6px; color: var(--muted); text-transform: uppercase; }
.uvt-top .spacer { flex: 1; }
.uvt-langtoggle { display: inline-flex; background: var(--bg-2); border-radius: 999px; padding: 3px; border: 1px solid var(--line); }
.uvt-langtoggle button { border: 0; background: transparent; padding: 6px 14px; border-radius: 999px;
  font-size: 13px; font-weight: 600; color: var(--muted); cursor: pointer; transition: .15s; }
.uvt-langtoggle button.on { background: #fff; color: var(--ink); box-shadow: var(--shadow); }

/* ---------- top nav ---------- */
.uvt-nav { display: flex; align-items: center; gap: 2px; margin-left: 20px; }
.uvt-nav > a, .uvt-nav summary { font-size: 14px; font-weight: 600; color: var(--ink-2);
  padding: 8px 13px; cursor: pointer; border-radius: 9px; list-style: none; white-space: nowrap; }
.uvt-nav > a:hover, .uvt-nav summary:hover { background: var(--bg-2); color: var(--ink); }
.uvt-nav-drop { position: relative; }
.uvt-nav-drop summary::-webkit-details-marker, .uvt-nav-drop summary::marker { display: none; content: ""; }
.uvt-nav-drop summary::after { content: " ⌄"; color: var(--muted); }
.uvt-nav-menu { position: absolute; top: calc(100% + 6px); left: 0; background: #fff;
  border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow-hover);
  padding: 8px; min-width: 220px; display: grid; grid-template-columns: 1fr 1fr; gap: 2px; z-index: 60; }
.uvt-nav-menu a { font-size: 13px; color: var(--ink-2); padding: 8px 11px; border-radius: 8px; white-space: nowrap; }
.uvt-nav-menu a:hover { background: var(--accent-soft); color: var(--accent-dark); }
/* hierarchical destination menu (大洲→国家→地区) */
.uvt-nav-menu.geo-nav { display: block; grid-template-columns: none; min-width: 240px;
  max-height: 72vh; overflow-y: auto; }
.geo-nav .gm-node { border-radius: 8px; }
.geo-nav .gm-node > summary { display: flex; align-items: center; font-size: 13px; font-weight: 600;
  color: var(--ink); padding: 8px 11px; border-radius: 8px; cursor: pointer; list-style: none; white-space: nowrap; }
.geo-nav .gm-node > summary::-webkit-details-marker, .geo-nav .gm-node > summary::marker { display: none; }
.geo-nav .gm-node > summary::after { content: "›"; margin-left: auto; padding-left: 12px; color: var(--muted);
  transition: transform .15s ease; }
.geo-nav details[open] > summary::after { transform: rotate(90deg); }
.geo-nav .gm-node > summary:hover { background: var(--bg-2); }
.geo-nav .gm-children { padding-left: 11px; margin-left: 4px; border-left: 1px solid var(--line); }
.geo-nav .gm-leaf, .geo-nav .gm-all { display: block; font-size: 13px; color: var(--ink-2);
  padding: 7px 11px; border-radius: 8px; white-space: nowrap; }
.geo-nav .gm-all { color: var(--accent-dark); font-weight: 600; }
.geo-nav .gm-leaf:hover, .geo-nav .gm-all:hover { background: var(--accent-soft); color: var(--accent-dark); }

@media (max-width: 820px) {
  .uvt-nav > a { display: none; }
  .uvt-nav { margin-left: 8px; }
  /* 全宽下拉面板：固定在页头下方、左右留边，避免菜单被屏幕左缘裁切 */
  .uvt-nav-menu, .uvt-nav-menu.geo-nav {
    position: fixed; top: 84px; left: 10px; right: 10px;
    width: auto; min-width: 0; max-width: none;
    grid-template-columns: 1fr; max-height: calc(100vh - 100px); overflow-y: auto; }
}

/* ---------- footer ---------- */
.foot-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 30px; text-align: left; padding-bottom: 22px; }
.foot-brand .brand-logo { height: 54px; width: auto; }
.foot-wechat{margin-top:18px;display:flex;align-items:center;gap:12px}
.foot-wechat img{width:96px;height:96px;border-radius:8px;border:1px solid var(--line);background:#fff;padding:4px;flex:none}
.foot-wechat .fw-txt{display:flex;flex-direction:column;gap:4px}
.foot-wechat .fw-t{font-size:12.5px;color:var(--muted);line-height:1.4}
.foot-wechat .fw-id{font-size:13px;color:var(--ink);font-weight:700}
.foot-col b { display: block; color: var(--ink); font-size: 14px; margin-bottom: 10px; }
.foot-col div, .foot-col a { display: block; font-size: 13px; color: var(--muted); margin-bottom: 6px; }
.foot-col a:hover { color: var(--accent); }
.foot-bottom { border-top: 1px solid var(--line); padding-top: 18px; font-size: 12.5px; color: var(--muted); text-align: center; }
@media (max-width: 700px) { .foot-grid { grid-template-columns: 1fr; gap: 18px; } }

/* ---------- homepage ---------- */
.home-hero { position: relative; border-radius: var(--radius); overflow: hidden; margin: 18px 0 34px; min-height: 360px;
  display: flex; align-items: center; }
.home-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.home-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.55), rgba(0,0,0,.15)); }
.home-hero .hero-in { position: relative; z-index: 2; color: #fff; padding: 48px; max-width: 640px; }
.home-hero h1 { color: #fff; font-size: 40px; line-height: 1.2; margin: 0 0 12px; }
.home-hero p { color: rgba(255,255,255,.92); font-size: 17px; margin: 0 0 22px; }
.home-hero .hero-cta { display: inline-block; background: var(--accent); color: #fff; font-weight: 700;
  padding: 13px 28px; border-radius: var(--radius-sm); font-size: 16px; }
.home-sec { margin: 40px 0; }
.home-sec h2 { font-size: 26px; margin: 0 0 6px; }
.sec-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 0 0 18px;
  padding: 11px 18px; border-radius: 12px; background: #f6f7f9; border-left: 6px solid var(--accent); }
.sec-head h2 { margin: 0; font-size: 23px; display: flex; align-items: center; gap: 10px; }
.sec-n { font-size: 13px; font-weight: 700; color: #fff; background: var(--accent); border-radius: 999px; padding: 2px 11px; line-height: 1.6; }
.home-sec .more { font-weight: 700; font-size: 14px; white-space: nowrap; color: var(--accent); }
/* quick-jump destination chips */
.cat-jump { display: flex; flex-wrap: wrap; gap: 9px; margin: 18px 0 4px; }
.cat-chip { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px; border-radius: 999px;
  font-size: 14px; font-weight: 700; color: var(--c); border: 1.5px solid var(--c); background: #fff;
  text-decoration: none; transition: background .14s, color .14s; }
.cat-chip b { font-size: 11.5px; font-weight: 700; background: var(--c); color: #fff; border-radius: 999px; padding: 0 7px; line-height: 1.7; }
.cat-chip:hover { background: var(--c); color: #fff; }
.cat-chip:hover b { background: rgba(255,255,255,.30); color: #fff; }
html { scroll-behavior: smooth; }
.cat-sec { scroll-margin-top: 84px; }
.home-sec .sub { color: var(--muted); margin: 0 0 20px; font-size: 15px; }
.region-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px; }
.region-card { position: relative; aspect-ratio: 4/3; border-radius: var(--radius); overflow: hidden; display: block; }
.region-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.region-card:hover img { transform: scale(1.06); }
.region-card .rc-in { position: absolute; inset: 0; background: linear-gradient(transparent 38%, rgba(0,0,0,.72));
  display: flex; flex-direction: column; justify-content: flex-end; padding: 16px; }
.region-card .rc-name { color: #fff; font-size: 19px; font-weight: 800; letter-spacing: -.2px; }
.region-card .rc-count { color: rgba(255,255,255,.85); font-size: 12.5px; font-weight: 600; }
.home-about { background: var(--bg-2); border-radius: var(--radius); padding: 34px; margin: 40px 0;
  display: grid; grid-template-columns: 1fr; gap: 12px; }
.home-about h2 { font-size: 24px; margin: 0; }
.home-about p { color: var(--ink-2); font-size: 15px; line-height: 1.8; margin: 0; max-width: 760px; }
.home-about .stats { display: flex; flex-wrap: wrap; gap: 30px; margin-top: 10px; }
.home-about .stat b { display: block; font-size: 26px; color: var(--accent); font-weight: 800; }
.home-about .stat span { font-size: 13px; color: var(--muted); }
.home-about .more { color: var(--accent); font-weight: 700; font-size: 14px; }
@media (max-width: 560px) { .home-hero h1 { font-size: 30px; } .home-hero .hero-in { padding: 28px 22px; } }

/* ---------- about page ---------- */
.ab-hero { position: relative; min-height: 460px; display: flex; align-items: center; justify-content: center; text-align: center; overflow: hidden; }
.ab-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ab-hero::after { content: ""; position: absolute; inset: 0; background: rgba(8,14,30,.45); }
.ab-hero-in { position: relative; z-index: 2; color: #fff; padding: 44px 20px; max-width: 920px; }
.ab-hero-in h1 { color: #fff; font-family: "Ma Shan Zheng","STKaiti","Kaiti SC","KaiTi","楷体",serif; font-size: 80px; font-weight: 400; letter-spacing: 8px; margin: 0 0 22px; text-shadow: 0 2px 18px rgba(0,0,0,.45); }
.ab-dest, .ab-svc { font-size: 17px; line-height: 1.9; margin: 0 0 6px; color: rgba(255,255,255,.95); text-shadow: 0 1px 8px rgba(0,0,0,.45); }
.ab-svc { color: rgba(255,255,255,.82); font-size: 15px; }
.ab-cta-down { display: inline-block; margin-top: 20px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.4); color: #fff; font-weight: 700; font-size: 15px; }
.ab-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; background: #4a5a66; padding: 32px 20px; text-align: center; }
.abs-item b { display: block; font-size: 38px; font-weight: 800; color: #fff; line-height: 1.1; }
.abs-item span { font-size: 14px; color: rgba(255,255,255,.85); }
.ab-sec { max-width: 900px; margin: 44px auto; }
.ab-sec h2 { font-size: 26px; margin: 0 0 16px; position: relative; padding-left: 14px; }
.ab-sec h2::before { content: ""; position: absolute; left: 0; top: 5px; bottom: 5px; width: 5px; border-radius: 3px; background: var(--accent); }
.ab-sec p { font-size: 15.5px; line-height: 1.95; color: var(--ink-2); margin: 0 0 14px; }
.ab-why { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: 18px; }
.ab-why-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 24px 20px; background: var(--bg); }
.ab-why-card .abw-ic { font-size: 30px; }
.ab-why-card h3 { font-size: 17px; color: var(--accent-dark); margin: 12px 0 8px; }
.ab-why-card p { font-size: 14px; line-height: 1.8; color: var(--ink-2); margin: 0; }
.ab-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 16px; }
.ab-gallery .abg-item { aspect-ratio: 3/2; border-radius: var(--radius); overflow: hidden; }
.ab-gallery img { width: 100%; height: 100%; object-fit: cover; }
.ab-contact { max-width: 1040px; margin: 56px auto; background: linear-gradient(135deg,#3f4f5c 0%,#2b3742 100%); color: #fff; border-radius: var(--radius); padding: 48px 52px; display: flex; flex-wrap: wrap; gap: 44px; align-items: center; justify-content: space-between; }
.abc-info { flex: 1 1 380px; }
.abc-info h2 { font-size: 32px; margin: 0 0 10px; color: #fff; letter-spacing: 1px; }
.abc-sub { font-size: 15px; color: rgba(255,255,255,.78); line-height: 1.7; margin: 0 0 22px; max-width: 460px; }
.abc-line { font-size: 18px; color: rgba(255,255,255,.94); line-height: 2.1; }
.abc-cta { display: flex; gap: 12px; margin-top: 26px; flex-wrap: wrap; }
.ab-btn { display: inline-block; text-align: center; padding: 13px 30px; border-radius: 10px; font-weight: 700; font-size: 15px; }
.ab-btn.primary { background: var(--accent); color: #fff; }
.ab-btn.ghost { border: 1px solid rgba(255,255,255,.55); color: #fff; }
.abc-qr { flex: 0 0 auto; background: #fff; border-radius: 16px; padding: 16px 16px 12px; text-align: center; box-shadow: 0 10px 30px rgba(0,0,0,.25); }
.abc-qr img { display: block; width: 200px; height: 200px; object-fit: contain; }
.abc-qr-cap { display: block; margin-top: 10px; font-size: 13px; color: #444; font-weight: 700; line-height: 1.5; }
@media (max-width: 700px) {
  .ab-hero-in h1 { font-size: 46px; letter-spacing: 3px; }
  .ab-stats { grid-template-columns: repeat(2,1fr); gap: 20px 8px; }
  .abs-item b { font-size: 30px; }
  .ab-contact { flex-direction: column; align-items: center; text-align: center; padding: 36px 24px; gap: 28px; }
  .abc-info h2 { font-size: 26px; }
  .abc-sub { margin-left: auto; margin-right: auto; }
  .abc-cta { justify-content: center; }
  .abc-qr img { width: 180px; height: 180px; }
}

/* ---------- hero ---------- */
.uvt-hero { padding: 40px 0 22px; }
.uvt-hero h1 { font-size: 34px; line-height: 1.2; margin: 0 0 8px; letter-spacing: -.6px; font-weight: 800; }
.uvt-hero p { margin: 0; color: var(--ink-2); font-size: 16px; }
.uvt-hero .crumbs { font-size: 13px; color: var(--muted); margin-bottom: 14px; }

/* ---------- controls ---------- */
.uvt-controls { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin: 6px 0 26px; }
.uvt-search { flex: 1; min-width: 220px; position: relative; }
.uvt-search input { width: 100%; height: 44px; border: 1px solid var(--line); border-radius: 999px;
  padding: 0 18px 0 42px; font-size: 14px; outline: none; background: var(--bg); transition: .15s; }
.uvt-search input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.uvt-search svg { position: absolute; left: 15px; top: 13px; color: var(--muted); }
.uvt-chip { height: 44px; padding: 0 16px; border: 1px solid var(--line); border-radius: 999px; background: var(--bg);
  font-size: 14px; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: .15s; }
.uvt-chip:hover { border-color: #d7d7df; }
.uvt-chip.on { background: var(--ink); color: #fff; border-color: var(--ink); }
.uvt-select { height: 44px; padding: 0 14px; border: 1px solid var(--line); border-radius: 999px; background: var(--bg);
  font-size: 14px; font-weight: 600; color: var(--ink-2); cursor: pointer; }
.uvt-count { color: var(--muted); font-size: 14px; margin-bottom: 16px; }

/* ---------- grid + cards ---------- */
.uvt-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: 26px 22px; }
.uvt-card { background: var(--bg); border-radius: var(--radius); overflow: hidden; cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease; display: flex; flex-direction: column;
  /* skip rendering off-screen cards (1100+ in the grid); ~360px placeholder keeps the scrollbar stable */
  content-visibility: auto; contain-intrinsic-size: auto 360px; }
.uvt-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.uvt-card .thumb { position: relative; aspect-ratio: 4/3; background: var(--bg-2); overflow: hidden; border-radius: var(--radius); }
.uvt-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.uvt-card:hover .thumb img { transform: scale(1.05); }
.uvt-badge { position: absolute; top: 12px; left: 12px; background: rgba(0,0,0,.62); color: #fff;
  font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: 999px; backdrop-filter: blur(4px); }
.uvt-tag { position: absolute; top: 12px; right: 12px; background: var(--accent); color: #fff;
  font-size: 11px; font-weight: 700; padding: 4px 9px; border-radius: 999px; }
.uvt-card .body { padding: 12px 4px 4px; display: flex; flex-direction: column; gap: 4px; }
.uvt-card .route { font-size: 12px; color: var(--accent-dark); font-weight: 700; }
.uvt-card .title { font-size: 15px; font-weight: 700; line-height: 1.4; letter-spacing: -.2px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 42px; }
.uvt-card .sub { font-size: 13px; color: var(--ink-2); line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden; min-height: 38px; }
.uvt-card .price { margin-top: 6px; display: flex; align-items: baseline; gap: 4px; }
.uvt-card .price .from { font-size: 12px; color: var(--muted); }
.uvt-card .price .num { font-size: 20px; font-weight: 800; color: var(--accent); letter-spacing: -.5px; }
.uvt-card .price .per { font-size: 12px; color: var(--muted); }
.uvt-empty { text-align: center; padding: 80px 0; color: var(--muted); }

/* card small-group / deal chips (top-right, opposite duration badge) */
.uvt-card .cchips { position: absolute; top: 12px; right: 12px; display: flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.cchip { font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 6px; color: #fff; box-shadow: 0 1px 4px rgba(0,0,0,.2); }
.cchip.sg { background: var(--teal, #2bb6a8); }
.cchip.promo { background: var(--accent, #FC9C18); }

/* ===== faceted filter (listing pages) ===== */
.uvt-listpage .uvt-layout { display: flex; gap: 28px; align-items: flex-start; }
.uvt-facets { width: 232px; flex: 0 0 232px; position: sticky; top: 78px; max-height: calc(100vh - 96px); overflow-y: auto; padding-right: 4px; }
.uvt-results { flex: 1; min-width: 0; }
.facet-bar { display: flex; align-items: center; gap: 8px; margin: 2px 0 4px; }
.facet-bar b { font-size: 16px; flex: 1; }
.facet-clear { border: 0; background: none; color: var(--accent); font-size: 13px; cursor: pointer; padding: 2px 4px; }
.facet-x { display: none; }
.facet-group { border-top: 1px solid var(--line); }
.facet-h { width: 100%; display: flex; justify-content: space-between; align-items: center; background: none;
  border: 0; padding: 11px 2px; font-size: 14px; font-weight: 700; cursor: pointer; color: var(--ink); }
.facet-h .fchev { color: var(--muted); transition: transform .2s ease; font-size: 12px; }
.facet-group.open .facet-h .fchev { transform: rotate(180deg); }
.facet-opts { display: none; padding: 0 2px 10px; max-height: 230px; overflow-y: auto; }
.facet-group.open .facet-opts { display: block; }
.facet-opt { display: flex; align-items: center; gap: 8px; padding: 5px 0; font-size: 13.5px; cursor: pointer; color: var(--ink-2); }
.facet-opt:hover { color: var(--ink); }
.facet-opt input { width: 15px; height: 15px; accent-color: var(--accent); flex: 0 0 auto; cursor: pointer; }
.facet-opt .fo-label { flex: 1; }
.facet-opt em { color: var(--muted); font-size: 12px; font-style: normal; }
.uvt-topbar { display: flex; gap: 10px; align-items: center; margin: 2px 0 12px; }
.uvt-filterbtn { display: none; }
.uvt-activebar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.uvt-activebar:empty { display: none; }
.active-chip { border: 1px solid var(--accent); color: var(--accent-dark); background: var(--accent-soft);
  border-radius: 999px; padding: 4px 11px; font-size: 12.5px; cursor: pointer; }
.active-chip .ac-x { margin-left: 5px; font-weight: 800; }
/* hierarchical geo tree */
.facet-opts.geo-tree { max-height: 400px; }
.geo-node { display: flex; align-items: center; gap: 2px; }
.geo-node .facet-opt { flex: 1; padding: 4px 0; }
.geo-toggle { width: 18px; flex: 0 0 18px; border: 0; background: none; cursor: pointer; color: var(--muted);
  font-size: 10px; line-height: 1; padding: 0; transition: transform .15s ease; }
.geo-toggle.open { transform: rotate(90deg); }
.geo-spacer { width: 18px; flex: 0 0 18px; }
.geo-children { padding-left: 15px; }
.geo-children[hidden] { display: none; }
.facet-grouphead { flex: 1; display: flex; align-items: center; gap: 8px; padding: 5px 0;
  font-size: 13.5px; font-weight: 600; color: var(--ink); cursor: pointer; }
.facet-grouphead .fo-label { flex: 1; }
.facet-grouphead em { color: var(--muted); font-size: 12px; font-style: normal; }
.city-sub { font-size: 12.5px; font-weight: 800; color: var(--accent-dark); letter-spacing: .3px;
  margin: 6px 0 5px; padding: 3px 0 3px 9px; border-left: 3px solid var(--accent); }
.city-sub.city-all { color: var(--ink); border-left-color: var(--ink-2);
  border-top: 1px solid var(--line); padding-top: 10px; margin-top: 12px; }

.uvt-facet-backdrop { display: none; }
@media (max-width: 860px) {
  .uvt-listpage .uvt-layout { display: block; }
  .uvt-facets { position: fixed; top: 0; left: 0; bottom: 0; width: 284px; max-height: 100vh; z-index: 320;
    background: #fff; transform: translateX(-102%); transition: transform .25s ease; box-shadow: 2px 0 24px rgba(0,0,0,.18);
    padding: 16px 16px 30px; }
  .uvt-facets.on { transform: translateX(0); }
  .facet-x { display: block; border: 0; background: none; font-size: 26px; line-height: 1; cursor: pointer; color: var(--muted); }
  .uvt-filterbtn { display: inline-flex; align-items: center; gap: 6px; height: 44px; padding: 0 15px;
    border: 1px solid var(--line); border-radius: 999px; background: var(--bg); cursor: pointer; font-size: 14px; font-weight: 600; }
  .uvt-facet-backdrop.on { display: block; position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 310; }
}

/* ---------- detail page ---------- */
.uvt-detail { padding: 26px 0 80px; }
.uvt-back { display: inline-flex; align-items: center; gap: 6px; color: var(--ink-2); font-weight: 600; font-size: 14px; margin-bottom: 16px; }
.uvt-gallery { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 8px;
  border-radius: var(--radius); overflow: hidden; max-height: 460px; }
.uvt-gallery .g0 { grid-row: 1 / 3; grid-column: 1; }
.uvt-gallery figure { margin: 0; background: var(--bg-2); overflow: hidden; }
.uvt-gallery img { width: 100%; height: 100%; object-fit: cover; min-height: 150px; cursor: zoom-in; transition: .25s; }
.uvt-gallery img:hover { opacity: .92; }
.uvt-gallery.single { grid-template-columns: 1fr; grid-template-rows: 1fr; }
.uvt-gallery.single .g0 { grid-row: auto; }

.uvt-head { display: flex; flex-wrap: wrap; gap: 8px 16px; align-items: flex-start; margin: 24px 0 8px; }
.uvt-head h1 { font-size: 27px; line-height: 1.3; margin: 0; letter-spacing: -.4px; flex: 1; min-width: 260px; }
.uvt-head .sub { color: var(--ink-2); font-size: 16px; margin: 4px 0 0; }
.uvt-facts { display: flex; flex-wrap: wrap; gap: 10px; margin: 16px 0 26px; }
.uvt-fact { display: inline-flex; align-items: center; gap: 7px; background: var(--bg-2); border-radius: 999px;
  padding: 8px 14px; font-size: 13px; font-weight: 600; color: var(--ink-2); }
.uvt-fact b { color: var(--ink); }
/* visiting / 途经 attractions chips (full accurate list) */
.uvt-visiting { display: flex; flex-wrap: wrap; align-items: center; gap: 7px; margin: -8px 0 24px; }
.uvt-visiting .vlabel { font-size: 13px; font-weight: 700; color: var(--ink-2); margin-right: 2px; }
.uvt-visiting .vtag { font-size: 12.5px; font-weight: 600; color: var(--teal); background: var(--teal-soft);
  padding: 4px 11px; border-radius: 999px; }

.uvt-cols { display: grid; grid-template-columns: 1fr 330px; gap: 40px; align-items: stretch; }
.uvt-cols > aside { position: relative; }
.uvt-section { padding: 26px 0; border-top: 1px solid var(--line); }
.uvt-section:first-child { border-top: 0; padding-top: 6px; }
.uvt-section h2 { font-size: 20px; margin: 0 0 14px; letter-spacing: -.3px; display: flex; align-items: center; gap: 10px; }
.uvt-section h2 .ic { width: 30px; height: 30px; border-radius: 9px; display: inline-flex; align-items: center;
  justify-content: center; font-size: 15px; background: var(--accent-soft); color: var(--accent); flex: none; }
.uvt-section h2 .ic.b { background: var(--blue-soft); color: var(--blue); }
.uvt-section h2 .ic.t { background: var(--teal-soft); color: var(--teal); }
.uvt-section h2 .ic.p { background: var(--pink-soft); color: var(--pink); }
.uvt-rich { font-size: 14.5px; color: var(--ink-2); }
.uvt-rich p { margin: 0 0 10px; }
.uvt-rich img { border-radius: 10px; margin: 10px 0; }
.uvt-rich ul, .uvt-rich ol { padding-left: 20px; margin: 0 0 10px; }
.uvt-rich strong { color: var(--ink); }
.uvt-rich table { border-collapse: collapse; width: 100%; font-size: 13px; }
.uvt-rich td, .uvt-rich th { border: 1px solid var(--line); padding: 6px 8px; }

/* highlights (行程特色) — tighter line spacing for list-like content */
.uvt-special .uvt-rich p { margin: 0 0 4px; }
.uvt-special .uvt-rich .promo-note { color: var(--accent); }   /* 促销注释 = 第1天/强调色 */
.uvt-special .uvt-rich p:empty, .uvt-special .uvt-rich p:last-child { margin-bottom: 0; }

/* notice sections — secondary content, compact */
.uvt-note-sec .uvt-rich { font-size: 13px; line-height: 1.55; color: var(--ink-2); }
.uvt-note-sec .uvt-rich p { margin: 0 0 5px; }
.uvt-note-sec .uvt-rich p:last-child { margin-bottom: 0; }
.uvt-note-sec .uvt-rich ul, .uvt-note-sec .uvt-rich ol { margin: 0 0 5px; }
.uvt-note-sec .uvt-rich td, .uvt-note-sec .uvt-rich th { padding: 4px 7px; }
/* standalone bold sub-headings inside a notice (e.g. 预订须知：/ 出行须知：) — larger */
.uvt-note-sec .uvt-rich p > strong:only-child { font-size: 15.5px; color: var(--ink);
  display: inline-block; margin-top: 8px; letter-spacing: .2px; }
.uvt-note-sec .uvt-rich p:first-child > strong:only-child { margin-top: 0; }

/* collapsible (fold) sections — clearly a clickable expander */
.uvt-section.uvt-fold { border-top: 0; padding: 9px 0; }
.uvt-fold .fold-head { cursor: pointer; user-select: none; margin: 0; font-size: 17px;
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; padding: 13px 16px;
  transition: background .15s, border-color .15s; }
.uvt-fold .fold-head:hover { background: #eceff3; border-color: #d6dae2; }
.uvt-fold.open .fold-head { background: var(--accent-soft); border-color: var(--accent-soft);
  border-radius: 12px 12px 0 0; }
.uvt-fold .fold-toggle { margin-left: auto; display: inline-flex; align-items: center; gap: 5px;
  font-size: 13px; font-weight: 700; color: var(--accent); white-space: nowrap; }
.uvt-fold .ft-open { display: none; }
.uvt-fold.open .ft-open { display: inline; }
.uvt-fold.open .ft-closed { display: none; }
.uvt-fold .fold-chev { color: var(--accent); transition: transform .25s; display: inline-flex; }
.uvt-fold.open .fold-chev { transform: rotate(180deg); }
.uvt-fold .fold-body { max-height: 0; overflow: hidden; transition: max-height .35s ease;
  border: 1px solid var(--line); border-top: 0; border-radius: 0 0 12px 12px; }
.uvt-fold.open .fold-body { max-height: 9000px; }
.uvt-fold .fold-inner { padding: 16px; }

/* itinerary timeline */
.uvt-day { position: relative; padding: 0 0 8px 30px; }
.uvt-day::before { content: ""; position: absolute; left: 7px; top: 28px; bottom: -8px; width: 2px; background: var(--line); }
.uvt-day:last-child::before { display: none; }
.uvt-day .dnum { position: absolute; left: 0; top: 4px; width: 16px; height: 16px; border-radius: 50%;
  background: #fff; border: 3px solid var(--accent); }
.uvt-day .dhead { cursor: pointer; display: flex; align-items: center; gap: 10px; padding: 2px 0; }
.uvt-day .dlabel { font-size: 15.5px; font-weight: 800; color: var(--accent); letter-spacing: .2px; flex: none; }
.uvt-day .dsection { font-weight: 700; font-size: 15.5px; flex: 1; }
.uvt-day .dtoggle { color: var(--muted); transition: transform .2s; }
.uvt-day.open .dtoggle { transform: rotate(180deg); }
.uvt-day .dbody { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.uvt-day.open .dbody { max-height: 4000px; }
.uvt-day .dbody-inner { padding: 10px 0 18px; }
.uvt-seg { margin: 0 0 12px; }
.uvt-seg .stype { display: inline-block; font-size: 11px; font-weight: 700; color: var(--teal);
  background: #e7f6f6; padding: 2px 8px; border-radius: 6px; margin-bottom: 5px; }
/* attraction (景点) cards — clean white card with teal pin */
.uvt-scenics { display: grid; gap: 8px; margin-top: 4px; }
.uvt-scenic { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 12px 15px;
  transition: box-shadow .15s, border-color .15s; }
.uvt-scenic:hover { box-shadow: var(--shadow); border-color: #dfe7e7; }
.uvt-scenic .sc-name { display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
  font-weight: 700; font-size: 15px; color: var(--ink); letter-spacing: -.2px; }
.uvt-scenic .sc-pin { color: var(--teal); flex: none; }
.uvt-scenic .sc-tag { font-size: 10.5px; font-weight: 700; color: var(--blue); background: var(--blue-soft);
  padding: 2px 9px; border-radius: 999px; }
.uvt-scenic.has-img { display: flex; gap: 14px; align-items: flex-start; }
.uvt-scenic .sc-text { flex: 1; min-width: 0; }
.uvt-scenic .sc-img { flex: none; width: 116px; height: 92px; object-fit: cover; border-radius: 10px;
  border: 1px solid var(--line); }
.uvt-scenic .sc-desc { margin-top: 7px; padding-left: 24px; }
.uvt-scenic.has-img .sc-desc { padding-left: 24px; }
@media (max-width: 560px) {
  /* attraction cards stack vertically — image on top, text below */
  .uvt-scenic.has-img { flex-direction: column; gap: 10px; }
  .uvt-scenic.has-img .sc-img { order: -1; width: 100%; height: 170px; }
  .uvt-scenic .sc-desc { padding-left: 0; margin-top: 6px; }
  .uvt-scenic .sc-name { font-size: 15.5px; }
}
.uvt-scenic .sc-desc .uvt-rich { font-size: 13.5px; color: var(--ink-2); line-height: 1.65; }
.uvt-scenic .sc-desc .uvt-rich p { margin: 0 0 6px; }
.uvt-scenic .sc-desc .uvt-rich p:last-child { margin-bottom: 0; }

/* hotel / accommodation — prominent */
.uvt-hotel { display: flex; align-items: baseline; flex-wrap: wrap; gap: 8px; margin-top: 12px;
  background: var(--bg-2); border-radius: 11px; padding: 11px 14px; }
.uvt-hotel .ht-ic { font-size: 15px; }
.uvt-hotel .ht-label { color: var(--muted); font-weight: 600; font-size: 12.5px; flex: none; }
.uvt-hotel .ht-name { color: var(--ink); font-weight: 700; font-size: 14px; }

/* pick-up / drop-off points */
.cpt-group { margin-bottom: 16px; }
.cpt-group:last-child { margin-bottom: 0; }
.cpt-gh { font-weight: 800; font-size: 14px; color: var(--ink); margin-bottom: 6px; display: flex; align-items: center; gap: 8px; }
.cpt-cnt { font-size: 11px; font-weight: 700; color: var(--teal); background: var(--teal-soft); padding: 1px 8px; border-radius: 999px; }
.cpt-row { display: flex; gap: 12px; padding: 9px 0; border-top: 1px solid var(--line); }
.cpt-row:first-of-type { border-top: 0; }
.cpt-time { flex: none; width: 50px; font-weight: 800; color: var(--accent); font-size: 13.5px; }
.cpt-addr { font-size: 13px; color: var(--ink-2); }
.cpt-addr b { color: var(--ink); font-weight: 700; }
.cpt-air { margin-left: 5px; color: var(--blue); }
.cpt-note { font-size: 12px; color: var(--muted); margin-top: 3px; }
.cpt-total { font-size: 12px; font-weight: 700; color: var(--teal); background: var(--teal-soft); padding: 1px 9px; border-radius: 999px; margin-left: 8px; }
.uvt-hotel { font-size: 13px; color: var(--muted); margin-top: 6px; }

/* booking card */
.uvt-book { position: sticky; top: 84px; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; box-shadow: var(--shadow); background: #fff; }
/* 套餐 (package scheme) selector — itinerary/costs/carpoints differ per scheme */
.uvt-schemes h2 { margin-bottom: 10px; }
.scheme-tabs { display: flex; flex-wrap: wrap; gap: 8px; }
.scheme-tab { font: inherit; font-size: 14px; font-weight: 700; color: var(--ink-2);
  background: var(--bg-2); border: 1.5px solid var(--line); border-radius: 10px;
  padding: 9px 14px; cursor: pointer; transition: .15s; text-align: left; line-height: 1.35; }
.scheme-tab:hover { border-color: var(--accent); color: var(--ink); }
.scheme-tab.active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent-dark); }
.scheme-hint { margin: 10px 0 0; font-size: 13px; color: var(--muted); }
.scheme-pane[hidden] { display: none; }

/* 自由行 optional day-tours (可选产品 table) */
.uvt-freeplan { margin-top: 10px; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.uvt-freeplan .fp-h { background: var(--bg-2); padding: 8px 12px; font-size: 13px; font-weight: 700; color: var(--ink-2); }
.fp-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
  padding: 9px 12px; border-top: 1px solid var(--line); }
.fp-name { font-size: 14px; line-height: 1.45; }
.fp-link { color: var(--accent-dark); font-weight: 600; }
.fp-link:hover { text-decoration: underline; }
.fp-price { font-size: 14px; font-weight: 700; color: var(--accent); white-space: nowrap; flex: none; }
.fp-q { font-size: 11px; font-weight: 600; color: var(--muted); margin-left: 2px; }

.uvt-book .pl { font-size: 13px; color: var(--muted); }
.uvt-book .pv { font-size: 32px; font-weight: 800; color: var(--accent); letter-spacing: -.6px; }
.uvt-book .pv small { font-size: 14px; color: #1a1a1a; font-weight: 600; }
/* room-occupancy price breakdown */
.uvt-occ-note { font-size: 11.5px; color: var(--muted); margin: 10px 0 5px; }
.uvt-occ { display: grid; gap: 5px; }
.occ-row { display: flex; justify-content: space-between; align-items: baseline; gap: 10px;
  font-size: 13px; padding: 6px 11px; border-radius: 9px; background: var(--bg-2); color: var(--ink-2); }
.occ-row b { font-weight: 800; color: var(--ink); letter-spacing: -.2px; }
.occ-row.main { background: var(--accent-soft); }
.occ-row.main span { color: var(--accent-dark); font-weight: 700; }
.occ-row.main b { color: var(--accent); }
.uvt-book .meta { margin: 14px 0; font-size: 13.5px; color: var(--ink-2); display: flex; flex-direction: column; gap: 8px; }
.uvt-book .meta div { display: flex; align-items: center; gap: 8px; }
.uvt-btn { display: block; width: 100%; text-align: center; background: var(--accent); color: #fff; border: 0;
  border-radius: 12px; padding: 14px; font-size: 16px; font-weight: 700; cursor: pointer; transition: .15s; }
.uvt-btn:hover { background: var(--accent-dark); }
.uvt-btn.ghost { background: #fff; color: var(--ink); border: 1px solid var(--line); margin-top: 10px; }
.uvt-btn.ghost:hover { border-color: var(--ink); background: var(--bg-2); }
.uvt-dates { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; max-height: 132px; overflow: auto; }
.uvt-dates span { font-size: 12px; padding: 4px 9px; background: var(--bg-2); border-radius: 7px; color: var(--ink-2); font-weight: 600; }

/* ---------- departure calendar ---------- */
.cal-freq { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700;
  color: var(--blue); background: var(--blue-soft); padding: 5px 12px; border-radius: 999px; margin-bottom: 12px; }
.uvt-cal { border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px 14px; background: #fff;
  scroll-margin-top: 84px; max-width: 540px; margin-left: auto; margin-right: auto; }
.cal-head { display: flex; align-items: center; justify-content: center; gap: 15px; margin-bottom: 11px; }
.cal-month { font-weight: 800; font-size: 17px; min-width: 150px; text-align: center; letter-spacing: -.2px; }
.cal-nav { width: 35px; height: 35px; border-radius: 50%; border: 1px solid var(--line); background: #fff;
  font-size: 19px; color: var(--ink-2); cursor: pointer; line-height: 1; transition: .15s; }
.cal-nav:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); }
.cal-nav:disabled { opacity: .3; cursor: default; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 5px; }
.cal-dow { text-align: center; font-size: 13px; font-weight: 700; color: var(--muted); padding-bottom: 3px; }
.cal-cell { min-height: 53px; border-radius: 9px; padding: 4px 3px 3px; display: flex; flex-direction: column;
  align-items: center; gap: 1px; font-size: 12.5px; border: 1px solid transparent; background: var(--bg-2); line-height: 1.25; }
.cal-cell.empty { background: transparent; }
.cal-cell.muted { color: #c8c8d0; background: transparent; }
.cal-cell.past .dn { color: #d2d2da; font-weight: 600; }
.cal-cell .dn { font-weight: 700; color: var(--ink-2); font-size: 14px; }
.cal-cell.avail { cursor: pointer; transition: .12s; }
.cal-cell.avail:hover { border-color: currentColor; transform: translateY(-1px); }
.cal-cell.ample { background: #eafaf0; color: #15a05a; }
.cal-cell.low   { background: #fff3e0; color: #d9820a; }
.cal-cell.sold  { background: #f3f3f6; color: #b3b3bd; }
.cal-cell .cprice { font-weight: 800; font-size: 13px; letter-spacing: -.3px; }
.cal-cell .cstk { font-size: 11px; font-weight: 700; }
.cal-cell.sold .cprice { text-decoration: line-through; }
.cal-cell.sel { outline: 2px solid var(--accent); outline-offset: -2px; }
.cal-legend { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 14px; font-size: 14px; color: var(--ink-2); justify-content: center; }
.cal-legend span { display: inline-flex; align-items: center; gap: 6px; }
.cal-legend i.dot { width: 12px; height: 12px; border-radius: 50%; }
.cal-legend i.ample { background: #15a05a; } .cal-legend i.low { background: #d9820a; } .cal-legend i.sold { background: #b3b3bd; }
.cal-updated { margin-top: 10px; font-size: 11.5px; color: var(--muted); }
.cal-empty { padding: 24px; text-align: center; color: var(--muted); }
/* sidebar stock summary */
.uvt-stock { margin-top: 14px; }
.uvt-stock .row { display: flex; gap: 10px; font-size: 12.5px; color: var(--ink-2); margin-bottom: 8px; flex-wrap: wrap; }
.uvt-stock .row b { color: var(--ink); }
.uvt-stock .pill { display: inline-flex; align-items: center; gap: 5px; font-weight: 700; }
.uvt-stock .pill i { width: 9px; height: 9px; border-radius: 50%; }

/* cost list — name + price prominent, everything else compact secondary text */
.uvt-costs { display: grid; gap: 8px; }
.uvt-cost { border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 10px 12px; }
.uvt-cost .cn { font-weight: 700; font-size: 14px; line-height: 1.35; }
.uvt-cost .cp { color: var(--accent); font-weight: 700; font-size: 13px; margin-top: 2px; }
.uvt-cost .cd { color: var(--muted); font-size: 11.5px; line-height: 1.5; margin-top: 5px; }
.uvt-cost .cd .uvt-rich { font-size: 11.5px; color: var(--muted); }
.uvt-cost .cd .uvt-rich p { margin: 0 0 2px; }
.uvt-cost .cd .uvt-rich p:last-child { margin-bottom: 0; }
.uvt-cost .cd .uvt-rich strong { color: var(--ink-2); font-weight: 700; }
.uvt-cost .cd .uvt-rich ul, .uvt-cost .cd .uvt-rich ol { margin: 0 0 2px; padding-left: 16px; }

/* mobile floating booking bar (hidden on desktop) */
.uvt-mobilebar { display: none; }

/* enquire modal (phone + WeChat QR) */
.uvt-modal { position: fixed; inset: 0; z-index: 300; display: none; align-items: center; justify-content: center; padding: 20px; }
.uvt-modal.on { display: flex; }
.uvt-modal-bg { position: absolute; inset: 0; background: rgba(20,20,40,.55); backdrop-filter: blur(3px); }
.uvt-modal-card { position: relative; background: #fff; border-radius: 20px; width: 100%; max-width: 360px;
  max-height: 90vh; overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding: 26px 24px 28px; box-shadow: 0 20px 60px rgba(20,20,40,.3); text-align: center; animation: uvtpop .2s ease; }
@keyframes uvtpop { from { transform: scale(.94); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.uvt-modal-x { position: absolute; top: 12px; right: 14px; border: 0; background: transparent; font-size: 26px;
  line-height: 1; color: var(--muted); cursor: pointer; }
.uvt-modal-x:hover { color: var(--ink); }
.uvt-modal-card h3 { margin: 0 0 4px; font-size: 20px; letter-spacing: -.3px; }
.uvt-modal-card .sub { color: var(--muted); font-size: 13px; margin-bottom: 18px; }
.enq-phone { display: block; background: var(--accent-soft); border-radius: 14px; padding: 14px; margin-bottom: 16px; }
.enq-phone .lbl { display: block; font-size: 12.5px; color: var(--accent-dark); font-weight: 700; margin-bottom: 4px; }
.enq-phone .num { font-size: 24px; font-weight: 800; color: var(--accent); letter-spacing: .3px; }
.enq-wechat { border: 1px solid var(--line); border-radius: 14px; padding: 16px 14px 14px; }
.enq-wechat .lbl { display: block; font-size: 12.5px; color: var(--teal); font-weight: 700; margin-bottom: 10px; }
.enq-wechat img { width: 190px; height: 190px; object-fit: contain; border-radius: 10px; margin: 0 auto; border: 1px solid var(--line); }
.enq-wechat .wid { display: block; margin-top: 10px; font-size: 13.5px; color: var(--ink); }
.enq-wechat .wid b { color: var(--teal); }
.enq-wechat .hint { display: block; margin-top: 2px; font-size: 12px; color: var(--muted); }

/* online booking form */
.uvt-modal-card:has(.uvt-order-form) { max-width: 480px; text-align: left; }
.uvt-modal-card:has(.uvt-order-form) h3 { text-align: left; }
.uvt-order-form { text-align: left; margin-bottom: 4px; }
.uvt-order-form .of-row { display: flex; gap: 10px; }
.uvt-order-form .of-field { flex: 1; display: block; margin-bottom: 11px; }
.uvt-order-form .of-field > span { display: block; font-size: 12px; color: var(--muted); font-weight: 600; margin-bottom: 4px; }
.uvt-order-form input, .uvt-order-form select, .uvt-order-form textarea {
  width: 100%; box-sizing: border-box; border: 1px solid var(--line); border-radius: 10px;
  padding: 9px 11px; font-size: 14px; font-family: inherit; background: #fff; color: var(--ink); }
.uvt-order-form input:focus, .uvt-order-form select:focus, .uvt-order-form textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.uvt-order-form textarea { resize: vertical; }
.of-total { min-height: 18px; font-size: 14px; font-weight: 700; color: var(--accent); margin: 2px 0 12px; }
.of-submit { width: 100%; justify-content: center; }
.of-hint { font-size: 11.5px; color: var(--muted); margin: 8px 0 0; text-align: center; }
.of-or { text-align: center; color: var(--muted); font-size: 12px; margin: 18px 0 14px; position: relative; }
.of-or::before, .of-or::after { content: ""; position: absolute; top: 50%; width: 32%; height: 1px; background: var(--line); }
.of-or::before { left: 0; } .of-or::after { right: 0; }
.of-success { text-align: center; padding: 18px 0 8px; }
.of-success .of-check { width: 54px; height: 54px; line-height: 54px; margin: 0 auto 10px; border-radius: 50%;
  background: var(--teal, #2bb6a8); color: #fff; font-size: 30px; font-weight: 800; }
.of-success h4 { margin: 0 0 6px; font-size: 18px; }
.of-success p { font-size: 13.5px; color: var(--muted); margin: 0; }

/* related tours (detail page, before footer) */
.uvt-related { margin: 10px auto 4px; padding-top: 30px; border-top: 1px solid var(--line); }
.uvt-related h2 { font-size: 22px; margin: 0 0 18px; }
.uvt-related .uvt-related-grid { margin-top: 0; }

/* lightbox */
.uvt-lb { position: fixed; inset: 0; background: rgba(0,0,0,.92); z-index: 200; display: none;
  align-items: center; justify-content: center; }
.uvt-lb.on { display: flex; }
.uvt-lb img { max-width: 92vw; max-height: 88vh; object-fit: contain; border-radius: 8px; }
.uvt-lb .x { position: absolute; top: 20px; right: 26px; color: #fff; font-size: 34px; cursor: pointer; line-height: 1; }
.uvt-lb .nav { position: absolute; top: 50%; transform: translateY(-50%); color: #fff; font-size: 44px;
  cursor: pointer; padding: 20px; user-select: none; opacity: .8; }
.uvt-lb .nav:hover { opacity: 1; }
.uvt-lb .prev { left: 10px; } .uvt-lb .next { right: 10px; }

/* footer note */
.uvt-foot { border-top: 1px solid var(--line); margin-top: 40px; padding: 28px 0; color: var(--muted); font-size: 13px; text-align: center; }

/* responsive */
@media (max-width: 900px) {
  .uvt-cols { grid-template-columns: 1fr; }
  .uvt-book { position: static; }
  .uvt-gallery { grid-template-columns: 1fr 1fr; grid-template-rows: auto; max-height: none; }
  .uvt-gallery .g0 { grid-row: auto; grid-column: 1 / 3; }
  .uvt-gallery figure:nth-child(n+5) { display: none; }
  /* floating bottom bar */
  .uvt-detail { padding-bottom: 92px; }
  .uvt-mobilebar { display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
    background: #fff; border-top: 1px solid var(--line); box-shadow: 0 -4px 22px rgba(20,20,40,.13);
    padding: 10px 16px calc(10px + env(safe-area-inset-bottom)); align-items: center; gap: 12px; }
  .uvt-mobilebar .mb-info { flex: 1; display: flex; align-items: baseline; gap: 4px; min-width: 0; }
  .uvt-mobilebar .mb-from, .uvt-mobilebar .mb-per { font-size: 12px; color: var(--muted); }
  .uvt-mobilebar .mb-price { font-size: 22px; font-weight: 800; color: var(--accent); letter-spacing: -.5px; }
  .uvt-mobilebar .uvt-btn { width: auto; flex: none; padding: 12px 22px; font-size: 15px; }
  .uvt-mobilebar .mb-cal { flex: none; width: 46px; height: 46px; border: 1px solid var(--line); border-radius: 12px;
    display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--ink-2); }
}
@media (max-width: 560px) {
  .uvt-hero h1 { font-size: 26px; }
  .uvt-head h1 { font-size: 22px; }
  .uvt-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 18px 14px; }
  .uvt-card .title { font-size: 14px; min-height: 38px; }
}

/* ---------- promotions page ---------- */
.nav-promo { color: #e0392b !important; font-weight: 700; }
.nav-hot { color: #e0392b !important; font-weight: 700; }
.rank-badge { position: absolute; top: 10px; left: 0; background: #e0392b; color: #fff; font-size: 13px; font-weight: 800; padding: 4px 13px 4px 9px; border-radius: 0 999px 999px 0; box-shadow: 0 3px 10px rgba(0,0,0,.28); z-index: 2; letter-spacing: .3px; }
.rank-badge.rank-1 { background: linear-gradient(135deg,#f6b800,#e2870c); }
.rank-badge.rank-2 { background: linear-gradient(135deg,#bcc6cf,#8b98a4); color: #2b3742; }
.rank-badge.rank-3 { background: linear-gradient(135deg,#dd9a5e,#b56e2c); }
.rank-badge.rank-promo { background: linear-gradient(135deg,#FC9C18,#e0732e); }
.rank-badge.rank-sa { background: linear-gradient(135deg,#2e9e6b,#1c7d59); }
/* promo deadline banner on tour detail pages */
.det-promo { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px; margin: 14px 0 4px;
  padding: 11px 16px; border-radius: 12px; background: linear-gradient(135deg,#fff1e0,#ffe3e3);
  border: 1px solid #ffcf9e; }
.det-promo-tag { font-weight: 800; font-size: 15px; color: #c0392b; }
.det-promo-dl { font-weight: 700; font-size: 13.5px; color: #fff; background: #e0392b; padding: 4px 12px; border-radius: 999px; }
/* when a rank badge is present (热销榜): No.X 左上，几天几晚移到右上，小团角标顺移到其下 */
.thumb:has(.rank-badge) .uvt-badge { top: 12px; left: auto; right: 12px; }
.thumb:has(.rank-badge) .cchips { top: 44px; }
.uvt-promopage { max-width: 1180px; }
/* ===== promo hero banners — premium redesign ===== */
.promo-hero, .eu-hero, .cancun-hero, .flash-hero {
  position: relative; overflow: hidden; isolation: isolate; color: #fff;
  border-radius: 20px; min-height: 178px; padding: 26px 286px 26px 38px; margin: 18px 0 22px;
  display: flex; flex-direction: column; justify-content: center; align-items: flex-start;
  box-shadow: 0 20px 44px -14px rgba(0,0,0,.40), inset 0 1px 0 rgba(255,255,255,.30);
}
.promo-hero > *, .eu-hero > *, .cancun-hero > *, .flash-hero > * { position: relative; z-index: 2; text-align: left; }
/* theme-matched gradients */
.promo-hero  { background: linear-gradient(135deg, #0a2e6e 0%, #1f6fd6 55%, #2f8be8 100%); }  /* 美国 · 蓝 */
.eu-hero     { background: linear-gradient(135deg, #371a73 0%, #7b2ff7 55%, #d4145a 100%); }  /* 欧洲 · 紫 */
.cancun-hero { background: linear-gradient(135deg, #0093b8 0%, #15c5bd 50%, #2bdc9a 100%); }  /* 坎昆 · 青绿 */
.flash-hero  { background: linear-gradient(135deg, #c01026 0%, #ff5a1f 100%); }               /* 特卖 · 红 */
/* destination illustration on the right */
.hero-gfx { position: absolute; right: 28px; top: 50%; transform: translateY(-50%); height: 154px; z-index: 1; pointer-events: none; }
.hero-gfx img { height: 154px; width: auto; display: block; filter: drop-shadow(0 5px 14px rgba(0,0,0,.32)); }
/* hero typography */
.promo-hero .ph-tag, .eu-hero .ph-tag, .cancun-hero .ph-tag, .flash-hero .ph-tag {
  display: inline-block; font-size: 13px; font-weight: 700; letter-spacing: 2px;
  background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.40);
  padding: 4px 15px; border-radius: 999px; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.promo-hero h1, .eu-hero h1, .cancun-hero h1 {
  font-size: 42px; margin: 12px 0 10px; letter-spacing: 1px; font-weight: 800; line-height: 1.15;
  text-shadow: 0 2px 16px rgba(0,0,0,.30);
}
.promo-hero h1 { font-size: 48px; letter-spacing: 1px; }
.flash-hero h2 {
  font-size: 40px; margin: 12px 0 10px; border: none; padding: 0; font-weight: 800;
  text-shadow: 0 2px 16px rgba(0,0,0,.30);
}
.eu-hero .ph-sub, .cancun-hero .ph-sub {
  font-size: 14px; line-height: 1.6; opacity: .97; max-width: 660px; margin: 0 0 14px;
  text-shadow: 0 1px 10px rgba(0,0,0,.5);
}
.promo-hero .ph-meta, .eu-hero .ph-meta, .cancun-hero .ph-meta, .flash-hero .ph-meta {
  display: inline-block; font-size: 13.5px; font-weight: 700; line-height: 1.85;
  background: rgba(0,0,0,.26); border: 1px solid rgba(255,255,255,.26);
  padding: 8px 18px; border-radius: 16px; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  box-shadow: 0 6px 16px rgba(0,0,0,.22);
}
.promo-warn {
  display: inline-block; margin: 14px 0 0; background: rgba(0,0,0,.24);
  border: 1px solid rgba(255,255,255,.30); color: #fff; font-size: 12.5px; font-weight: 700;
  padding: 7px 16px; border-radius: 999px;
}
.promo-sec { font-size: 18px; font-weight: 700; margin: 26px 0 13px; padding-left: 11px; border-left: 4px solid #FC9C18; }
.promo-ribbon {
  position: absolute; top: 12px; left: 0; background: linear-gradient(135deg,#e8412e,#ff7a18);
  color: #fff; font-size: 12.5px; font-weight: 800; padding: 5px 13px 5px 10px;
  border-radius: 0 999px 999px 0; box-shadow: 0 3px 11px rgba(200,30,58,.40); z-index: 2;
}
.promo-dates {
  position: absolute; top: 45px; left: 0; background: rgba(0,0,0,.82); color: #ffe08a;
  font-size: 11.5px; font-weight: 600; padding: 3px 11px; border-radius: 0 8px 8px 0; z-index: 2;
}
@media (max-width: 640px) {
  .promo-hero, .eu-hero, .cancun-hero, .flash-hero { min-height: 128px; padding: 20px 108px 20px 20px; border-radius: 16px; }
  .hero-gfx { height: 96px; right: 12px; }
  .hero-gfx img { height: 96px; }
  .promo-hero h1 { font-size: 32px; }
  .eu-hero h1, .cancun-hero h1, .flash-hero h2 { font-size: 22px; }
  .eu-hero .ph-sub, .cancun-hero .ph-sub { font-size: 12px; }
  .promo-hero .ph-meta, .eu-hero .ph-meta, .cancun-hero .ph-meta, .flash-hero .ph-meta { font-size: 11.5px; padding: 6px 12px; }
}

/* ============ "砍杀级" homepage redesign ============ */
.qhy-hero { position: relative; height: 88vh; min-height: 540px; overflow: hidden; display: flex; align-items: flex-end; justify-content: center; }
.qhy-hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center 30%; animation: kenburns 20s ease-in-out infinite alternate; }
@keyframes kenburns { from { transform: scale(1.02);} to { transform: scale(1.12);} }
.qhy-hero-scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,18,32,.10) 0%, rgba(10,18,32,.18) 40%, rgba(10,18,32,.55) 68%, rgba(10,18,32,.90) 100%); }
.qhy-hero-in { position: relative; z-index: 2; text-align: center; color: #fff; padding: 0 20px 10.5vh; max-width: 980px; }
.qhy-cred { display: inline-block; font-size: 12.5px; letter-spacing: 2px; font-weight: 600; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.32); padding: 6px 16px; border-radius: 999px; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); animation: fadeUp .7s .05s both; }
.qhy-h1 { font-family: "Ma Shan Zheng","STKaiti","Kaiti SC","楷体",serif; font-weight: 400; font-size: clamp(34px, 7.4vw, 90px); letter-spacing: 5px; white-space: nowrap; margin: 12px 0 6px; text-shadow: 0 3px 22px rgba(0,0,0,.5); animation: fadeUp .7s .18s both; }
.qhy-en { display: inline-block; font-size: clamp(12px,1.55vw,15px); letter-spacing: .42em; text-indent: .42em; font-weight: 800; color: #FFC24D; background: rgba(12,26,46,.42); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); border: 1px solid rgba(255,200,90,.5); border-radius: 999px; padding: 7px 20px; margin-bottom: 2px; text-shadow: 0 1px 6px rgba(0,0,0,.55); box-shadow: 0 6px 18px -8px rgba(0,0,0,.5); animation: fadeUp .7s .3s both; }
.qhy-sub { font-size: clamp(13px,1.8vw,16px); opacity: .95; margin: 16px auto 24px; max-width: 700px; text-shadow: 0 1px 10px rgba(0,0,0,.5); animation: fadeUp .7s .42s both; }
.qhy-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; animation: fadeUp .7s .54s both; }
.qhy-btn { display: inline-flex; align-items: center; gap: 6px; font-weight: 800; font-size: 15px; padding: 13px 26px; border-radius: 999px; text-decoration: none; transition: transform .15s, box-shadow .15s, background .15s; }
.qhy-btn.sm { padding: 10px 20px; font-size: 14px; }
.qhy-btn.primary { background: #FC9C18; color: #412402; box-shadow: 0 8px 22px rgba(252,156,24,.4); }
.qhy-btn.primary:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(252,156,24,.5); background: #ffae33; }
.qhy-btn.ghost { background: rgba(255,255,255,.12); color: #fff; border: 1.5px solid rgba(255,255,255,.6); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.qhy-btn.ghost:hover { background: rgba(255,255,255,.22); transform: translateY(-2px); }
.qhy-scroll { position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%); z-index: 2; color: #fff; font-size: 22px; opacity: .85; animation: bob 1.7s ease-in-out infinite; }
@keyframes bob { 0%,100%{ transform: translate(-50%,0);} 50%{ transform: translate(-50%,8px);} }
@keyframes fadeUp { from { opacity: 0; transform: translateY(16px);} to { opacity: 1; transform: none;} }

.entry-bar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin: -54px 0 10px; position: relative; z-index: 5; }
.entry-card { display: flex; flex-direction: row; align-items: center; gap: 14px; background: #fff; border-radius: 16px; padding: 18px; box-shadow: 0 14px 34px -14px rgba(0,0,0,.30); text-decoration: none; transition: transform .16s, box-shadow .16s; border-top: 4px solid var(--ec); }
.entry-card:hover { transform: translateY(-5px); box-shadow: 0 20px 40px -14px rgba(0,0,0,.38); }
.entry-ic { width: 46px; height: 46px; flex: none; display: grid; place-items: center; border-radius: 12px; background: var(--ecb); color: var(--ec); margin-bottom: 0; }
.entry-ic svg { width: 25px; height: 25px; }
.entry-txt { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.entry-zh { font-size: 18px; font-weight: 800; color: var(--ec); }
.entry-sub { font-size: 12.5px; color: var(--muted); }

.sec-lead { margin: 8px 0 18px; }
.sec-lead h2 { font-size: clamp(22px,3.4vw,30px); margin: 0 0 4px; }
.sec-lead .sub { color: var(--muted); margin: 0; font-size: 14.5px; }

.region-mosaic { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.rm-card { position: relative; display: block; overflow: hidden; border-radius: 14px; aspect-ratio: 4/3; text-decoration: none; }
.rm-card:first-child { grid-column: span 2; grid-row: span 2; }
.rm-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.rm-card:hover img { transform: scale(1.07); }
.rm-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 38%, rgba(0,0,0,.74) 100%); }
.rm-in { position: absolute; left: 14px; bottom: 12px; z-index: 2; color: #fff; }
.rm-name { display: block; font-weight: 800; font-size: 19px; text-shadow: 0 2px 8px rgba(0,0,0,.5); }
.rm-card:first-child .rm-name { font-size: 30px; }
.rm-n { font-size: 12.5px; opacity: .92; }

.sg-spot { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: center; background: linear-gradient(135deg,#f3fbf8,#eafaf3); border-radius: 20px; padding: 24px; margin-top: 8px; }
.sg-media { position: relative; border-radius: 14px; overflow: hidden; }
.sg-media img { width: 100%; max-height: 340px; object-fit: cover; display: block; }
.sg-badge { position: absolute; top: 12px; left: 12px; background: #0F6E56; color: #fff; font-weight: 700; font-size: 12.5px; padding: 4px 12px; border-radius: 999px; }
.sg-body h2 { font-size: clamp(22px,3.2vw,30px); margin: 0 0 12px; }
.sg-num { color: #E8820C; }
.sg-vs { display: flex; align-items: baseline; gap: 8px; margin: 0 0 14px; color: #0F6E56; }
.sg-vs b { font-size: 40px; font-weight: 900; }
.sg-vs b.dim { color: #b3b3bd; font-size: 30px; }
.sg-vs span { font-size: 14px; color: var(--ink-2); }
.sg-vs i { font-style: normal; color: var(--muted); margin: 0 4px; }
.sg-pts { list-style: none; padding: 0; margin: 0 0 14px; }
.sg-pts li { padding-left: 22px; position: relative; margin-bottom: 6px; font-size: 14.5px; }
.sg-pts li::before { content: "✓"; position: absolute; left: 0; color: #0F6E56; font-weight: 800; }
.sg-tag { display: block; margin-top: 3px; font-size: 13px; font-style: italic; color: #0F6E56; opacity: .9; }
.sg-chips { display: flex; flex-wrap: wrap; gap: 7px; margin: 0 0 16px; }
.sg-chip { font-size: 13px; font-weight: 600; padding: 5px 12px; border-radius: 999px; background: #fff; border: 1px solid #cfe8df; color: #0F6E56; text-decoration: none; transition: .14s; }
.sg-chip:hover { background: #0F6E56; color: #fff; }
.sg-strip { margin-top: 20px; }

.deal-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.deal-card { display: flex; flex-direction: column; border-radius: 16px; overflow: hidden; text-decoration: none; color: #fff; box-shadow: 0 14px 30px -16px rgba(0,0,0,.42); transition: transform .16s, box-shadow .16s; }
.deal-card:hover { transform: translateY(-4px); box-shadow: 0 22px 44px -16px rgba(0,0,0,.52); }
.deal-pic { display: block; height: 130px; background-size: cover; background-position: center; }
.deal-body { display: flex; flex-direction: column; gap: 7px; padding: 14px 16px 16px; flex: 1; background: rgb(var(--c1)); border-top: 4px solid rgb(var(--c2)); }
.deal-t { font-size: 14px; font-weight: 800; color: #fff; opacity: .97; text-shadow: 0 1px 3px rgba(0,0,0,.4); }
.deal-d { font-size: 21px; font-weight: 900; color: #fff; line-height: 1.22; text-shadow: 0 1px 4px rgba(0,0,0,.35); }
.deal-dl { font-size: 12px; font-weight: 700; color: #fff; background: rgba(0,0,0,.42); align-self: flex-start; padding: 4px 11px; border-radius: 999px; }
.deal-go { margin-top: 2px; font-weight: 800; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,.4); }

.trust-strip { background: #26211f; color: #fff; padding: 48px 0; margin-top: 48px; }
.trust-stats { display: flex; flex-wrap: wrap; justify-content: center; gap: 38px; margin-bottom: 34px; }
.trust-stats > div { text-align: center; }
.trust-stats b { display: block; font-family: Georgia, "Songti SC", serif; font-size: clamp(30px,5vw,52px); color: #FAC775; line-height: 1; }
.trust-stats span { font-size: 13px; opacity: .8; letter-spacing: 1px; }
.trust-cards { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 28px; }
.tc { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 14px; padding: 18px; text-align: center; }
.tc-ic { font-size: 26px; }
.tc b { display: block; margin: 8px 0 3px; font-size: 15px; }
.tc span { font-size: 12.5px; opacity: .75; }
.trust-strip .qhy-btn { display: flex; width: max-content; margin: 0 auto; }

.foot-cta { background: linear-gradient(135deg,#FC9C18,#e0732e); color: #fff; text-align: center; padding: 48px 20px; }
.foot-cta h2 { font-size: clamp(24px,4vw,38px); margin: 0 0 20px; text-shadow: 0 2px 12px rgba(0,0,0,.18); }
.foot-cta .qhy-btn.primary { background: #fff; color: #c0392b; }
.foot-cta .qhy-btn.ghost.light { border-color: rgba(255,255,255,.85); color: #fff; }
.fc-wechat{display:inline-flex;align-items:center;gap:16px;margin-top:26px;background:#fff;border-radius:16px;padding:14px 20px;box-shadow:0 12px 30px -10px rgba(0,0,0,.28)}
.fc-wechat img{width:104px;height:104px;display:block;flex:none}
.fc-wx-txt{display:flex;flex-direction:column;gap:6px;text-align:left}
.fc-wx-txt span{font-size:13.5px;color:#5b6b7a}
.fc-wx-txt b{font-size:16px;color:#16181d;font-weight:800}

.mobile-cta { display: none; }
@media (max-width: 760px) {
  .entry-bar, .region-mosaic, .deal-grid { grid-template-columns: 1fr 1fr; }
  .rm-card:first-child { grid-column: span 2; grid-row: span 1; }
  .sg-spot { grid-template-columns: 1fr; }
  .trust-cards { grid-template-columns: 1fr 1fr; }
  .mobile-cta { display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 80; box-shadow: 0 -4px 16px rgba(0,0,0,.18); }
  .mobile-cta a { flex: 1; text-align: center; padding: 14px; font-weight: 800; font-size: 15px; text-decoration: none; }
  .mc-call { background: #fff; color: #FC9C18; border-top: 2px solid #FC9C18; }
  .mc-hot { background: #FC9C18; color: #412402; }
  body { padding-bottom: 52px; }
}
@media (prefers-reduced-motion: reduce) {
  .qhy-hero-bg, .qhy-scroll, .qhy-cred, .qhy-h1, .qhy-en, .qhy-sub, .qhy-cta { animation: none !important; }
}

/* hero search bar */
.hero-search { display: flex; gap: 0; max-width: 720px; margin: 4px auto 12px; background: #fff; border-radius: 999px; padding: 6px 6px 6px 6px; box-shadow: 0 14px 38px -10px rgba(0,0,0,.45); animation: fadeUp .7s .5s both; }
.hero-search input { flex: 1; min-width: 0; border: none; outline: none; background: transparent; font-size: 15px; padding: 0 16px; color: #16181d; -webkit-text-fill-color: #16181d; }
.hero-search input::placeholder { color: #8a8f98; opacity: 1; -webkit-text-fill-color: #8a8f98; }
.hero-search select { border: none; outline: none; background: #f3f4f6; border-radius: 999px; font-size: 14px; font-weight: 600; color: #2b3742; padding: 10px 12px; max-width: 130px; cursor: pointer; }
.hero-search button { border: none; cursor: pointer; background: #FC9C18; color: #412402; font-weight: 800; font-size: 15px; padding: 11px 22px; border-radius: 999px; margin-left: 6px; white-space: nowrap; transition: background .15s; }
.hero-search button:hover { background: #ffae33; }
.hero-quick { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 8px; animation: fadeUp .7s .6s both; }
.hero-quick span { color: rgba(255,255,255,.85); font-size: 13px; }
.hero-quick a { color: #fff; font-size: 13px; font-weight: 600; padding: 4px 12px; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; text-decoration: none; -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); transition: background .14s; }
.hero-quick a:hover { background: rgba(255,255,255,.22); }
@media (max-width: 640px) {
  .hero-search { flex-wrap: wrap; border-radius: 18px; gap: 6px; }
  .hero-search input { flex: 1 1 100%; padding: 10px 14px; }
  .hero-search select { flex: 1; max-width: none; }
  .hero-search button { flex: 1; }
}


/* ===================== 邮轮团 Cruises ===================== */
.cr-wrap{max-width:1100px;margin:0 auto;padding:0 24px 60px}
.cr-hero{position:relative;min-height:clamp(440px,62vh,620px);background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff}
.cr-hero-in{max-width:1100px;width:100%;margin:0 auto;padding:0 24px 46px}
.cr-eyebrow{letter-spacing:.2em;text-transform:uppercase;font-size:12.5px;font-weight:700;color:var(--cr-accent-soft)}
.cr-h1{font-size:clamp(34px,6vw,62px);font-weight:800;margin:6px 0 4px;text-shadow:0 3px 22px rgba(0,0,0,.5);line-height:1.08}
.cr-ship{font-size:clamp(15px,2.2vw,20px);font-weight:600;color:var(--cr-accent-soft);text-shadow:0 2px 12px rgba(0,0,0,.5)}
.cr-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.cr-meta span{background:color-mix(in srgb,var(--cr-deep) 45%,transparent);border:1px solid color-mix(in srgb,var(--cr-accent) 55%,transparent);color:var(--cr-accent-soft);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.cr-hero-cta{display:flex;align-items:center;gap:20px;margin-top:22px;flex-wrap:wrap}
.cr-price{font-size:15px}
.cr-price b{font-size:30px;font-weight:800;color:var(--cr-price)}
.cr-lead{font-size:16px;line-height:1.85;color:#3a4654;margin:28px 0}
.cr-sec{margin:42px 0}
.cr-h2{font-size:clamp(20px,3vw,26px);font-weight:800;color:var(--cr-deep);margin:0 0 18px;padding-left:14px;border-left:4px solid var(--cr-accent)}
.cr-hl{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.cr-hl-item{display:flex;gap:10px;align-items:flex-start;background:#f4f8fc;border:1px solid #e4edf5;border-radius:12px;padding:14px 16px;font-size:14.5px;color:#283543}
.cr-hl-i{color:var(--cr-accent);font-weight:800}
.cr-route{display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:linear-gradient(135deg,var(--cr-deep),var(--cr-deep2));border-radius:16px;padding:18px 20px}
.cr-stop{color:#fff;font-weight:700;font-size:14.5px;background:rgba(255,255,255,.10);padding:6px 13px;border-radius:999px}
.cr-arrow{color:var(--cr-accent);font-weight:800}
.cr-ports{display:inline-block;font-size:13px;font-weight:600;color:var(--cr-deep2);background:color-mix(in srgb,var(--cr-deep2) 9%,#fff);padding:6px 11px;border-radius:8px;margin-bottom:12px}
.cr-acts{list-style:none;padding:0;margin:0}
.cr-acts li{position:relative;padding-left:18px;margin-bottom:8px;line-height:1.6;font-size:14.5px;color:#283543}
.cr-acts li::before{content:"•";position:absolute;left:2px;color:var(--cr-accent);font-weight:800}
.cr-daymeta{display:flex;flex-wrap:wrap;gap:16px;margin-top:13px;padding-top:12px;border-top:1px dashed #e2e2e2;font-size:13px;color:#5b6b7a}
.cr-cabins{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.cr-cabin{display:flex;gap:14px;border:1px solid #e4edf5;border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 10px 26px -16px rgba(0,0,0,.25)}
.cr-cabin-img{width:150px;flex:none}
.cr-cabin-img img{width:100%;height:150px;object-fit:cover;display:block}
.cr-cabin-b{padding:14px 14px 14px 0;flex:1;display:flex;flex-direction:column;min-width:0}
.cr-cabin-name{font-weight:800;color:var(--cr-deep);font-size:15px}
.cr-cabin-size{font-size:13px;color:#5b6b7a;margin:2px 0 6px}
.cr-cabin-price b{font-size:24px;font-weight:800;color:var(--cr-accent)}
.cr-cabin-price span{color:#5b6b7a;font-size:13px}
.cr-cabin-b .qhy-btn{margin-top:auto;align-self:flex-start}
.cr-note{font-size:12.5px;color:#8a94a0;margin-top:12px;line-height:1.65}
.cr-giftbox{background:linear-gradient(135deg,color-mix(in srgb,var(--cr-accent) 15%,#fff),color-mix(in srgb,var(--cr-accent) 40%,#fff));border:2px solid color-mix(in srgb,var(--cr-accent) 62%,#fff);border-radius:16px;padding:18px 20px;margin-bottom:18px;box-shadow:0 12px 30px -12px color-mix(in srgb,var(--cr-accent) 48%,transparent);position:relative;overflow:hidden}
.cr-giftbox::before{content:"";position:absolute;right:-40px;top:-40px;width:150px;height:150px;background:radial-gradient(circle,rgba(255,255,255,.6),transparent 70%);pointer-events:none}
.cr-gift-top{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:13px}
.cr-gift-badge{background:linear-gradient(135deg,var(--cr-accent),color-mix(in srgb,var(--cr-accent) 70%,#000));color:#fff;font-weight:800;font-size:15.5px;padding:7px 16px;border-radius:999px;box-shadow:0 5px 14px color-mix(in srgb,var(--cr-accent) 42%,transparent);letter-spacing:.5px;white-space:nowrap}
.cr-gift-val{font-size:18px;font-weight:700;color:color-mix(in srgb,var(--cr-accent) 60%,#000)}
.cr-gift-val b{font-size:27px;font-weight:900;color:#d8281f;margin:0 2px}
.cr-gift-chips{display:flex;flex-wrap:wrap;gap:8px;position:relative}
.cr-gift-chip{background:#fff;border:1px solid color-mix(in srgb,var(--cr-accent) 45%,#fff);color:color-mix(in srgb,var(--cr-accent) 60%,#000);padding:6px 13px;border-radius:999px;font-size:13px;font-weight:600;box-shadow:0 1px 3px rgba(180,140,40,.15)}
.cr-fees{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cr-fee-col{border:1px solid #e4edf5;border-radius:14px;padding:16px 18px}
.cr-fee-col h4{margin:0 0 10px;font-size:15px}
.cr-inc h4{color:#0F6E56}.cr-exc h4{color:#b04a4a}
.cr-fee-col ul{margin:0;padding-left:18px}
.cr-fee-col li{margin-bottom:7px;line-height:1.6;font-size:14px;color:#3a4654}
.cr-shipsec{background:#f4f8fc;border-radius:18px;padding:24px}
.cr-specs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:18px 0}
.cr-spec{background:#fff;border:1px solid #e4edf5;border-radius:12px;padding:12px 14px;text-align:center}
.cr-spec-k{display:block;font-size:12.5px;color:#5b6b7a}
.cr-spec-v{display:block;font-size:17px;font-weight:800;color:var(--cr-deep);margin-top:3px}
.cr-ship-hero{width:100%;height:auto;border-radius:14px;display:block;margin:0 0 18px;box-shadow:0 14px 34px -16px rgba(11,28,54,.4)}
.cr-onbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.cr-onb{margin:0;border-radius:12px;overflow:hidden;position:relative}
.cr-onb img{width:100%;height:155px;object-fit:cover;display:block}
.cr-onb figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(0,0,0,.6));color:#fff;padding:20px 12px 8px;font-size:13px;font-weight:600}
.cr-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.cr-g{margin:0;border-radius:12px;overflow:hidden;position:relative}
.cr-g img{width:100%;height:172px;object-fit:cover;display:block;transition:transform .45s}
.cr-g:hover img{transform:scale(1.06)}
.cr-g figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,color-mix(in srgb,var(--cr-deep) 85%,transparent));color:#fff;padding:26px 12px 10px}
.cr-g figcaption b{display:block;font-size:15px}
.cr-g figcaption span{font-size:12px;opacity:.85}
.cr-pols{display:grid;gap:2px}
.cr-pol{display:grid;grid-template-columns:130px 1fr;gap:14px;padding:12px 0;border-bottom:1px solid #eef2f6}
.cr-pol-k{font-weight:800;color:var(--cr-deep);font-size:14px}
.cr-pol-v{color:#3a4654;font-size:14px;line-height:1.6}
.cr-disc{list-style:none;padding:0;margin:30px 0 0;font-size:12px;color:#95a0ab;line-height:1.75}
.cr-disc li::before{content:"* "}
.cr-bottomcta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:linear-gradient(135deg,var(--cr-deep),var(--cr-deep2));border-radius:18px;padding:22px 26px;margin-top:38px;color:#fff}
.cr-bc-t{font-size:16px}
.cr-bc-t b{color:var(--cr-price)}
/* listing */
.cr-list{max-width:1100px;margin:0 auto;padding:24px 24px 60px}
.cr-list-hero{text-align:center;padding:30px 0 26px}
.cr-list-hero h1{font-size:clamp(28px,5vw,42px);color:#102a4c;margin:0}
.cr-list-hero p{color:#5b6b7a;margin-top:8px}
.cr-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px}
.cr-card{display:block;border-radius:16px;overflow:hidden;background:#fff;border:1px solid #e4edf5;box-shadow:0 14px 34px -16px rgba(0,0,0,.28);text-decoration:none;color:inherit;transition:transform .16s,box-shadow .16s}
.cr-card:hover{transform:translateY(-5px);box-shadow:0 22px 44px -16px rgba(0,0,0,.36)}
.cr-card-img{height:210px;background-size:cover;background-position:center;position:relative}
.cr-card-tag{position:absolute;top:12px;left:12px;background:var(--cr-accent);color:#1a1205;font-weight:800;padding:5px 12px;border-radius:999px;font-size:13px}
.cr-card-b{padding:16px 18px 18px}
.cr-card-ship{font-size:12.5px;color:color-mix(in srgb,var(--cr-accent) 78%,#000);font-weight:700}
.cr-card-b h3{margin:4px 0 6px;font-size:20px;color:var(--cr-deep)}
.cr-card-meta{font-size:13px;color:#5b6b7a}
.cr-card-route{font-size:13px;color:#3a4654;margin-top:8px;line-height:1.5}
.cr-card-link{display:inline-block;margin-top:12px;color:var(--cr-deep2);font-weight:800;font-size:14px}
@media(max-width:760px){
  .cr-hl,.cr-cabins,.cr-fees{grid-template-columns:1fr}
  .cr-specs{grid-template-columns:repeat(2,1fr)}
  .cr-onbs{grid-template-columns:repeat(2,1fr)}
  .cr-gallery{grid-template-columns:repeat(2,1fr)}
  .cr-pol{grid-template-columns:1fr;gap:2px}
  .cr-bottomcta{flex-direction:column;align-items:flex-start}
}




.cr-page{--accent:var(--cr-deep2)}  /* 邮轮：行程日标签/节点圆点等品牌橙→蓝 */


/* 邮轮 CTA 按钮 = Champagne hairline on navy (改良版·提亮首图对比) */
.cr-page .cr-cta{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:15px;letter-spacing:.04em;
  padding:14px 30px;border-radius:999px;text-decoration:none;position:relative;isolation:isolate;cursor:pointer;color:var(--cr-btn-text);
  background:linear-gradient(180deg,var(--cr-btn1),var(--cr-btn2));border:1.5px solid var(--cr-btn-border);
  box-shadow:0 10px 26px -10px rgba(5,14,30,.65),inset 0 1px 0 rgba(244,229,188,.18);
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s ease,border-color .25s ease,background .25s ease,color .2s ease;-webkit-font-smoothing:antialiased}
.cr-page .cr-cta::after{content:"";position:absolute;left:14px;right:14px;top:1px;height:42%;border-radius:999px;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,0))}
.cr-page .cr-cta:hover{transform:translateY(-2px);color:var(--cr-btn-text);border-color:var(--cr-btn-border);
  background:linear-gradient(180deg,color-mix(in srgb,var(--cr-btn1) 86%,#fff),color-mix(in srgb,var(--cr-btn2) 86%,#fff));
  box-shadow:0 16px 34px -12px rgba(5,14,30,.7),0 0 24px -6px color-mix(in srgb,var(--cr-btn-border) 55%,transparent),inset 0 1px 0 rgba(244,229,188,.24)}


/* 邮轮：头图右上角徽章 + 价格浮动提示 */
.cr-emblem{position:absolute;top:18px;right:22px;width:186px;height:auto;z-index:2;
  filter:drop-shadow(0 2px 3px rgba(0,0,0,.45)) drop-shadow(0 6px 16px rgba(0,0,0,.35))}
.cr-pricewarn{display:flex;align-items:center;gap:8px;font-weight:800;font-size:14.5px;
  color:#a8261b;background:linear-gradient(135deg,#fff1ee,#ffe3dd);border:1.5px solid #f3b6ac;
  border-left:5px solid #d8281f;border-radius:12px;padding:11px 16px;margin:0 0 16px}
@media(max-width:760px){.cr-emblem{width:128px;top:12px;right:12px}}


/* 热门景点 */
.spot-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.spot-card{position:relative;display:block;border-radius:14px;overflow:hidden;aspect-ratio:4/3;text-decoration:none;box-shadow:0 10px 26px -16px rgba(0,0,0,.3)}
.spot-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s}
.spot-card:hover img{transform:scale(1.07)}
.spot-in{position:absolute;left:0;right:0;bottom:0;padding:26px 12px 10px;background:linear-gradient(transparent,rgba(11,28,54,.85));color:#fff}
.spot-name{display:block;font-size:16px;font-weight:800;text-shadow:0 1px 6px rgba(0,0,0,.5)}
.spot-n{font-size:12px;opacity:.92}
@media(max-width:900px){.spot-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.spot-grid{grid-template-columns:repeat(2,1fr)}}


/* 为什么选择我们 */
.whyus{display:grid;grid-template-columns:.82fr 1.18fr;gap:46px;align-items:center}
.whyus-img{position:relative}
.whyus-img img{width:100%;max-height:500px;object-fit:cover;object-position:center top;border-radius:20px;display:block;box-shadow:0 24px 55px -22px rgba(20,30,80,.42)}
.wu-plane{position:absolute;top:-16px;right:-6px;font-size:42px;transform:rotate(10deg);filter:drop-shadow(0 4px 8px rgba(0,0,0,.22))}
.wu-pin{position:absolute;top:16px;left:-10px;background:#fff;color:#e0316f;font-weight:800;font-size:12.5px;letter-spacing:.1em;padding:6px 13px;border-radius:999px;box-shadow:0 10px 22px -8px rgba(0,0,0,.32)}
.whyus-body h2{font-size:clamp(26px,3.6vw,40px);color:#16185a;margin:0 0 24px;font-weight:900;letter-spacing:.5px}
.wu-feat{margin-bottom:22px}
.wu-feat h3{font-size:20px;color:#4a5bd4;margin:0 0 7px;font-weight:800}
.wu-feat p{font-size:15px;line-height:1.85;color:#475569;margin:0;max-width:660px}
.whyus-body .qhy-btn{margin-top:8px}
@media(max-width:820px){.whyus{grid-template-columns:1fr;gap:24px}.whyus-img img{max-height:340px}.wu-plane{font-size:34px}}


/* 为什么选择我们 (纯文字版) */
.whyus2{padding:6px 0}
.whyus2-h{font-size:clamp(26px,3.6vw,40px);color:#16185a;font-weight:900;margin:0 0 26px;letter-spacing:.5px}
.whyus2-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.wu2{border-radius:18px;padding:26px 24px;box-shadow:0 16px 36px -22px rgba(30,40,90,.35)}
.wu2-ic{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;background:rgba(255,255,255,.78);font-size:24px;box-shadow:0 6px 16px -8px rgba(0,0,0,.2);margin-bottom:14px}
.wu2 h3{font-size:20px;font-weight:800;margin:0 0 9px}
.wu2 p{font-size:14.5px;line-height:1.8;color:#46506a;margin:0}
.wu2-a{background:linear-gradient(160deg,#eef4ff,#dde9ff)} .wu2-a h3{color:#2f55d4}
.wu2-b{background:linear-gradient(160deg,#f4edff,#e7d9ff)} .wu2-b h3{color:#7a45d2}
.wu2-c{background:linear-gradient(160deg,#fff4e8,#ffe6cf)} .wu2-c h3{color:#d9781d}
.wu2-more{display:inline-block;margin-top:24px;color:#4a5bd4;font-weight:800;font-size:15px;text-decoration:none}
.wu2-more:hover{text-decoration:underline}
@media(max-width:820px){.whyus2-grid{grid-template-columns:1fr;gap:18px}}}
