/*
Theme Name: HanoiSkyGroup
Theme URI: http:///hanoiskygroup.com
Description: Giao diện website du lịch quốc tế đẳng cấp V5!
Author: Chuotbu
Version: 5.0.0
*/

/* CSS from includes/head_v5.php */

/* ══ TOKENS ══ */
:root{
  --red:    #E01E26;
  --red-d:  #B8161B;
  --red-bg: #FEF1F1;
  --ink:    #0D0D0D;
  --body:   #222222;
  --sub:    #555555;
  --mute:   #999999;
  --line:   #E0E0E0;
  --bg:     #F6F6F6;
  --white:  #FFFFFF;
  --W:      1200px;
  --ease:   cubic-bezier(.4,0,.2,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Be Vietnam Pro',sans-serif;background:var(--white);color:var(--body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}

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

/* ══ TOPBAR ══ */
.topbar{background:#111;border-bottom:2px solid var(--red)}
.topbar .W{display:flex;justify-content:space-between;align-items:center;padding-top:9px;padding-bottom:9px;gap:12px;flex-wrap:wrap}
.tb-l{display:flex;gap:24px;font-size:12.5px;color:#999}
.tb-l span{display:flex;align-items:center;gap:5px}
.tb-l b{color:var(--red);font-weight:700}
.tb-r{display:flex;gap:18px;font-size:12.5px}
.tb-r a{color:#777;transition:color .15s}
.tb-r a:hover{color:#fff}
.tb-r a.accent{color:#fff;font-weight:600}

/* ══ HEADER ══ */
header{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:800;transition:box-shadow .25s}
header.raised{box-shadow:0 4px 20px rgba(0,0,0,.08)}
header .W{display:flex;align-items:center;height:70px}

.logo{display:flex;align-items:center;gap:10px;padding-right:20px;border-right:1px solid var(--line);flex-shrink:0;margin-right:4px}
nav{flex:1;display:flex;align-items:stretch;padding:0 8px}
.ni{position:relative;display:flex;align-items:center}
.nl{padding:0 14px;font-size:14px;font-weight:500;color:var(--sub);height:70px;display:flex;align-items:center;gap:3px;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap}
.nl:hover,.nl.on{color:var(--red);border-bottom-color:var(--red)}
.nl svg{width:11px;height:11px}
.drop{position:absolute;top:calc(100% + 1px);left:0;background:var(--white);min-width:215px;border:1px solid var(--line);border-top:3px solid var(--red);padding:6px;opacity:0;pointer-events:none;transform:translateY(6px);transition:opacity .18s,transform .18s;z-index:99;box-shadow:0 12px 32px rgba(0,0,0,.09)}
.ni:hover .drop{opacity:1;pointer-events:auto;transform:none}
.drop a{display:block;padding:10px 14px;font-size:14px;font-weight:500;color:var(--sub);border-left:3px solid transparent;transition:.12s}
.drop a:hover{background:var(--red-bg);color:var(--red);border-left-color:var(--red);padding-left:18px}

.hdr-cta{display:flex;gap:8px;align-items:center;padding-left:14px;border-left:1px solid var(--line);flex-shrink:0;margin-left:auto}
.btn-o{font-size:13.5px;font-weight:700;color:var(--red);border:2px solid var(--red);padding:7px 18px;transition:.15s;white-space:nowrap}
.btn-o:hover{background:var(--red);color:#fff}
.btn-f{background:var(--red);color:#fff;font-size:13.5px;font-weight:700;padding:9px 22px;transition:.15s;white-space:nowrap}
.btn-f:hover{background:var(--red-d)}

/* ══ PAGE HEADER (inner pages) ══ */
.page-hdr{position:relative;padding:64px 0 48px;overflow:hidden}
.page-hdr-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hdr-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.8) 0%,rgba(0,0,0,.35) 100%)}
.page-hdr-content{position:relative;z-index:2}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:14px;font-weight:500}
.breadcrumb a{color:rgba(255,255,255,.8);transition:.15s}
.breadcrumb a:hover{color:#fff}
.breadcrumb span.sep{color:rgba(255,255,255,.3)}
.breadcrumb span.cur{color:var(--red);font-weight:600}
.page-hdr h1{font-size:clamp(28px,4vw,48px);font-weight:900;color:#fff;line-height:1.1;letter-spacing:-1.5px;margin-bottom:16px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.tag-board{display:flex;gap:8px;flex-wrap:wrap}
.tag-pill{padding:7px 18px;font-size:13.5px;font-weight:600;border:1.5px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff;cursor:pointer;transition:.18s}
.tag-pill.on,.tag-pill:hover{background:var(--red);border-color:var(--red)}

/* ══ SECTION COMMON ══ */
.sec{padding:88px 0}
.sec-gray{background:var(--bg)}
.eyebrow{font-size:11.5px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:8px;margin-bottom:10px}
.eyebrow::before{content:'';width:20px;height:2px;background:var(--red);flex-shrink:0}
.sec-title{font-size:clamp(30px,3.5vw,46px);font-weight:900;color:var(--ink);line-height:1.1;letter-spacing:-1.5px}
.sec-title em{font-style:normal;color:var(--red)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:40px;flex-wrap:wrap}
.link-all{font-size:13.5px;font-weight:700;color:var(--red);display:flex;align-items:center;gap:6px;transition:gap .15s;border-bottom:1.5px solid var(--red);padding-bottom:1px;white-space:nowrap}
.link-all:hover{gap:12px}

/* ══ TOUR CARDS ══ */
.tc{background:var(--white);border:1px solid var(--line);overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.tc:hover{box-shadow:0 10px 36px rgba(0,0,0,.09);transform:translateY(-4px)}
.tc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.tc:hover::after{transform:scaleX(1)}
.tc-thumb{height:200px;position:relative;overflow:hidden}
.tc-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s var(--ease)}
.tc:hover .tc-bg{transform:scale(1.07)}
.tc-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 55%)}
.t-pill{position:absolute;top:12px;left:12px;z-index:2;padding:3px 10px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff}
.tp-r{background:var(--red)} .tp-b{background:#222}
.tc-body{padding:16px 18px 20px;border-top:1px solid var(--line)}
.tc-dest{font-size:10.5px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px}
.tc-name{font-size:15px;font-weight:800;color:var(--ink);line-height:1.35;margin-bottom:8px;letter-spacing:-.2px;transition:color .15s}
.tc:hover .tc-name{color:var(--red)}
.tc-meta{display:flex;gap:14px;font-size:12px;color:var(--mute);margin-bottom:12px;flex-wrap:wrap}
.tc-meta span{display:flex;align-items:center;gap:4px}
.tc-footer{display:flex;align-items:flex-end;justify-content:space-between;padding-top:12px;border-top:1px solid var(--line)}
.tc-price{font-size:20px;font-weight:900;color:var(--red);line-height:1;letter-spacing:-.5px}
.tc-price span{font-size:11px;font-weight:400;color:var(--mute);display:block;margin-bottom:2px;letter-spacing:0}
.tc-cta{font-size:12px;font-weight:700;color:var(--sub);display:flex;align-items:center;gap:3px;transition:color .15s,gap .15s}
.tc:hover .tc-cta{color:var(--red);gap:6px}

/* ══ NEWS CARDS ══ */
.news-c{background:var(--white);border:1px solid var(--line);overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.news-c:hover{box-shadow:0 10px 36px rgba(0,0,0,.09);transform:translateY(-4px)}
.news-c::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.news-c:hover::after{transform:scaleX(1)}
.news-thumb{height:200px;position:relative;overflow:hidden}
.news-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.news-c:hover .news-thumb img{transform:scale(1.06)}
.news-pill{position:absolute;top:12px;left:12px;z-index:2;padding:3px 10px;font-size:10.5px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}
.np-b{background:#222} .np-r{background:var(--red)}
.news-body{padding:18px 20px 22px;border-top:1px solid var(--line)}
.news-date{font-size:11.5px;color:var(--mute);margin-bottom:8px}
.news-title{font-size:16px;font-weight:800;color:var(--ink);line-height:1.4;letter-spacing:-.2px;margin-bottom:10px;transition:color .15s}
.news-c:hover .news-title{color:var(--red)}
.news-excerpt{font-size:13.5px;color:var(--sub);line-height:1.7;margin-bottom:14px}
.news-link{font-size:12.5px;font-weight:700;color:var(--red);display:flex;align-items:center;gap:5px;transition:gap .15s}
.news-c:hover .news-link{gap:9px}

/* ══ SIDEBAR ══ */
.sidebar-box{border:1px solid var(--line);border-top:3px solid var(--red);background:var(--white);margin-bottom:24px;overflow:hidden}
.sidebar-box-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink);padding:16px 20px;border-bottom:1px solid var(--line)}
.sidebar-box-body{padding:20px}

/* ══ FILTER SIDEBAR ══ */
.filter-wrap{position:sticky;top:90px;display:flex;flex-direction:column;gap:0}
.filter-group{border-bottom:1px solid var(--line);padding:18px 20px}
.filter-group:last-child{border:none}
.filter-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ink);margin-bottom:12px}
.filter-input{width:100%;padding:9px 12px;border:1.5px solid var(--line);font-size:14px;font-family:inherit;background:#fff;outline:none;transition:.2s;color:var(--body)}
.filter-input:focus{border-color:var(--red)}
.filter-opts{display:flex;flex-direction:column;gap:8px}
.filter-opt{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--sub);cursor:pointer}
.filter-opt input{accent-color:var(--red)}
.btn-filter{width:100%;background:var(--red);color:#fff;padding:12px;font-weight:700;font-size:14px;border:none;cursor:pointer;font-family:inherit;transition:.15s;margin-top:4px}
.btn-filter:hover{background:var(--red-d)}

/* ══ PAGINATION ══ */
.pagination{display:flex;gap:4px;justify-content:center;margin-top:56px}
.page-btn{width:42px;height:42px;border:1.5px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;cursor:pointer;transition:.15s;color:var(--sub)}
.page-btn:hover{border-color:var(--red);color:var(--red)}
.page-btn.active{background:var(--red);border-color:var(--red);color:#fff}

/* ══ TOUR LISTING ══ */
.tour-item{display:flex;background:var(--white);border:1px solid var(--line);overflow:hidden;transition:box-shadow .25s var(--ease),transform .25s var(--ease);margin-bottom:3px}
.tour-item:hover{box-shadow:0 8px 32px rgba(0,0,0,.08);transform:translateX(3px)}
.tour-item-thumb{width:240px;flex-shrink:0;position:relative;overflow:hidden;background-size:cover;background-position:center}
.tour-item-thumb img{width:100%;height:100%;object-fit:cover}
.tour-item-badge{position:absolute;top:12px;left:12px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;color:#fff}
.badge-hot{background:var(--red)}
.badge-new{background:#222}
.badge-sale{background:#F59E0B;color:#000}
.thumb-label{position:absolute;bottom:0;left:0;right:0;padding:12px 14px;background:linear-gradient(to top,rgba(0,0,0,.75),transparent);font-size:13px;font-weight:700;color:#fff}
.thumb-dates{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}
.thumb-date{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);font-size:11px;padding:2px 8px;color:#fff;font-weight:600;backdrop-filter:blur(4px)}
.thumb-date.red{background:var(--red);border-color:var(--red)}
.tour-item-body{flex:1;padding:20px 24px;display:flex;flex-direction:column}
.tour-item-dest{font-size:11px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px}
.tour-item-name{font-size:17px;font-weight:800;color:var(--ink);line-height:1.35;letter-spacing:-.3px;margin-bottom:12px;transition:color .15s}
.tour-item:hover .tour-item-name{color:var(--red)}
.tour-item-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--mute);margin-bottom:auto}
.tour-item-meta span{display:flex;align-items:center;gap:5px}
.tour-countdown{font-size:12px;font-weight:600;color:var(--red);margin-top:10px;display:flex;align-items:center;gap:6px}
.tour-item-footer{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:14px;border-top:1px solid var(--line);flex-wrap:wrap;gap:10px}
.tour-price-wrap .label{font-size:11px;color:var(--mute);margin-bottom:2px}
.tour-price-wrap .price{font-size:22px;font-weight:900;color:var(--red);letter-spacing:-.5px;line-height:1}
.tour-price-wrap .old{font-size:13px;color:var(--mute);text-decoration:line-through;margin-top:2px}
.tour-btns{display:flex;gap:8px}
.btn-detail{font-size:13px;font-weight:700;color:var(--red);border:2px solid var(--red);padding:9px 20px;transition:.15s}
.btn-detail:hover{background:var(--red);color:#fff}
.btn-book-now{background:var(--red);color:#fff;font-size:13px;font-weight:700;padding:9px 20px;border:none;transition:.15s}
.btn-book-now:hover{background:var(--red-d)}

/* ══ SCHEDULE SLIDER ══ */
.sch-wrap{display:flex;align-items:center;gap:6px}
.sch-title{display:flex;align-items:center;gap:5px;flex-shrink:0}
.sch-slider{display:flex;align-items:center;gap:4px}
.sch-arr{background:var(--bg);border:1px solid var(--line);color:var(--sub);width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px;cursor:pointer;border-radius:2px;transition:.15s}
.sch-arr:hover{background:var(--red);color:#fff;border-color:var(--red)}
.sch-vp{width:128px;overflow:hidden}
.sch-track{display:flex;gap:4px;transition:transform .3s ease}
.sch-date{font-size:11px;font-weight:600;color:var(--ink);background:var(--bg);border:1px solid var(--line);padding:2px 0;width:40px;text-align:center;border-radius:3px;flex-shrink:0}

/* ══ FLASH TIMER WIDGET ══ */
.flash-box{border:1px solid var(--line);overflow:hidden;margin-bottom:24px}
.flash-hdr{background:var(--ink);color:#fff;padding:12px 16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;gap:8px}
.flash-item{display:flex;gap:12px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line)}
.flash-item:last-child{border:none}
.flash-thumb{width:60px;height:60px;background-size:cover;background-position:center;flex-shrink:0}
.flash-info .name{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:4px;line-height:1.3}
.flash-info .price{font-size:14px;font-weight:800;color:var(--red)}
.flash-timer{display:flex;gap:2px;font-size:11px;font-weight:700;color:var(--red);margin-top:4px;align-items:center}
.flash-timer span{background:var(--red);color:#fff;padding:2px 5px}

/* ══ QUICK FORM ══ */
.quick-form{border:1px solid var(--line);border-top:3px solid var(--red);background:#fff;padding:24px}
.quick-form h3{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:6px;letter-spacing:-.2px}
.quick-form p{font-size:13px;color:var(--mute);margin-bottom:18px;line-height:1.6}
.qf-input{width:100%;padding:10px 14px;border:1.5px solid var(--line);font-size:14px;font-family:inherit;background:#fff;outline:none;transition:.2s;color:var(--body);margin-bottom:10px;display:block}
.qf-input:focus{border-color:var(--red)}
.qf-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.qf-row .qf-input{margin-bottom:0}
.qf-btn{width:100%;background:var(--red);color:#fff;padding:12px;font-weight:700;font-size:14px;border:none;cursor:pointer;font-family:inherit;transition:.15s;letter-spacing:.3px}
.qf-btn:hover{background:var(--red-d)}

/* ══ CLIENTS / TICKER ══ */
.ticker{background:var(--red);overflow:hidden;padding:11px 0}
.tk{display:flex;white-space:nowrap;animation:tk 32s linear infinite}
.tk-i{display:inline-flex;align-items:center;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.85);padding:0 36px;border-right:1px solid rgba(255,255,255,.2);flex-shrink:0}
.tk-dot{color:rgba(255,255,255,.35);margin:0 8px}
@keyframes tk{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ CTA BAND ══ */
.cta-band{background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-band .W{display:flex;align-items:center;justify-content:space-between;padding-top:64px;padding-bottom:64px;gap:40px;flex-wrap:wrap}
.cta-ey{font-size:11.5px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.cta-title{font-size:clamp(28px,3.2vw,44px);font-weight:900;color:var(--ink);line-height:1.1;letter-spacing:-1.5px}
.cta-title em{font-style:normal;color:var(--red)}
.cta-r{display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.cta-lbl{font-size:11.5px;color:var(--mute);text-align:right}
.cta-phone{font-size:40px;font-weight:900;color:var(--ink);letter-spacing:-2px;line-height:1}
.cta-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.btn-ct{background:var(--red);color:#fff;font-size:14px;font-weight:700;padding:13px 28px;transition:.15s}
.btn-ct:hover{background:var(--red-d)}
.btn-ctl{border:2px solid var(--line);color:var(--ink);font-size:14px;font-weight:600;padding:12px 24px;transition:.15s}
.btn-ctl:hover{border-color:var(--red);color:var(--red)}

/* ══ REVEAL ══ */
.rv{opacity:0;transform:translateY(22px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.rv.show{opacity:1;transform:none}
.d1{transition-delay:.08s} .d2{transition-delay:.16s} .d3{transition-delay:.24s} .d4{transition-delay:.32s}

/* ══ RESPONSIVE ══ */
@media(max-width:1080px){nav,.hdr-cta .btn-o{display:none}}
@media(max-width:900px){
  .W{padding:0 20px}
  .sec{padding:60px 0}
  .tour-item{flex-direction:column}
  .tour-item-thumb{width:100%;height:220px}
  .cta-band .W{flex-direction:column;align-items:flex-start;text-align:left}
  .cta-r{align-items:flex-start}
}
@media(max-width:560px){
  .qf-row{grid-template-columns:1fr}
}
/* ══ THUMB IMAGES ══ */
.c1{background:url('images/event_anniversary_1778088482676.png') center/cover}
.c2{background:url('images/tour_japan_1778088532886.png') center/cover}
.c3{background:url('images/tour_thailand_1778088548301.png') center/cover}
.c4{background:url('images/event_teambuilding_1778088513069.png') center/cover}
.c5{background:url('images/event_gala_1778088497636.png') center/cover}
.c6{background:url('images/tour_australia_1778088563758.png') center/cover}
.c7{background:url('images/tour_korea.png') center/cover}
.c8{background:url('images/tour_europe.png') center/cover}
.c9{background:url('images/tour_usa.png') center/cover}

/* CSS from home_v5.php */

/* ══ HERO ══ */
.hero{border-bottom:1px solid var(--line);overflow:hidden}
.hero .W{display:grid;grid-template-columns:1fr 400px;min-height:580px}

.hl{padding:72px 56px 72px 0;border-right:1px solid var(--line);display:flex;flex-direction:column;justify-content:center;position:relative}
.hl::before{content:'';position:absolute;left:-32px;top:24px;bottom:24px;width:4px;background:var(--red);border-radius:0 2px 2px 0}

.h-label{display:flex;align-items:center;gap:8px;margin-bottom:22px}
.h-label-dot{width:8px;height:8px;background:var(--red);border-radius:50%;animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.6}}
.h-label-text{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--mute)}

.h-title{font-size:clamp(44px,5vw,72px);font-weight:900;line-height:1.08;color:var(--ink);letter-spacing:-2px;margin-bottom:0}
.h-title .line-red{color:var(--red);display:block}
.h-title .line-n{display:block}

.h-divider{width:52px;height:4px;background:var(--red);margin:24px 0}

.h-desc{font-size:17px;line-height:1.75;color:var(--sub);margin-bottom:32px;max-width:440px;font-weight:400}
.h-desc b{color:var(--ink);font-weight:700}

.h-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-h-red{background:var(--red);color:#fff;font-size:15px;font-weight:700;padding:14px 34px;transition:.18s;display:inline-flex;align-items:center;gap:8px}
.btn-h-red:hover{background:var(--red-d);transform:translateX(2px)}
.btn-h-red svg{width:16px;height:16px;transition:transform .18s}
.btn-h-red:hover svg{transform:translateX(4px)}
.btn-h-ghost{font-size:15px;font-weight:600;color:var(--ink);border:2px solid var(--line);padding:13px 26px;transition:.15s}
.btn-h-ghost:hover{border-color:var(--red);color:var(--red)}

.h-stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:48px;padding-top:24px;border-top:1px solid var(--line)}
.hstat{padding-right:16px;border-right:1px solid var(--line);margin-right:16px}
.hstat:last-child{border:none;margin:0;padding:0}
.hstat-n{font-size:38px;font-weight:900;color:var(--ink);line-height:1;letter-spacing:-1.5px}
.hstat-n sup{font-size:20px;color:var(--red);font-weight:700}
.hstat-l{font-size:12.5px;color:var(--mute);margin-top:4px;font-weight:500}

/* RIGHT panel */
.hr{background:var(--ink);position:relative;overflow:hidden;display:flex;flex-direction:column}
.hr::after{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:40px 40px;pointer-events:none}
.hr-inner{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;justify-content:center;padding:44px 36px;gap:20px}

.hr-chip{display:inline-flex;align-items:baseline;gap:6px;background:var(--red);padding:7px 14px;align-self:flex-start}
.hr-chip-n{font-size:24px;font-weight:900;color:#fff;line-height:1;letter-spacing:-1px}
.hr-chip-t{font-size:11px;font-weight:600;color:rgba(255,255,255,.7);letter-spacing:1.5px;text-transform:uppercase}

.hr-heading{font-size:22px;font-weight:700;color:rgba(255,255,255,.92);line-height:1.35;letter-spacing:-.3px}
.hr-heading span{color:var(--red)}

.svc-stack{display:flex;flex-direction:column;gap:2px}
.sv{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid rgba(255,255,255,.07);cursor:pointer;transition:background .15s,border-color .15s}
.sv:hover{background:rgba(224,30,38,.13);border-color:rgba(224,30,38,.3)}
.sv:hover .sv-arr{color:var(--red);transform:translateX(3px)}
.sv-left{display:flex;align-items:center;gap:13px}
.sv-num{font-size:10.5px;font-weight:700;color:rgba(255,255,255,.2);width:20px;flex-shrink:0}
.sv-name{font-size:14px;font-weight:700;color:rgba(255,255,255,.88)}
.sv-sub{font-size:11.5px;color:rgba(255,255,255,.35);margin-top:2px;font-weight:400}
.sv-arr{font-size:18px;color:rgba(255,255,255,.2);transition:color .15s,transform .15s;flex-shrink:0}

.hr-cta{display:flex;align-items:center;gap:14px}
.btn-wh{background:#fff;color:var(--ink);font-size:14px;font-weight:700;padding:12px 26px;transition:.18s}
.btn-wh:hover{background:var(--red);color:#fff}
.hr-tel{font-size:13px;color:rgba(255,255,255,.4);font-weight:400}
.hr-tel b{color:rgba(255,255,255,.8);font-weight:700}

/* ══ TICKER ══ */
.ticker{background:var(--red);overflow:hidden;padding:11px 0}
.tk{display:flex;white-space:nowrap;animation:tk 32s linear infinite}
.tk-i{display:inline-flex;align-items:center;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.85);padding:0 36px;border-right:1px solid rgba(255,255,255,.2);flex-shrink:0}
.tk-dot{color:rgba(255,255,255,.35);margin:0 8px}
@keyframes tk{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ SERVICES GRID ══ */
.svc-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3px}
.sc{background:var(--white);border:1px solid var(--line);padding:32px 28px;min-height:272px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;position:relative;overflow:hidden;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.sc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.sc:hover::after{transform:scaleX(1)}
.sc:hover{box-shadow:0 10px 36px rgba(0,0,0,.08);transform:translateY(-4px)}
.sc::before{content:'';position:absolute;inset:0;background:var(--red-bg);opacity:0;transition:opacity .25s}
.sc:hover::before{opacity:1}
.sc>*{position:relative;z-index:1}
.sc.red{background:var(--red);border-color:var(--red)}
.sc.red::before{background:var(--red-d)}
.sc.red::after{background:rgba(255,255,255,.3)}
.sc.red:hover{box-shadow:0 10px 36px rgba(224,30,38,.28)}
.sc.red .sc-n,.sc.red .sc-desc{color:rgba(255,255,255,.65)}
.sc.red .sc-title{color:#fff;font-size:22px}
.sc.red .sc-ico{background:rgba(255,255,255,.12)}
.sc.red .sc-ico svg{stroke:#fff}
.sc.red .sc-tag{background:rgba(255,255,255,.12);color:rgba(255,255,255,.65)}
.sc.red .sc-arrow{color:rgba(255,255,255,.7)}
.sc.red:hover .sc-arrow{color:#fff}
.sc-n{font-size:10px;font-weight:700;letter-spacing:2.5px;color:var(--mute);margin-bottom:16px}
.sc-ico{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--red-bg);margin-bottom:14px;transition:background .2s}
.sc:not(.red):hover .sc-ico{background:var(--red)}
.sc:not(.red):hover .sc-ico svg{stroke:#fff}
.sc-ico svg{width:22px;height:22px;stroke:var(--red);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s}
.sc-title{font-size:18px;font-weight:800;color:var(--ink);margin-bottom:9px;line-height:1.25;letter-spacing:-.3px}
.sc-desc{font-size:13.5px;color:var(--sub);line-height:1.65;font-weight:400}
.sc-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:10px}
.sc-tag{background:var(--bg);font-size:11.5px;font-weight:600;padding:3px 9px;color:var(--sub)}
.sc-arrow{font-size:12.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--red);margin-top:20px;display:flex;align-items:center;gap:5px;transition:gap .15s}
.sc-arrow::after{content:'→'}
.sc:hover .sc-arrow{gap:10px}

/* ══ EVENTS ══ */
.ev-tabs{display:flex;gap:3px;margin-bottom:32px;flex-wrap:wrap}
.ev-tab{padding:8px 20px;font-size:13.5px;font-weight:600;color:var(--sub);border:1px solid var(--line);cursor:pointer;transition:.15s;background:var(--white)}
.ev-tab.on,.ev-tab:hover{background:var(--red);color:#fff;border-color:var(--red)}

.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.ev-card{background:var(--white);border:1px solid var(--line);overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.ev-card:hover{box-shadow:0 10px 36px rgba(0,0,0,.09);transform:translateY(-4px)}
.ev-thumb{height:215px;position:relative;overflow:hidden}
.ev-thumb-bg{position:absolute;inset:0;transition:transform .5s var(--ease)}
.ev-card:hover .ev-thumb-bg{transform:scale(1.06)}
.et1{background:linear-gradient(145deg,#180408 0%,#8b1018 55%,#1a0810 100%)}
.et2{background:linear-gradient(145deg,#040e14 0%,#065870 55%,#040e14 100%)}
.et3{background:linear-gradient(145deg,#180c04 0%,#7a3808 55%,#040e14 100%)}
.ev-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 55%)}
.ev-pill{position:absolute;top:14px;left:14px;z-index:2;padding:4px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff}
.ep-r{background:var(--red)} .ep-b{background:#222}
.ev-body{padding:20px 22px 22px;border-top:1px solid var(--line)}
/* Red bar bottom reveal */
.ev-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.ev-card:hover::after{transform:scaleX(1)}
.ev-title{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:10px;line-height:1.35;letter-spacing:-.2px;transition:color .15s}
.ev-card:hover .ev-title{color:var(--red)}
.ev-meta{display:flex;gap:14px;font-size:12.5px;color:var(--mute);margin-bottom:16px;flex-wrap:wrap}
.ev-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--line)}
.ev-price{font-size:18px;font-weight:900;color:var(--red);line-height:1;letter-spacing:-.5px}
.ev-price small{font-size:11.5px;font-weight:400;color:var(--mute);display:block;margin-top:2px;letter-spacing:0}
.ev-link{font-size:12.5px;font-weight:700;color:var(--red);display:flex;align-items:center;gap:5px;transition:gap .15s;border-bottom:1.5px solid var(--red);padding-bottom:1px}
.ev-card:hover .ev-link{gap:9px}

/* ══ TOURS ══ */
.tour-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.tc{background:var(--white);border:1px solid var(--line);overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.tc:hover{box-shadow:0 10px 36px rgba(0,0,0,.09);transform:translateY(-4px)}
.tc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.tc:hover::after{transform:scaleX(1)}
.tc-thumb{height:190px;position:relative;overflow:hidden}
.tc-bg{position:absolute;inset:0;transition:transform .5s var(--ease)}
.tc:hover .tc-bg{transform:scale(1.07)}
.tg1{background:linear-gradient(145deg,#180c00,#b85010 70%,#100820)}
.tg2{background:linear-gradient(145deg,#00080e,#0568a0 70%,#00080e)}
.tg3{background:linear-gradient(145deg,#180005,#a81020 70%,#040a14)}
.tg4{background:linear-gradient(145deg,#060010,#4010a0 70%,#040a14)}
.tg5{background:linear-gradient(145deg,#001008,#0c7040 70%,#000c18)}
.tg6{background:linear-gradient(145deg,#000610,#1030a0 70%,#000610)}
.tg7{background:linear-gradient(145deg,#100004,#b01828 70%,#040810)}
.tg8{background:linear-gradient(145deg,#000810,#048090 70%,#060008)}
.tc-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 55%)}
.t-pill{position:absolute;top:12px;left:12px;z-index:2;padding:3px 10px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff}
.tp-r{background:var(--red)} .tp-b{background:#222}
.tc-body{padding:14px 16px 16px;border-top:1px solid var(--line)}
.tc-dest{font-size:10.5px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px}
.tc-name{font-size:15px;font-weight:800;color:var(--ink);line-height:1.35;margin-bottom:6px;letter-spacing:-.2px;transition:color .15s}
.tc:hover .tc-name{color:var(--red)}
.tc-info{font-size:12.5px;color:var(--mute);margin-bottom:12px}
.tc-footer{display:flex;align-items:flex-end;justify-content:space-between}
.tc-price{font-size:19px;font-weight:900;color:var(--red);line-height:1;letter-spacing:-.5px}
.tc-price span{font-size:11px;font-weight:400;color:var(--mute);display:block;margin-bottom:2px;letter-spacing:0}
.tc-cta{font-size:12px;font-weight:700;color:var(--sub);display:flex;align-items:center;gap:3px;transition:color .15s,gap .15s}
.tc:hover .tc-cta{color:var(--red);gap:6px}

/* ══ COMBO ══ */
.combo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.cc{background:var(--white);border:1px solid var(--line);overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.cc:hover{box-shadow:0 10px 36px rgba(0,0,0,.09);transform:translateY(-4px)}
.cc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.cc:hover::after{transform:scaleX(1)}
.cc-thumb{height:148px;position:relative;overflow:hidden}
.ccb1{background:linear-gradient(135deg,#001418,#0070a0)}
.ccb2{background:linear-gradient(135deg,#180202,var(--red))}
.ccb3{background:linear-gradient(135deg,#001018,#c04510 55%,#001018)}
.cc-body{padding:18px 20px 20px;border-top:1px solid var(--line)}
.cc-tag{display:inline-block;background:var(--bg);font-size:10.5px;font-weight:700;padding:3px 9px;color:var(--sub);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.cc-name{font-size:15.5px;font-weight:800;color:var(--ink);margin-bottom:6px;line-height:1.3;letter-spacing:-.2px;transition:color .15s}
.cc:hover .cc-name{color:var(--red)}
.cc-inc{font-size:12.5px;color:var(--sub);margin-bottom:12px;line-height:1.65}
.cc-price{font-size:20px;font-weight:900;color:var(--red);letter-spacing:-.5px}

/* ══ ABOUT ══ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.ab-l{padding-right:60px;border-right:1px solid var(--line);display:flex;flex-direction:column;justify-content:center}
.ab-r{padding-left:60px;display:flex;flex-direction:column;gap:3px;justify-content:center}
.ab-text{font-size:16px;line-height:1.78;color:var(--sub);margin-bottom:10px;font-weight:400}
.ab-text b{color:var(--ink);font-weight:700}
.ab-certs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:22px 0}
.ab-cert{border:1px solid var(--line);border-left:3px solid var(--red);padding:12px 14px;transition:background .18s}
.ab-cert:hover{background:var(--red-bg)}
.ab-ct{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--ink);margin-bottom:3px}
.ab-cv{font-size:13px;color:var(--sub);font-weight:400}
.ab-btns{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.btn-ab{background:var(--red);color:#fff;font-size:14px;font-weight:700;padding:12px 26px;transition:.15s}
.btn-ab:hover{background:var(--red-d)}
.btn-abl{border:2px solid var(--line);color:var(--ink);font-size:14px;font-weight:600;padding:11px 22px;transition:.15s}
.btn-abl:hover{border-color:var(--red);color:var(--red)}
/* Number cards */
.nc{display:grid;grid-template-columns:90px 1fr;align-items:center;gap:20px;padding:20px;border:1px solid var(--line);border-left:4px solid var(--red);background:var(--white);transition:transform .2s var(--ease),background .2s;cursor:default}
.nc:hover{background:var(--red-bg);transform:translateX(5px)}
.nc-n{font-size:46px;font-weight:900;color:var(--ink);line-height:1;letter-spacing:-2px;white-space:nowrap}
.nc-n sup{font-size:20px;color:var(--red);font-weight:700}
.nc-t{font-size:14.5px;font-weight:800;color:var(--ink);margin-bottom:3px;letter-spacing:-.2px}
.nc-s{font-size:13px;color:var(--sub);line-height:1.5;font-weight:400}

/* ══ TESTIMONIALS ══ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.testi{background:var(--white);border:1px solid var(--line);padding:28px;position:relative;overflow:hidden;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.testi:hover{box-shadow:0 10px 36px rgba(0,0,0,.08);transform:translateY(-4px)}
.testi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.testi:hover::after{transform:scaleX(1)}
.testi::before{content:'"';position:absolute;top:8px;right:16px;font-size:80px;color:var(--red);opacity:.06;line-height:1}
.testi-stars{font-size:13.5px;color:#F59E0B;letter-spacing:3px;margin-bottom:12px}
.testi-txt{font-size:14px;color:var(--sub);line-height:1.8;margin-bottom:18px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--line)}
.t-av{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;flex-shrink:0}
.av-r{background:var(--red)} .av-k{background:#0d0d0d} .av-g{background:#555}
.t-name{font-size:14px;font-weight:800;color:var(--ink);line-height:1.2}
.t-role{font-size:12px;color:var(--mute);margin-top:2px}

/* ══ CLIENTS ══ */
.clients-sec{padding:44px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cl-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--mute);text-align:center;margin-bottom:22px}
.cl-slider-wrap{display:flex;align-items:center;gap:12px;position:relative}
.cl-viewport{flex:1;overflow:hidden;border:1px solid var(--line)}
.cl-track{display:flex;transition:transform .4s var(--ease)}
.cl{flex:0 0 calc(100%/5);padding:18px 0;text-align:center;font-size:14.5px;font-weight:700;color:var(--mute);transition:color .15s,background .15s;cursor:default;border-right:1px solid var(--line)}
.cl:hover{color:var(--red);background:var(--red-bg)}
.cl-arr{width:38px;height:38px;border:1.5px solid var(--line);background:#fff;color:var(--sub);font-size:22px;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.cl-arr:hover{border-color:var(--red);color:var(--red);background:var(--red-bg)}

/* ══ NEWS ══ */
.news-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.news-c{background:var(--white);border:1px solid var(--line);overflow:hidden;cursor:pointer;position:relative;transition:box-shadow .25s var(--ease),transform .25s var(--ease)}
.news-c:hover{box-shadow:0 10px 36px rgba(0,0,0,.09);transform:translateY(-4px)}
.news-c::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.news-c:hover::after{transform:scaleX(1)}
.news-thumb{height:158px;position:relative;overflow:hidden}
.nb-bg{position:absolute;inset:0;transition:transform .5s var(--ease)}
.news-c:hover .nb-bg{transform:scale(1.06)}
.nb1{background:linear-gradient(145deg,#001418,#0070a0)}
.nb2{background:linear-gradient(145deg,#180202,#a01020)}
.nb3{background:linear-gradient(145deg,#001008,#0c7840)}
.nb4{background:linear-gradient(145deg,#100002,#901020)}
.news-pill{position:absolute;top:12px;left:12px;z-index:2;padding:3px 10px;font-size:10.5px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}
.np-b{background:#222} .np-r{background:var(--red)}
.news-body{padding:14px 16px 18px;border-top:1px solid var(--line)}
.news-date{font-size:11.5px;color:var(--mute);margin-bottom:6px}
.news-title{font-size:14.5px;font-weight:800;color:var(--ink);line-height:1.4;letter-spacing:-.2px;transition:color .15s}
.news-c:hover .news-title{color:var(--red)}

/* ══ RESPONSIVE ══ */
@media(max-width:1080px){nav,.hdr-cta .btn-o{display:none}}
@media(max-width:900px){
  .W{padding:0 20px}
  .sec{padding:60px 0}
  .hero .W{grid-template-columns:1fr}
  .hr{display:none}
  .hl{padding:52px 0}
  .hl::before{display:none}
  .svc-grid{grid-template-columns:1fr 1fr}
  .ev-grid,.combo-grid,.testi-grid{grid-template-columns:1fr 1fr}
  .tour-grid,.news-grid{grid-template-columns:1fr 1fr}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .ab-l{padding-right:0;border-right:none;padding-bottom:32px;border-bottom:1px solid var(--line)}
  .ab-r{padding-left:0}
  .cta-band .W{flex-direction:column;align-items:flex-start;text-align:left}
  .cta-r{align-items:flex-start}
  .ft-inner .W{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .svc-grid,.ev-grid,.combo-grid,.testi-grid,.tour-grid,.news-grid{grid-template-columns:1fr}
  .ft-inner .W{grid-template-columns:1fr}
  .h-stats{grid-template-columns:1fr 1fr;gap:16px}
  .hstat{border-right:none;margin:0;padding:0}
}

/* ══ HERO SLIDESHOW ══ */
.hero-slides{display:flex;width:400%;height:100%;animation:slideHero 16s infinite}
@keyframes slideHero{0%,22%{transform:translateX(0)}25%,47%{transform:translateX(-25%)}50%,72%{transform:translateX(-50%)}75%,97%{transform:translateX(-75%)}100%{transform:translateX(0)}}
.hero-slide{width:25%;height:100%;position:relative;flex-shrink:0}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.1) 0%,rgba(0,0,0,.55) 100%)}
.hs1{background:url('images/hero_banner_travel_1778088451169.png') center/cover}
.hs2{background:url('https://images.unsplash.com/photo-1540575467063-178a50c2df87?auto=format&fit=crop&q=80&w=1600') center/cover}
.hs3{background:url('images/event_anniversary_1778088482676.png') center/cover}
.hs4{background:url('https://images.unsplash.com/photo-1511795409834-ef04bbd61622?auto=format&fit=crop&q=80&w=1600') center/cover}
.hero-over{position:absolute;bottom:0;left:0;right:0;top:0;z-index:10;display:flex;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(184,146,58,.15);border:1px solid rgba(184,146,58,.45);color:#F0C96A;font-size:11px;font-weight:600;padding:5px 14px;margin-bottom:16px;letter-spacing:.5px}
.hero-title{font-size:clamp(32px,5vw,60px);font-weight:900;color:#fff;line-height:1.15;margin-bottom:16px;text-shadow:0 2px 20px rgba(0,0,0,.4)}
.hero-title em{color:#F5D080;font-style:normal}
.hero-sub{color:rgba(255,255,255,.8);font-size:clamp(14px,1.8vw,18px);max-width:540px;line-height:1.6;margin-bottom:32px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-hero-primary{background:var(--red);color:#fff;padding:12px 28px;font-weight:700;font-size:15px;transition:.2s}
.btn-hero-primary:hover{background:var(--red-d);transform:translateY(-1px)}
.btn-hero-secondary{background:rgba(255,255,255,.12);color:#fff;padding:12px 28px;font-weight:600;font-size:15px;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(8px);transition:.2s}
.btn-hero-secondary:hover{background:rgba(255,255,255,.22)}
.hero-dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:8px}
.hero-dot{width:8px;height:8px;background:rgba(255,255,255,.4);transition:.3s;cursor:pointer}
.hero-dot.active{background:#fff;width:24px}
/* Search bar */
.search-bar-wrap{background:#fff;margin:-28px auto 0;max-width:960px;border:1px solid var(--line);padding:24px 28px;position:relative;z-index:20;border-top:3px solid var(--red);box-shadow:0 4px 24px rgba(0,0,0,.08)}
.search-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid var(--line)}
.search-tab{font-size:13px;font-weight:600;color:var(--mute);cursor:pointer;padding:10px 22px;transition:.2s;border-bottom:2px solid transparent;margin-bottom:-1px}
.search-tab.on{color:var(--red);border-bottom-color:var(--red)}
.search-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:12px;align-items:end}
.search-field label{font-size:12px;font-weight:600;color:var(--sub);margin-bottom:6px;display:block;text-transform:uppercase;letter-spacing:.5px}
.search-field select,.search-field input{width:100%;padding:10px 14px;border:1.5px solid var(--line);font-size:14px;font-family:inherit;background:#fff;color:var(--body);outline:none;transition:.2s}
.search-field select:focus,.search-field input:focus{border-color:var(--red)}
.btn-search{background:var(--red);color:#fff;padding:11px 24px;font-weight:600;font-size:14px;border:none;cursor:pointer;transition:.2s;white-space:nowrap;font-family:inherit}
.btn-search:hover{background:var(--red-d)}
/* TB Slider */
.tb-slider-wrapper{overflow:hidden;padding:10px 0;margin:0 -10px;position:relative}
.tb-track{display:flex;transition:transform .5s ease;gap:20px}
.tb-item{flex:0 0 calc(33.3333% - 13.33px);height:300px;position:relative;display:flex;align-items:flex-end;justify-content:flex-start;color:#fff;padding:24px 20px;overflow:hidden;cursor:pointer;transition:.3s}
.tb-item::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 60%,transparent 100%);z-index:1}
.tb-item:hover::before{background:linear-gradient(to top,rgba(0,0,0,.95) 0%,rgba(0,0,0,.4) 60%,transparent 100%)}
.tb-item:hover{transform:translateY(-4px);box-shadow:0 10px 36px rgba(0,0,0,.09)}
.tb-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transition:transform .5s}
.tb-item:hover .tb-bg{transform:scale(1.05)}
.tb-content{position:relative;z-index:2;width:100%}
.tb-tag{display:inline-block;background:var(--red);padding:4px 10px;font-size:10px;font-weight:700;margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}
.tb-title{font-size:18px;font-weight:700;margin-bottom:8px;line-height:1.3;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}
.tb-desc{font-size:13px;opacity:.9;margin-bottom:14px;line-height:1.5;text-shadow:0 1px 2px rgba(0,0,0,.3)}
.tb-btn{background:var(--red);color:#fff;padding:8px 20px;font-weight:600;font-size:13px;display:inline-block;cursor:pointer;transition:.2s;text-decoration:none}
.tb-btn:hover{background:var(--red-d)}
.tb-dots{display:flex;justify-content:center;gap:8px;margin-top:24px}
.tb-dot{width:8px;height:8px;background:var(--line);cursor:pointer;transition:.3s}
.tb-dot.active{background:var(--red);width:24px}
/* Thumb image classes */
.c1{background:url('images/event_anniversary_1778088482676.png') center/cover}
.c2{background:url('images/tour_japan_1778088532886.png') center/cover}
.c3{background:url('images/tour_thailand_1778088548301.png') center/cover}
.c4{background:url('images/event_teambuilding_1778088513069.png') center/cover}
.c5{background:url('images/event_gala_1778088497636.png') center/cover}
.c6{background:url('images/tour_australia_1778088563758.png') center/cover}
.thumb-txt{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;padding:12px;text-align:center}
.thumb-txt span{color:rgba(255,255,255,.9);font-size:13px;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.thumb-txt small{color:rgba(255,255,255,.6);font-size:11px}
@media(max-width:900px){.tb-item{flex:0 0 calc(50% - 10px)}.search-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tb-item{flex:0 0 100%}.search-grid{grid-template-columns:1fr}}

/* ══ HERO OVERRIDE - Prevent demo .hero CSS from breaking slideshow ══ */
section > .hero {
  display: block !important;
  position: relative !important;
  padding: 0 !important;
  grid-template-columns: unset !important;
}
section > .hero > .W {
  display: block !important;
}
.hero-over .W {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
  width: 100%;
  display: flex !important;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.hero-btns {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 0;
}
.btn-hero-primary, .btn-hero-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  line-height: 1;
  transition: .2s;
}

/* ══ TOUR VIDEO ══ */
.tc-video{grid-row:span 2}.tc-video .tc-thumb{height:100%;min-height:400px;position:relative;overflow:hidden;background:#111}.tc-video iframe{position:absolute;inset:0;width:100%;height:100%;border:none}.tc-video .tc-thumb::after{display:none}

/* ==== MENU & SUB-MENU (WP_NAV_MENU) ==== */
#site-nav { flex: 1; display: flex; align-items: stretch; padding: 0 8px; }
#site-nav > ul { display: flex; align-items: stretch; list-style: none; margin: 0; padding: 0; }
#site-nav > ul > li { position: relative; display: flex; align-items: center; }
#site-nav > ul > li > a { padding: 0 14px; font-size: 14px; font-weight: 500; color: var(--sub); height: 70px; display: flex; align-items: center; gap: 3px; cursor: pointer; border-bottom: 2px solid transparent; transition: color .15s, border-color .15s; white-space: nowrap; }
#site-nav > ul > li:hover > a, #site-nav > ul > li.current-menu-item > a { color: var(--red); border-bottom-color: var(--red); }
#site-nav .sub-menu { position: absolute; top: calc(100% + 1px); left: 0; background: var(--white); min-width: 215px; border: 1px solid var(--line); border-top: 3px solid var(--red); padding: 6px; opacity: 0; pointer-events: none; transform: translateY(6px); transition: opacity .18s, transform .18s; z-index: 99; box-shadow: 0 12px 32px rgba(0,0,0,.09); list-style: none; }
#site-nav li:hover > .sub-menu { opacity: 1; pointer-events: auto; transform: none; }
#site-nav .sub-menu li a { display: block; padding: 10px 14px; font-size: 14px; font-weight: 500; color: var(--sub); border-left: 3px solid transparent; transition: .12s; text-decoration: none; }
#site-nav .sub-menu li a:hover { background: var(--red-bg); color: var(--red); border-left-color: var(--red); padding-left: 18px; }
#site-nav .sub-menu .sub-menu { top: -3px; left: 100%; }

/* ==== RESPONSIVE GRID OVERRIDES ==== */
.news-bento { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; align-items: stretch; }
.ft-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 44px; }
@media (max-width: 900px) {
  .news-bento { grid-template-columns: 1fr; }
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
}
@media (max-width: 560px) {
  .ft-grid { grid-template-columns: 1fr; gap: 24px; }
}

