/* =========================================================
   VCI GLOBAL HUMAN RESOURCES — Stylesheet
   Palette derived from brand logo (green / blue / red / gold)
   ========================================================= */

/* =========================================================
   PAGE HERO (inner pages) + breadcrumb + WP content
   ========================================================= */
.page-hero{position:relative;overflow:hidden;background:var(--grad-brand);color:#fff;padding:clamp(46px,7vw,86px) 0 clamp(38px,6vw,68px)}
.page-hero__bg{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.13) 1.4px,transparent 1.4px);background-size:28px 28px;opacity:.55}
.page-hero__bg::after{content:"";position:absolute;right:-80px;top:-100px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%)}
.page-hero__inner{position:relative}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:14px}
.breadcrumb a{color:rgba(255,255,255,.85);transition:color var(--t)}
.breadcrumb a:hover{color:#fff;text-decoration:underline}
.breadcrumb__sep{opacity:.6}
.page-hero__title{color:#fff;font-size:clamp(1.9rem,4.2vw,3rem);margin:0}
.page-hero__sub{color:rgba(255,255,255,.92);font-size:clamp(1rem,1.5vw,1.15rem);margin-top:12px;max-width:700px}

.entry-content h2{color:var(--ink);font-size:1.6rem;margin:1.4em 0 .5em}
.entry-content h3{color:var(--ink);font-size:1.25rem;margin:1.2em 0 .4em}
.entry-content p{margin:0 0 1em}
.entry-content ul,.entry-content ol{margin:0 0 1em 1.3em;display:grid;gap:.4em}
.entry-content ul{list-style:disc}
.entry-content ol{list-style:decimal}
.entry-content a{color:var(--green);text-decoration:underline}
.entry-content img{border-radius:var(--radius-sm);margin:1em 0;height:auto}
.entry-content blockquote{border-left:4px solid var(--green);background:var(--bg-soft);padding:14px 18px;border-radius:0 10px 10px 0;margin:1.2em 0}
.entry-content table{width:100%;border-collapse:collapse;margin:1.2em 0}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.entry-content th{background:var(--bg-soft)}

.pagination .nav-links,.posts-navigation .nav-links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.pagination a,.pagination span,.posts-navigation a{display:inline-grid;place-items:center;min-width:44px;height:44px;padding:0 14px;border-radius:11px;border:1.5px solid var(--line);font-weight:700;color:var(--ink);transition:var(--t)}
.pagination .current{background:var(--green);color:#fff;border-color:var(--green)}
.pagination a:hover,.posts-navigation a:hover{border-color:var(--green);color:var(--green)}

:root{
  /* Brand */
  --green:#0F7A3C;
  --green-d:#0B5A2C;
  --green-l:#16A34A;
  --blue:#0E6FBE;
  --blue-d:#0A4F8A;
  --red:#E11D2A;
  --gold:#F6B915;
  --gold-d:#D99A00;

  /* Neutrals */
  --ink:#0E1B14;
  --body:#3a4a42;
  --muted:#6b7c73;
  --line:#e4ece7;
  --bg:#ffffff;
  --bg-soft:#f4f8f5;
  --bg-dark:#0B2A19;

  /* System */
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 2px 10px rgba(11,42,25,.06);
  --shadow:0 14px 40px rgba(11,42,25,.10);
  --shadow-lg:0 30px 70px rgba(11,42,25,.16);
  --ring:0 0 0 4px rgba(15,122,60,.15);
  --container:1200px;
  --t:.32s cubic-bezier(.4,0,.2,1);
  --grad-brand:linear-gradient(120deg,var(--green) 0%,var(--blue) 100%);
  --grad-gold:linear-gradient(120deg,var(--gold) 0%,var(--red) 120%);

  --font:'Be Vietnam Pro',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--body);
  background:var(--bg);
  line-height:1.7;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
svg{fill:currentColor}
h1,h2,h3,h4{color:var(--ink);line-height:1.2;font-weight:800;letter-spacing:-.01em}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}
.ic{width:1em;height:1em;flex:0 0 auto;vertical-align:-.12em}

.skip-link{position:absolute;left:-9999px;top:0;z-index:999;background:var(--green);color:#fff;padding:10px 16px;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

::selection{background:var(--gold);color:var(--ink)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--green);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--bg);color:var(--fg);
  font-weight:700;font-size:.95rem;
  padding:.85em 1.5em;border-radius:999px;
  transition:transform var(--t),box-shadow var(--t),background var(--t),color var(--t);
  white-space:nowrap;line-height:1;
  box-shadow:0 6px 18px rgba(15,122,60,.22);
}
.btn:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(15,122,60,.30)}
.btn:active{transform:translateY(-1px)}
.btn:focus-visible{outline:none;box-shadow:var(--ring),0 6px 18px rgba(15,122,60,.22)}
.btn--primary{--bg:var(--green)}
.btn--gold{background:var(--grad-gold);color:#fff;box-shadow:0 8px 22px rgba(225,29,42,.30)}
.btn--gold:hover{box-shadow:0 16px 34px rgba(225,29,42,.40)}
.btn--white{background:#fff;color:var(--green);box-shadow:0 8px 22px rgba(0,0,0,.12)}
.btn--ghost{background:transparent;color:var(--green);box-shadow:inset 0 0 0 2px var(--green)}
.btn--ghost:hover{background:var(--green);color:#fff}
.btn--lg{padding:1.05em 2em;font-size:1.02rem}
.btn--sm{padding:.6em 1.1em;font-size:.85rem}
.btn--block{width:100%}

/* ---------- Flags (pure CSS) ---------- */
.flag{display:inline-block;width:22px;height:15px;border-radius:3px;overflow:hidden;vertical-align:-.18em;box-shadow:0 0 0 1px rgba(0,0,0,.08);flex:0 0 auto;position:relative;background:#fff}
.flag--xl{width:56px;height:38px;border-radius:7px;box-shadow:0 6px 16px rgba(0,0,0,.18)}
.flag-vn{background:#DA251D}
.flag-vn::after{content:"★";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#FF0;font-size:.7em}
.flag--xl.flag-vn::after{font-size:1.4em}
.flag-jp{background:#fff}
.flag-jp::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:55%;height:80%;background:#BC002D;border-radius:50%}
.flag-kr{background:#fff}
.flag-kr::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44%;aspect-ratio:1;border-radius:50%;background:linear-gradient(180deg,#CD2E3A 50%,#0047A0 50%)}
.flag-de{background:linear-gradient(180deg,#000 33.3%,#DD0000 33.3% 66.6%,#FFCE00 66.6%)}
.flag-en{background:linear-gradient(180deg,#012169 0,#012169 100%)}
.flag-en::after{content:"";position:absolute;inset:0;background:
  linear-gradient(to bottom right,transparent 44%,#fff 44% 56%,transparent 56%),
  linear-gradient(to bottom left,transparent 44%,#fff 44% 56%,transparent 56%)}

/* =========================================================
   TOP BAR
   ========================================================= */
.topbar{background:var(--green-d);color:#dcefe2;font-size:.82rem}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;min-height:42px;gap:16px}
.topbar__contact{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.topbar__contact a{display:inline-flex;align-items:center;gap:6px;transition:color var(--t)}
.topbar__contact li{display:inline-flex;align-items:center;gap:6px}
.topbar__contact a:hover{color:var(--gold)}
.topbar__contact strong{color:#fff}
.topbar__right{display:flex;align-items:center;gap:18px}

.lang{position:relative}
.lang__btn{display:inline-flex;align-items:center;gap:6px;color:#dcefe2;font-size:.82rem;font-weight:600}
.lang__btn .caret{width:16px;height:16px}
.caret{width:18px;height:18px;transition:transform var(--t)}
.lang__menu{position:absolute;top:130%;right:0;background:#fff;border-radius:10px;box-shadow:var(--shadow);padding:6px;min-width:160px;opacity:0;visibility:hidden;transform:translateY(6px);transition:var(--t);z-index:60}
.lang:hover .lang__menu,.lang:focus-within .lang__menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang__menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:7px;color:var(--ink);font-size:.85rem;text-align:left}
.lang__menu button:hover{background:var(--bg-soft)}

.socials{display:flex;gap:8px}
.socials a{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.12);transition:var(--t)}
.socials a svg{width:15px;height:15px}
.socials a:hover{background:var(--gold);color:var(--ink);transform:translateY(-2px)}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line);transition:box-shadow var(--t),background var(--t)}
.header.scrolled{box-shadow:var(--shadow-sm)}
.header__inner{display:flex;align-items:center;gap:24px;min-height:78px;transition:min-height var(--t)}
.header.scrolled .header__inner{min-height:66px}

.brand{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.brand__logo{width:54px;height:54px;border-radius:50%;object-fit:cover;box-shadow:0 4px 12px rgba(11,42,25,.18);transition:width var(--t),height var(--t)}
.header.scrolled .brand__logo{width:46px;height:46px}
.brand__text{display:flex;flex-direction:column;line-height:1.18}
.brand__text strong{font-size:1.02rem;color:var(--green-d);letter-spacing:.01em;font-weight:800;white-space:nowrap}
.brand__text small{font-size:.63rem;letter-spacing:.11em;color:var(--muted);font-weight:600;white-space:nowrap}

.nav{display:flex;align-items:center;gap:14px;margin-left:auto}
.nav__list{display:flex;align-items:center;gap:0}
.nav__list>li{position:relative}
.nav__list>li>a{display:inline-flex;align-items:center;gap:4px;padding:.55em .6em;border-radius:10px;font-weight:600;font-size:.92rem;color:var(--ink);transition:var(--t)}
.nav__list>li>a:hover,.nav__list>li>a.active{color:var(--green);background:var(--bg-soft)}
.nav__list>li>a.active{position:relative}
.nav__list .caret{width:16px;height:16px}

.has-sub .sub{position:absolute;top:100%;left:0;background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:8px;min-width:200px;opacity:0;visibility:hidden;transform:translateY(8px);transition:var(--t);z-index:50}
.has-sub:hover .sub,.has-sub:focus-within .sub{opacity:1;visibility:visible;transform:translateY(0)}
.has-sub .sub a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:.92rem;font-weight:500;color:var(--ink)}
.has-sub .sub a:hover{background:var(--bg-soft);color:var(--green)}

.nav__close{display:none}

.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;margin-left:auto}
.hamburger span{width:26px;height:3px;background:var(--green-d);border-radius:3px;transition:var(--t)}
.nav-overlay{position:fixed;inset:0;background:rgba(11,42,25,.5);opacity:0;visibility:hidden;transition:var(--t);z-index:98}
.nav-overlay.show{opacity:1;visibility:visible}

/* =========================================================
   SECTION SCAFFOLD
   ========================================================= */
.section{padding:clamp(64px,8vw,110px) 0}
.section--alt{background:var(--bg-soft)}
.section--dark{background:radial-gradient(120% 120% at 80% 0%,#15402a 0%,var(--bg-dark) 60%);color:#cfe0d6}
.section__head{max-width:720px;margin:0 auto clamp(38px,5vw,60px);text-align:center}
.section__title{font-size:clamp(1.7rem,3.6vw,2.6rem);margin:.35em 0}
.section__title--light{color:#fff}
.section__sub{color:var(--muted);font-size:1.05rem}
.section__sub--light{color:#a9c4b6}

.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green);background:rgba(15,122,60,.09);padding:.5em 1em;border-radius:999px}
.eyebrow--light{color:var(--gold);background:rgba(246,185,21,.14)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:currentColor}

.grad{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-gold{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;overflow:hidden;padding-top:clamp(40px,5vw,70px);padding-bottom:clamp(40px,5vw,60px)}
.hero__bg{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(60% 80% at 85% 10%,rgba(14,111,190,.10),transparent 60%),
  radial-gradient(50% 70% at 0% 100%,rgba(15,122,60,.10),transparent 60%),
  linear-gradient(180deg,#f7fbf8,#ffffff 70%)}
.hero__bg::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(15,122,60,.10) 1.2px,transparent 1.2px);background-size:26px 26px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);mask-image:linear-gradient(180deg,#000,transparent 70%);opacity:.6}
.hero__inner{display:grid;grid-template-columns:1.08fr .92fr;align-items:center;gap:clamp(30px,5vw,64px);padding-block:clamp(20px,4vw,46px)}

.hero__title{font-size:clamp(2.1rem,5.2vw,3.7rem);font-weight:800;margin:.45em 0 .35em;color:var(--ink)}
.hero__lead{font-size:clamp(1rem,1.6vw,1.16rem);color:var(--body);max-width:560px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin:2em 0 1.6em}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 22px}
.hero__trust li{display:inline-flex;align-items:center;gap:7px;font-size:.9rem;font-weight:600;color:var(--green-d)}
.hero__trust .ic{color:var(--green);background:rgba(15,122,60,.12);border-radius:50%;padding:3px;width:1.5em;height:1.5em}

/* Hero visual */
.hero__visual{display:grid;place-items:center}
.globe-card{position:relative;width:min(440px,100%);aspect-ratio:1;display:grid;place-items:center;
  background:linear-gradient(160deg,#ffffff,#eef6f1);border-radius:32px;box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.7)}
.globe-card::before{content:"";position:absolute;inset:14px;border-radius:24px;border:1.5px dashed rgba(14,111,190,.25)}
.globe-svg{width:78%;height:78%;filter:drop-shadow(0 18px 30px rgba(10,79,138,.35))}
.globe-svg .plane{transform-origin:center;animation:planeFloat 5s ease-in-out infinite}
@keyframes planeFloat{0%,100%{transform:translate(296px,122px) rotate(-38deg)}50%{transform:translate(290px,112px) rotate(-38deg)}}
.globe-svg .trail{stroke-dashoffset:0;animation:dash 2.4s linear infinite}
@keyframes dash{to{stroke-dashoffset:-44}}

.badge{position:absolute;display:inline-flex;align-items:center;gap:7px;background:#fff;padding:.55em .9em;border-radius:999px;font-weight:700;font-size:.85rem;color:var(--ink);box-shadow:var(--shadow);animation:floaty 4.5s ease-in-out infinite}
.badge--jp{top:8%;left:-6%}
.badge--kr{top:46%;right:-8%;animation-delay:.8s}
.badge--de{bottom:8%;left:6%;animation-delay:1.6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:clamp(36px,5vw,56px);
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,34px);box-shadow:var(--shadow)}
.stat{text-align:center;position:relative}
.stat+.stat::before{content:"";position:absolute;left:-9px;top:10%;height:80%;width:1px;background:var(--line)}
.stat__num{font-size:clamp(1.8rem,3.6vw,2.7rem);font-weight:800;color:var(--green);line-height:1}
.stat__plus{font-size:clamp(1.4rem,2.6vw,2rem);font-weight:800;color:var(--gold)}
.stat p{margin-top:6px;font-size:.9rem;color:var(--muted);font-weight:600}

/* =========================================================
   TRUST LOGOS MARQUEE
   ========================================================= */
.trustlogos{padding:36px 0;border-block:1px solid var(--line);background:#fff}
.trustlogos__label{text-align:center;color:var(--muted);font-size:.85rem;font-weight:600;margin-bottom:18px;letter-spacing:.02em}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee__track{display:flex;gap:56px;width:max-content;animation:marquee 28s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-weight:800;font-size:1.15rem;color:#9fb3a8;letter-spacing:.04em;white-space:nowrap}
@keyframes marquee{to{transform:translateX(-50%)}}

/* =========================================================
   ABOUT
   ========================================================= */
.about__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,5vw,70px);align-items:center}
.about__imgwrap{position:relative;background:var(--grad-brand);border-radius:28px;padding:clamp(30px,5vw,56px);display:grid;place-items:center;box-shadow:var(--shadow-lg);overflow:hidden}
.about__imgwrap::after{content:"";position:absolute;width:140%;height:140%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 60%);top:-40%;right:-40%}
.about__logo{width:min(74%,260px);border-radius:50%;box-shadow:0 20px 50px rgba(0,0,0,.25);position:relative;z-index:1;background:#fff}
.about__ribbon{position:absolute;bottom:18px;right:18px;background:#fff;border-radius:14px;padding:12px 18px;box-shadow:var(--shadow);z-index:2;text-align:center}
.about__ribbon strong{display:block;color:var(--green);font-size:1.1rem}
.about__ribbon span{font-size:.78rem;color:var(--muted)}
.about__content>p{margin:1em 0 1.4em;font-size:1.05rem}
.about__list{display:grid;gap:14px;margin-bottom:1.8em}
.about__list li{display:flex;gap:12px;align-items:flex-start}
.about__list .ic{color:#fff;background:var(--green);border-radius:50%;padding:4px;width:1.7em;height:1.7em;margin-top:2px;box-shadow:0 4px 10px rgba(15,122,60,.3)}
.about__list strong{color:var(--ink)}

/* =========================================================
   MARKETS
   ========================================================= */
.market-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.market{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;box-shadow:var(--shadow-sm);transition:var(--t);overflow:hidden}
.market::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--grad-brand);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.market:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.market:hover::before{transform:scaleX(1)}
.market--featured{background:linear-gradient(170deg,#fff,#f0f7f2);border-color:rgba(15,122,60,.25);box-shadow:var(--shadow)}
.market--featured::before{transform:scaleX(1)}
.market__hot{position:absolute;top:18px;right:18px;background:var(--grad-gold);color:#fff;font-size:.72rem;font-weight:700;padding:.3em .8em;border-radius:999px;text-transform:uppercase;letter-spacing:.06em}
.market__flag{margin-bottom:16px}
.market h3{font-size:1.5rem;margin-bottom:4px}
.market__tag{color:var(--blue);font-weight:600;font-size:.9rem;margin-bottom:16px}
.market ul{display:grid;gap:10px;margin-bottom:22px}
.market ul li{position:relative;padding-left:26px;font-size:.95rem}
.market ul li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:14px;border-radius:50%;background:rgba(15,122,60,.15);background-image:linear-gradient(var(--green),var(--green));background-size:6px 6px;background-repeat:no-repeat;background-position:center}
.market__link{display:inline-flex;align-items:center;gap:6px;color:var(--green);font-weight:700;font-size:.95rem;transition:gap var(--t)}
.market__link:hover{gap:12px}

/* =========================================================
   SERVICES (cards)
   ========================================================= */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;transition:var(--t);box-shadow:var(--shadow-sm)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card__icon{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;background:var(--grad-brand);color:#fff;margin-bottom:18px;box-shadow:0 10px 24px rgba(15,122,60,.28);transition:var(--t)}
.card__icon svg{width:30px;height:30px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.card:nth-child(2) .card__icon,.card:nth-child(4) .card__icon{background:var(--grad-gold);box-shadow:0 10px 24px rgba(225,29,42,.28)}
.card:hover .card__icon{transform:rotate(-6deg) scale(1.05)}
.card h3{font-size:1.25rem;margin-bottom:8px}
.card p{color:var(--muted);font-size:.96rem}

/* =========================================================
   PROCESS (steps)
   ========================================================= */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;list-style:none;margin:0;padding:0}
.step{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:30px 26px;transition:var(--t);backdrop-filter:blur(4px)}
.step:hover{background:rgba(255,255,255,.10);transform:translateY(-6px);border-color:rgba(246,185,21,.4)}
.step__num{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:14px;background:var(--grad-gold);color:#fff;font-weight:800;font-size:1.3rem;margin-bottom:16px;box-shadow:0 10px 24px rgba(225,29,42,.3)}
.step h3{color:#fff;font-size:1.2rem;margin-bottom:8px}
.step p{color:#a9c4b6;font-size:.95rem}

/* =========================================================
   JOBS
   ========================================================= */
.job-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.job{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:var(--t)}
.job:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:rgba(15,122,60,.2)}
.job__top{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.job__country{font-size:.85rem;font-weight:700;color:var(--ink)}
.job__badge{margin-left:auto;font-size:.68rem;font-weight:700;padding:.3em .7em;border-radius:999px;background:var(--bg-soft);color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.job__badge--new{background:rgba(14,111,190,.12);color:var(--blue)}
.job__badge--hot{background:rgba(225,29,42,.12);color:var(--red)}
.job h3{font-size:1.15rem;margin-bottom:14px;min-height:2.4em}
.job__meta{display:grid;gap:9px;margin-bottom:18px}
.job__meta li{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--body)}
.job__meta .ic{color:var(--green);width:1.15em;height:1.15em;fill:none;stroke:var(--green);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.job__foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:16px;border-top:1px dashed var(--line)}
.job__slots{font-size:.85rem;color:var(--muted)}
.job__slots strong{color:var(--red)}
.jobs__more{text-align:center;margin-top:40px}

/* =========================================================
   WHY US
   ========================================================= */
.why__grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(34px,5vw,64px);align-items:center}
.why__intro>p{margin:1em 0 1.6em;font-size:1.05rem;color:var(--body)}
.why__features{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.why__item{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:var(--t)}
.why__item:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.why__ic{flex:0 0 auto;width:48px;height:48px;border-radius:13px;display:grid;place-items:center;background:rgba(15,122,60,.1);color:var(--green)}
.why__ic svg{width:24px;height:24px;fill:none;stroke:var(--green);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.why__item h3{font-size:1.08rem;margin-bottom:4px}
.why__item p{font-size:.9rem;color:var(--muted)}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-sm);position:relative;transition:var(--t)}
.quote::before{content:"\201C";position:absolute;top:6px;right:24px;font-size:5rem;line-height:1;color:rgba(15,122,60,.1);font-family:Georgia,serif}
.quote:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.quote__stars{color:var(--gold);letter-spacing:2px;margin-bottom:12px}
.quote blockquote{font-size:1rem;color:var(--body);margin-bottom:20px;position:relative;z-index:1}
.quote figcaption{display:flex;align-items:center;gap:12px}
.avatar{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--grad-brand);color:#fff;font-weight:700;font-size:.95rem;flex:0 0 auto}
.quote figcaption strong{display:block;color:var(--ink);font-size:.95rem}
.quote figcaption small{color:var(--muted);font-size:.82rem}

/* =========================================================
   CTA BAND
   ========================================================= */
.ctaband{position:relative;overflow:hidden;background:var(--grad-brand);color:#fff;padding:clamp(48px,6vw,72px) 0}
.ctaband::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.12) 1.5px,transparent 1.5px);background-size:30px 30px;opacity:.5}
.ctaband__inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.ctaband h2{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem)}
.ctaband p{color:rgba(255,255,255,.9);margin-top:8px;font-size:1.05rem}
.ctaband__btns{display:flex;gap:14px;flex-wrap:wrap}

/* =========================================================
   NEWS
   ========================================================= */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--t)}
.post:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.post__thumb{display:block;height:190px;position:relative;background-size:cover;background-position:center}
.post__thumb--jp{background:linear-gradient(135deg,#0E6FBE,#0A4F8A)}
.post__thumb--kr{background:linear-gradient(135deg,#E11D2A,#a01018)}
.post__thumb--de{background:linear-gradient(135deg,#0F7A3C,#0B5A2C)}
.post__thumb::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.18) 1.5px,transparent 1.5px);background-size:22px 22px;opacity:.5}
.post__cat{position:absolute;bottom:14px;left:14px;background:rgba(255,255,255,.95);color:var(--ink);font-size:.75rem;font-weight:700;padding:.35em .8em;border-radius:999px;z-index:1}
.post__body{padding:22px 24px 26px}
.post__body time{font-size:.8rem;color:var(--muted);font-weight:600}
.post__body h3{font-size:1.12rem;margin:8px 0 10px;line-height:1.35}
.post__body h3 a{transition:color var(--t)}
.post__body h3 a:hover{color:var(--green)}
.post__body p{font-size:.92rem;color:var(--muted)}

/* =========================================================
   FAQ
   ========================================================= */
.faq__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,5vw,60px);align-items:start}
.faq__intro{position:sticky;top:110px}
.faq__intro>p{margin-top:1em;color:var(--body)}
.faq__intro a{color:var(--green)}
.faq__list{display:grid;gap:14px}
.qa{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;transition:var(--t)}
.qa[open]{box-shadow:var(--shadow);border-color:rgba(15,122,60,.25)}
.qa summary{list-style:none;cursor:pointer;padding:20px 56px 20px 24px;font-weight:700;color:var(--ink);position:relative;font-size:1.02rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:var(--bg-soft);color:var(--green);font-size:1.3rem;font-weight:700;transition:var(--t)}
.qa[open] summary::after{content:"–";background:var(--green);color:#fff;transform:translateY(-50%) rotate(180deg)}
.qa__body{padding:0 24px 22px;color:var(--muted)}

/* =========================================================
   CONTACT
   ========================================================= */
.contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(34px,5vw,60px);align-items:start}
.contact__lead{margin:1em 0 1.8em;font-size:1.05rem}
.contact__list{display:grid;gap:18px}
.contact__list li{display:flex;gap:16px;align-items:center}
.contact__ic{flex:0 0 auto;width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:var(--grad-brand);color:#fff;box-shadow:0 8px 20px rgba(15,122,60,.25)}
.contact__ic svg{width:24px;height:24px}
.contact__list small{display:block;font-size:.8rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.contact__list a,.contact__list span{font-weight:700;color:var(--ink);font-size:1.05rem}
.contact__list a:hover{color:var(--green)}

.contact__form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(26px,4vw,40px);box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-size:.88rem;font-weight:700;color:var(--ink);margin-bottom:7px}
.field label span{color:var(--red)}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.96rem;color:var(--ink);background:#fcfdfc;transition:var(--t)}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:var(--ring);background:#fff}
.field input.invalid,.field select.invalid{border-color:var(--red);box-shadow:0 0 0 4px rgba(225,29,42,.12)}
.form__note{font-size:.8rem;color:var(--muted);margin-top:12px;text-align:center}
.form__success{margin-top:14px;text-align:center;font-weight:700;color:var(--green);background:rgba(15,122,60,.1);padding:12px;border-radius:11px}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--bg-dark);color:#a9c4b6;padding-top:clamp(50px,6vw,72px)}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:48px}
.brand--footer .brand__text strong{color:#fff}
.brand--footer .brand__text small{color:#7fa392}
.footer__brand p{margin:18px 0 20px;font-size:.92rem;max-width:340px}
.socials--footer a{background:rgba(255,255,255,.1)}
.socials--footer a:hover{background:var(--gold);color:var(--ink)}
.footer__col h4{color:#fff;font-size:1.05rem;margin-bottom:18px}
.footer__col ul{display:grid;gap:11px}
.footer__col a{font-size:.92rem;transition:var(--t)}
.footer__col a:hover{color:var(--gold);padding-left:4px}
.footer__contact li{display:flex;align-items:center;gap:10px;font-size:.92rem;margin-bottom:11px}
.footer__contact .ic{color:var(--gold)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0}
.footer__bottom-inner{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.85rem}
.footer__bottom strong{color:var(--gold)}

/* =========================================================
   FLOATING CONTACT + TO TOP
   ========================================================= */
.floaty{position:fixed;right:20px;bottom:20px;z-index:90;display:flex;flex-direction:column;gap:12px}
.floaty__btn{position:relative;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:0 8px 22px rgba(0,0,0,.25);transition:var(--t)}
.floaty__btn svg{width:24px;height:24px}
.floaty__btn:hover{transform:scale(1.1)}
.floaty__btn--call{background:var(--green)}
.floaty__btn--zalo{background:var(--blue)}
.floaty__btn--form{background:var(--red)}
.floaty__pulse{position:absolute;inset:0;border-radius:50%;background:var(--green);z-index:-1;animation:pulse 2s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.8);opacity:0}}

.totop{position:fixed;right:20px;bottom:20px;z-index:89;width:46px;height:46px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;opacity:0;visibility:hidden;transform:translateY(20px);transition:var(--t)}
.totop svg{width:22px;height:22px}
.totop.show{opacity:1;visibility:visible;transform:translateY(0);bottom:200px}
.totop:hover{background:var(--green)}

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none!important}
  html{scroll-behavior:auto}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .hide-md{display:none}
  .job-grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr 1fr;gap:28px}
  .footer__brand{grid-column:1/-1}

  /* Mobile nav kicks in here to avoid a cramped middle range */
  .hamburger{display:flex}
  .nav{position:fixed;top:0;right:0;bottom:0;width:min(330px,84vw);background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:80px 24px 30px;margin:0;
    transform:translateX(105%);transition:transform var(--t);box-shadow:-10px 0 40px rgba(0,0,0,.18);z-index:99;overflow-y:auto}
  .nav.open{transform:translateX(0)}
  .nav__list{flex-direction:column;align-items:stretch;gap:2px;width:100%}
  .nav__list>li>a{padding:14px 12px;border-radius:10px;justify-content:space-between;font-size:1rem}
  .has-sub .sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;padding:0 0 0 14px;display:none}
  .has-sub.open-sub .sub{display:block}
  .nav__cta{margin-top:18px;width:100%}
  .nav__close{display:block;position:absolute;top:18px;right:20px;font-size:2.2rem;line-height:1;color:var(--ink)}
}

@media (max-width:900px){
  .hero__inner{grid-template-columns:1fr;text-align:center}
  .hero__content{order:2}
  .hero__visual{order:1}
  .hero__lead{margin-inline:auto}
  .hero__cta,.hero__trust{justify-content:center}
  .globe-card{width:min(360px,86%)}
  .about__grid,.why__grid,.faq__grid,.contact__grid{grid-template-columns:1fr}
  .faq__intro{position:static}
  .why__features{grid-template-columns:1fr 1fr}
  .market-grid,.cards,.steps,.quote-grid,.news-grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:680px){
  .topbar__contact{gap:14px}
  .hide-sm{display:none}
  .stats{grid-template-columns:1fr 1fr;gap:14px}
  .stat:nth-child(3)::before{display:none}
  .stat+.stat::before{display:none}
  .market-grid,.cards,.steps,.quote-grid,.news-grid,.job-grid,.why__features,.field-row{grid-template-columns:1fr}
  .ctaband__inner{flex-direction:column;text-align:center}
  .ctaband__btns{justify-content:center;width:100%}
  .footer__grid{grid-template-columns:1fr 1fr}
  .footer__bottom-inner{flex-direction:column;text-align:center}
  .badge{font-size:.75rem;padding:.45em .7em}
  .floaty__btn{width:48px;height:48px}
}

@media (max-width:420px){
  .container{padding-inline:18px}
  .brand__text small{display:none}
  .footer__grid{grid-template-columns:1fr}
}
