/*
Theme Name: HTE Global
Theme URI: https://hteglobal.net
Author: HTE Global
Description: Theme kiến trúc, cảnh quan và nội thất cho HTE Global — hiện đại, sang trọng, song ngữ VI/EN. Thiết kế gallery tối, accent brass. Dự án & tin tức lấy động từ CMS.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hte-global
*/

:root{
  --bg:oklch(0.145 0.004 250); --bg-2:oklch(0.192 0.006 250); --bg-3:oklch(0.242 0.008 248);
  --ink:oklch(0.965 0.004 250); --muted:oklch(0.725 0.012 250); --faint:oklch(0.62 0.012 250);
  --brass:oklch(0.855 0.155 95); --brass-deep:oklch(0.76 0.15 88);          /* brand gold #FFCE31 */
  --blue:oklch(0.62 0.13 245); --blue-deep:oklch(0.52 0.13 248);            /* brand blue #0D77BB */
  --line:oklch(1 0 0 / 0.11); --line-2:oklch(1 0 0 / 0.06);
  --maxw:1280px;
  --e-out:cubic-bezier(.16,1,.3,1);
  --z-header:100; --z-overlay:200;
  --sans:"Hanken Grotesk",system-ui,sans-serif; --disp:"Archivo",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--ink); font-family:var(--sans);
  font-size:clamp(15px,.5vw + 14px,17px); line-height:1.65; letter-spacing:-.005em;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
h1,h2,h3,h4{font-family:var(--disp);font-weight:800;line-height:1.14;letter-spacing:-.02em;text-wrap:balance}
::selection{background:var(--brass);color:#1a1509}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,64px)}
.eyebrow{font-family:var(--disp);font-weight:700;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass);opacity:.7}
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--disp);font-weight:700;font-size:.86rem;letter-spacing:.02em;padding:.92em 1.6em;border-radius:2px;transition:transform .5s var(--e-out),background .3s,color .3s,border-color .3s;will-change:transform;cursor:pointer}
.btn-primary{background:var(--brass);color:#1a1509}
.btn-primary:hover{transform:translateY(-3px);background:oklch(0.89 0.16 96)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass);transform:translateY(-3px)}
.btn svg{width:15px;height:15px}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}

/* ---------- header ---------- */
.site-header{position:fixed;inset:0 0 auto;z-index:var(--z-header);transition:background .5s var(--e-out),backdrop-filter .5s,border-color .5s,padding .5s var(--e-out);border-bottom:1px solid transparent;padding:22px 0}
.site-header.scrolled{background:oklch(0.145 0.005 250 / .84);backdrop-filter:blur(16px) saturate(1.4);border-color:var(--line-2);padding:12px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.brand .mark{width:42px;height:42px;background:var(--brass);color:#171206;display:grid;place-items:center;font-family:var(--disp);font-weight:900;font-size:1.02rem;letter-spacing:-.06em;border-radius:3px}
.brand-txt b{font-family:var(--disp);font-weight:900;font-size:1.06rem;letter-spacing:.02em;line-height:1;display:block}
.brand-txt span{display:block;font-size:.62rem;letter-spacing:.34em;color:var(--muted);font-weight:600;margin-top:3px}
.brand .custom-logo-link{display:inline-flex;align-items:center;line-height:0}
.brand img.custom-logo,.brand .custom-logo-link img{height:46px!important;width:auto!important;max-width:none;display:block}
.site-header.scrolled .brand img.custom-logo,.site-header.scrolled .brand .custom-logo-link img{height:38px!important}
.menu{display:flex;align-items:center;gap:2rem;list-style:none}
.menu a{font-family:var(--disp);font-weight:600;font-size:.86rem;letter-spacing:.01em;color:var(--muted);position:relative;padding:4px 0;transition:color .3s;display:inline-block}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1.5px;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--e-out)}
.menu a:hover,.menu .current-menu-item>a{color:var(--ink)}.menu a:hover::after,.menu .current-menu-item>a::after{transform:scaleX(1)}
.menu .sub-menu{display:none}
.nav-right{display:flex;align-items:center;gap:1.4rem}
.lang{display:flex;border:1px solid var(--line);border-radius:2px;overflow:hidden;font-family:var(--disp);font-weight:700;font-size:.74rem}
.lang button,.lang a{background:none;border:none;color:var(--muted);padding:.5em .8em;cursor:pointer;transition:background .3s,color .3s;letter-spacing:.06em;text-decoration:none;line-height:1.5}
.lang button.on,.lang a.on{background:var(--brass);color:#171206}
.burger{display:none;background:none;border:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.4s var(--e-out)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.08);animation:kb 20s var(--e-out) forwards}
@keyframes kb{to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(to top,var(--bg) 2%,transparent 46%),
  linear-gradient(to right,oklch(0.14 0.006 250 / .86) 0%,transparent 64%),
  linear-gradient(to bottom,oklch(0.14 0.006 250 / .55) 0%,transparent 30%)}
