/* ═════════════════════════════════════════════════
   HSIEHSHUN — Editorial Premium Design
   Magazine-inspired, image-rich, bold typography
   ═════════════════════════════════════════════════ */
:root{
  --f-display:'Cormorant',Georgia,serif;
  --f-body:'Outfit',sans-serif;
  --f-cjk:'Noto Serif SC',serif;
  --bg:#fafaf7;
  --paper:#ffffff;
  --paper-warm:#f4efe6;
  --paper-deep:#e8e1d0;
  --ink:#0a0a0a;
  --ink2:#1a1a1a;
  --char:#2c2c2c;
  --gray:#5a5a5a;
  --gray2:#8a8a8a;
  --gray3:#bdbdbd;
  --line:#e0d9c8;
  --line-soft:#eee9dd;
  --gold:#a07d3a;
  --gold-deep:#7a5d28;
  --accent-red:#9a3a2a;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
body{background:var(--bg);color:var(--ink2);font-family:var(--f-body);font-weight:400;overflow-x:hidden;line-height:1.5;font-size:16px;}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--paper-warm);}
::-webkit-scrollbar-thumb{background:var(--ink);}
.reg{font-size:.42em;vertical-align:super;letter-spacing:0;font-weight:400;opacity:.7;}

/* ═══════════════ NAV ═══════════════ */
nav{
  position:fixed;inset:0 0 auto;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 56px;
  background:rgba(250,250,247,.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  transition:all .4s;
}
nav.scrolled{
  padding:14px 56px;
  background:rgba(250,250,247,.98);
  border-bottom:1px solid var(--line);
}
.nav-brand{display:flex;align-items:center;gap:14px;}
.nav-mark{
  font-family:var(--f-display);
  font-size:24px;font-weight:700;letter-spacing:.18em;
  color:var(--ink);line-height:1;
}
.nav-mark-sub{
  font-family:var(--f-cjk);font-size:9px;font-weight:300;
  letter-spacing:.22em;color:var(--gray);
  margin-top:4px;
}
.nav-right{display:flex;align-items:center;gap:0;list-style:none;}
.nav-right a{
  font-family:var(--f-body);font-size:13px;font-weight:400;
  letter-spacing:.04em;color:var(--gray);
  padding:10px 18px;transition:color .3s;position:relative;
}
.nav-right a:hover,.nav-right a.active{color:var(--ink);}
.nav-right a.active::after{content:'';position:absolute;bottom:6px;left:18px;right:18px;height:1px;background:var(--gold);}
.nav-cta{
  margin-left:14px;
  font-family:var(--f-body)!important;font-size:11px!important;font-weight:500!important;
  letter-spacing:.18em!important;text-transform:uppercase;
  background:var(--ink)!important;color:#fff!important;
  padding:14px 26px!important;
  transition:all .3s;
}
.nav-cta:hover{background:var(--gold)!important;}
.nav-cta::after{display:none!important;}
.menu-toggle{display:none;width:32px;height:32px;border:none;background:transparent;cursor:pointer;flex-direction:column;justify-content:center;gap:5px;}
.menu-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);transition:all .3s;}

/* ═══════════════ HERO — EDITORIAL BIG TYPE ═══════════════ */
.editorial-hero{
  min-height:100vh;
  background:var(--bg);
  position:relative;
  display:flex;flex-direction:column;
  padding:140px 0 0;
  overflow:hidden;
}

.eh-grid{
  display:grid;grid-template-columns:1fr 1fr;
  max-width:1400px;margin:0 auto;
  padding:0 56px;
  gap:80px;align-items:center;
  flex:1;
}

.eh-left{position:relative;z-index:2;}

.eh-meta{
  display:flex;align-items:center;gap:14px;
  margin-bottom:48px;
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.32em;color:var(--gold);text-transform:uppercase;
}
.eh-meta-line{flex:0 0 28px;height:1px;background:var(--gold);}

.eh-title{
  font-family:var(--f-display);
  font-size:clamp(64px,9vw,160px);
  font-weight:600;
  line-height:.88;
  letter-spacing:-.01em;
  color:var(--ink);
  margin-bottom:8px;
}
.eh-title-italic{
  font-style:italic;
  font-weight:500;
  color:var(--gold);
}

.eh-cn{
  font-family:var(--f-cjk);font-weight:300;
  font-size:clamp(13px,1.4vw,15px);
  letter-spacing:.42em;
  color:var(--gray);
  margin-bottom:48px;
  margin-top:20px;
}

