/* ============================================================
   Wander & Wonder · 悠游漫游 — Marketing Site
   Modern Travel direction (navy + teal)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,500&family=DM+Sans:wght@300;400;500;600;700&family=Montserrat:wght@800;900&family=Noto+Serif+SC:wght@500;700;900&family=Noto+Sans+SC:wght@300;400;500;700&display=swap');

:root{
  /* All-blue refined palette — midnight → cobalt → ice */
  --navy:#0a1c3d;--navy-deep:#050d1f;--blue:#14306b;--sky:#3b6fc4;
  --teal:#2f6fe5;--teal-2:#1e4fb8;--teal-soft:rgba(47,111,229,.15);
  --gold:#6ba0ff;--gold-soft:#8ab4ff;--gold-deep:#3b6fc4;
  --red:#1e4fb8;--green:#3db87a;--whatsapp:#25D366;
  --ink-1:#0a1c3d;--ink-2:#14254a;--ink-3:#2c3e60;--muted:#6b7e9c;--muted-2:#a0afc5;
  --bg:#ffffff;--bg-warm:#f3f6fc;--bg-cool:#eef3fb;
  --bdr:#d4e1f2;--bdr-warm:#dbe5f3;
  --r-sm:9px;--r-md:13px;--r-lg:18px;--r-xl:22px;--r-pill:50px;
  --ff-display:'Playfair Display','Noto Serif SC',Georgia,serif;
  --ff-body:'DM Sans','Noto Sans SC',system-ui,sans-serif;
  --ff-cn:'Noto Sans SC','DM Sans',sans-serif;
  --shadow-sm:0 4px 20px rgba(12,34,72,.06);
  --shadow-md:0 8px 30px rgba(12,34,72,.1);
  --shadow-lg:0 24px 60px rgba(12,34,72,.16);
  --shadow-cta:0 6px 24px rgba(47,111,229,.45);
  --shadow-gold:0 6px 20px rgba(107,160,255,.3);
  --t-fast:.2s cubic-bezier(.4,0,.2,1);
  --t:.3s cubic-bezier(.4,0,.2,1);
  --t-slow:.6s cubic-bezier(.4,0,.2,1);
  --section-pad:120px;
  --container:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--ff-body);color:var(--ink-2);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased}
:lang(zh),html[data-lang="zh"] body{font-family:var(--ff-cn)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}

.container{max-width:var(--container);margin:0 auto;padding:0 32px}
section{padding:var(--section-pad) 0}

/* ── Top bar ── */
.topbar{background:#000;color:rgba(255,255,255,.7);font-size:.78rem;padding:8px 0;position:relative;z-index:1001}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.tb-left{display:flex;gap:24px;flex-wrap:wrap}
.tb-left a,.tb-left span{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.75);transition:color var(--t-fast)}
.tb-left a:hover{color:var(--gold)}
.tb-right{display:flex;gap:14px}
.tb-right a{color:rgba(255,255,255,.6);transition:color var(--t-fast)}
.tb-right a:hover{color:var(--gold)}