.hero-inner{position:relative;z-index:1;width:100%;padding-bottom:clamp(48px,7vh,96px);padding-top:140px}
.hero h1{font-size:clamp(2.7rem,6.2vw,5.6rem);font-weight:900;letter-spacing:-.04em;max-width:16ch;line-height:1.12;padding-bottom:.06em}
.hero h1 em{font-style:normal;color:var(--brass)}
.hero-lead{margin-top:1.5rem;max-width:52ch;color:var(--muted);font-size:clamp(1.02rem,1.4vw,1.22rem);line-height:1.6}
.hero-cta{margin-top:2.4rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero-fields{margin-top:3.2rem;display:flex;gap:clamp(1.5rem,4vw,3.5rem);flex-wrap:wrap;padding-top:1.8rem;border-top:1px solid var(--line-2)}
.hero-fields b{font-family:var(--disp);font-weight:800;font-size:1.02rem;letter-spacing:.02em;display:block}
.hero-fields small{color:var(--faint);font-size:.8rem;letter-spacing:.02em}
.scroll-cue{position:absolute;right:clamp(20px,5vw,64px);bottom:clamp(48px,7vh,96px);z-index:1;display:flex;flex-direction:column;align-items:center;gap:.8rem;color:var(--muted);font-family:var(--disp);font-size:.66rem;letter-spacing:.28em;text-transform:uppercase;writing-mode:vertical-rl}
.scroll-cue span{width:1px;height:52px;background:linear-gradient(var(--brass),transparent);animation:cue 2.2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- marquee ---------- */
.marquee{border-block:1px solid var(--line-2);background:var(--bg-2);overflow:hidden;padding:1.1rem 0}
.marquee-track{display:flex;gap:3rem;white-space:nowrap;animation:scrollx 32s linear infinite;font-family:var(--disp);font-weight:800;font-size:clamp(1rem,1.6vw,1.35rem);letter-spacing:.02em;color:var(--faint)}
.marquee-track b{color:var(--ink)}
.marquee-track i{color:var(--blue);font-style:normal}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- section shell ---------- */
.sec{padding-block:clamp(72px,11vh,140px);position:relative}
.sec-head{display:grid;grid-template-columns:1fr;gap:1.2rem;max-width:60ch;margin-bottom:clamp(2.5rem,5vw,4rem)}
.sec-head h2{font-size:clamp(2rem,4vw,3.4rem)}
.sec-head p{color:var(--muted);font-size:1.06rem}

/* ---------- about + stats ---------- */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2.5rem,6vw,6rem);align-items:center}
.about h2{font-size:clamp(2rem,4vw,3.4rem);margin-top:1.2rem}
.about .about-lead{color:var(--muted);font-size:1.06rem;margin-top:1.4rem;max-width:56ch}
.about-vis{border:1px solid var(--line);border-radius:4px;padding:clamp(1.8rem,3vw,2.6rem);background:linear-gradient(160deg,var(--bg-2),var(--bg))}
.about-vis h3{font-size:1.5rem;color:var(--brass);margin-bottom:.5rem}
.about-vis p{color:var(--muted)}
.about-vis .vi-row{padding-block:1.4rem;border-top:1px solid var(--line-2)}
.about-vis .vi-row:first-of-type{border-top:none;padding-top:0}
.values{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.4rem}
.values span{font-family:var(--disp);font-weight:700;font-size:.76rem;letter-spacing:.06em;color:var(--ink);border:1px solid var(--line);padding:.4em .8em;border-radius:2px}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:4px;overflow:hidden;margin-top:clamp(3rem,6vw,5rem)}
.stat{background:var(--bg);padding:clamp(1.6rem,3vw,2.4rem)}
.stat b{font-family:var(--disp);font-weight:900;font-size:clamp(2.4rem,4.5vw,3.6rem);letter-spacing:-.04em;color:var(--ink);display:block;line-height:1}
.stat b i{font-style:normal;color:var(--brass);font-size:.6em;vertical-align:top;margin-left:.05em}
.stat small{color:var(--muted);font-size:.86rem;letter-spacing:.02em;margin-top:.5rem;display:block}