.eh-divider{
  display:flex;align-items:center;gap:24px;
  margin-bottom:36px;
}
.eh-divider-num{
  font-family:var(--f-display);font-size:14px;
  letter-spacing:.18em;color:var(--gold);font-weight:500;
}
.eh-divider-line{flex:1;height:1px;background:var(--ink);max-width:120px;}

.eh-lede{
  font-family:var(--f-body);font-size:16px;
  line-height:1.85;color:var(--char);
  max-width:480px;margin-bottom:48px;
  letter-spacing:.005em;
}

.eh-actions{display:flex;align-items:center;gap:32px;flex-wrap:wrap;}
.eh-btn{
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  background:var(--ink);color:#fff;
  padding:18px 36px;
  display:inline-flex;align-items:center;gap:14px;
  transition:all .35s;
}
.eh-btn:hover{background:var(--gold);transform:translateY(-2px);}
.eh-btn .arrow{transition:transform .3s;}
.eh-btn:hover .arrow{transform:translateX(5px);}

.eh-link{
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);
  display:inline-flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--ink);padding-bottom:6px;
  transition:all .3s;
}
.eh-link:hover{color:var(--gold);border-color:var(--gold);}

/* RIGHT — large editorial image with overlay */
.eh-right{position:relative;height:680px;}
.eh-image-wrap{
  position:relative;width:100%;height:100%;
  overflow:hidden;
}
.eh-image{
  width:100%;height:100%;
  background-image:url('https://images.unsplash.com/photo-1494412651409-8963ce7935a7?auto=format&fit=crop&w=900&q=80');
  background-size:cover;background-position:center;
  filter:grayscale(.15) contrast(1.05);
}
.eh-image-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(10,10,10,.15) 0%,rgba(10,10,10,0) 50%,rgba(10,10,10,.4) 100%);
}

/* Editorial frame number */
.eh-frame-num{
  position:absolute;
  top:24px;left:24px;
  font-family:var(--f-display);font-size:14px;
  letter-spacing:.18em;color:#fff;font-weight:400;
  background:rgba(10,10,10,.55);
  backdrop-filter:blur(8px);
  padding:8px 16px;
  z-index:2;
}

.eh-quote{
  position:absolute;
  bottom:32px;left:32px;right:32px;
  z-index:2;
  font-family:var(--f-display);font-style:italic;
  font-size:24px;font-weight:400;
  line-height:1.35;color:#fff;
  letter-spacing:.01em;
}
.eh-quote::before{content:'';display:block;width:32px;height:2px;background:var(--gold);margin-bottom:18px;}

/* Hero scroll indicator */
.eh-scroll{
  position:absolute;left:50%;bottom:32px;
  transform:translateX(-50%);
  font-family:var(--f-body);font-size:10px;letter-spacing:.32em;
  color:var(--gray);text-transform:uppercase;
  display:flex;align-items:center;gap:14px;
  z-index:3;
}
.eh-scroll-line{width:50px;height:1px;background:var(--gold);position:relative;overflow:hidden;}
.eh-scroll-line::after{content:'';position:absolute;left:-50%;top:0;width:50%;height:100%;background:var(--ink);animation:scrollPulse 2.5s ease-in-out infinite;}
@keyframes scrollPulse{0%{left:-50%;}100%{left:100%;}}

/* ═══════════════ BANNER STRIP ═══════════════ */
.banner-strip{
  background:var(--ink);color:#fff;
  padding:32px 56px;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
}
.bs-cell{
  padding:0 36px;border-right:1px solid rgba(255,255,255,.1);
}
.bs-cell:first-child{padding-left:0;}
.bs-cell:last-child{border-right:none;padding-right:0;}
.bs-num{
  font-family:var(--f-display);font-size:54px;font-weight:600;
  line-height:1;color:#fff;margin-bottom:8px;
  letter-spacing:-.01em;
}
.bs-num em{font-style:normal;color:var(--gold);font-size:.5em;font-weight:400;margin-left:2px;}
.bs-lbl{font-family:var(--f-body);font-size:12px;color:rgba(255,255,255,.55);letter-spacing:.06em;}
.bs-en{display:block;font-size:10px;letter-spacing:.22em;color:var(--gold);text-transform:uppercase;margin-top:4px;}

