
/* v147 — hard public header + fees hero layout reset
   Goal: stop clipped left content, restore readable nav size, and rebuild Fees hero safely. */

html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden !important;
}

/* HEADER / TOPBAR RESET */
.topbar{
  width:100%;
  max-width:100%;
  overflow:hidden !important;
  background:#071936;
}

.topbar .container.nav,
.topbar .nav,
.container.nav{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:18px 44px !important;
  min-height:116px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:34px !important;
  box-sizing:border-box !important;
}

.topbar .brand.brand-logo,
.brand.brand-logo{
  flex:0 0 auto !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  min-width:240px !important;
  max-width:320px !important;
  margin:0 !important;
  padding:0 !important;
  overflow:visible !important;
}

.topbar .brand.brand-logo img,
.brand.brand-logo img,
.home-page .topbar .brand.brand-logo img{
  display:block !important;
  width:auto !important;
  height:76px !important;
  max-width:320px !important;
  object-fit:contain !important;
}

.topbar .navlinks,
.navlinks{
  flex:1 1 auto !important;
  min-width:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:24px !important;
  white-space:nowrap !important;
  overflow:visible !important;
}

.topbar .navlinks a:not(.btn),
.navlinks a:not(.btn){
  display:inline-flex !important;
  align-items:center !important;
  color:#f8fafc !important;
  font-size:18px !important;
  line-height:1.15 !important;
  font-weight:850 !important;
  letter-spacing:-.02em !important;
  white-space:nowrap !important;
  flex:0 0 auto !important;
}

.topbar .navlinks .nav-apply-btn,
.navlinks .nav-apply-btn,
.nav-apply-btn{
  flex:0 0 auto !important;
  min-width:150px !important;
  padding:16px 28px !important;
  font-size:18px !important;
  font-weight:900 !important;
}