/* ---------- services ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.svc{border:1px solid var(--line-2);border-radius:4px;padding:clamp(1.8rem,3vw,2.6rem);background:var(--bg-2);transition:transform .6s var(--e-out),border-color .5s,background .5s;position:relative;overflow:hidden}
.svc::before{content:attr(data-n);position:absolute;top:1.2rem;right:1.4rem;font-family:var(--disp);font-weight:900;font-size:3rem;color:var(--line);line-height:1;transition:color .5s}
.svc:hover{transform:translateY(-6px);border-color:var(--brass);background:var(--bg-3)}
.svc:hover::before{color:oklch(0.855 0.155 95 / .26)}
.svc-ic{width:48px;height:48px;color:var(--brass);margin-bottom:1.4rem}
.svc h3{font-size:1.32rem;margin-bottom:.8rem}
.svc p{color:var(--muted);font-size:.96rem}

/* ---------- projects ---------- */
/* Bố cục showroom (CDC): lưới đồng đều, thẻ ảnh-trên / chữ-dưới */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{position:relative;overflow:hidden;border-radius:6px;background:var(--bg-2);display:block;border:1px solid var(--line-2);transition:transform .6s var(--e-out),box-shadow .5s,border-color .5s}
.card img{position:relative;width:100%;height:clamp(200px,20vw,244px);object-fit:cover;display:block;filter:saturate(.97) brightness(.96);transition:transform 1s var(--e-out),filter .6s}
.card::after{display:none}
.card:hover{transform:translateY(-6px);border-color:var(--brass);box-shadow:0 20px 50px oklch(0 0 0 / .4)}
.card:hover img{transform:scale(1.05);filter:saturate(1.05) brightness(1)}
.card-body{padding:1.3rem 1.5rem 1.6rem}
.card-cat{font-family:var(--disp);font-weight:700;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);margin-bottom:.5rem;display:block}
.card h3{font-size:clamp(1.14rem,1.5vw,1.42rem);letter-spacing:-.02em}
.card .card-meta{color:var(--muted);font-size:.88rem;margin-top:.4rem}
.proj-foot{margin-top:2.6rem;display:flex;justify-content:center}

/* ---------- global presence ---------- */
.presence{background:var(--bg-2);border-block:1px solid var(--line-2)}
.offices{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:clamp(2rem,4vw,3rem)}
.office{border:1px solid var(--line-2);border-radius:4px;padding:clamp(1.6rem,2.6vw,2.2rem);transition:border-color .4s,transform .5s var(--e-out)}
.office:hover{border-color:var(--brass);transform:translateY(-4px)}
.office .flag{font-size:1.7rem;line-height:1}
.office h3{font-size:1.3rem;margin:.9rem 0 .2rem}
.office .role{color:var(--brass);font-family:var(--disp);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}
.office address{font-style:normal;color:var(--muted);font-size:.94rem;margin-top:.8rem;line-height:1.55}