/* ── Header / nav ── */
header.nav{position:sticky;top:0;z-index:1000;background:rgba(12,34,72,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06);transition:background var(--t)}
header.nav .container{display:flex;align-items:center;justify-content:space-between;height:80px;gap:24px}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo img{height:54px;width:54px;object-fit:contain;border-radius:50%}
.logo-txt{display:flex;flex-direction:column;line-height:1.05}
.logo-txt strong{font-family:var(--ff-display);font-weight:900;font-size:.92rem;color:#fff;letter-spacing:.02em}
.logo-txt small{font-family:var(--ff-cn);font-size:.7rem;color:rgba(255,255,255,.6);letter-spacing:.18em;margin-top:2px}
.nav-menu{display:flex;gap:28px;list-style:none}
.nav-menu a{color:rgba(255,255,255,.85);font-size:.85rem;font-weight:500;letter-spacing:.04em;position:relative;padding:6px 0;transition:color var(--t-fast)}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--teal);transition:width var(--t)}
.nav-menu a:hover{color:#fff}
.nav-menu a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:18px;flex-shrink:0}
.lang-switcher{display:flex;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.15);overflow:hidden;background:rgba(0,0,0,.25)}
.lang-btn{padding:6px 12px;font-size:.74rem;font-weight:700;letter-spacing:.04em;color:rgba(255,255,255,.55);transition:all var(--t-fast)}
.lang-btn:hover{color:#fff}
.lang-btn.active{background:#fff;color:#000}
.cta-primary{background:var(--teal);color:#fff;padding:10px 22px;border-radius:var(--r-pill);font-size:.84rem;font-weight:700;letter-spacing:.02em;transition:all var(--t);box-shadow:var(--shadow-cta);display:inline-flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}
.cta-primary:hover{background:var(--teal-2);transform:translateY(-2px);box-shadow:0 10px 32px rgba(47,111,229,.55)}
.menu-btn{display:none;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;color:#fff;background:rgba(255,255,255,.08)}
.menu-btn span{width:20px;height:2px;background:#fff;position:relative;transition:all var(--t)}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;width:20px;height:2px;background:#fff;left:0;transition:all var(--t)}
.menu-btn span::before{top:-7px}.menu-btn span::after{top:7px}

/* ── Mobile menu ── */
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1100;opacity:0;pointer-events:none;transition:opacity var(--t)}
.mobile-overlay.open{opacity:1;pointer-events:auto}
.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:min(360px,84vw);background:var(--navy);z-index:1101;padding:24px;transform:translateX(100%);transition:transform var(--t-slow);display:flex;flex-direction:column;gap:24px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu .close-x{align-self:flex-end;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;font-size:1.4rem;display:flex;align-items:center;justify-content:center}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px}
.mobile-menu nav a{color:rgba(255,255,255,.85);font-size:1.05rem;font-weight:500;padding:14px 12px;border-radius:10px;transition:all var(--t-fast)}
.mobile-menu nav a:hover{background:rgba(255,255,255,.06);color:var(--teal)}
.mobile-lang{display:flex;gap:4px;justify-content:center;margin-top:auto}

/* ── Hero ── */
.hero{position:relative;min-height:calc(100vh - 32px);display:flex;align-items:center;justify-content:center;padding:80px 0 120px;color:#fff;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2;background:linear-gradient(135deg,rgba(6,17,42,.65) 0%,rgba(12,34,72,.5) 45%,rgba(13,58,90,.4) 75%,rgba(9,58,58,.5) 100%),url('https://images.unsplash.com/photo-1545893835-abaa50cbe628?fm=jpg&q=80&w=2400&auto=format&fit=crop') center/cover no-repeat}
.hero-bg image-slot{width:100%;height:100%;display:block;opacity:.55;mix-blend-mode:screen}
.hero-video{width:100%;height:100%;object-fit:cover;display:block;opacity:.7}

/* ── Showreel video section ── */
.showreel{padding:0;background:#000;position:relative}
.showreel-inner{max-width:1280px;margin:0 auto;padding:40px 32px;position:relative}
.showreel-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:20px;flex-wrap:wrap}
.showreel-head h2{font-family:var(--ff-display);font-weight:900;font-size:clamp(1.8rem,3vw,2.6rem);color:#fff;line-height:1.15;letter-spacing:-.01em;margin-bottom:8px}
.showreel-head h2 em{font-style:normal;color:var(--teal)}
.showreel-head .eyebrow{color:var(--gold-soft);margin-bottom:10px}
.showreel-head p{color:rgba(255,255,255,.6);font-size:.95rem;max-width:420px;line-height:1.7}
.showreel-frame{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9;background:#06112a;box-shadow:0 24px 80px rgba(0,0,0,.6)}
.showreel-frame video{width:100%;height:100%;object-fit:cover;display:block}
.showreel-frame::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);pointer-events:none}
@media (max-width:640px){.showreel-inner{padding:56px 24px}.showreel-head{flex-direction:column;align-items:flex-start}}
.hero-overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(135deg,rgba(5,13,31,.9) 0%,rgba(10,28,61,.7) 50%,rgba(20,48,107,.5) 100%)}
.hero-grid{position:absolute;inset:0;z-index:-1;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%)}
.hero-glow{position:absolute;width:800px;height:800px;border-radius:50%;background:radial-gradient(ellipse,rgba(47,111,229,.22) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1;animation:pulse 6s ease-in-out infinite}
@keyframes pulse{50%{opacity:.65}}
.hero-orb{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06);z-index:-1}
.hero-orb.o1{width:520px;height:520px;top:-100px;right:-120px;animation:rot 40s linear infinite}
.hero-orb.o2{width:340px;height:340px;bottom:-80px;left:-80px;animation:rot 28s linear infinite reverse}
.hero-stars{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.hero-stars span{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;box-shadow:0 0 6px 1px rgba(255,255,255,.8),0 0 12px 2px rgba(138,180,255,.5);animation:twinkle var(--d,3s) ease-in-out infinite;opacity:0}
.hero-stars span.lg{width:3px;height:3px;box-shadow:0 0 10px 2px rgba(255,255,255,.9),0 0 22px 4px rgba(138,180,255,.6)}
.hero-stars span.gold{box-shadow:0 0 8px 2px rgba(255,222,150,.85),0 0 18px 3px rgba(255,200,120,.5)}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.4)}50%{opacity:1;transform:scale(1)}}
@keyframes rot{to{transform:rotate(360deg)}}
.hero-content{text-align:center;max-width:920px;padding:0 32px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;margin-bottom:32px}
.hero-eyebrow::before,.hero-eyebrow::after{content:"";width:36px;height:1px;background:var(--gold-soft)}
.hero h1{font-family:var(--ff-display);font-weight:900;font-size:clamp(2.4rem,5.5vw,4.6rem);line-height:1.15;letter-spacing:-.01em;margin-bottom:32px;color:#fff}
.hero h1 em{font-style:normal;color:var(--teal);position:relative;display:inline-block;white-space:nowrap;padding-bottom:.08em}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:var(--teal);opacity:.18;border-radius:3px}
.hero-sub{font-family:var(--ff-display);font-style:italic;font-weight:500;font-size:clamp(.95rem,1.5vw,1.2rem);letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:28px}
.hero-desc{font-size:1rem;line-height:1.85;color:rgba(255,255,255,.78);max-width:640px;margin:0 auto 40px}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--r-pill);font-size:.92rem;font-weight:700;letter-spacing:.02em;transition:all var(--t);white-space:nowrap}
.btn-emoji{font-size:1.1em;line-height:1;display:inline-block}
.btn-tealbg{background:var(--teal);color:#fff;box-shadow:var(--shadow-cta)}
.btn-tealbg:hover{background:var(--teal-2);transform:translateY(-3px);box-shadow:0 12px 36px rgba(47,111,229,.55)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.45);color:#fff;background:rgba(255,255,255,.04)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-dark{background:var(--ink-1);color:#fff}
.btn-dark:hover{background:var(--navy);transform:translateY(-2px)}
.btn-outline-dark{border:1.5px solid var(--ink-2);color:var(--ink-2)}
.btn-outline-dark:hover{background:var(--ink-2);color:#fff}
.btn-red{background:var(--red);color:#fff;box-shadow:0 6px 24px rgba(20,48,107,.4)}
.btn-red:hover{background:#0a1c3d;transform:translateY(-3px)}

.scroll-hint{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);font-size:.58rem;letter-spacing:.28em;color:rgba(255,255,255,.42);text-transform:uppercase;writing-mode:horizontal-tb;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.scroll-hint::after{content:"";width:1px;height:48px;background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);animation:scroll-line 2.5s ease-in-out infinite}
@keyframes scroll-line{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ── Stats strip ── */
.stats{background:var(--navy-deep);padding:56px 0;color:#fff;position:relative}
.stats::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:48px 48px;opacity:.5}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative}
.stat{text-align:center;padding:0 16px;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:0;top:20%;bottom:20%;width:1px;background:rgba(255,255,255,.1)}
.stat-num{font-family:var(--ff-display);font-size:clamp(2.4rem,4vw,3.2rem);font-weight:900;color:var(--gold);line-height:1;letter-spacing:-.02em;margin-bottom:8px;display:block}
.stat-label{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500}
.stat-zh{font-size:.95rem;color:rgba(255,255,255,.85);margin-top:6px}

/* ── Section heading common ── */
.eyebrow{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
.eyebrow.gold{color:var(--gold-soft)}
.eyebrow.red{color:var(--red)}
.section-title{font-family:var(--ff-display);font-weight:900;font-size:clamp(2rem,3.6vw,2.9rem);line-height:1.15;color:var(--navy);letter-spacing:-.01em;margin-bottom:18px}
.section-title em{font-style:normal;color:var(--teal)}
.section-sub{font-size:1.02rem;line-height:1.8;color:var(--muted);max-width:640px}
.section-head{margin-bottom:64px}
.section-head.center{text-align:center}
.section-head.center .section-sub{margin:0 auto}

/* ── About ── */
.about{background:var(--bg)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-vis{position:relative}
.about-vis .frame{position:relative;border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg)}
.about-vis .frame::before{content:"";position:absolute;inset:0;border:2px solid var(--gold-soft);border-radius:var(--r-xl);transform:translate(20px,20px);z-index:-1}
.about-vis image-slot{width:100%;height:100%}
.about-badge{position:absolute;bottom:-24px;right:-24px;background:var(--blue);color:#fff;border-radius:var(--r-md);padding:18px 22px;text-align:center;box-shadow:0 12px 36px rgba(20,48,107,.45)}
.about-badge strong{display:block;font-family:var(--ff-display);font-size:2rem;font-weight:900;line-height:1}
.about-badge span{display:block;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;margin-top:4px;opacity:.85}
.about-feats{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:32px 0}
.about-feat{display:flex;gap:14px;align-items:flex-start}
.feat-ico{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--teal),var(--sky));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 6px 18px rgba(12,184,164,.32)}
.feat-ico svg{width:22px;height:22px}
.about-feat strong{display:block;font-weight:700;color:var(--navy);font-size:.96rem;margin-bottom:2px}
.about-feat span{font-size:.85rem;color:var(--muted);line-height:1.5}

/* ── Services ── */
.services{background:var(--bg-warm)}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.svc-card{background:#fff;border-radius:var(--r-lg);padding:0 0 32px;border:1px solid var(--bdr-warm);transition:all var(--t);position:relative;overflow:hidden}
.svc-img{display:block;width:100%;height:200px;background:#1a3a7e}
.svc-body{padding:24px 28px 0}
.svc-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--sky));transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:rgba(47,111,229,.35)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-ico{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,var(--teal),var(--sky));display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:20px;box-shadow:0 8px 22px rgba(12,184,164,.32)}
.svc-ico svg{width:30px;height:30px}
.svc-card h3{font-family:var(--ff-display);font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:10px;line-height:1.25}
.svc-card h3 small{display:block;font-family:var(--ff-body);font-size:.74rem;font-weight:500;color:var(--muted);margin-top:4px;letter-spacing:.04em}
.svc-card p{font-size:.88rem;line-height:1.7;color:var(--muted);margin-bottom:14px}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px}
.svc-tag{font-size:.7rem;padding:3px 10px;border-radius:var(--r-pill);background:var(--teal-soft);color:var(--teal);font-weight:500}

/* ── SEO guide ── */
.seo-guide{background:#fff;padding:96px 0;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.seo-guide-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.seo-guide-copy p{font-size:1rem;line-height:1.9;color:var(--muted);margin-bottom:16px}
.seo-guide-points{display:grid;gap:14px}
.seo-guide-points article{padding:24px 26px;border:1px solid var(--bdr);border-radius:var(--r-md);background:linear-gradient(180deg,#f8fbff 0%,#fff 100%);box-shadow:0 12px 32px rgba(10,28,61,.05)}
.seo-guide-points strong{display:block;color:var(--navy);font-family:var(--ff-display);font-size:1.08rem;margin-bottom:8px}
.seo-guide-points p{font-size:.92rem;line-height:1.75;color:var(--muted);margin:0}

/* ── Content hub ── */
.content-hub{background:linear-gradient(180deg,#f8fbff 0%,#fff 100%);padding:88px 0;border-bottom:1px solid var(--bdr)}
.content-hub-head{max-width:760px;margin-bottom:34px}
.content-hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.insight-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);padding:26px;min-height:260px;display:flex;flex-direction:column;box-shadow:0 14px 34px rgba(10,28,61,.06);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.insight-card:hover{transform:translateY(-4px);box-shadow:0 20px 42px rgba(10,28,61,.1);border-color:#b9d3f7}
.insight-card span{font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:16px}
.insight-card h3{font-family:var(--ff-display);font-size:1.35rem;line-height:1.25;color:var(--navy);margin-bottom:14px}
.insight-card p{font-size:.94rem;line-height:1.78;color:var(--muted);margin:0 0 20px}
.insight-card a{margin-top:auto;font-weight:800;color:var(--red);font-size:.9rem}

/* ── Destinations ── */
.destinations{background:var(--bg)}
.destinations-world{background:linear-gradient(180deg,#eef5fb 0%,#f8fbff 100%);border-top:1px solid #d9e6f5;border-bottom:1px solid #d9e6f5}
.destinations-malaysia{background:linear-gradient(180deg,#f2fbf8 0%,#ffffff 100%);border-top:1px solid #d6ebe4;border-bottom:1px solid #d6ebe4}
.destinations-world + .why{background:#fff}
.dest-block{margin-top:64px}
.section-head + .dest-block{margin-top:0}
.dest-block-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:24px;border-bottom:1px solid var(--bdr);padding-bottom:18px}
.dest-block-head h3{font-family:var(--ff-display);font-weight:900;font-size:clamp(1.6rem,2.6vw,2.35rem);line-height:1.15;color:var(--navy);margin:0}
.dest-block-head p{font-size:.95rem;line-height:1.7;color:var(--muted);max-width:520px;margin:0;text-align:right}
.dest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.dest-card{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;cursor:pointer;background:var(--navy)}
.dest-photo-stack{position:absolute;inset:0;z-index:0}
.dest-card image-slot,
.gallery-cell image-slot{touch-action:pan-y pinch-zoom}
.dest-photo-stack image-slot{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;opacity:0;transform:scale(1.04);filter:brightness(.82) saturate(.95);transition:none;transform-origin:center}
.dest-photo-stack image-slot:first-child{opacity:1;transform:scale(1.02);filter:brightness(.88) saturate(.95)}
.dest-card:hover .dest-photo-stack image-slot:nth-child(1){animation:dest-photo-cycle-1 6s infinite}
.dest-card:hover .dest-photo-stack image-slot:nth-child(2){animation:dest-photo-cycle-2 6s infinite}
.dest-card:hover .dest-photo-stack image-slot:nth-child(3){animation:dest-photo-cycle-3 6s infinite}
.dest-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,17,42,.88) 0%,rgba(12,34,72,.38) 55%,rgba(6,17,42,.05) 100%);z-index:1;pointer-events:none;transition:background var(--t-med)}
.dest-card:hover::after{background:linear-gradient(to top,rgba(6,17,42,.76) 0%,rgba(12,34,72,.22) 56%,rgba(6,17,42,.02) 100%)}
@keyframes dest-photo-cycle-1{
  0%{opacity:1;transform:scale(1.02);filter:brightness(1.08) saturate(1.03)}
  30%{opacity:1;transform:scale(1.12);filter:brightness(1.08) saturate(1.03)}
  36%{opacity:0;transform:scale(1.14);filter:brightness(.82) saturate(.95)}
  94%{opacity:0;transform:scale(1.02);filter:brightness(.82) saturate(.95)}
  100%{opacity:1;transform:scale(1.02);filter:brightness(1.08) saturate(1.03)}
}
@keyframes dest-photo-cycle-2{
  0%,30%{opacity:0;transform:scale(1.02);filter:brightness(.82) saturate(.95)}
  36%{opacity:1;transform:scale(1.02);filter:brightness(1.08) saturate(1.03)}
  63%{opacity:1;transform:scale(1.12);filter:brightness(1.08) saturate(1.03)}
  69%,100%{opacity:0;transform:scale(1.14);filter:brightness(.82) saturate(.95)}
}
@keyframes dest-photo-cycle-3{
  0%,63%{opacity:0;transform:scale(1.02);filter:brightness(.82) saturate(.95)}
  69%{opacity:1;transform:scale(1.02);filter:brightness(1.08) saturate(1.03)}
  94%{opacity:1;transform:scale(1.12);filter:brightness(1.08) saturate(1.03)}
  100%{opacity:0;transform:scale(1.14);filter:brightness(.82) saturate(.95)}
}
.dest-info{position:absolute;left:24px;right:24px;bottom:24px;color:#fff;z-index:2;pointer-events:none}
.dest-tag{display:inline-block;font-size:.66rem;padding:4px 10px;border-radius:var(--r-pill);background:rgba(255,255,255,.95);color:var(--navy);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;position:absolute;top:20px;left:20px;z-index:3;pointer-events:none}
.dest-tag.popular{background:var(--red);color:#fff}
.dest-tag.recommend{background:var(--teal);color:#fff}
.dest-rot-dots{position:absolute;right:20px;bottom:24px;z-index:3;display:flex;gap:7px;pointer-events:none}
.dest-rot-dots i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.45)}
.dest-rot-dots i:first-child{background:#fff;transform:scale(1.35)}
.dest-card:hover .dest-rot-dots i:nth-child(1){animation:dest-dot-cycle-1 6s infinite}
.dest-card:hover .dest-rot-dots i:nth-child(2){animation:dest-dot-cycle-2 6s infinite}
.dest-card:hover .dest-rot-dots i:nth-child(3){animation:dest-dot-cycle-3 6s infinite}
@keyframes dest-dot-cycle-1{
  0%,30%,100%{background:#fff;transform:scale(1.35)}
  36%,94%{background:rgba(255,255,255,.45);transform:scale(1)}
}
@keyframes dest-dot-cycle-2{
  0%,30%,69%,100%{background:rgba(255,255,255,.45);transform:scale(1)}
  36%,63%{background:#fff;transform:scale(1.35)}
}
@keyframes dest-dot-cycle-3{
  0%,63%,100%{background:rgba(255,255,255,.45);transform:scale(1)}
  69%,94%{background:#fff;transform:scale(1.35)}
}
@media (hover:none) and (pointer:coarse) and (prefers-reduced-motion:no-preference){
  .dest-photo-stack image-slot:nth-child(1){animation:dest-photo-cycle-1 6s infinite}
  .dest-photo-stack image-slot:nth-child(2){animation:dest-photo-cycle-2 6s infinite}
  .dest-photo-stack image-slot:nth-child(3){animation:dest-photo-cycle-3 6s infinite}
  .dest-rot-dots i:nth-child(1){animation:dest-dot-cycle-1 6s infinite}
  .dest-rot-dots i:nth-child(2){animation:dest-dot-cycle-2 6s infinite}
  .dest-rot-dots i:nth-child(3){animation:dest-dot-cycle-3 6s infinite}
}
.dest-more{display:flex;justify-content:center;margin-top:48px}
.dest-more .btn{padding:16px 36px}
.dest-info h3{font-family:var(--ff-display);font-weight:900;font-size:1.45rem;margin-bottom:4px}
.dest-info h3 em{font-style:normal;font-family:var(--ff-cn);font-weight:500;font-size:.85em;color:rgba(255,255,255,.78);display:block;letter-spacing:.08em;margin-top:2px}
.dest-info .region{font-size:.8rem;color:rgba(255,255,255,.65);margin-bottom:10px}
.dest-info .price{font-size:.82rem;color:var(--gold);font-weight:600}
.dest-info .price strong{font-family:var(--ff-display);font-size:1.05rem;color:#fff;font-weight:900;margin-left:6px}

/* ── Custom intro ── */
.custom{background:var(--bg-warm)}
.custom-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
.custom-vis{position:relative}
.custom-vis .frame{position:relative;border-radius:50%;overflow:hidden;aspect-ratio:1;max-width:520px;margin:0 auto;box-shadow:var(--shadow-lg)}
.custom-vis .frame::before{content:"";position:absolute;inset:-12px;border:2px dashed var(--gold-soft);border-radius:50%;animation:rot 60s linear infinite}
.custom-vis image-slot{width:100%;height:100%}
.custom-list{display:flex;flex-direction:column;gap:16px;margin:24px 0 32px}
.custom-list li{display:flex;gap:14px;align-items:flex-start;list-style:none;font-size:.95rem;line-height:1.6;color:var(--ink-2)}
.custom-list .check{width:26px;height:26px;border-radius:50%;background:var(--gold-soft);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.custom-list .check svg{width:14px;height:14px}
.custom-list strong{display:block;font-weight:700;color:var(--navy);margin-bottom:2px}
.custom-list span{color:var(--muted);font-size:.86rem}

/* ── Process ── */
.process{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden}
.process::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 75%);opacity:.6}
.process .section-title,.process .eyebrow{color:#fff}.process .eyebrow{color:var(--teal)}
.process .section-sub{color:rgba(255,255,255,.65)}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.proc-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:36px 28px;transition:all var(--t);position:relative;overflow:hidden}
.proc-card:hover{border-color:var(--gold-soft);background:rgba(255,255,255,.07);transform:translateY(-4px)}
.proc-num{font-family:var(--ff-display);font-size:5rem;font-weight:900;color:#8b9eff;line-height:1;letter-spacing:-.04em;margin-bottom:12px;display:block}
.proc-card h3{font-family:var(--ff-display);font-size:1.25rem;font-weight:700;color:#fff;margin-bottom:8px}
.proc-card h3 small{display:block;font-family:var(--ff-body);font-size:.78rem;font-weight:400;color:rgba(255,255,255,.5);margin-top:3px}
.proc-card p{font-size:.9rem;line-height:1.7;color:rgba(255,255,255,.7)}
.proc-list{list-style:none;margin:14px 0 0;padding:14px 0 0;border-top:1px solid rgba(255,255,255,.08);display:grid;grid-template-columns:1fr 1fr;gap:6px 14px}
.proc-list li{font-size:.82rem;line-height:1.5;color:rgba(255,255,255,.78);padding-left:14px;position:relative}
.proc-list li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--gold-soft)}
.proc-cta{display:flex;justify-content:center;margin-top:56px}
.proc-cta .btn{padding:18px 42px;font-size:1rem}
.gallery-cell[data-filled] image-slot{cursor:default}

/* ── Why us ── */
.why{background:var(--bg)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why-card{background:#fff;border:1px solid var(--bdr);border-left:3px solid var(--gold-soft);border-radius:var(--r-lg);padding:32px 28px;transition:all var(--t);position:relative}
.why-card:hover{border-left-color:var(--red);transform:translateX(8px);box-shadow:var(--shadow-md)}
.why-ico{width:54px;height:54px;border-radius:14px;background:var(--bg-cool);display:flex;align-items:center;justify-content:center;color:var(--teal);margin-bottom:18px;transition:all var(--t)}
.why-card:hover .why-ico{background:var(--teal);color:#fff}
.why-ico svg{width:26px;height:26px}
.why-card h3{font-family:var(--ff-display);font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.why-card h3 small{display:block;font-family:var(--ff-body);font-size:.74rem;font-weight:500;color:var(--muted);margin-top:3px}
.why-card p{font-size:.9rem;line-height:1.7;color:var(--muted)}

/* ── Testimonials ── */
.testi{background:var(--bg-warm)}
.testi-grid{overflow:hidden;position:relative;padding:8px 0;mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%)}
.testi-track{display:flex;gap:24px;width:max-content;animation:testi-marquee 78s linear infinite;will-change:transform}
.testi-grid:hover .testi-track{animation-play-state:paused}
.testi-card{background:#fff;border-radius:var(--r-lg);padding:36px 32px;border:1px solid var(--bdr);transition:all var(--t);position:relative;width:390px;flex:0 0 390px}
.testi-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
@keyframes testi-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.testi-card .quote{position:absolute;top:24px;right:28px;font-family:var(--ff-display);font-size:5rem;line-height:.8;color:var(--gold-soft);opacity:.2}
.testi-stars{color:var(--gold);font-size:1rem;letter-spacing:2px;margin-bottom:18px}
.testi-text{font-size:.95rem;line-height:1.85;color:var(--ink-2);margin-bottom:24px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--bdr)}
.testi-avatar{width:48px!important;height:48px!important;flex:0 0 48px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--sky));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.05rem;flex-shrink:0;font-family:var(--ff-display)}
.testi-author strong{display:block;font-weight:700;color:var(--navy);font-size:.95rem}
.testi-author span{display:block;font-size:.78rem;color:var(--muted);margin-top:2px}

/* ── Gallery ── */
.gallery{background:var(--bg)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;grid-auto-rows:200px}
.gallery-cell{position:relative;border-radius:var(--r-md);overflow:hidden;cursor:pointer;background:var(--bg-cool);background-size:cover;background-position:center}
.gallery-cell.span-2{grid-column:span 2;grid-row:span 2}
.gallery-cell image-slot{width:100%;height:100%;transition:transform var(--t-slow),filter var(--t-slow)}
.gallery-cell:hover image-slot{transform:scale(1.08);filter:brightness(1.16) saturate(1.06)}
.gallery-cell::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(6,17,42,.66) 0%,rgba(6,17,42,.14) 58%,transparent 100%);opacity:0;transition:opacity var(--t);pointer-events:none}
.gallery-cell:hover::after{opacity:.82}
.gallery-cell.is-video,.gallery-cell.has-local-video{background-color:#06112a}
.gallery-cell.is-video image-slot{opacity:0;filter:none}
.gallery-cell.has-local-video image-slot{opacity:1;filter:none}
.gallery-cell.is-video::after,.gallery-cell.has-local-video::after{opacity:1;background:rgba(6,17,42,.08)}
.gallery-cell.is-video .gallery-cap{display:none}
.gallery-cell.has-local-video .gallery-cap{display:block}
.gallery-cell.is-playing::after,.gallery-cell.is-playing .gallery-play{display:none}
.gallery-embed{position:absolute;inset:0;z-index:6;width:100%;height:100%;border:0;display:block;background:#000}
.gallery-local-video{position:absolute;inset:0;z-index:6;width:100%;height:100%;object-fit:cover;display:block;background:#000}
.gallery-play{position:absolute;left:50%;top:50%;z-index:4;width:64px;height:64px;border-radius:50%;transform:translate(-50%,-50%);background:rgba(255,255,255,.94);box-shadow:0 14px 34px rgba(6,17,42,.28);display:none;align-items:center;justify-content:center;transition:transform var(--t),background var(--t)}
.gallery-play::before{content:"";display:block;margin-left:5px;border-left:18px solid var(--teal);border-top:12px solid transparent;border-bottom:12px solid transparent}
.gallery-cell.is-video .gallery-play,.gallery-cell.has-local-video .gallery-play{display:flex}
.gallery-cell.is-video:hover .gallery-play,.gallery-cell.has-local-video:hover .gallery-play{transform:translate(-50%,-50%) scale(1.06);background:#fff}
.gallery-cap{position:absolute;left:18px;right:18px;bottom:18px;color:#fff;opacity:0;transform:translateY(8px);transition:all var(--t);z-index:2;pointer-events:none}
.gallery-cell:hover .gallery-cap{opacity:1;transform:translateY(0)}
.gallery-cap strong{display:block;font-family:var(--ff-display);font-weight:700;font-size:1.05rem}
.gallery-cap span{font-size:.78rem;color:rgba(255,255,255,.7)}
.video-modal{position:fixed;inset:0;z-index:2100;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;padding:28px;opacity:0;pointer-events:none;transition:opacity var(--t)}
.video-modal.open{opacity:1;pointer-events:auto}
.video-frame{width:min(1080px,92vw);aspect-ratio:16/9;background:#000;border-radius:var(--r-md);overflow:hidden;box-shadow:0 30px 90px rgba(0,0,0,.55)}
.video-frame iframe{width:100%;height:100%;border:0;display:block}
.video-modal-close{position:absolute;top:22px;right:26px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:28px;line-height:1;display:flex;align-items:center;justify-content:center}
.video-modal-close:hover{background:rgba(255,255,255,.2)}

@media (hover:none) and (pointer:coarse){
  .dest-card,
  .gallery-cell,
  .gallery-play{touch-action:pan-y pinch-zoom}
  .gallery-cell.is-video,
  .gallery-cell.has-local-video{cursor:default}
}

/* ── FAQ ── */
.faq{background:var(--bg-warm)}
.faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--bdr);border-radius:var(--r-md);overflow:hidden;transition:all var(--t)}
.faq-item.open{border-color:var(--gold-soft);box-shadow:var(--shadow-md)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px 28px;text-align:left;font-family:var(--ff-display);font-size:1.05rem;font-weight:700;color:var(--navy);transition:color var(--t-fast)}
.faq-q:hover{color:var(--teal)}
.faq-icon{width:32px;height:32px;flex-shrink:0;border-radius:50%;border:1.5px solid var(--bdr);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all var(--t)}
.faq-item.open .faq-icon{background:var(--red);border-color:var(--red);color:#fff;transform:rotate(45deg)}
.faq-icon svg{width:16px;height:16px}
.faq-a{padding:0 28px;max-height:0;overflow:hidden;transition:max-height var(--t-slow),padding var(--t)}
.faq-item.open .faq-a{padding:0 28px 24px;max-height:500px}
.faq-a p{font-size:.95rem;line-height:1.8;color:var(--muted)}

/* ── CTA banner ── */
.cta-banner{background:linear-gradient(135deg,#050d1f 0%,#0a1c3d 50%,#14306b 100%);color:#fff;padding:140px 0;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:48px 48px;opacity:.7;mask-image:radial-gradient(ellipse at center,black 0%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 0%,transparent 70%)}
.cta-banner-glow{position:absolute;width:1000px;height:1000px;border-radius:50%;background:radial-gradient(ellipse,rgba(107,160,255,.18) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%)}
.cta-banner h2{font-family:var(--ff-display);font-weight:900;font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1.1;margin-bottom:12px;position:relative;letter-spacing:-.01em}
.cta-banner h2 em{font-style:normal;color:var(--gold)}
.cta-banner .cta-zh{font-family:var(--ff-cn);font-size:1.05rem;color:rgba(255,255,255,.6);letter-spacing:.32em;margin-bottom:24px;position:relative}
.cta-banner p{font-size:1rem;line-height:1.85;color:rgba(255,255,255,.7);max-width:580px;margin:0 auto 36px;position:relative}
.cta-btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;position:relative}

/* ── Contact ── */
.contact{background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:80px}
.contact-info{display:flex;flex-direction:column;gap:24px;margin-top:32px}
.ci-row{display:flex;gap:18px;align-items:flex-start}
.ci-ico{width:52px;height:52px;border-radius:14px;background:var(--bg-cool);color:var(--teal);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid var(--bdr)}
.ci-ico svg{width:24px;height:24px}
.ci-row strong{display:block;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:6px}
.ci-row span,.ci-row a{display:block;font-size:.95rem;color:var(--ink-2);line-height:1.5}
.contact-form{background:var(--bg-cool);border-radius:var(--r-xl);padding:44px;border:1px solid var(--bdr)}
.contact-form h3{font-family:var(--ff-display);font-weight:900;font-size:1.6rem;color:var(--navy);margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);margin-bottom:8px}
.fg input,.fg select,.fg textarea{width:100%;border:1.5px solid var(--bdr);border-radius:var(--r-sm);padding:12px 14px;font-family:inherit;font-size:.95rem;color:var(--ink-2);background:#fff;transition:all var(--t-fast)}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(47,111,229,.15)}
.fg textarea{resize:vertical;min-height:110px}
.fg-error input,.fg-error textarea{border-color:var(--red)}
.fg-msg{font-size:.78rem;color:var(--red);margin-top:6px;display:none}
.fg-error .fg-msg{display:block}
.form-success{background:rgba(61,184,122,.1);border:1px solid var(--green);color:#1d6e44;padding:18px;border-radius:var(--r-sm);margin-bottom:16px;font-size:.92rem;display:none}
.form-success.show{display:block;animation:fadein .3s}
@keyframes fadein{from{opacity:0;transform:translateY(-4px)}}
.form-submit{width:100%;background:var(--red);color:#fff;padding:16px;border-radius:var(--r-pill);font-weight:700;font-size:1rem;letter-spacing:.04em;transition:all var(--t);margin-top:8px}
.form-submit:hover{background:#0a1c3d;transform:translateY(-2px);box-shadow:0 12px 32px rgba(20,48,107,.4)}

/* ── Footer ── */
footer{background:#000;color:rgba(255,255,255,.55);padding:80px 0 32px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:48px}
.foot-brand .logo img{height:64px;width:64px}
.foot-brand .logo-txt strong{font-size:1.05rem}
.foot-brand p{margin-top:16px;font-size:.88rem;line-height:1.75;color:rgba(255,255,255,.5);max-width:300px}
.foot-soc{display:flex;gap:10px;margin-top:18px}
.foot-soc a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:all var(--t-fast)}
.foot-soc a:hover{background:var(--red);color:#fff}
.foot-soc svg{width:18px;height:18px}
.foot-col h4{font-family:var(--ff-display);font-size:.92rem;font-weight:700;color:#fff;margin-bottom:18px;letter-spacing:.04em}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a,.foot-col li{font-size:.88rem;color:rgba(255,255,255,.5);transition:color var(--t-fast)}
.foot-col a:hover{color:var(--gold)}
.foot-col li{display:flex;gap:8px;align-items:flex-start;line-height:1.5}
.foot-col li svg{width:16px;height:16px;color:var(--teal);flex-shrink:0;margin-top:3px}
.foot-bot{padding-top:28px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:rgba(255,255,255,.35);flex-wrap:wrap;gap:16px}
.foot-legal{display:flex;gap:24px}
.foot-legal a:hover{color:var(--gold)}

/* ── WhatsApp float ── */
.wa-float{position:fixed;bottom:32px;right:32px;z-index:990;width:60px;height:60px;border-radius:50%;background:var(--whatsapp);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(37,211,102,.55);animation:wapulse 2.5s ease-in-out infinite;transition:transform var(--t)}
.wa-float:hover{transform:scale(1.06)}
.wa-float svg{width:30px;height:30px}
@keyframes wapulse{0%,100%{box-shadow:0 8px 28px rgba(37,211,102,.55)}50%{box-shadow:0 8px 36px rgba(37,211,102,.7),0 0 0 14px rgba(37,211,102,.08)}}

/* ── Reveal ── */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ── Density tweak ── */
body[data-density="compact"]{--section-pad:80px}
body[data-density="cozy"]{--section-pad:120px}
body[data-density="airy"]{--section-pad:160px}

/* ── Accent tweak ── */
body[data-accent="gold"]{--teal:#3b6fc4;--teal-2:#2e58a3;--teal-soft:rgba(59,111,196,.18)}
body[data-accent="red"]{--teal:#14306b;--teal-2:#0a1c3d;--teal-soft:rgba(20,48,107,.18)}

/* ── Responsive ── */
@media (max-width:1100px){
  :root{--section-pad:80px}
  .container{padding:0 24px}
  .nav-menu,.tb-left,.tb-right{display:none}
  .nav-right>.lang-switcher,.nav-right>.cta-primary{display:none}
  .menu-btn{display:flex}
  .services-grid,.gallery-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{gap:18px}
  .dest-grid,.process-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:40px 24px}
  .stat:nth-child(2)::after{display:none}
  .about-grid,.custom-grid,.contact-grid,.seo-guide-grid,.content-hub-grid{grid-template-columns:1fr;gap:48px}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
  .gallery-grid{grid-auto-rows:160px}
}
@media (max-width:640px){
  :root{--section-pad:64px}
  header.nav .container{height:68px}
  .logo img{height:44px;width:44px}
  .logo-txt strong{font-size:.82rem}
  .logo-txt small{font-size:.62rem}
  .nav-right{margin-left:auto}
  .nav-right>.lang-switcher,.nav-right>.cta-primary{display:none}
  .menu-btn{display:flex!important;flex:0 0 42px;position:absolute;right:20px;top:13px}
  .topbar{display:none}
  .hero{padding:60px 0 80px;min-height:auto}
  .hero h1{font-size:2.2rem}
  .hero h1 em{white-space:normal}
  .hero-content{padding:0 22px}
  .dest-block{margin-top:48px}
  .dest-block-head{display:block}
  .dest-block-head p{text-align:left;margin-top:8px}
  .hero-eyebrow{font-size:.66rem;letter-spacing:.24em}
  .hero-eyebrow::before,.hero-eyebrow::after{width:20px}
  .hero-sub{font-size:.78rem;letter-spacing:.24em}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat::after{display:none!important}
  .services-grid,.dest-grid,.process-grid,.why-grid{grid-template-columns:1fr;gap:16px}
  .seo-guide{padding:64px 0}
  .seo-guide-grid{gap:28px}
  .seo-guide-points article{padding:20px}
  .content-hub{padding:64px 0}
  .content-hub-grid{gap:16px}
  .insight-card{min-height:0;padding:22px}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:130px}
  .gallery-cell.span-2{grid-column:span 2;grid-row:span 2}
  .form-row{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:32px}
  .foot-bot{flex-direction:column;text-align:center}
  .contact-form{padding:28px 22px}
  .btn{padding:12px 22px;font-size:.86rem}
  .btn,.cta-primary,.form-submit{max-width:320px;width:100%;justify-content:center}
  .hero-btns,.cta-btns{flex-direction:column;align-items:center}
  .scroll-hint{display:flex;left:50%;right:auto;bottom:12px;transform:translateX(-50%);font-size:.48rem;letter-spacing:.18em;opacity:.72}
  .scroll-hint::after{height:30px}
  .wa-float{bottom:20px;right:20px;width:54px;height:54px}
  .about-vis .frame::before{transform:translate(12px,12px)}
  .about-badge{bottom:-16px;right:-8px;padding:14px 16px}
  .about-badge strong{font-size:1.5rem}
  .testi-card{padding:28px 22px}
  .testi-track{gap:16px;animation-duration:88s}
  .testi-card{width:310px;flex-basis:310px}
  .section-head{margin-bottom:40px}
}

/* WeChat QR modal */
.wechat-modal{position:fixed;inset:0;z-index:200;background:rgba(8,12,20,.78);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease;padding:20px}
.wechat-modal.open{opacity:1;pointer-events:auto}
.wechat-modal-bd{background:#fff;border-radius:18px;padding:28px 28px 22px;max-width:340px;width:100%;text-align:center;position:relative;transform:translateY(8px) scale(.98);transition:transform .3s cubic-bezier(.2,.7,.2,1);box-shadow:0 30px 80px rgba(0,0,0,.5)}
.wechat-modal.open .wechat-modal-bd{transform:translateY(0) scale(1)}
.wechat-modal-bd img{display:block;width:100%;height:auto;border-radius:10px}
.wechat-modal-cap{margin-top:14px;display:flex;flex-direction:column;gap:2px}
.wechat-modal-cap strong{font-family:var(--ff-display);font-size:1.05rem;color:#0d1320}
.wechat-modal-cap span{font-size:.82rem;color:#6b7280;letter-spacing:.04em}
.wechat-modal-close{position:absolute;top:8px;right:10px;width:32px;height:32px;border:0;background:transparent;font-size:24px;line-height:1;color:#6b7280;cursor:pointer;border-radius:50%;transition:all .2s}
.wechat-modal-close:hover{background:#f3f4f6;color:#0d1320}