/* ═══════════════ SECTION SCAFFOLD ═══════════════ */
.section{padding:140px 0;}
.section-tight{padding:96px 0;}
.sw{max-width:1280px;margin:0 auto;padding:0 56px;}
.sw-narrow{max-width:1080px;margin:0 auto;padding:0 56px;}

/* Editorial section header */
.ed-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:60px;margin-bottom:80px;flex-wrap:wrap;
}
.ed-head-left{flex:1;min-width:280px;}
.ed-head-meta{
  display:flex;align-items:center;gap:14px;
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.3em;color:var(--gold);text-transform:uppercase;
  margin-bottom:24px;
}
.ed-head-meta::before{content:'';display:block;width:36px;height:1px;background:var(--gold);}
.ed-head-title{
  font-family:var(--f-display);
  font-size:clamp(36px,5vw,72px);
  font-weight:600;line-height:.98;
  color:var(--ink);letter-spacing:-.005em;
}
.ed-head-title em{font-style:italic;color:var(--gold);}
.ed-head-cn{
  font-family:var(--f-cjk);font-size:13px;font-weight:300;
  letter-spacing:.32em;color:var(--gray);
  margin-top:18px;
}
.ed-head-right{flex:0 0 320px;}
.ed-head-desc{
  font-size:15px;line-height:1.85;color:var(--gray);
  border-left:1px solid var(--line);padding-left:24px;
}

/* ═══════════════ ROUTES — EDITORIAL CARDS ═══════════════ */
.routes-mag{padding:140px 0;background:var(--bg);}

.routes-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--ink);}
.route-row{
  display:grid;grid-template-columns:80px 1fr 2fr auto 60px;
  gap:48px;align-items:center;
  padding:48px 0;border-bottom:1px solid var(--line);
  cursor:pointer;
  transition:all .4s;
  position:relative;
  text-decoration:none;color:inherit;
}
.route-row::before{
  content:'';position:absolute;
  left:-100%;top:0;bottom:0;right:100%;
  background:var(--paper-warm);transition:all .5s;z-index:-1;
}
.route-row:hover::before{left:0;right:0;}
.route-row:hover{padding-left:24px;padding-right:24px;}

.rr-num{
  font-family:var(--f-display);font-size:42px;font-weight:500;
  color:var(--gold);line-height:1;
}
.rr-title{}
.rr-title-en{
  font-family:var(--f-display);font-size:32px;font-weight:600;
  color:var(--ink);line-height:1.1;letter-spacing:-.005em;
  margin-bottom:8px;
}
.rr-title-cn{
  font-family:var(--f-cjk);font-size:13px;font-weight:400;
  letter-spacing:.16em;color:var(--gray);
}
.rr-desc{
  font-size:14.5px;line-height:1.85;color:var(--gray);
  max-width:480px;
}
.rr-tags{display:flex;flex-direction:column;gap:6px;align-items:flex-end;}
.rr-tag{
  font-family:var(--f-body);font-size:9.5px;font-weight:500;
  letter-spacing:.18em;color:var(--ink);text-transform:uppercase;
  padding:4px 10px;border:1px solid var(--ink);
}
.rr-arrow{
  font-family:var(--f-display);font-size:32px;color:var(--ink);
  transition:transform .35s;
}
.route-row:hover .rr-arrow{transform:translateX(8px);color:var(--gold);}

/* ═══════════════ FEATURE / SPLIT CONTENT ═══════════════ */
.split-feature{padding:140px 0;background:var(--paper-warm);position:relative;}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.sf-image{
  height:600px;background-size:cover;background-position:center;
  position:relative;overflow:hidden;
  filter:grayscale(.1) contrast(1.05);
}
.sf-image::after{
  content:'';position:absolute;
  bottom:24px;left:24px;
  font-family:var(--f-display);font-size:13px;
  letter-spacing:.2em;color:#fff;
  background:rgba(10,10,10,.65);backdrop-filter:blur(6px);
  padding:6px 14px;
}
.sf-image[data-label]::after{content:attr(data-label);}