/* FEES HERO HARD RESET */
body .fees-hero{
  width:100% !important;
  max-width:100% !important;
  overflow:hidden !important;
  padding:72px 0 70px !important;
  background:
    radial-gradient(circle at 88% 6%, rgba(191,219,254,.56), transparent 38%),
    linear-gradient(90deg,#ffffff 0%,#f8fafc 56%,#eef6ff 100%) !important;
}

body .fees-hero .fees-hero-grid{
  width:100% !important;
  max-width:1500px !important;
  margin:0 auto !important;
  padding:0 56px !important;
  box-sizing:border-box !important;
  display:grid !important;
  grid-template-columns:minmax(0,0.95fr) minmax(460px,0.85fr) !important;
  align-items:center !important;
  gap:52px !important;
  overflow:visible !important;
}

body .fees-hero .fees-hero-grid > div{
  min-width:0 !important;
  max-width:100% !important;
  overflow:visible !important;
}

body .fees-hero .eyebrow{
  font-size:16px !important;
  line-height:1.2 !important;
  letter-spacing:.12em !important;
  margin-bottom:18px !important;
}

body .fees-hero h1{
  display:block !important;
  max-width:760px !important;
  margin:0 0 26px !important;
  padding:0 !important;
  overflow:visible !important;
  color:#0f172a !important;
  font-size:clamp(48px,4.25vw,78px) !important;
  line-height:1.04 !important;
  letter-spacing:-.045em !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
}

body .fees-hero .muted{
  max-width:760px !important;
  margin:0 0 30px !important;
  color:#52627a !important;
  font-size:22px !important;
  line-height:1.58 !important;
}

body .fees-hero .hero-actions{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  gap:18px !important;
  margin-top:28px !important;
}

body .fees-hero .hero-actions .btn{
  min-width:180px !important;
  min-height:58px !important;
  padding:16px 28px !important;
  font-size:17px !important;
}

body .fees-hero .urgent-visual-card{
  width:100% !important;
  max-width:680px !important;
  justify-self:end !important;
  overflow:hidden !important;
  border-radius:34px !important;
}

body .fees-hero .urgent-visual-card img,
body .fees-hero img.media-focus-fees-page{
  display:block !important;
  width:100% !important;
  height:auto !important;
  min-height:420px !important;
  max-height:520px !important;
  object-fit:cover !important;
  object-position:center center !important;
}

/* Keep floating buttons from covering Fees calculator card too aggressively */
.fees-hero ~ .whatsapp-float,
body .whatsapp-float{
  right:34px !important;
}

/* RESPONSIVE HEADER + FEES */
@media(max-width:1500px){
  .topbar .container.nav,
  .topbar .nav,
  .container.nav{
    padding-left:34px !important;
    padding-right:34px !important;
    gap:24px !important;
    min-height:106px !important;
  }
  .topbar .brand.brand-logo,
  .brand.brand-logo{
    min-width:220px !important;
  }
  .topbar .brand.brand-logo img,
  .brand.brand-logo img,
  .home-page .topbar .brand.brand-logo img{
    height:68px !important;
    max-width:280px !important;
  }
  .topbar .navlinks,
  .navlinks{
    gap:18px !important;
  }
  .topbar .navlinks a:not(.btn),
  .navlinks a:not(.btn){
    font-size:16px !important;
  }
  .topbar .navlinks .nav-apply-btn,
  .navlinks .nav-apply-btn,
  .nav-apply-btn{
    min-width:138px !important;
    padding:14px 22px !important;
    font-size:16px !important;
  }
  body .fees-hero .fees-hero-grid{
    max-width:1360px !important;
    padding-left:44px !important;
    padding-right:44px !important;
    gap:40px !important;
    grid-template-columns:minmax(0,1fr) minmax(430px,.78fr) !important;
  }
  body .fees-hero h1{
    font-size:clamp(44px,4vw,68px) !important;
  }
  body .fees-hero .muted{
    font-size:20px !important;
  }
}

@media(max-width:1260px){
  .topbar .container.nav,
  .topbar .nav,
  .container.nav{
    min-height:96px !important;
    padding-left:26px !important;
    padding-right:26px !important;
  }
  .topbar .brand.brand-logo,
  .brand.brand-logo{
    min-width:190px !important;
  }
  .topbar .brand.brand-logo img,
  .brand.brand-logo img,
  .home-page .topbar .brand.brand-logo img{
    height:58px !important;
    max-width:240px !important;
  }
  .topbar .navlinks,
  .navlinks{
    gap:13px !important;
  }
  .topbar .navlinks a:not(.btn),
  .navlinks a:not(.btn){
    font-size:14px !important;
  }
  .topbar .navlinks .nav-apply-btn,
  .navlinks .nav-apply-btn,
  .nav-apply-btn{
    min-width:120px !important;
    padding:12px 18px !important;
    font-size:15px !important;
  }
  body .fees-hero .fees-hero-grid{
    grid-template-columns:1fr !important;
    max-width:980px !important;
    gap:34px !important;
  }
  body .fees-hero .urgent-visual-card{
    justify-self:start !important;
    max-width:780px !important;
  }
  body .fees-hero h1,
  body .fees-hero .muted{
    max-width:820px !important;
  }
}

@media(max-width:900px){
  .topbar .navlinks{
    display:none !important;
  }
  .mobile-only{
    display:inline-flex !important;
  }
  .topbar .container.nav,
  .topbar .nav,
  .container.nav{
    min-height:82px !important;
    padding:14px 18px !important;
  }
  .topbar .brand.brand-logo,
  .brand.brand-logo{
    min-width:0 !important;
    max-width:230px !important;
  }
  .topbar .brand.brand-logo img,
  .brand.brand-logo img,
  .home-page .topbar .brand.brand-logo img{
    height:50px !important;
    max-width:220px !important;
  }
  body .fees-hero{
    padding:46px 0 48px !important;
  }
  body .fees-hero .fees-hero-grid{
    padding-left:22px !important;
    padding-right:22px !important;
  }
  body .fees-hero h1{
    font-size:clamp(34px,8vw,48px) !important;
    letter-spacing:-.035em !important;
  }
  body .fees-hero .muted{
    font-size:18px !important;
  }
  body .fees-hero .urgent-visual-card img,
  body .fees-hero img.media-focus-fees-page{
    min-height:280px !important;
    max-height:360px !important;
  }
}

/* v253U — Public UI critical mobile/header/chat/trust reset
   Scope: first UI-only pass after v252. Focus on safe visible fixes, not new modules. */
:root{
  --vge-ui253-navy:#071936;
  --vge-ui253-blue:#1d4ed8;
  --vge-ui253-red:#dc2626;
  --vge-ui253-line:#d8e0ea;
}

html, body{
  overflow-x:hidden !important;
}
body{
  padding-bottom:calc(18px + env(safe-area-inset-bottom,0px));
}

/* Header: reduce desktop crowding and create a real mobile menu path. */
.topbar{
  position:relative !important;
  z-index:1000 !important;
  overflow:visible !important;
  background:var(--vge-ui253-navy) !important;
}
.topbar .container.nav,
.topbar .nav,
.container.nav{
  max-width:1440px !important;
  margin:0 auto !important;
  min-height:84px !important;
  padding:14px 28px !important;
  gap:18px !important;
  overflow:visible !important;
}
.topbar .brand.brand-logo,
.brand.brand-logo{
  min-width:160px !important;
  max-width:260px !important;
}
.topbar .brand.brand-logo img,
.brand.brand-logo img,
.home-page .topbar .brand.brand-logo img{
  height:54px !important;
  max-width:240px !important;
}
.topbar .navlinks,
.navlinks{
  gap:14px !important;
  flex-wrap:nowrap !important;
}
.topbar .navlinks a:not(.btn),
.navlinks a:not(.btn){
  font-size:14px !important;
  font-weight:750 !important;
  letter-spacing:-.01em !important;
}
.topbar .navlinks .nav-apply-btn,
.navlinks .nav-apply-btn,
.nav-apply-btn{
  min-width:118px !important;
  padding:11px 17px !important;
  font-size:14px !important;
}
.vge-mobile-menu-button{
  display:none;
  align-items:center;
  justify-content:center;
  gap:7px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.09);
  color:#fff;
  min-height:42px;
  padding:10px 12px;
  border-radius:999px;
  font:inherit;
  font-weight:850;
  cursor:pointer;
  white-space:nowrap;
}
.vge-mobile-menu-button span:first-child{font-size:18px;line-height:1}
.vge-mobile-menu-drawer{
  position:absolute;
  left:12px;
  right:12px;
  top:calc(100% + 8px);
  z-index:1001;
  background:#fff;
  color:#0f172a;
  border:1px solid rgba(15,23,42,.12);
  border-radius:22px;
  box-shadow:0 28px 70px rgba(15,23,42,.28);
  padding:10px;
}
.vge-mobile-menu-drawer[hidden]{display:none !important}
.vge-mobile-menu-inner{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.vge-mobile-menu-inner a{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 12px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
  color:#0f172a !important;
  font-size:13px;
  font-weight:850;
  text-align:center;
}
.vge-mobile-menu-inner a:hover{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8 !important}

@media(max-width:1260px){
  .topbar .container.nav,
  .topbar .nav,
  .container.nav{padding-left:22px !important;padding-right:22px !important;min-height:78px !important}
  .topbar .brand.brand-logo img,
  .brand.brand-logo img,
  .home-page .topbar .brand.brand-logo img{height:48px !important;max-width:220px !important}
  .topbar .navlinks a:not(.btn),
  .navlinks a:not(.btn){font-size:13px !important}
  .topbar .navlinks,
  .navlinks{gap:10px !important}
}
@media(max-width:900px){
  .topbar .container.nav,
  .topbar .nav,
  .container.nav{
    min-height:70px !important;
    padding:10px 14px !important;
    gap:8px !important;
  }
  .topbar .navlinks{display:none !important}
  .vge-mobile-menu-button{display:inline-flex !important;order:2}
  .mobile-only.btn.secondary,
  .mobile-only{
    display:inline-flex !important;
    order:3;
    width:auto !important;
    min-width:0 !important;
    min-height:42px !important;
    padding:10px 12px !important;
    border-radius:999px !important;
    font-size:13px !important;
    font-weight:850 !important;
    white-space:nowrap !important;
  }
  .topbar .brand.brand-logo,
  .brand.brand-logo{
    order:1;
    min-width:0 !important;
    flex:1 1 auto !important;
    max-width:calc(100vw - 178px) !important;
  }
  .topbar .brand.brand-logo img,
  .brand.brand-logo img,
  .home-page .topbar .brand.brand-logo img{
    height:42px !important;
    max-width:178px !important;
  }
}
@media(max-width:390px){
  .topbar .brand.brand-logo img,
  .brand.brand-logo img,
  .home-page .topbar .brand.brand-logo img{height:38px !important;max-width:148px !important}
  .vge-mobile-menu-button{padding:9px 10px !important;font-size:12px !important}
  .mobile-only.btn.secondary,.mobile-only{padding:9px 10px !important;font-size:12px !important}
  .vge-mobile-menu-inner{grid-template-columns:1fr}
}

/* Home mobile: force headline first, remove the large blank visual gap, keep fee card below copy. */
.home-page .hero{
  min-height:auto !important;
}
.home-page .hero-grid > .home-hero-copy,
.home-page .hero-grid > div:first-child{
  min-width:0 !important;
}
@media(max-width:1180px){
  .home-page .hero-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
  }
  .home-page .hero-grid > .home-hero-copy,
  .home-page .hero-grid > div:first-child{order:1 !important;justify-self:stretch !important}
  .home-page .hero-grid > .hero-fee-compact{order:2 !important;justify-self:stretch !important;max-width:680px !important}
}
@media(max-width:640px){
  .home-page .hero{
    padding:34px 0 32px !important;
    background:
      linear-gradient(180deg,rgba(7,17,38,.92) 0%,rgba(9,22,50,.88) 52%,rgba(11,28,66,.76) 100%),
      url('/assets/img/hero-vietnam-arrival-flip.png') 42% center / cover no-repeat !important;
  }
  .home-page .hero-grid{gap:18px !important}
  .home-page .hero-grid > .home-hero-copy{display:block !important;visibility:visible !important;opacity:1 !important}
  .home-page .hero-grid > .home-hero-copy .eyebrow{font-size:11px !important;line-height:1.35 !important;margin-bottom:10px !important;color:#bfdbfe !important}
  .home-page .hero h1,
  .home-page .home-hero-headline{
    display:block !important;
    visibility:visible !important;
    margin:0 0 12px !important;
    color:#fff !important;
    font-size:clamp(31px,9vw,42px) !important;
    line-height:1.07 !important;
    letter-spacing:-.04em !important;
    max-width:100% !important;
    min-height:0 !important;
  }
  .home-page .hero p,
  .home-page .home-hero-subcopy{
    display:block !important;
    color:#dbeafe !important;
    font-size:15.5px !important;
    line-height:1.58 !important;
    max-width:100% !important;
    margin:0 0 12px !important;
  }
  .home-page .hero .notice{
    font-size:12.5px !important;
    line-height:1.5 !important;
    padding:10px 12px !important;
    margin:10px 0 12px !important;
  }
  .home-page .trust-signal-bar{display:grid !important;grid-template-columns:1fr !important;gap:8px !important;margin:12px 0 !important}
  .home-page .trust-signal-bar span{justify-content:flex-start !important;text-align:left !important;font-size:12.5px !important;padding:8px 10px !important}
  .home-page .hero-actions,
  .home-page .home-hero-actions{display:grid !important;grid-template-columns:1fr !important;gap:10px !important;margin-top:14px !important}
  .home-page .hero-actions .btn{width:100% !important;min-height:46px !important}
  .home-page .hero-fee-compact{margin-top:2px !important;border-radius:22px !important;padding:16px !important}
}

/* Trust Center: guarantee contrast on the dark hero. */
.trust-center-page .trust-center-hero,
.trust-center-hero{
  background:linear-gradient(135deg,#071936 0%,#0b4a6f 55%,#0f766e 100%) !important;
  color:#fff !important;
}
.trust-center-hero .eyebrow,
.trust-center-hero h1,
.trust-center-hero p,
.trust-center-hero .muted{
  color:#fff !important;
  opacity:1 !important;
  text-shadow:0 10px 26px rgba(0,0,0,.25);
}
.trust-center-hero p,
.trust-center-hero .muted{color:#dbeafe !important}
.trust-center-hero-card{background:rgba(255,255,255,.14) !important;color:#fff !important}

/* Floating contact widgets: prevent overlap with content/form and with each other. */
.whatsapp-float{
  right:20px !important;
  bottom:18px !important;
  z-index:9997 !important;
}
.vge-chatbot-root{z-index:9998 !important}
body.vge-any-chat-open .whatsapp-float,
.vge-chatbot-root.is-open ~ .whatsapp-float{
  opacity:0 !important;
  pointer-events:none !important;
  transform:translateY(12px) scale(.96) !important;
}
@media(max-width:640px){
  body{padding-bottom:calc(96px + env(safe-area-inset-bottom,0px)) !important}
  .whatsapp-float{
    right:12px !important;
    bottom:calc(14px + env(safe-area-inset-bottom,0px)) !important;
    width:52px !important;
    height:52px !important;
    min-width:52px !important;
    padding:0 !important;
    justify-content:center !important;
    border-radius:999px !important;
  }
  .whatsapp-text{display:none !important}
  .whatsapp-icon{width:30px !important;height:30px !important}
  .vge-chatbot-root{
    right:74px !important;
    bottom:calc(14px + env(safe-area-inset-bottom,0px)) !important;
  }
  .vge-chatbot-root .vge-chatbot-launcher{
    width:52px !important;
    height:52px !important;
    min-width:52px !important;
    padding:0 !important;
    justify-content:center !important;
  }
  .vge-chatbot-root .vge-chatbot-launcher span:last-child{display:none !important}
  .vge-chatbot-root.is-open{
    right:0 !important;
    bottom:0 !important;
  }
  .vge-chatbot-root.is-open .vge-chatbot-panel{
    position:fixed !important;
    left:10px !important;
    right:10px !important;
    bottom:calc(76px + env(safe-area-inset-bottom,0px)) !important;
    width:auto !important;
    max-height:calc(100dvh - 96px) !important;
  }
  .lp-sticky{padding-bottom:calc(8px + env(safe-area-inset-bottom,0px)) !important}
  .lp-page .whatsapp-float{bottom:calc(84px + env(safe-area-inset-bottom,0px)) !important}
  .lp-page .vge-chatbot-root{bottom:calc(84px + env(safe-area-inset-bottom,0px)) !important}
}

/* Landing pages: fix clipped mobile header and crowded sticky CTA. */
.lp-page .topbar{overflow:visible !important}
@media(max-width:900px){
  .lp-page .topbar .container.nav{padding:10px 14px !important;min-height:70px !important}
  .lp-page .mobile-only{font-size:13px !important;padding:10px 12px !important}
  .lp-page .lp-hero{padding-top:42px !important}
  .lp-page .lp-hero-grid{grid-template-columns:1fr !important;gap:22px !important}
  .lp-page .lp-hero h1{font-size:clamp(31px,8.4vw,42px) !important;line-height:1.08 !important}
  .lp-page .lp-lead{font-size:16px !important;line-height:1.62 !important}
  .lp-page .lp-sticky .container{align-items:stretch !important;display:grid !important;grid-template-columns:1fr !important}
  .lp-page .lp-sticky .lp-actions{display:grid !important;grid-template-columns:1fr !important;gap:8px !important}
  .lp-page .lp-sticky .lp-cta{width:100% !important;min-height:44px !important}
}

/* FAQ first pass: keep the functional tools closer to the top on mobile. */
@media(max-width:640px){
  .faq-tools-card{margin-top:0 !important;padding:16px !important;border-radius:20px !important}
  .faq-page-pills{gap:8px !important}
  .page-hero + .section,
  .page-hero + main .section{padding-top:34px !important}
}