/* ---------- news ---------- */
.news{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.post-card{background:var(--bg-2);border:1px solid var(--line-2);border-radius:6px;overflow:hidden;transition:transform .6s var(--e-out),box-shadow .5s,border-color .5s}
.post-card:hover{transform:translateY(-6px);border-color:var(--brass);box-shadow:0 20px 50px oklch(0 0 0 / .4)}
.post-img{display:block;overflow:hidden;aspect-ratio:16/10;background:var(--bg-3)}
.post-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.97) brightness(.96);transition:transform 1s var(--e-out),filter .6s;display:block}
.post-card:hover .post-img img{transform:scale(1.05);filter:saturate(1.05) brightness(1)}
.post-body{padding:1.3rem 1.5rem 1.6rem}
.post-card time{font-family:var(--disp);font-weight:700;font-size:.74rem;letter-spacing:.1em;color:var(--faint);text-transform:uppercase}
.post-card h3{font-size:1.16rem;margin:.6rem 0;line-height:1.28}
.post-card p{color:var(--muted);font-size:.92rem}
.post-card .rd{display:inline-flex;align-items:center;gap:.4em;margin-top:1rem;font-family:var(--disp);font-weight:700;font-size:.8rem;color:var(--brass);transition:gap .4s var(--e-out)}
.post-card:hover .rd{gap:.9em}

/* ---------- CTA ---------- */
.cta{position:relative;text-align:center;padding-block:clamp(80px,12vh,150px);overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 100% at 50% 0%,oklch(0.855 0.155 95 / .12),transparent 70%)}
.cta h2{font-size:clamp(2.2rem,5vw,4.2rem);position:relative;max-width:18ch;margin-inline:auto}
.cta h2 em{font-style:normal;color:var(--brass)}
.cta p{position:relative;color:var(--muted);max-width:52ch;margin:1.4rem auto 0;font-size:1.1rem}
.cta-row{position:relative;margin-top:2.6rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.cta-phone{position:relative;margin-top:2.2rem;font-family:var(--disp);font-weight:800;font-size:1.1rem;letter-spacing:.02em}
.cta-phone a{color:var(--ink)}.cta-phone a:hover{color:var(--brass)}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line-2);background:var(--bg)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;padding-block:clamp(3rem,6vw,5rem)}
.foot-top h4{font-family:var(--disp);font-weight:700;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:1.2rem}
.foot-col a{display:block;color:var(--muted);padding:.32em 0;font-size:.95rem;transition:color .3s,transform .3s var(--e-out)}
.foot-col a:hover{color:var(--brass);transform:translateX(.4em)}
.foot-brand p{color:var(--muted);font-size:.95rem;max-width:34ch;margin-top:1.2rem}
.socials{display:flex;gap:.6rem;margin-top:1.4rem}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:2px;display:grid;place-items:center;color:var(--muted);transition:.4s var(--e-out)}
.socials a:hover{border-color:var(--brass);color:var(--brass);transform:translateY(-3px)}
.socials svg{width:17px;height:17px}
.foot-bot{border-top:1px solid var(--line-2);padding-block:1.6rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--faint);font-size:.85rem}