.sf-content{}
.sf-meta{
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.32em;color:var(--gold);text-transform:uppercase;
  margin-bottom:24px;display:flex;align-items:center;gap:12px;
}
.sf-meta::before{content:'';display:block;width:32px;height:1px;background:var(--gold);}
.sf-h2{
  font-family:var(--f-display);
  font-size:clamp(32px,4vw,56px);font-weight:600;
  line-height:1.05;color:var(--ink);letter-spacing:-.005em;
  margin-bottom:14px;
}
.sf-h2 em{font-style:italic;color:var(--gold);}
.sf-cn{
  font-family:var(--f-cjk);font-size:13px;font-weight:300;
  letter-spacing:.28em;color:var(--gray);margin-bottom:28px;
}
.sf-text{font-size:15px;line-height:1.95;color:var(--char);margin-bottom:18px;}
.sf-text strong{color:var(--ink);font-weight:600;}

.sf-list{list-style:none;margin-top:24px;}
.sf-list li{
  position:relative;padding:14px 0 14px 32px;
  border-bottom:1px solid var(--line);
  font-size:14.5px;color:var(--char);
}
.sf-list li::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:18px;height:1px;background:var(--gold);
}
.sf-list li:last-child{border-bottom:none;}
.sf-list li strong{color:var(--ink);font-weight:600;}

/* ═══════════════ EDITORIAL QUOTE ═══════════════ */
.ed-quote{
  background:var(--ink);color:#fff;
  padding:140px 56px;
  position:relative;overflow:hidden;
}
.ed-quote::before{
  content:'"';
  position:absolute;
  top:30px;left:50%;transform:translateX(-50%);
  font-family:var(--f-display);font-size:300px;
  color:rgba(160,125,58,.08);line-height:1;
  font-weight:700;
}
.ed-quote-inner{
  max-width:1400px;margin:0 auto;text-align:center;
  position:relative;z-index:1;
  padding:0 24px;
}
.eq-meta{
  font-family:var(--f-body);font-size:10px;font-weight:500;
  letter-spacing:.4em;color:var(--gold);text-transform:uppercase;
  margin-bottom:36px;
  display:flex;align-items:center;justify-content:center;gap:18px;
}
.eq-meta::before,.eq-meta::after{content:'';display:block;width:36px;height:1px;background:var(--gold);}

/* Multi-line value statement with auto-fit-to-one-line */
.eq-lines{
  display:flex;flex-direction:column;gap:14px;align-items:center;
  width:100%;overflow:hidden;
}
.eq-line{
  font-family:var(--f-display);font-weight:500;
  white-space:nowrap;
  line-height:1.3;
  letter-spacing:.08em;
}
/* Line 1: ~12 chars - can be larger */
.eq-line-1{
  font-size:clamp(22px,4.6vw,50px);
  color:#fff;
  letter-spacing:.12em;
}
/* Line 2: ~19 chars - smaller to fit one line */
.eq-line-2{
  font-size:clamp(11px,3.6vw,28px);
  color:var(--gold);
  letter-spacing:.08em;
}
@media(max-width:560px){
  .eq-line{letter-spacing:.04em;}
  .eq-line-1{letter-spacing:.06em;}
}

/* legacy fallback for any other places using .eq-text */
.eq-text{
  font-family:var(--f-display);font-style:italic;font-weight:400;
  font-size:clamp(28px,4vw,48px);
  line-height:1.35;
  letter-spacing:-.005em;
}
.eq-attrib{
  margin-top:48px;
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.32em;color:var(--gold);text-transform:uppercase;
}

/* ═══════════════ SERVICES — IMAGE GRID ═══════════════ */
.services-grid-img{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line);
}
.svc-cell{
  padding:48px 40px;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--paper);
  position:relative;overflow:hidden;
  transition:all .5s;
  cursor:default;
  min-height:320px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.svc-cell::before{
  content:'';position:absolute;
  top:0;left:0;right:0;bottom:0;
  background:var(--ink);
  transform:translateY(100%);transition:transform .55s ease;
  z-index:0;
}
.svc-cell:hover::before{transform:translateY(0);}
.svc-cell > *{position:relative;z-index:1;transition:color .4s;}
.svc-cell:hover > *{color:#fff;}

.svc-num{
  font-family:var(--f-display);font-size:13px;font-weight:500;
  letter-spacing:.2em;color:var(--gold);
  margin-bottom:20px;
}
.svc-cell:hover .svc-num{color:var(--gold);}
.svc-h{
  font-family:var(--f-display);font-size:32px;font-weight:600;
  line-height:1.1;color:var(--ink);
  margin-bottom:6px;letter-spacing:-.005em;
}
.svc-cn{
  font-family:var(--f-cjk);font-size:11px;font-weight:400;
  letter-spacing:.24em;color:var(--gray);margin-bottom:24px;
}
.svc-cell:hover .svc-h{color:#fff;}
.svc-cell:hover .svc-cn{color:rgba(255,255,255,.55);}
.svc-text{
  font-size:13.5px;line-height:1.85;color:var(--gray);
}
.svc-cell:hover .svc-text{color:rgba(255,255,255,.65);}

/* ═══════════════ FULL IMAGE BAND ═══════════════ */
.image-band{
  height:520px;
  background-size:cover;background-position:center;
  background-attachment:fixed;
  position:relative;
  filter:grayscale(.15);
}
.image-band-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,.45) 0%,rgba(10,10,10,.55) 100%);
  display:flex;align-items:center;justify-content:center;
}
.image-band-text{
  text-align:center;color:#fff;padding:0 56px;max-width:900px;
}
.image-band-eyebrow{
  font-family:var(--f-body);font-size:10px;font-weight:500;
  letter-spacing:.4em;color:var(--gold);text-transform:uppercase;
  margin-bottom:24px;
}
.image-band-title{
  font-family:var(--f-display);font-style:italic;font-weight:400;
  font-size:clamp(34px,5vw,64px);line-height:1.18;
  margin-bottom:32px;letter-spacing:-.005em;
}
.image-band-cn{
  font-family:var(--f-cjk);font-size:13px;font-weight:300;
  letter-spacing:.34em;color:rgba(255,255,255,.65);
}

/* ═══════════════ DESTINATIONS — IMAGE TILES ═══════════════ */
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.dest-tile{
  background:var(--paper);
  padding:0;
  position:relative;
  aspect-ratio:1/1.1;
  overflow:hidden;
  cursor:default;
  transition:transform .5s;
}
.dest-tile:hover{transform:scale(1.01);}
.dest-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:grayscale(.45) contrast(1.05);
  transition:filter .5s,transform .8s;
}
.dest-tile:hover .dest-bg{filter:grayscale(0);transform:scale(1.06);}
.dest-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,0) 0%,rgba(10,10,10,.7) 100%);
}
.dest-content{
  position:absolute;inset:0;z-index:2;
  padding:24px;color:#fff;
  display:flex;flex-direction:column;justify-content:space-between;
}
.dest-flag{
  font-size:22px;
  background:rgba(10,10,10,.45);backdrop-filter:blur(8px);
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.dest-bottom{}
.dest-name{
  font-family:var(--f-display);font-size:24px;font-weight:600;
  line-height:1;letter-spacing:-.005em;margin-bottom:4px;
}
.dest-cn{
  font-family:var(--f-cjk);font-size:11px;font-weight:300;
  letter-spacing:.2em;color:rgba(255,255,255,.7);
}

/* ═══════════════ TIMELINE / TIMETABLE ═══════════════ */
.tt-table{
  width:100%;border-collapse:collapse;
  margin:36px 0;
}
.tt-table thead tr{border-top:2px solid var(--ink);border-bottom:1px solid var(--ink);}
.tt-table th{
  text-align:left;padding:16px 20px;
  font-family:var(--f-body);font-size:10px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);
}
.tt-table tbody tr{border-bottom:1px solid var(--line);transition:background .3s;}
.tt-table tbody tr:hover{background:var(--paper-warm);}
.tt-table td{
  padding:20px;font-size:14.5px;color:var(--char);
}
.tt-table td:first-child{
  font-family:var(--f-display);font-size:18px;font-weight:600;color:var(--ink);
  width:24%;
}
.tt-table td.time{
  font-family:var(--f-display);font-style:italic;color:var(--gold);font-size:17px;
  width:22%;
}