/* ---------- content pages (single/page/archive) ---------- */
.page-hero{padding-top:clamp(140px,18vh,200px);padding-bottom:clamp(2rem,4vw,3rem)}
.page-hero h1{font-size:clamp(2.2rem,5vw,4rem)}
.entry{max-width:74ch;margin-inline:auto;padding-bottom:clamp(4rem,8vw,7rem)}
.entry p{margin-block:1.1em;color:oklch(0.88 0.008 80)}
.entry h2,.entry h3{margin-top:1.6em;margin-bottom:.5em}
.entry img{border-radius:4px;margin-block:1.5em}
.entry a{color:var(--brass);text-decoration:underline;text-underline-offset:3px;transition:color .3s}
.entry a:hover{color:var(--blue)}
.archive-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.1rem}
.pagination{display:flex;gap:.5rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}
.pagination .page-numbers{font-family:var(--disp);font-weight:700;padding:.6em 1em;border:1px solid var(--line);border-radius:2px;color:var(--muted)}
.pagination .current{background:var(--brass);color:#171206;border-color:var(--brass)}

/* ---------- project filter ---------- */
.proj-filter{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.proj-filter button{font-family:var(--disp);font-weight:700;font-size:.82rem;letter-spacing:.02em;color:var(--muted);background:none;border:1px solid var(--line);border-radius:2px;padding:.6em 1.2em;cursor:pointer;transition:.3s var(--e-out)}
.proj-filter button:hover{color:var(--ink);border-color:var(--muted)}
.proj-filter button.on{background:var(--brass);color:#171206;border-color:var(--brass)}

/* ---------- related projects + breadcrumbs ---------- */
.breadcrumbs{font-family:var(--disp);font-weight:600;font-size:.78rem;letter-spacing:.04em;color:var(--faint);margin-bottom:1.2rem}
.breadcrumbs a{color:var(--muted)}.breadcrumbs a:hover{color:var(--brass)}
.breadcrumbs span{color:var(--faint);margin:0 .5em}
.proj-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:4px;overflow:hidden;margin:2rem 0}
.proj-info .pi{background:var(--bg);padding:1.2rem 1.4rem}
.proj-info .pi span{display:block;color:var(--faint);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--disp);font-weight:700}
.proj-info .pi b{font-weight:600;font-size:1rem;margin-top:.3rem;display:block}
.related{border-top:1px solid var(--line-2);margin-top:clamp(3rem,6vw,5rem);padding-top:clamp(2.5rem,5vw,4rem)}
/* gallery ảnh dự án (responsive) */
.proj-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.pg-item{display:block;overflow:hidden;border-radius:6px;aspect-ratio:4/3;background:var(--bg-3)}
.pg-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--e-out)}
.pg-item:hover img{transform:scale(1.05)}
@media(max-width:900px){.proj-gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.proj-gallery{grid-template-columns:1fr}}

/* ---------- process (Quy trình) ---------- */
.process{background:var(--bg-2);border-block:1px solid var(--line-2)}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;counter-reset:proc}
.proc-step{position:relative;padding:1.6rem 0 0;border-top:2px solid var(--line)}
.proc-step::before{content:"";position:absolute;top:-2px;left:0;width:38%;height:2px;background:var(--blue)}
.proc-n{font-family:var(--disp);font-weight:900;font-size:.9rem;letter-spacing:.1em;color:var(--blue)}
.proc-step h3{font-size:1.2rem;margin:.7rem 0 .5rem}
.proc-step p{color:var(--muted);font-size:.94rem}

/* ---------- client logos ---------- */
.client-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(1rem,3vw,1.6rem)}
.client-logo{background:#fff;border-radius:8px;padding:0 1.4rem;display:grid;place-items:center;width:180px;height:92px;flex:0 0 auto;transition:transform .5s var(--e-out),box-shadow .5s}
.client-logo:hover{transform:translateY(-4px);box-shadow:0 12px 30px oklch(0 0 0 / .4)}
.client-logo img{max-height:54px!important;max-width:140px!important;width:auto!important;height:auto!important;object-fit:contain;display:block}

/* dải logo dạng băng chạy (hiển thị nhiều logo) */
.client-marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.client-track{display:flex;align-items:center;gap:clamp(1rem,2.5vw,1.6rem);width:max-content;animation:scrollx 55s linear infinite}
.client-marquee:hover .client-track{animation-play-state:paused}
@media(prefers-reduced-motion:reduce){.client-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}}

/* accent xanh brand cho số liệu (một ô) */
.stat:nth-child(2) b i{color:var(--blue)}

/* ---------- team (Công ty) ---------- */
.team-group{margin-top:clamp(2.5rem,5vw,4rem)}
.team-group:first-of-type{margin-top:0}
.team-group-title{font-size:1.4rem;color:var(--brass);margin-bottom:1.4rem;padding-bottom:.9rem;border-bottom:1px solid var(--line)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.1rem}
.member{border:1px solid var(--line-2);border-radius:4px;padding:clamp(1.4rem,2.4vw,2rem);background:var(--bg);transition:border-color .4s,transform .5s var(--e-out)}
.member:hover{border-color:var(--brass);transform:translateY(-4px)}
.member h4{font-family:var(--disp);font-weight:800;font-size:1.16rem;letter-spacing:-.02em}
.member-role{color:var(--brass);font-family:var(--disp);font-weight:700;font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;margin:.4rem 0 .8rem}
.member-bio{color:var(--muted);font-size:.92rem;line-height:1.6}