/* ═══════════════ CTA / CONTACT BLOCK ═══════════════ */
.cta-wide{
  background:var(--ink);color:#fff;
  padding:140px 56px;text-align:center;
  position:relative;overflow:hidden;
}
.cta-wide::before{
  content:'HSIEHSHUN';
  font-family:var(--f-display);font-size:clamp(120px,18vw,260px);
  font-weight:700;color:rgba(255,255,255,.025);
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  white-space:nowrap;letter-spacing:-.01em;line-height:1;
  pointer-events:none;
}
.cta-inner{position:relative;z-index:1;max-width:880px;margin:0 auto;}
.cta-meta{
  font-family:var(--f-body);font-size:10px;font-weight:500;
  letter-spacing:.4em;color:var(--gold);text-transform:uppercase;
  margin-bottom:32px;display:flex;align-items:center;justify-content:center;gap:18px;
}
.cta-meta::before,.cta-meta::after{content:'';display:block;width:36px;height:1px;background:var(--gold);}
.cta-h{
  font-family:var(--f-display);font-size:clamp(36px,5vw,68px);font-weight:600;
  line-height:1.05;letter-spacing:-.005em;
  margin-bottom:24px;
}
.cta-h em{font-style:italic;color:var(--gold);}
.cta-text{
  font-size:16px;line-height:1.85;color:rgba(255,255,255,.55);
  max-width:580px;margin:0 auto 56px;
}
.cta-actions{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;align-items:center;}
.cta-btn{
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  background:var(--gold);color:#fff;
  padding:18px 42px;
  display:inline-flex;align-items:center;gap:14px;
  transition:all .35s;
}
.cta-btn:hover{background:#fff;color:var(--ink);}
.cta-link{
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:#fff;border-bottom:1px solid rgba(255,255,255,.4);
  padding-bottom:6px;transition:all .3s;
}
.cta-link:hover{color:var(--gold);border-color:var(--gold);}

/* ═══════════════ FOOTER ═══════════════ */
footer{
  background:var(--ink);color:#fff;
  padding:96px 56px 36px;
  position:relative;
}
.ft-top{
  display:grid;grid-template-columns:2.4fr 1fr 1fr 1fr;
  gap:72px;margin-bottom:72px;
  padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.08);
}
.ft-mark{
  font-family:var(--f-display);font-size:32px;font-weight:600;
  letter-spacing:.18em;color:#fff;display:block;margin-bottom:6px;
}
.ft-mark-cn{font-family:var(--f-cjk);font-size:11px;font-weight:300;letter-spacing:.22em;color:rgba(255,255,255,.45);display:block;}
.ft-tagline{
  margin-top:20px;font-family:var(--f-display);font-style:italic;
  font-size:18px;color:rgba(255,255,255,.55);font-weight:400;
  line-height:1.55;max-width:340px;
}
.ft-contact{
  margin-top:24px;font-family:var(--f-body);font-size:13.5px;
  color:rgba(255,255,255,.5);line-height:2;
}
.ft-contact a{color:rgba(255,255,255,.5);}
.ft-contact a:hover{color:var(--gold);}
.ft-col h5{
  font-family:var(--f-body);font-size:11px;font-weight:600;
  letter-spacing:.24em;color:var(--gold);text-transform:uppercase;
  margin-bottom:24px;
}
.ft-col ul{list-style:none;}
.ft-col ul li{margin-bottom:12px;}
.ft-col ul li a{
  font-family:var(--f-body);font-size:13.5px;font-weight:300;
  color:rgba(255,255,255,.55);transition:color .25s;
  letter-spacing:.02em;
}
.ft-col ul li a:hover{color:var(--gold);}
.ft-bottom{
  display:flex;justify-content:space-between;align-items:center;
  gap:18px;flex-wrap:wrap;
}
.ft-copy{font-family:var(--f-body);font-size:11px;letter-spacing:.1em;color:rgba(255,255,255,.25);}
.ft-beian{display:flex;gap:18px;flex-wrap:wrap;align-items:center;}
.ft-beian a{font-family:var(--f-body);font-size:11.5px;color:rgba(255,255,255,.32);letter-spacing:.04em;transition:color .2s;}
.ft-beian a:hover{color:rgba(255,255,255,.65);}
.ft-beian-sep{color:rgba(255,255,255,.12);font-size:11.5px;}

/* ═══════════════ TICKER ═══════════════ */
.ticker{background:var(--paper-warm);padding:18px 0;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.ticker-track{display:flex;animation:ticker 38s linear infinite;width:max-content;}
.ticker-item{
  display:flex;align-items:center;gap:14px;padding:0 36px;
  font-family:var(--f-display);font-size:14px;font-weight:500;
  letter-spacing:.04em;color:var(--ink);
  white-space:nowrap;
}
.ticker-item em{font-style:italic;color:var(--gold);font-weight:500;}
.tick-star{color:var(--gold);font-size:10px;}
@keyframes ticker{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ═══════════════ SUBPAGE HERO ═══════════════ */
.sub-hero{
  min-height:80vh;
  background:var(--bg);
  position:relative;overflow:hidden;
  padding:140px 0 80px;
  display:flex;align-items:center;
}
.sub-hero-grid{
  display:grid;grid-template-columns:6fr 5fr;gap:80px;
  max-width:1400px;margin:0 auto;padding:0 56px;
  align-items:center;width:100%;
}
.sub-hero-left{}
.sub-bc{
  font-family:var(--f-body);font-size:11px;color:var(--gray);
  letter-spacing:.16em;margin-bottom:36px;text-transform:uppercase;
}
.sub-bc a{color:var(--gray);transition:color .2s;}
.sub-bc a:hover{color:var(--ink);}
.sub-bc-sep{margin:0 10px;color:var(--gold);}
.sub-meta{
  display:flex;align-items:center;gap:16px;
  font-family:var(--f-body);font-size:11px;font-weight:500;
  letter-spacing:.32em;color:var(--gold);text-transform:uppercase;
  margin-bottom:36px;
}
.sub-meta-line{flex:0 0 32px;height:1px;background:var(--gold);}
.sub-h1{
  font-family:var(--f-display);font-size:clamp(54px,7vw,108px);
  font-weight:600;line-height:.95;color:var(--ink);
  letter-spacing:-.005em;margin-bottom:8px;
}
.sub-h1 em{font-style:italic;color:var(--gold);}
.sub-h1-cn{
  font-family:var(--f-cjk);font-size:clamp(13px,1.4vw,16px);
  font-weight:300;letter-spacing:.42em;color:var(--gray);
  margin-top:18px;margin-bottom:48px;
}
.sub-divider{
  display:flex;align-items:center;gap:24px;margin-bottom:32px;
}
.sub-divider-num{font-family:var(--f-display);font-size:14px;letter-spacing:.18em;color:var(--gold);}
.sub-divider-line{flex:1;height:1px;background:var(--ink);max-width:120px;}
.sub-lede{
  font-size:16px;line-height:1.85;color:var(--char);
  max-width:520px;margin-bottom:48px;
}
.sub-actions{display:flex;align-items:center;gap:32px;flex-wrap:wrap;}
.sub-hero-right{position:relative;height:560px;}
.sub-image{
  width:100%;height:100%;background-size:cover;background-position:center;
  filter:grayscale(.15) contrast(1.05);
}
.sub-image-tag{
  position:absolute;top:24px;left:24px;
  background:rgba(10,10,10,.65);backdrop-filter:blur(8px);
  padding:8px 16px;color:#fff;
  font-family:var(--f-display);font-size:13px;letter-spacing:.18em;
  z-index:2;
}

/* ═══════════════ ARTICLE / PROSE (premium) ═══════════════ */
.article{padding:120px 0;background:var(--paper);}
.article-inner{max-width:880px;margin:0 auto;padding:0 56px;}
.article-meta{
  font-family:var(--f-body);font-size:11px;letter-spacing:.32em;
  color:var(--gold);text-transform:uppercase;font-weight:500;
  margin-bottom:24px;display:flex;align-items:center;gap:14px;
}
.article-meta::before{content:'';display:block;width:32px;height:1px;background:var(--gold);}
.article h2{
  font-family:var(--f-display);font-size:clamp(28px,3.5vw,46px);
  font-weight:600;line-height:1.12;color:var(--ink);
  letter-spacing:-.005em;
  margin:64px 0 8px;
}
.article h2:first-of-type{margin-top:0;}
.article h2 em{font-style:italic;color:var(--gold);}
.article .h2-cn{
  font-family:var(--f-cjk);font-size:13px;font-weight:300;
  letter-spacing:.3em;color:var(--gray);margin-bottom:32px;display:block;
}
.article h3{
  font-family:var(--f-display);font-size:22px;font-weight:600;
  color:var(--ink);margin:36px 0 12px;letter-spacing:-.005em;
}
.article p{
  font-size:16.5px;line-height:1.95;color:var(--char);
  margin-bottom:20px;
}
.article p strong{color:var(--ink);font-weight:600;}
.article ul{margin:24px 0 28px;list-style:none;}
.article ul li{
  position:relative;padding-left:32px;margin-bottom:14px;
  font-size:15.5px;line-height:1.85;color:var(--char);
}
.article ul li::before{
  content:'';position:absolute;left:0;top:13px;
  width:18px;height:1px;background:var(--gold);
}
.article ul li strong{color:var(--ink);}
.article-pull{
  margin:48px 0;padding:36px 0;
  border-top:2px solid var(--ink);border-bottom:1px solid var(--ink);
  font-family:var(--f-display);font-style:italic;font-weight:400;
  font-size:24px;line-height:1.55;color:var(--ink);
  letter-spacing:-.005em;
}

/* ═══════════════ ANIMATIONS ═══════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
@keyframes slideRight{from{opacity:0;transform:translateX(-30px);}to{opacity:1;transform:translateX(0);}}
.eh-left > *,.sub-hero-left > *{animation:fadeUp .85s cubic-bezier(.2,.6,.2,1) both;}
.eh-meta,.sub-meta{animation-delay:.05s;}
.eh-title,.sub-h1{animation-delay:.18s;}
.eh-cn,.sub-h1-cn{animation-delay:.28s;}
.eh-divider,.sub-divider{animation-delay:.36s;}
.eh-lede,.sub-lede{animation-delay:.44s;}
.eh-actions,.sub-actions{animation-delay:.52s;}
.eh-right,.sub-hero-right{animation:fadeUp 1s cubic-bezier(.2,.6,.2,1) .25s both;}

/* ═══════════════ RESPONSIVE ═══════════════ */
@media(max-width:1024px){
  nav{padding:18px 24px;}
  nav.scrolled{padding:14px 24px;}
  .nav-right{position:fixed;inset:64px 0 auto;background:var(--bg);flex-direction:column;align-items:stretch;padding:16px 20px;border-bottom:1px solid var(--line);transform:translateY(-110%);transition:transform .3s;}
  .nav-right.open{transform:translateY(0);}
  .nav-right a{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--line-soft);}
  .nav-right a.active::after{display:none;}
  .nav-cta{margin:8px 0 0;text-align:center;}
  .menu-toggle{display:flex;}

  .eh-grid,.sub-hero-grid{grid-template-columns:1fr;gap:48px;padding:0 24px;}
  .eh-right,.sub-hero-right{height:420px;}
  .editorial-hero{padding-top:96px;min-height:auto;}
  .sub-hero{padding:96px 0 60px;min-height:auto;}

  .banner-strip{grid-template-columns:1fr 1fr;padding:24px;gap:0;}
  .bs-cell{padding:24px;border-right:none;border-bottom:1px solid rgba(255,255,255,.1);}
  .bs-cell:nth-child(2){border-right:none;}
  .bs-cell:nth-child(odd){border-right:1px solid rgba(255,255,255,.1);}
  .bs-cell:nth-last-child(-n+2){border-bottom:none;}

  .sw,.sw-narrow,.article-inner{padding:0 24px;}
  .section{padding:80px 0;}
  .ed-head{flex-direction:column;align-items:flex-start;}
  .ed-head-right{flex:0 0 auto;width:100%;}

  .route-row{grid-template-columns:auto 1fr auto;gap:20px;padding:32px 0;}
  .rr-num{font-size:32px;}
  .rr-title-en{font-size:24px;}
  .rr-desc,.rr-tags{display:none;}
  .route-row:hover{padding-left:0;padding-right:0;}

  .split-grid{grid-template-columns:1fr;gap:48px;}
  .sf-image{height:380px;}

  .services-grid-img{grid-template-columns:1fr;}
  .svc-cell{min-height:260px;padding:36px 28px;}

  .dest-grid{grid-template-columns:1fr 1fr;}

  .ed-quote,.cta-wide{padding:80px 24px;}
  .image-band{height:380px;background-attachment:scroll;}
  .ft-top{grid-template-columns:1fr 1fr;gap:36px;padding-bottom:36px;}
  footer{padding:64px 24px 32px;}

  .article{padding:64px 0;}
  .tt-table{font-size:13px;}
  .tt-table th,.tt-table td{padding:12px;}
}
@media(max-width:640px){
  .banner-strip{grid-template-columns:1fr;}
  .bs-cell{border-right:none!important;}
  .dest-grid{grid-template-columns:1fr;}
  .ft-top{grid-template-columns:1fr;}
  .tt-table thead{display:none;}
  .tt-table tbody td{display:block;width:100%!important;padding:6px 0;}
  .tt-table tbody td:first-child{padding-top:16px;font-size:15px;}
  .tt-table tbody td.time{padding-bottom:14px;}
  .tt-table tbody tr{border-bottom:1px solid var(--line);}
}