/* ---------- careers (Tuyển dụng) ---------- */
.jobs{display:flex;flex-direction:column;gap:1rem}
.job{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:clamp(1rem,3vw,2rem);border:1px solid var(--line-2);border-radius:4px;padding:clamp(1.3rem,2.4vw,1.8rem) clamp(1.4rem,3vw,2.2rem);background:var(--bg-2);transition:border-color .4s,transform .5s var(--e-out)}
.job:hover{border-color:var(--brass);transform:translateY(-3px)}
.job-n{font-family:var(--disp);font-weight:900;font-size:2rem;color:var(--line);line-height:1}
.job-main h3{font-size:1.24rem}
.job-main p{color:var(--muted);font-size:.94rem;margin-top:.3rem}
.job-qty{text-align:center}
.job-qty span{display:block;color:var(--faint);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}
.job-qty b{font-family:var(--disp);font-weight:900;font-size:1.6rem;color:var(--ink)}
@media(max-width:760px){
  .job{grid-template-columns:auto 1fr;gap:1rem}
  .job-qty{grid-column:2;text-align:left;display:flex;gap:.6rem;align-items:baseline}
  .job-qty b{font-size:1.1rem}
  .job-apply{grid-column:1/-1;justify-content:center}
}

/* ---------- Contact Form 7 (nền tối) ---------- */
.wpcf7 input,.wpcf7 select,.wpcf7 textarea{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:3px;padding:.8em 1em;color:var(--ink);font-family:var(--sans);font-size:.95rem;margin-bottom:.9rem;transition:border-color .3s}
.wpcf7 input::placeholder,.wpcf7 textarea::placeholder{color:var(--faint)}
.wpcf7 input:focus,.wpcf7 select:focus,.wpcf7 textarea:focus{outline:none;border-color:var(--brass)}
.wpcf7 textarea{min-height:120px;resize:vertical}
.wpcf7 select{appearance:none}
.wpcf7 input[type=submit]{width:auto;background:var(--brass);color:#171206;border:none;border-radius:2px;font-family:var(--disp);font-weight:700;font-size:.86rem;letter-spacing:.02em;cursor:pointer;padding:.92em 1.8em;transition:transform .4s var(--e-out),background .3s;margin-bottom:0}
.wpcf7 input[type=submit]:hover{background:oklch(0.89 0.16 96);transform:translateY(-2px)}
.wpcf7 .wpcf7-response-output{border-radius:3px;margin:.6rem 0 0!important;padding:.7em 1em!important;font-size:.9rem}
.wpcf7-not-valid-tip{color:oklch(0.7 0.17 25);font-size:.82rem}
.hte-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 .9rem}
.hte-form-grid p{margin:0}
.hte-form-grid p:nth-child(n+3){grid-column:1/-1}
@media(max-width:520px){.hte-form-grid{grid-template-columns:1fr}}

/* ---------- reveal (visible by default; JS enhances) ---------- */
.rv{opacity:1;transform:none}
html.js .rv{opacity:0;transform:translateY(28px);transition:opacity .9s var(--e-out),transform .9s var(--e-out)}
html.js .rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}.rv-d4{transition-delay:.32s}

/* ---------- WP admin bar offset ---------- */
.admin-bar .site-header{top:32px}
@media(max-width:782px){.admin-bar .site-header{top:46px}}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .menu,.nav-right .lang.desktop-lang{display:none}
  .burger{display:flex}
  .about{grid-template-columns:1fr}
  .services{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .offices,.news{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
/* tablet: nhẹ nhàng lại kiểu chữ + hero */
@media(max-width:768px){
  .hero h1{font-size:clamp(2.1rem,7.4vw,3.4rem)}
  .hero-lead{font-size:1.02rem;max-width:44ch}
  .hero-inner{padding-top:112px}
  .sec-head h2,.about h2,.cta h2{font-size:clamp(1.7rem,5.6vw,2.6rem)}
  .job-main h3{font-size:1.12rem}
  .proc-grid{grid-template-columns:repeat(2,1fr);gap:1.6rem 1.1rem}
}
/* điện thoại */
@media(max-width:620px){
  /* ẩn nút CTA trong header (tránh xuống 3 dòng); menu nằm trong drawer */
  .nav-right .btn-primary{display:none}
  .site-header{padding:16px 0}
  .hero{min-height:88svh}
  .hero-inner{padding-top:96px;padding-bottom:120px}   /* chừa chỗ cho nút liên hệ nổi */
  /* lớp phủ tối mạnh hơn để chữ hero dễ đọc trên nền ảnh sáng */
  .hero-bg::after{background:
    linear-gradient(to bottom,oklch(0.13 0.006 250 / .74) 0%,oklch(0.13 0.006 250 / .5) 52%,var(--bg) 99%)}
  .hero h1{font-size:clamp(1.9rem,8.4vw,2.6rem);letter-spacing:-.03em}
  .hero-lead{color:oklch(0.9 0.008 250)}
  .hero .eyebrow{font-size:.66rem;letter-spacing:.16em}
  .hero-lead{margin-top:1.1rem;font-size:.98rem;line-height:1.55}
  .hero-cta{margin-top:1.8rem;flex-direction:column}
  .hero-cta .btn{justify-content:center;width:100%}
  .hero-fields{margin-top:2rem;gap:1.2rem 1.6rem;padding-top:1.3rem}
  .hero-fields b{font-size:.94rem}
  .scroll-cue{display:none}
  .proj-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr;gap:1.4rem}
  .sec{padding-block:clamp(56px,10vh,80px)}
  .stat b{font-size:clamp(2rem,10vw,2.6rem)}
}
/* điện thoại nhỏ */
@media(max-width:380px){
  .hero h1{font-size:1.72rem}
  .brand-txt span{display:none}   /* ẩn dòng tagline nhỏ để header gọn */
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto}
  .rv,html.js .rv{opacity:1;transform:none}
  .hero-bg img{transform:none}
}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:var(--z-overlay);background:oklch(0.145 0.006 250 / .98);backdrop-filter:blur(10px);display:flex;flex-direction:column;justify-content:center;padding:2rem clamp(20px,5vw,64px);transform:translateX(100%);transition:transform .6s var(--e-out);visibility:hidden}
.drawer.open{transform:none;visibility:visible}
.drawer a{font-family:var(--disp);font-weight:800;font-size:1.8rem;padding:.6rem 0;color:var(--ink);border-bottom:1px solid var(--line-2);display:block}
.drawer .drawer-menu{list-style:none;width:100%;margin:0;padding:0}
.drawer .drawer-menu .sub-menu{display:none}
.drawer .drawer-menu a:hover,.drawer a:hover{color:var(--brass)}
.drawer .close{position:absolute;top:24px;right:clamp(20px,5vw,64px);background:none;border:none;color:var(--ink);font-size:2rem;cursor:pointer;line-height:1}
.drawer .lang{display:inline-flex;margin-top:2rem;align-self:flex-start}

/* ===== POLISH ===== */
/* Nút gọi nổi (plugin Floating Contact Buttons): bỏ nền đỏ mờ (3.8:1) -> đỏ ĐẶC để chữ trắng đạt WCAG AA (5.9:1) */
.hotline-bar{background:#cc0000!important}
.hotline-phone-ring-img-circle{background:#cc0000!important}
.text-hotline{color:#fff!important;font-weight:700}

/* Focus bàn phím rõ ràng cho người dùng keyboard/screen-reader (a11y) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.btn:focus-visible,.lang a:focus-visible,summary:focus-visible{
  outline:2px solid var(--brass);
  outline-offset:2px;
  border-radius:2px;
}
