/* =========================================================
   ITC Hưng Yên - main.css (v7)
   Bám layout taiwaneduconsult.com · Royal blue #1C3E95 + đỏ #D32F2F
   Hero ảnh full-bleed + overlay · khối số màu · blue split · process dotted
   ========================================================= */

:root{
  /* PALETTE CHÍNH XÁC theo duhocicc.edu.vn (Astra global): đỏ #EE200F primary + navy #153D8B secondary.
     Đỏ tươi chủ đạo (nút, band, footer, chữ nhấn); navy làm accent. */
  --blue:#EE200F;        /* đỏ tươi - brand chủ đạo */
  --blue-dk:#CC1709;     /* đỏ đậm hơn cho gradient/hover */
  --blue-2:#1E50C8;      /* xanh royal "số 1" (đổi từ navy #153D8B - chốt 2026-06-15) */
  --red:#EE200F;
  --red-dk:#CC1709;
  --red-soft:#FDEBE9;    /* nền đỏ rất nhạt cho band/icon */
  --ink:#16294E;         /* chữ chính = navy đậm (bỏ đen, giữ hệ 3 màu: đỏ+navy+trắng) */
  --muted:#5E6E92;       /* chữ phụ = navy nhạt (bỏ xám trung tính) */
  --paper:#FFFFFF;
  --paper-2:#F7F9FC;
  --line:#E7EBF0;
  --line-dk:rgba(255,255,255,.18);

  /* FONT CHÍNH = Barlow Semi Condensed - Hiếu chốt 2026-06-16, áp TOÀN TRANG (cả tiêu đề lẫn body).
     Be Vietnam Pro làm fallback an toàn đủ dấu tiếng Việt khi webfont chưa swap. */
  --font-display:'Barlow Semi Condensed','Be Vietnam Pro','Segoe UI',Roboto,system-ui,-apple-system,Arial,sans-serif;
  --font-body:'Barlow Semi Condensed','Be Vietnam Pro','Segoe UI',Roboto,system-ui,-apple-system,Arial,sans-serif;

  --wrap:1210px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;font-size:104%}/* Barlow condensed nhỏ thị giác -> nâng cỡ gốc bù (rem scale toàn site) */
body{margin:0;font-family:var(--font-body);color:var(--ink);
  line-height:1.6;font-size:1.06rem;letter-spacing:.004em;-webkit-font-smoothing:antialiased;overflow-x:clip;
  /* NỀN HÀNH TRÌNH liền mạch toàn site: đường bay + ghim + máy bay (lặp dọc) + vân kẻ chéo nhạt */
  background-color:#fbfcfe;
  background-image:url(../images/journey-path.svg),repeating-linear-gradient(45deg,rgba(21,61,139,.018) 0 1px,transparent 1px 24px);
  background-repeat:repeat-y,repeat;
  background-position:top center,top left;
  background-size:100% auto,auto}
img{max-width:100%;height:auto;display:block}
/* PARALLAX: section 1 (hero) ghim lại, nội dung từ section 2 trượt ĐÈ lên -> hiện đại.
   .itc-flow (JS bọc quanh mọi section sau hero) mang nền "hành trình" ĐỤC để che hero khi trượt qua. */
.itc-flow{background-color:#fbfcfe;
  background-image:url(../images/journey-path.svg),repeating-linear-gradient(45deg,rgba(21,61,139,.018) 0 1px,transparent 1px 24px);
  background-repeat:repeat-y,repeat;background-position:top center,top left;background-size:100% auto,auto}
/* Bật parallax cho ĐIỆN THOẠI (≤640, hero poster ~540px < cao màn hình) + DESKTOP (≥901).
   Bỏ khoảng tablet 641-900 (hero poster có thể cao hơn viewport ngang ngắn). */
@media (max-width:640px), (min-width:901px){
  #main>.clx-hero,#main>.dhero{position:sticky;top:0;z-index:0}
  #main>.itc-flow{position:relative;z-index:1;box-shadow:0 -22px 50px rgba(16,41,75,.14)}
}
@media (prefers-reduced-motion:reduce){
  #main>.clx-hero,#main>.dhero{position:relative;top:auto}
}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit;cursor:pointer}
p{margin:0}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.14;margin:0;
  color:var(--ink);letter-spacing:-.018em;text-wrap:balance}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:12px;top:12px;background:#fff;padding:8px 14px;border-radius:8px;z-index:9999}
:focus-visible{outline:3px solid var(--blue-2);outline-offset:2px;border-radius:3px}

/* ---------- Layout ---------- */
.wrap{width:min(var(--wrap),91%);margin-inline:auto}
.section{padding:clamp(76px,9.5vw,128px) 0;background-color:transparent}
.section--alt{background-color:rgba(21,61,139,.045)}
/* BAND NAVY đặc - "điểm dừng" phá thế trắng đều, thẻ trắng nổi bật trên nền navy (trẻ trung, có chiều sâu) */
.section--navy{position:relative;overflow:hidden;
  background:radial-gradient(120% 130% at 50% -24%, rgba(255,255,255,.15), rgba(255,255,255,0) 56%), linear-gradient(165deg,#2F5AC4 0%,#1C3E8C 100%)}/* royal sáng hơn - giảm "đậm" (K10) */
.section--navy .clx-head h2{color:#fff}
.section--navy .clx-head h2 .u{color:#fff;text-decoration-color:rgba(255,255,255,.5)}
.section--navy .clx-head p,.section--navy .lead{color:rgba(255,255,255,.84)}
.section--navy .clx-squiggle path{stroke:rgba(255,255,255,.7)}
/* chấm trang trí mờ cho band navy */
.section--navy::before{content:"";position:absolute;right:-40px;top:-30px;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.06),transparent 70%);pointer-events:none}

.kicker{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:.82rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.kicker--light{color:var(--red)}

.section-head{max-width:min(920px,94%);margin-bottom:clamp(46px,5.2vw,66px)}
.section-head h2{max-width:none;color:var(--blue-2)}
.section-head--center{margin-inline:0;text-align:left}
h2{font-size:clamp(2rem,3.9vw,3.05rem);color:var(--blue-2)}/* tiêu đề = xanh royal, KHÔNG dùng --ink (đen) - giữ 3 màu */
.section-head .lead{margin-top:16px;color:var(--muted);font-size:1.07rem;max-width:560px}
.section-head--center .lead{margin-inline:0}
.lead{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;
  font-size:.95rem;padding:14px 26px;border-radius:8px;border:2px solid transparent;
  transition:.22s var(--ease);white-space:nowrap}
.btn svg{transition:transform .22s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-lg{padding:16px 32px;font-size:1rem}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--blue-2)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-dk)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:#fff;color:var(--blue);border-color:#fff}
.btn-outline{background:#fff;color:var(--blue);border-color:var(--line)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}

/* ---------- Topbar ---------- */
.topbar{background:var(--blue-dk);color:rgba(255,255,255,.82);font-size:.82rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:28px;min-height:42px;padding:6px 0;flex-wrap:nowrap}
.topbar__left{display:flex;align-items:center;gap:20px;flex-wrap:nowrap;min-width:0;flex:1}
.topbar__right{display:flex;align-items:center;gap:20px;flex-wrap:nowrap;flex-shrink:0}
.topbar__left span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex}
.topbar span,.topbar a{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.topbar svg{color:#FFD9A0;flex-shrink:0}
.topbar a:hover{color:#fff}
.topbar__call{font-weight:600;color:#fff}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:600;background:#fff;border-bottom:1px solid var(--line);transition:.3s var(--ease)}
.site-header.scrolled{box-shadow:0 6px 24px rgba(20,44,107,.08)}
.site-header .wrap{display:flex;align-items:center;gap:24px;height:74px}
.site-logo{flex-shrink:0;display:block}
.site-logo img{height:56px;width:auto}
.primary-nav{margin-left:8px}
.primary-nav ul{display:flex;align-items:center;gap:2px}
.primary-nav a{position:relative;font-family:var(--font-display);font-weight:600;font-size:.92rem;
  color:var(--ink);padding:9px 13px;white-space:nowrap;transition:.2s}
.primary-nav a::after{content:"";position:absolute;left:13px;right:13px;bottom:2px;height:2px;
  background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.primary-nav a:hover{color:var(--blue)}
.primary-nav a:hover::after,.primary-nav .current-menu-item>a::after{transform:scaleX(1)}
.primary-nav .current-menu-item>a{color:var(--blue)}
.primary-nav li{position:relative}
.primary-nav .menu-item-has-children>a{padding-right:24px}
.primary-nav .menu-item-has-children>a::before{content:"";position:absolute;right:10px;top:50%;
  width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:translateY(-70%) rotate(45deg);opacity:.5}
.primary-nav .sub-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:212px;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 34px rgba(20,44,107,.14);padding:8px;
  display:grid;gap:2px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s var(--ease);z-index:50}
.primary-nav .sub-menu::before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px}
.primary-nav li:hover>.sub-menu,.primary-nav li:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.primary-nav .sub-menu a{padding:10px 14px;border-radius:7px;font-size:.9rem}
.primary-nav .sub-menu a::after{display:none}
.primary-nav .sub-menu a:hover{background:var(--paper-2);color:var(--blue)}
.header-actions{margin-left:auto;display:flex;align-items:center;gap:14px;flex-shrink:0}
.header-hotline{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;
  border:1.5px solid var(--line);color:var(--blue);transition:.22s}
.header-hotline:hover{border-color:var(--blue);background:var(--blue);color:#fff}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:9px;
  background:#fff;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.nav-toggle span{width:20px;height:2px;background:var(--blue);border-radius:2px}

/* ---------- HERO (full-bleed ảnh + overlay) ---------- */
.hero{position:relative;background:var(--bg) center/cover no-repeat,var(--blue);color:#fff;overflow:hidden}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,28,55,.92) 0%,rgba(28,62,149,.84) 55%,rgba(28,62,149,.6) 100%)}
.hero__inner{position:relative;z-index:2;max-width:none;padding:clamp(80px,11vw,150px) 0 clamp(120px,15vw,200px)}
.hero__inner>*{max-width:720px}
.hero__kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;
  font-size:.84rem;letter-spacing:.04em;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  padding:8px 16px;border-radius:40px;margin-bottom:24px}
.hero__kicker svg{color:#FFD9A0}
.hero__title{color:#fff;font-size:clamp(2.4rem,5vw,4rem);font-weight:800;line-height:1.08;letter-spacing:-.025em;max-width:min(1100px,92vw)}
.hero__title .r{color:#FFD9A0}
.hero__sub{margin-top:22px;max-width:560px;font-size:1.12rem;color:rgba(255,255,255,.9)}
.hero__cta{margin-top:34px;display:flex;gap:16px;flex-wrap:wrap}

/* ---------- USP cards (airy, red accent) ---------- */
.usp{position:relative;z-index:5;margin-top:clamp(-56px,-5vw,-40px)}
.usp__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.usp__item{padding:clamp(30px,3vw,40px);color:var(--ink);position:relative;background:#fff;
  border:1px solid var(--line);border-radius:16px;box-shadow:0 14px 36px rgba(20,44,107,.09)}
.usp__item::before{content:"";position:absolute;left:0;top:30px;width:4px;height:32px;background:var(--red);border-radius:0 4px 4px 0}
.usp__item--blue::before{background:var(--blue)}
.usp__no{font-family:var(--font-display);font-weight:800;font-size:2.1rem;color:var(--red);line-height:1;display:block;margin-bottom:12px}
.usp__item--blue .usp__no{color:var(--blue)}
.usp__item h3{color:var(--blue-2);font-size:1.2rem;margin-bottom:10px}
.usp__item p{color:var(--muted);font-size:.96rem;line-height:1.7}

/* ---------- SERVICES (photo overlay cards) ---------- */
.svc__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc{position:relative;border-radius:14px;overflow:hidden;min-height:430px;display:flex;isolation:isolate}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 18%;z-index:0;transition:transform .6s var(--ease)}
.svc:hover img{transform:scale(1.06)}
.svc__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,28,55,.05) 0%,rgba(20,28,55,.45) 45%,rgba(20,28,55,.92) 100%)}
.svc__body{position:relative;z-index:2;margin-top:auto;padding:28px 26px;color:#fff}
.svc__ico{display:grid;place-items:center;width:50px;height:50px;border-radius:12px;background:var(--red);color:#fff;margin-bottom:14px}
.svc__body h3{color:#fff;font-size:1.4rem;margin-bottom:8px}
.svc__body p{color:rgba(255,255,255,.88);font-size:.96rem;margin-bottom:14px}
.svc__link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:.93rem;color:#fff}
.svc__link svg{transition:transform .22s var(--ease)}
.svc:hover .svc__link svg{transform:translateX(4px)}

/* ---------- WHY (blue split + ảnh) ---------- */
.why{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.why__media{position:relative;min-height:480px}
.why__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 30%}
.why__panel{background:var(--paper-2);color:var(--ink);display:flex;align-items:center;
  padding:clamp(48px,6vw,90px) clamp(32px,5vw,72px)}
.why__panel .kicker--light{color:var(--red)}
.why__inner{max-width:540px}
.why__panel h2{color:var(--blue-2);font-size:clamp(1.7rem,3vw,2.5rem);margin-bottom:8px}
.why__list{margin:26px 0 32px;display:grid;gap:22px}
.why__list li{display:grid;grid-template-columns:38px 1fr;gap:16px;align-items:start}
.why__check{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--red);color:#fff;margin-top:2px}
.why__list b{font-family:var(--font-display);font-weight:700;font-size:1.14rem;color:var(--ink)}
.why__list p{color:var(--muted);font-size:.96rem;margin-top:3px}

/* ---------- PROCESS (dotted) ---------- */
.proc__track{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;position:relative}
.proc__track::before{content:"";position:absolute;top:36px;left:11%;right:11%;height:0;
  border-top:2px dashed var(--red);opacity:.45;z-index:0}
.proc{position:relative;z-index:1;text-align:center;padding:0 8px}
.proc__no{display:grid;place-items:center;width:74px;height:74px;margin:0 auto 18px;border-radius:50%;
  background:#fff;border:2px solid var(--line);color:var(--blue);position:relative;transition:.25s var(--ease)}
.proc__no b{position:absolute;right:-2px;top:-2px;width:26px;height:26px;border-radius:50%;background:var(--red);color:#fff;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:.82rem}
.proc:hover .proc__no{border-color:var(--blue);background:var(--blue);color:#fff}
.proc h3{font-size:1.14rem;margin-bottom:8px}
.proc p{color:var(--muted);font-size:.95rem}

/* ---------- GALLERY (masonry - giữ nguyên ảnh, KHÔNG cắt cúp) ---------- */
.gallery__masonry{column-count:3;column-gap:16px}
.gitem{margin:0 0 16px;break-inside:avoid;border-radius:12px;overflow:hidden;
  box-shadow:0 4px 14px rgba(20,44,107,.07);background:var(--paper-2);position:relative}
.gitem img{width:100%;height:auto;display:block;transition:transform .6s var(--ease)}
.gitem:hover img{transform:scale(1.04)}
/* gallery horizontal scroll */
.gallery__scroll{display:flex;overflow-x:auto;gap:12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:10px}
.gallery__scroll .gitem{flex:0 0 220px;margin:0;scroll-snap-align:start}
.gallery__scroll .gitem img{width:220px;height:165px;object-fit:cover}
/* testimonials horizontal scroll */
.tscroll{display:flex;overflow-x:auto;gap:20px;padding:20px 0 8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.tscroll .tcard{flex:0 0 300px;scroll-snap-align:start}
/* gallery page: caption overlay */
.gitem--cap{cursor:zoom-in}
.gitem--cap figcaption{position:absolute;inset:auto 0 0 0;padding:30px 16px 14px;color:#fff;font-size:.92rem;font-weight:600;
  background:linear-gradient(to top,rgba(16,30,66,.86),rgba(16,30,66,0));opacity:0;transform:translateY(8px);
  transition:.28s var(--ease);display:flex;flex-direction:column;gap:6px}
.gitem--cap:hover figcaption{opacity:1;transform:translateY(0)}
.gitem__tag{align-self:flex-start;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  background:var(--red);color:#fff;padding:3px 10px;border-radius:20px}
/* gallery social-proof strip */
.gstats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.gstat b{display:flex;align-items:flex-start;justify-content:center;font-family:var(--font-display);
  font-weight:900;font-size:clamp(2.4rem,4vw,3.2rem);color:var(--blue);line-height:1}
.gstat b i{font-size:.42em;color:var(--red);font-style:normal;margin-left:2px}
.gstat>span{display:block;margin-top:8px;color:var(--muted);font-size:.95rem}
/* lightbox */
/* flipbook lightbox */
.glb{position:fixed;inset:0;z-index:999;background:rgba(8,16,38,.94);display:none;align-items:center;justify-content:center;
  gap:clamp(8px,2vw,28px);padding:28px;opacity:0;transition:opacity .3s var(--ease)}
.glb.is-open{display:flex;opacity:1}
.glb__book{flex:1;max-width:min(86vw,1040px);height:min(84vh,760px);display:flex;align-items:center;justify-content:center;
  perspective:2400px}
.glb__page{position:relative;width:100%;height:100%;transform-style:preserve-3d;transform-origin:center center;transform:rotateY(0deg)}
.glb__face{position:absolute;inset:0;margin:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  backface-visibility:hidden;-webkit-backface-visibility:hidden}
.glb__back{transform:rotateY(180deg)}
.glb__face img{max-width:100%;max-height:calc(100% - 42px);border-radius:10px;box-shadow:0 30px 70px rgba(0,0,0,.6);background:#234CA8}
.glb__face figcaption{color:#fff;font-weight:600;font-size:.98rem;text-align:center;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.glb__close{position:absolute;top:20px;right:28px;background:none;border:none;color:#fff;font-size:2.4rem;line-height:1;cursor:pointer;z-index:2;opacity:.85}
.glb__close:hover{opacity:1}
.glb__nav{flex-shrink:0;width:54px;height:54px;border-radius:50%;border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.08);color:#fff;font-size:1.9rem;line-height:1;cursor:pointer;display:grid;place-items:center;
  transition:.2s var(--ease)}
.glb__nav:hover{background:var(--red);border-color:var(--red);transform:scale(1.08)}
.glb__count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;font-weight:600;font-size:.92rem;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:6px 16px;border-radius:30px;letter-spacing:.03em}
.glb__count b{color:#FFD9A0}

/* ---------- ALBUM LẬT TỪNG ẢNH LỚN (Thư viện ảnh) ---------- */
.flipx{margin-top:6px}
.flipx__stage{display:flex;align-items:center;justify-content:center;gap:18px;perspective:2200px}
.flipx__nav{width:54px;height:54px;flex-shrink:0;border-radius:50%;border:1px solid var(--line);
  background:#fff;color:var(--red);font-size:1.6rem;line-height:1;cursor:pointer;
  box-shadow:0 8px 22px rgba(60,2,0,.12);transition:.2s var(--ease)}
.flipx__nav:hover{background:var(--red);color:#fff;border-color:var(--red);transform:scale(1.07)}
.flipx__frame{position:relative;width:min(82vw,820px);aspect-ratio:16/10;border-radius:16px;
  overflow:hidden;background:#234CA8;box-shadow:0 36px 80px rgba(16,28,60,.22)}
.flipx__page{position:relative;width:100%;height:100%}
.flipx__face{position:absolute;inset:0;margin:0;overflow:hidden;background:#234CA8;will-change:transform,opacity}
.flipx__front{z-index:1}
.flipx__back{z-index:2;opacity:0;pointer-events:none}
.flipx__face img{width:100%;height:100%;object-fit:cover;display:block;cursor:zoom-in}
.flipx__face figcaption{position:absolute;left:0;right:0;bottom:0;padding:38px 22px 16px;color:#fff;
  font-weight:600;font-size:1rem;line-height:1.3;
  background:linear-gradient(180deg,transparent,rgba(8,16,38,.8));text-shadow:0 1px 4px rgba(0,0,0,.45)}
/* thanh meta */
.flipx__bar{display:flex;flex-direction:column;align-items:center;gap:2px;margin-top:22px}
.flipx__catnow{color:var(--red);font-weight:700;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}
.flipx__count{color:var(--ink);font-weight:600;font-size:.98rem}
.flipx__count em{color:var(--muted);font-style:normal}
/* dải thumbnail */
.flipx__film{display:flex;gap:10px;overflow-x:auto;padding:16px 4px 8px;margin-top:16px;
  scroll-snap-type:x proximity;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.flipx__film::-webkit-scrollbar{height:7px}
.flipx__film::-webkit-scrollbar-thumb{background:var(--line);border-radius:20px}
.flipx__thumb{flex:0 0 auto;width:96px;height:64px;border-radius:9px;overflow:hidden;cursor:pointer;
  padding:0;border:2px solid transparent;opacity:.58;background:#234CA8;
  scroll-snap-align:center;transition:opacity .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease)}
.flipx__thumb img{width:100%;height:100%;object-fit:cover;display:block}
.flipx__thumb:hover{opacity:.92;transform:translateY(-2px)}
.flipx__thumb.is-active{opacity:1;border-color:var(--red)}
.flipx__hint{text-align:center;color:var(--muted);font-size:.86rem;margin:14px 0 0}

/* ---------- TESTIMONIALS ---------- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 28px;transition:.22s var(--ease)}
.tcard:hover{border-color:var(--blue);box-shadow:0 16px 36px rgba(20,44,107,.1)}
.tcard__stars{color:#F5A623;letter-spacing:3px;margin-bottom:14px}
.tcard__quote{color:var(--ink);font-size:1.02rem}
.tcard__person{display:flex;align-items:center;gap:13px;margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.tcard__person img{width:52px;height:52px;border-radius:50%;object-fit:cover}
.tcard__person b{display:block;font-family:var(--font-display);color:var(--blue)}
.tcard__person span{font-size:.84rem;color:var(--muted)}

/* ---------- NEWS ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.26s var(--ease)}
.pcard:hover{border-color:var(--blue);transform:translateY(-4px)}
.pcard__media{aspect-ratio:600/360;overflow:hidden}
.pcard__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pcard:hover .pcard__media img{transform:scale(1.05)}
.pcard__body{padding:22px 24px 26px}
.pcard__date{font-size:.8rem;color:var(--red);font-weight:600}
.pcard__body h3{font-size:1.12rem;margin:9px 0 9px}
.pcard__body h3 a:hover{color:var(--blue)}
.pcard__body p{color:var(--muted);font-size:.93rem}

/* ---------- CTA BAND ---------- */
.ctaband{position:relative;background:var(--bg) center/cover no-repeat,var(--blue);color:#fff;text-align:center}
.ctaband--solid{background:radial-gradient(120% 130% at 50% -26%, rgba(255,255,255,.18), rgba(255,255,255,0) 55%), linear-gradient(100deg,#234CA8,#2F5AC4)}/* royal sáng hơn (K10) */
.ctaband__overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,28,55,.92),rgba(28,62,149,.82))}
.ctaband__inner{position:relative;z-index:2;padding:clamp(60px,7vw,96px) 0;max-width:680px}
.ctaband h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.7rem)}
.ctaband p{margin:14px 0 28px;color:rgba(255,255,255,.88);font-size:1.06rem}

/* ---------- REGISTER (band đỏ kiểu taiwan: trái callout + bong bóng, phải form trắng) ---------- */
.register{position:relative;overflow:hidden;color:#fff;padding-block:clamp(36px,4vw,60px);
  background:radial-gradient(120% 120% at 50% -22%, rgba(255,255,255,.15), rgba(255,255,255,0) 54%), linear-gradient(180deg,#2F5AC4 0%,#234CA8 100%)}
.register::before{content:"";position:absolute;left:42%;top:46%;transform:translate(-50%,-50%);width:min(620px,70%);height:480px;
  border-radius:50%;background:radial-gradient(ellipse,rgba(255,255,255,.13),transparent 66%);pointer-events:none}
/* hoạ tiết nền dải đỏ đăng ký: chấm trắng rõ + đường bay (mạch hành trình) */
.clx-deco--reg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.clx-deco--reg .dco-dots--w{position:absolute;color:#fff;
  background-image:radial-gradient(rgba(255,255,255,.85) 2px,transparent 2.4px);background-size:18px 18px}
.clx-deco--reg .dco-dots--w{top:48px;left:46px;width:168px;height:118px;opacity:.28}
.clx-deco--reg .dco-dots--w.is-br{top:auto;left:auto;bottom:54px;right:50px;width:150px;height:104px;opacity:.22}
.reg-fly{position:absolute;right:6%;top:14%;width:min(360px,34%);height:auto;opacity:.5}
.reg-fly path,.reg-fly circle{fill:none}
.reg-fly .rf-arc{stroke:rgba(255,255,255,.6);stroke-width:2;stroke-dasharray:6 8;stroke-linecap:round}
.reg-fly .rf-pin-o{stroke:rgba(255,255,255,.85);stroke-width:2}
.reg-fly .rf-pin-i{fill:#fff}
.reg-fly .rf-plane path{fill:#fff}
.register .wrap{position:relative;z-index:3}
.register .wrap{max-width:1320px}
.register__grid{display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(20px,3vw,56px);align-items:center}
/* ----- SÂN KHẤU TRÁI: cô gái cutout + thẻ nổi (chỉ desktop) ----- */
.register__stage{position:relative;align-self:stretch;min-height:520px;display:flex;align-items:flex-end;justify-content:center;isolation:isolate}
.register__girl{margin:0;position:relative;z-index:2;pointer-events:none}
/* spotlight glow ôm lấy người -> đóng khung, không "dán nổi" trên nền phẳng */
.register__girl::before{content:"";position:absolute;left:50%;top:4%;transform:translateX(-50%);width:122%;height:92%;z-index:-2;border-radius:50% 50% 46% 46%;
  background:radial-gradient(ellipse 58% 56% at 50% 42%, rgba(135,178,255,.40), rgba(120,162,245,.14) 48%, transparent 72%)}
/* vòng cung trang trí mảnh sau người */
.register__girl::after{content:"";position:absolute;left:50%;top:8%;width:84%;height:80%;z-index:-1;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.16);border-bottom-color:transparent;border-right-color:transparent;transform:translateX(-50%) rotate(-18deg)}
.register__girl img{display:block;height:clamp(540px,50vw,720px);width:auto;position:relative;z-index:1;filter:drop-shadow(0 14px 32px rgba(4,12,34,.36));-webkit-mask-image:linear-gradient(to bottom,#000 86%,rgba(0,0,0,.55) 94%,transparent 100%);mask-image:linear-gradient(to bottom,#000 86%,rgba(0,0,0,.55) 94%,transparent 100%)}
/* thẻ nổi quanh người */
.regf{position:absolute;z-index:4;display:inline-flex;align-items:center;gap:11px;box-shadow:0 18px 36px rgba(6,18,48,.30)}
/* badge + 3 thẻ tính năng = kính navy mờ, chữ trắng */
.regf--badge,.regf--feat{background:rgba(18,40,92,.52);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(8px) saturate(1.1);-webkit-backdrop-filter:blur(8px) saturate(1.1);color:#fff}
.regf--badge{top:10%;left:11%;padding:9px 20px 9px 9px;border-radius:44px;font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase}
.regf--badge svg{width:34px;height:34px;padding:8px;border-radius:11px;background:var(--blue-2);color:#fff;flex-shrink:0}
.regf-feats{position:absolute;left:-16px;top:38%;display:flex;flex-direction:column;gap:14px;z-index:4;margin:0;padding:0;list-style:none}
.regf--feat{position:static;padding:12px 20px 12px 12px;border-radius:16px;min-width:196px}
.regf__ic{flex-shrink:0;display:grid;place-items:center;width:40px;height:40px;border-radius:12px;background:var(--blue-2);color:#fff}
.regf-feats li:nth-child(2) .regf__ic{background:var(--red)}
.regf__tx{display:flex;flex-direction:column;line-height:1.22;min-width:0}
.regf__tx b{font-family:var(--font-display);font-weight:700;font-size:.96rem;color:#fff}
.regf__tx i{font-style:normal;font-size:.79rem;color:rgba(255,255,255,.72)}
/* clock + trust = pill trắng */
.regf--clock,.regf--trust{background:rgba(255,255,255,.97);border:1px solid rgba(255,255,255,.7)}
.regf--clock{bottom:9%;left:1%;padding:10px 20px;border-radius:44px;font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--ink)}
.regf--clock svg{color:var(--blue-2)}.regf--clock b{color:var(--red)}
.regf--trust{bottom:-12px;left:50%;transform:translateX(-50%);padding:8px 20px 8px 10px;border-radius:48px;white-space:nowrap}
.regf-avs{display:inline-flex}
.regf-avs img{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid #fff;margin-left:-12px;box-shadow:0 2px 5px rgba(0,0,0,.18)}
.regf-avs img:first-child{margin-left:0}
.regf-trust__tx{display:flex;flex-direction:column;line-height:1.18;font-size:.78rem;color:var(--muted);margin-left:8px}
.regf-trust__tx b{font-family:var(--font-display);font-weight:700;font-size:.9rem;color:var(--ink)}
.register__col{align-self:center;display:flex;flex-direction:column;gap:clamp(14px,1.6vw,20px);min-width:0}
.register .kicker--light{color:rgba(255,255,255,.85)}
/* tiêu đề 2 dòng: dòng 1 trắng, dòng 2 nhấn lam sáng - mỗi dòng 1 hàng */
.reg-h{font-size:clamp(1.65rem,2.6vw,2.4rem);line-height:1.14;margin-top:6px;color:#fff;letter-spacing:-.3px}
.reg-h__a,.reg-h__b{display:block;white-space:nowrap}
.reg-h__a{color:#fff}
.reg-h__b{color:#7FB0FF}
.register__intro .lead{margin-top:10px;color:rgba(255,255,255,.9);font-size:.97rem;max-width:520px}
/* icon trong ô input */
.field__wrap{position:relative;display:block}
.field__ic{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--muted);display:grid;place-items:center;pointer-events:none}
.register__form .field__wrap input{padding-left:44px}
.reg__bubble{display:inline-flex;align-items:center;gap:9px;margin-top:20px;background:#fff;color:var(--blue-2);
  font-family:var(--font-display);font-weight:700;font-size:.95rem;padding:11px 20px;border-radius:40px;box-shadow:0 10px 24px rgba(60,2,0,.25)}
.reg__bubble svg{color:var(--red)}
.reg__contact{margin-top:22px;display:grid;gap:13px}
.reg__contact li{display:flex;gap:14px;align-items:center}
.reg__ico{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.15);color:#fff;flex-shrink:0}
.reg__contact small{display:block;font-size:.78rem;color:rgba(255,255,255,.72);text-transform:uppercase;letter-spacing:.06em}
.reg__contact a,.reg__contact div>span{font-family:var(--font-display);font-weight:600;color:#fff}
.reg__contact a:hover{color:#FFD9D3}
.register__form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:32px 30px;box-shadow:0 24px 50px rgba(20,44,107,.1)}
.register__form h3{font-size:1.36rem;margin-bottom:20px}
.field{margin-bottom:15px}
.field label{display:block;font-size:.87rem;font-weight:600;margin-bottom:7px;color:var(--ink)}
.field label i{color:var(--red);font-style:normal}
.field input,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:9px;
  font-family:inherit;font-size:.98rem;background:#fff;transition:.2s}
.field input:focus,.field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(28,62,149,.12)}
.register__note{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.82rem;color:var(--muted);margin-top:14px}
.register__note svg{color:var(--blue)}

/* ===== K21 (Hiếu chốt 2026-06-16): khối Đăng ký NỀN TRẮNG (bỏ navy) ===== */
.register{background:#fff;color:var(--ink)}
.register::before{display:none}
/* deco trắng vô hình + quầng sáng + vòng cung sau người -> ẩn HẾT (nền trắng không để lộ họa tiết) */
.register .clx-deco--reg,.register .reg-fly{display:none}
.register__girl::before,.register__girl::after{display:none!important}
/* tiêu đề + lead -> navy/đỏ thay vì trắng/lam */
.register .kicker--light{color:var(--red)}
.reg-h__a{color:var(--blue-2)}/* dòng 1 xanh royal, KHÔNG đen (giữ 3 màu) */
.reg-h__b{color:var(--red)}
.register__intro .lead{color:var(--muted)}
/* chỉ giữ bóng đổ MỀM trung tính dưới chân người (đặt người xuống nền), KHÔNG quầng màu */
.register__girl img{filter:drop-shadow(0 16px 22px rgba(20,30,60,.16))}
/* thẻ nổi: kính navy mờ -> thẻ TRẮNG đặc, chữ navy */
.register .regf--badge,.register .regf--feat{background:#fff;border:1px solid var(--line);backdrop-filter:none;-webkit-backdrop-filter:none;color:var(--ink);box-shadow:0 14px 30px rgba(20,44,107,.14)}
.register .regf__tx b{color:var(--ink)}
.register .regf__tx i{color:var(--muted)}
.register .regf--badge{color:var(--ink)}
/* contact list (nếu hiển thị) -> navy */
.register .reg__ico{background:var(--red-soft);color:var(--red)}
.register .reg__contact small{color:var(--muted)}
.register .reg__contact a,.register .reg__contact div>span{color:var(--ink)}
.register .reg__contact a:hover{color:var(--red)}

/* ---------- FOOTER ---------- */
/* FOOTER kiểu taiwan: nền navy đậm, 3 cột (thương hiệu+địa chỉ / social tròn / map) */
.site-footer{position:relative;color:rgba(255,255,255,.82);padding-top:clamp(20px,3vw,40px);
  /* đỏ "có khối": sáng ở giữa-trên, tối dần ra mép + xuống đáy -> có chiều sâu, không phẳng lì */
  background:
    radial-gradient(120% 80% at 50% -18%, rgba(255,255,255,.18), rgba(255,255,255,0) 50%),
    radial-gradient(135% 95% at 50% -12%, #F6442C 0%, #E0210F 28%, #C5161C 56%, #A6130B 80%, #8A0F06 100%),
    #A6130B;
  background-blend-mode:normal}
/* lớp vân noise rất nhẹ -> đỏ đỡ "in phẳng", có chất */
.site-footer::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.05;mix-blend-mode:soft-light}
.site-footer>*{position:relative;z-index:1}
/* sóng mềm kéo lên đè band trên -> chuyển tiếp mượt vào footer navy */
.foot-wave{line-height:0;position:relative;z-index:1;margin-top:calc(-1 * clamp(52px,6vw,90px) - 20px);margin-bottom:clamp(6px,1.6vw,18px)}
/* divider THẲNG, ĐƠN GIẢN: đỏ phẳng, KHÔNG bóng/gradient (Hiếu chốt 2026-06-16) */
.foot-wave svg{display:block;width:100%;height:clamp(52px,6vw,90px)}
.foot-wave .fw-main{fill:var(--red)}
.foot-wave .fw-hi{stroke:none}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1.05fr;gap:clamp(28px,3.4vw,48px);align-items:stretch;padding-bottom:40px}
.foot-logo{display:inline-block;background:#fff;padding:10px 18px;border-radius:12px;margin-bottom:18px;box-shadow:0 8px 20px rgba(0,0,0,.28)}
.foot-logo img{height:48px;width:auto;display:block}
.foot-h{color:#fff;font-size:1.14rem;font-weight:700;margin:0 0 16px;position:relative}
.foot-h--u{padding-bottom:12px}
.foot-h--u::after{content:"";position:absolute;left:0;bottom:0;width:46px;height:3px;border-radius:3px;background:#fff}
.foot-c1 .foot-h{padding-bottom:12px}
.foot-c1 .foot-h::after{content:"";position:absolute;left:0;bottom:0;width:46px;height:3px;border-radius:3px;background:#fff}
.foot-addr{display:grid;gap:13px;margin:0 0 18px;padding:0;list-style:none}
.foot-addr li{display:flex;gap:10px;font-size:.92rem;line-height:1.55}
.foot-pin{flex:0 0 auto;color:#fff;margin-top:1px;display:inline-flex}
.foot-addr b{color:#fff;font-weight:700}
.foot-reach{display:grid;gap:11px}
.foot-phone,.foot-mail{display:inline-flex;align-items:center;gap:11px;color:#fff}
.foot-ri{flex:0 0 auto;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;display:grid;place-items:center}
.foot-phone{font-family:var(--font-display);font-weight:800;font-size:1.24rem;letter-spacing:.01em}
.foot-mail{color:rgba(255,255,255,.82);font-size:.95rem}
.foot-mail:hover,.foot-phone:hover{color:#fff}
.foot-hours{display:inline-flex;align-items:center;gap:11px;font-size:.92rem;color:rgba(255,255,255,.82);margin:0}
.foot-hours .foot-ri{width:34px;height:34px}
.foot-hours b{color:#fff;font-weight:700}
/* cột 2: liên kết nhanh dạng danh sách dọc */
.foot-nav{display:grid;gap:11px;margin:0 0 26px;padding:0;list-style:none}
.foot-nav a{display:inline-flex;align-items:center;gap:9px;color:rgba(255,255,255,.84);font-size:.95rem;transition:.2s var(--ease)}
.foot-nav a svg{color:rgba(255,255,255,.7);transition:.2s var(--ease)}
.foot-nav a:hover{color:#fff}
.foot-nav a:hover svg{transform:translateX(3px);color:#fff}
.foot-qh{color:#fff;font-size:1.02rem;font-weight:700;margin:0 0 14px}
.foot-soc{display:flex;flex-wrap:wrap;gap:12px}
.foot-soc a{color:#fff;transition:.2s var(--ease)}
.foot-soc__ic{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;
  transition:.2s var(--ease);font-family:var(--font-display);font-weight:700;font-size:.78rem;box-shadow:0 4px 12px rgba(0,0,0,.16)}
.foot-soc a:hover .foot-soc__ic{transform:translateY(-3px);filter:brightness(1.1);box-shadow:0 10px 22px rgba(0,0,0,.32)}
.foot-soc--fb   .foot-soc__ic{background:#1877F2}
.foot-soc--mess .foot-soc__ic{background:#0084FF}
.foot-soc--zalo .foot-soc__ic{background:#0068FF}
.foot-soc svg{width:20px;height:20px}
.foot-map{border-radius:18px;overflow:hidden;line-height:0;border:1px solid rgba(255,255,255,.14);box-shadow:0 16px 34px rgba(0,0,0,.34);height:100%;min-height:320px}
.foot-map iframe{height:100%;min-height:320px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:6px}
.foot-bottom .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;font-size:.84rem;color:rgba(255,255,255,.55)}
.foot-links a{color:rgba(255,255,255,.72)}
.foot-links a:hover{color:#fff}

/* ---------- FLOAT CONTACT (FAB speed-dial) ---------- */
.fab{position:fixed;right:20px;bottom:20px;z-index:700;width:60px;height:60px}
.fab__list{position:absolute;right:5px;bottom:5px;list-style:none;margin:0;padding:0;width:50px;height:50px}
/* nút con toả ra theo VÒNG CUNG quanh nút chính (toạ độ --x/--y ở inline style) */
.fab__item{position:absolute;right:0;bottom:0;width:50px;height:50px;
  opacity:0;visibility:hidden;transform:translate(0,0) scale(.2);
  transition:opacity .3s var(--ease),transform .5s cubic-bezier(.34,1.56,.64,1),visibility .3s;
  transition-delay:calc((3 - var(--i)) * .04s)}
.fab[data-open="true"] .fab__item{opacity:1;visibility:visible;
  transform:translate(var(--x),var(--y)) scale(1);
  transition-delay:calc(var(--i) * .06s)}
.fab[data-open="true"] .fab__item:hover{transform:translate(var(--x),var(--y)) scale(1.12)}
/* nút con */
.fab__btn{position:absolute;inset:0;display:grid;place-items:center;width:50px;height:50px;border-radius:50%;color:#fff;
  text-decoration:none;font-family:var(--font-display);font-weight:800;font-size:.95rem;letter-spacing:.2px;
  box-shadow:0 8px 22px rgba(20,44,107,.26)}
.fab__btn--phone{background:var(--red)}
.fab__btn--zalo{background:#0068FF}/* xanh Zalo thật - đồng bộ header/footer */
.fab__btn--mess{background:#0084FF}
.fab__btn--mess svg{display:block}
/* nhãn pill hiện bên trái khi hover */
.fab__label{position:absolute;right:60px;top:50%;padding:7px 13px;border-radius:999px;background:#234CA8;color:#fff;
  font-size:.82rem;font-weight:600;white-space:nowrap;box-shadow:0 6px 16px rgba(20,44,107,.22);
  opacity:0;transform:translateY(-50%) translateX(8px);pointer-events:none;
  transition:opacity .22s var(--ease),transform .22s var(--ease)}
.fab__label::after{content:"";position:absolute;right:-5px;top:50%;width:9px;height:9px;background:#234CA8;
  transform:translateY(-50%) rotate(45deg);border-radius:1px}
.fab__item:hover .fab__label{opacity:1;transform:translateY(-50%) translateX(0)}
/* nút chính */
.fab__toggle{position:absolute;right:0;bottom:0;width:60px;height:60px;border:0;border-radius:50%;cursor:pointer;
  background:var(--red);color:#fff;display:grid;place-items:center;padding:0;
  box-shadow:0 12px 30px rgba(238,32,15,.36);transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease)}
.fab__toggle::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--red);z-index:-1;
  animation:fab-halo 2.6s var(--ease) infinite}
.fab__toggle:hover{transform:scale(1.05);box-shadow:0 14px 34px rgba(238,32,15,.46)}
.fab__ic{position:absolute;display:grid;place-items:center;transition:opacity .25s var(--ease),transform .35s var(--ease)}
.fab__ic--open{opacity:1;transform:rotate(0) scale(1)}
.fab__ic--close{opacity:0;transform:rotate(-90deg) scale(.4)}
.fab[data-open="true"] .fab__toggle{transform:rotate(0)}
.fab[data-open="true"] .fab__toggle::before{animation:none;opacity:0}
.fab[data-open="true"] .fab__ic--open{opacity:0;transform:rotate(90deg) scale(.4)}
.fab[data-open="true"] .fab__ic--close{opacity:1;transform:rotate(0) scale(1)}
/* chấm "đang online" nhấp nháy */
.fab__dot{position:absolute;top:9px;right:9px;width:11px;height:11px;border-radius:50%;background:#fff;
  box-shadow:0 0 0 2px var(--red);animation:fab-blink 1.8s ease-in-out infinite}
.fab[data-open="true"] .fab__dot{opacity:0}
@keyframes fab-halo{0%{transform:scale(1);opacity:.5}70%,100%{transform:scale(1.7);opacity:0}}
/* FAB tự đổi màu: nằm trên section nền ĐỎ -> chuyển navy thương hiệu (nổi, không chìm vào đỏ); nền trắng/navy giữ nguyên đỏ */
.fab__toggle::before{transition:background .3s var(--ease)}
.fab--onred .fab__toggle{background:var(--blue-2);box-shadow:0 12px 30px rgba(21,61,139,.42)}
.fab--onred .fab__toggle::before{background:var(--blue-2)}
.fab--onred .fab__toggle:hover{box-shadow:0 14px 34px rgba(21,61,139,.5)}
.fab--onred .fab__dot{box-shadow:0 0 0 2px var(--blue-2)}
@keyframes fab-blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes ring{0%,92%,100%{transform:rotate(0)}94%{transform:rotate(-12deg)}96%{transform:rotate(12deg)}98%{transform:rotate(-8deg)}}
@media(max-width:640px){
  .fab{right:14px;bottom:14px}
  .fab__toggle{width:54px;height:54px}
  .fab__btn{width:46px;height:46px}
  /* Mobile: bỏ khối liên hệ + bubble trong khối Đăng ký (footer đã có) cho gọn */
  .reg__contact,.reg__bubble{display:none}
  .register__text .lead{margin-top:12px}
}
@media(prefers-reduced-motion:reduce){
  .fab__item,.fab__btn,.fab__ic,.fab__label{transition-duration:.01ms}
  .fab__toggle::before,.fab__dot{animation:none}
}

/* =========================================================
   TRANG CON (inner pages)
   ========================================================= */
/* mặc định: dải sáng (bớt mảng đậm) - đỏ chỉ ở chữ nhấn + breadcrumb */
.page-hero{position:relative;background:linear-gradient(160deg,#FFFFFF,#FFF4F1);border-bottom:1px solid var(--line);
  color:var(--ink);padding:clamp(40px,5vw,68px) 0;overflow:hidden}
.page-hero h1{color:var(--blue-2);font-size:clamp(2rem,4vw,3rem)}
.page-hero>.wrap>p{margin-top:12px;color:var(--muted);max-width:620px;font-size:1.08rem}
.crumb{display:flex;align-items:center;gap:9px;font-size:.86rem;color:var(--muted);margin-bottom:16px}
.crumb a:hover{color:var(--red)}
.crumb span{opacity:.5}
.crumb b{color:var(--red);font-weight:600}

/* ---------- Diagonal cover hero (clone sharingtaiwan: nền đỏ + ảnh thật cắt chéo + H1 xanh in hoa) ---------- */
.dhero{position:relative;width:100%;overflow:hidden;
  /* KHOÁ TỈ LỆ KHUNG cố định -> vùng cắt ảnh GIỐNG NHAU ở mọi bề rộng thiết bị
     (trước đây cao cố định + trần 300px khiến màn rộng bị méo tỉ lệ -> cắt cụt người) */
  aspect-ratio:24/5;min-height:180px;max-height:360px;
  /* VÙNG CHỮ AN TOÀN: bám mép ảnh chéo (~46% viewport) ở MỌI bề rộng -> chữ KHÔNG tràn qua đường chéo.
     min(380px,38vw): mép phải chữ luôn nằm trái mép ảnh từ 640px tới ultrawide (xem rule design-system) */
  --safe-text:min(380px,38vw);
  /* ĐỎ TRƠN phẳng (giống panel đặc sharingtaiwan) */
  background:var(--red)}
/* vân noise rất nhẹ -> đỏ đỡ phẳng lì, có chất (đồng bộ footer) */
.dhero::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.045;mix-blend-mode:soft-light}
.dhero__deco{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(106deg,transparent 0 37%,rgba(255,255,255,.09) 37% 43.5%,transparent 43.5%),
    linear-gradient(106deg,transparent 0 45.5%,rgba(255,255,255,.055) 45.5%,transparent 49%)}
.dhero__photo{position:absolute;top:0;right:0;height:100%;width:54%;z-index:2;
  -webkit-clip-path:polygon(20% 0,100% 0,100% 100%,6% 100%);clip-path:polygon(20% 0,100% 0,100% 100%,6% 100%)}
.dhero__photo img{width:100%;height:100%;object-fit:cover;object-position:var(--obj-d,50% 28%)}
.dhero__photo::before{content:"";position:absolute;inset:0;z-index:3;background:var(--blue-2);
  -webkit-clip-path:polygon(20% 0,22.6% 0,8.6% 100%,6% 100%);clip-path:polygon(20% 0,22.6% 0,8.6% 100%,6% 100%)}
.dhero__inner{position:absolute;inset:0;z-index:4;display:flex;align-items:center}
.dhero__inner>.wrap{width:min(var(--wrap),91%)}
.dhero .crumb{display:flex;align-items:center;gap:6px;max-width:var(--safe-text);white-space:nowrap;margin:0 0 14px;color:rgba(255,255,255,.85);font-size:.9rem}
.dhero .crumb a{color:rgba(255,255,255,.85);flex:0 0 auto}
.dhero .crumb a:hover{color:#fff}
.dhero .crumb span{opacity:.6;flex:0 0 auto}
.dhero .crumb b{color:#fff;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dhero h1{margin:0;color:#fff;font-weight:800;text-transform:uppercase;max-width:var(--safe-text);
  font-size:clamp(1.3rem,2.7vw,2.15rem);line-height:1.1;letter-spacing:-.01em;text-shadow:0 1px 3px rgba(0,0,0,.18);
  overflow-wrap:break-word;word-break:break-word;text-wrap:balance}
@media(max-width:640px){
  .dhero__photo{width:50%;-webkit-clip-path:polygon(18% 0,100% 0,100% 100%,4% 100%);clip-path:polygon(18% 0,100% 0,100% 100%,4% 100%)}
  .dhero__photo::before{-webkit-clip-path:polygon(18% 0,20.8% 0,6.8% 100%,4% 100%);clip-path:polygon(18% 0,20.8% 0,6.8% 100%,4% 100%)}
  .dhero__photo img{object-position:var(--obj-m,52% 36%)}
  .dhero{--safe-text:48vw}
  .dhero h1{font-size:1.5rem}
  .dhero .crumb{font-size:.76rem;margin-bottom:8px}
  /* trang Giới thiệu: XẾP DỌC - chữ trên nền đỏ, ẢNH ĐỘI NGŨ full bên dưới (không cắt mặt) */
  .dhero--team{height:auto;display:flex;flex-direction:column}
  .dhero--team .dhero__deco{display:none}
  .dhero--team .dhero__inner{order:-1;position:relative;inset:auto;padding:24px 0 20px}
  .dhero--team .dhero__photo{order:0;position:relative;inset:auto;width:100%;height:auto;
    -webkit-clip-path:none;clip-path:none}
  .dhero--team .dhero__photo::before{display:none}
  .dhero--team .dhero__photo img{position:relative;width:100%;height:auto;object-fit:contain;object-position:center}
  .dhero--team h1{max-width:100%}
}
/* ===== Cover trang Giới thiệu: hero CAO + ảnh ĐỘI NGŨ giữ trọn mặt (chốt 2026-06-10) ===== */
.dhero--tall{height:clamp(320px,30vw,440px)}
/* ít cắt chéo hơn (mép trái 14%/4% thay vì 20%/6%) -> không ăn vào người bìa trái */
.dhero--team .dhero__photo{width:51%;
  -webkit-clip-path:polygon(14% 0,100% 0,100% 100%,4% 100%);clip-path:polygon(14% 0,100% 0,100% 100%,4% 100%)}
.dhero--team .dhero__photo::before{
  -webkit-clip-path:polygon(14% 0,16.6% 0,6.6% 100%,4% 100%);clip-path:polygon(14% 0,16.6% 0,6.6% 100%,4% 100%)}
.dhero--team .dhero__photo img{object-position:center 32%}
/* biến thể có ẢNH thật: giữ overlay tối + chữ trắng (ảnh, không phải mảng đỏ phẳng) */
.page-hero--img{background:var(--bg) center/cover no-repeat,var(--ink);color:#fff;border-bottom:0;padding:clamp(48px,6vw,82px) 0}
.page-hero--img h1{color:#fff}
.page-hero--img>.wrap>p{color:rgba(255,255,255,.88)}
.page-hero--img .crumb{color:rgba(255,255,255,.8)}
.page-hero--img .crumb a:hover{color:#fff}
.page-hero--img .crumb b{color:#FFD9A0}
.page-hero__ov{position:absolute;inset:0;background:linear-gradient(100deg,rgba(16,20,28,.82),rgba(16,20,28,.5))}
.page-hero .wrap{position:relative;z-index:2}
.page-hero--center{text-align:center;padding:clamp(54px,7vw,96px) 0}
.page-hero--center h1{font-size:clamp(2.4rem,5.2vw,4rem);font-weight:800;letter-spacing:-.02em}
.page-hero--center>.wrap>p{margin-inline:auto}
.page-hero--center .crumb{justify-content:center;margin:18px 0 0}

/* prose (nội dung WP) */
.prose{max-width:760px;color:var(--ink);font-size:1.05rem;line-height:1.8}
.prose>*+*{margin-top:18px}
.prose h2{font-size:1.7rem;margin-top:38px}
.prose h3{font-size:1.3rem;margin-top:28px}
.prose a{color:var(--blue-2);text-decoration:underline}
.prose ul,.prose ol{padding-left:22px}
.prose li{margin-bottom:8px}
.prose img{border-radius:12px}
.prose blockquote{border-left:4px solid var(--red);padding:6px 0 6px 20px;color:var(--muted);font-style:italic}

/* layout 2 cột nội dung + sidebar */
.page-layout{display:grid;grid-template-columns:1fr 340px;gap:clamp(34px,4vw,60px);align-items:start}
.sidebar{position:sticky;top:100px;display:grid;gap:22px}
/* TOC bài viết */
.single .prose h2,.single .prose h3{scroll-margin-top:100px}
.post-toc{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;max-height:calc(100vh - 130px);overflow:auto}
.post-toc__h{font-family:var(--font-display);font-weight:700;color:var(--blue-2);margin:0 0 10px;font-size:1rem}
.post-toc ul{list-style:none;margin:0;padding:0;display:grid;gap:1px}
.post-toc li.lv2{padding-left:14px}
.post-toc a{display:block;padding:6px 10px;border-radius:7px;color:var(--ink);font-size:.9rem;line-height:1.4;border-left:2px solid transparent;transition:.18s var(--ease)}
.post-toc a:hover{background:var(--red-soft);color:var(--red)}
.post-toc a.active{color:var(--red);border-left-color:var(--red);background:var(--red-soft);font-weight:600}
.post-toc-m{display:none}
/* Nút nổi + panel mục lục (mobile) */
.toc-fab{display:none;position:fixed;left:16px;bottom:18px;z-index:690;align-items:center;gap:8px;
  background:var(--blue-2);color:#fff;border:0;border-radius:40px;padding:11px 17px;cursor:pointer;
  font-family:var(--font-display);font-weight:700;font-size:.9rem;box-shadow:0 10px 26px rgba(16,32,78,.32);
  opacity:0;transform:translateY(12px);transition:.25s var(--ease)}
.toc-fab__bd{position:fixed;inset:0;background:rgba(16,32,78,.5);z-index:695;opacity:0;visibility:hidden;transition:.25s}
.toc-fab__bd.open{opacity:1;visibility:visible}
.toc-fab__panel{position:fixed;left:0;right:0;bottom:0;z-index:696;background:#fff;border-radius:18px 18px 0 0;
  max-height:74vh;overflow:auto;transform:translateY(101%);transition:.3s var(--ease);
  padding:0 18px 26px;box-shadow:0 -12px 40px rgba(16,32,78,.22)}
.toc-fab__panel.open{transform:none}
.toc-fab__head{display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;
  padding:15px 0 11px;border-bottom:1px solid var(--line);margin-bottom:8px}
.toc-fab__head b{font-family:var(--font-display);color:var(--blue-2);font-size:1.05rem}
.toc-fab__x{border:0;background:none;font-size:1.7rem;line-height:.7;color:var(--muted);cursor:pointer;padding:0 4px}
.toc-fab__panel ul{list-style:none;margin:0;padding:0;display:grid;gap:1px}
.toc-fab__panel li.lv2{padding-left:16px}
.toc-fab__panel a{display:block;padding:11px 10px;border-radius:8px;color:var(--ink);font-size:.97rem;line-height:1.4;border-bottom:1px solid var(--paper-2)}
.toc-fab__panel a.active{color:var(--red);font-weight:600}
@media(max-width:1024px){.toc-fab.show{display:inline-flex;opacity:1;transform:none}}
.sidebar__card{background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:26px 24px}
.sidebar__card h3{font-size:1.18rem;margin-bottom:14px}
.sidebar__card.is-blue{background:linear-gradient(155deg,#2F5AC4,#234CA8);color:#fff;border-color:#234CA8}/* royal sáng - bỏ navy thẫm (K10) */
.sidebar__card.is-blue h3{color:#fff}
.sidebar__card.is-blue p{color:rgba(255,255,255,.85);margin-bottom:16px}
.sidebar__menu{display:grid;gap:4px}
.sidebar__menu a{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;border-radius:9px;
  background:#fff;border:1px solid var(--line);font-weight:600;font-family:var(--font-display);font-size:.94rem;transition:.2s}
.sidebar__menu a:hover,.sidebar__menu a.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.sidebar__menu a::after{content:"›";opacity:.6}
/* widget "Tin nổi bật" (kiểu sharingtaiwan) */
.sidebar__card h3 svg{vertical-align:-3px;color:var(--red);margin-right:5px}
.sidebar__hot{display:grid;gap:16px}
.sidebar__hot li{display:grid;grid-template-columns:84px 1fr;gap:13px;align-items:center}
.sidebar__hot .shot__media{display:block;border-radius:10px;overflow:hidden;aspect-ratio:84/60}
.sidebar__hot .shot__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.sidebar__hot li:hover .shot__media img{transform:scale(1.06)}
.sidebar__hot .shot__date{display:block;font-size:.74rem;color:var(--red);font-weight:600;margin-bottom:3px}
.sidebar__hot .shot__body a{font-family:var(--font-display);font-weight:600;font-size:.9rem;line-height:1.34;color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sidebar__hot .shot__body a:hover{color:var(--blue)}
/* lưới bài trong cột chính của layout 2 cột → 2 cột thay vì 3 */
.page-layout .posts{grid-template-columns:repeat(2,1fr);gap:22px}
.page-layout>main>.prose,.page-layout .single .prose{max-width:none;margin-inline:0}
.page-layout .post-thumb{max-width:none;margin-inline:0}

/* feature list (icon + text) trên trang con */
.flist{display:grid;gap:18px;margin:28px 0}
.flist li{display:grid;grid-template-columns:48px 1fr;gap:16px;align-items:start}
.flist .fico{display:grid;place-items:center;width:46px;height:46px;border-radius:11px;background:var(--paper-2);color:var(--blue)}
.flist b{font-family:var(--font-display);font-size:1.12rem;color:var(--ink)}
.flist p{color:var(--muted);margin-top:3px;font-size:.97rem}

/* khối số liệu */
.figrow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:8px 0}
.figrow .fig{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 20px;text-align:center}
.figrow .fig b{display:flex;align-items:flex-start;justify-content:center;gap:3px;
  font-family:var(--font-display);font-weight:900;font-size:clamp(2.8rem,4.5vw,3.6rem);
  color:var(--blue);line-height:1;letter-spacing:-.02em}
.figrow .fig b span{display:inline-block}
.figrow .fig b i{font-style:normal;font-size:.42em;color:var(--red);margin-top:.25em;font-weight:800}
.figrow .fig{padding:30px 18px}
.figrow .fig>span{display:block;margin-top:12px;font-size:.95rem;font-weight:500;color:var(--muted)}
.figrow .fig b span{font-size:inherit;color:inherit}
.figrow .fig span{display:block;margin-top:6px;color:var(--muted);font-size:.9rem}

/* info cards (liên hệ) */
.infocards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:42px}
.infocard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 24px;text-align:center}
.infocard .ico{display:grid;place-items:center;width:56px;height:56px;border-radius:14px;background:var(--blue);color:#fff;margin:0 auto 16px}
.infocard h3{font-size:1.12rem;margin-bottom:6px}
.infocard p,.infocard a{color:var(--muted);font-size:.96rem}
.infocard a:hover{color:var(--blue)}
.branch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.branch-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 24px;transition:.22s var(--ease);position:relative}
.branch-card:hover{border-color:var(--blue);box-shadow:0 16px 36px rgba(20,44,107,.1);transform:translateY(-3px)}
.branch-card__ico{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:var(--paper-2);color:var(--blue);margin-bottom:14px}
.branch-card h3{font-size:1.1rem;margin-bottom:8px;color:var(--blue-dk)}
.branch-card p{color:var(--muted);font-size:.95rem;line-height:1.6}
.branch-card__tel{margin-top:8px;display:flex;align-items:center;gap:7px}
.branch-card__tel svg{color:var(--red)}
.branch-card__map{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-weight:600;font-size:.9rem;color:var(--red)}
.branch-card__map:hover{gap:9px}
/* 3 cơ sở: bản đồ + chỉ đường (xen kẽ trái/phải) */
.branches{display:grid;gap:28px}
.branch{display:grid;grid-template-columns:1.05fr .95fr;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 8px 26px rgba(20,44,107,.07)}
.branch:nth-child(even){grid-template-columns:.95fr 1.05fr}
.branch:nth-child(even) .branch__map{order:2}
.branch__map{position:relative;min-height:320px;background:var(--paper-2)}
.branch__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.branch__info{padding:clamp(24px,3vw,40px);display:flex;flex-direction:column}
.branch__badge{align-self:flex-start;display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);
  font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:#fff;background:var(--blue);
  padding:6px 15px;border-radius:30px;margin-bottom:15px}
.branch__badge svg{color:#FFD9A0}
.branch__info h3{font-size:1.22rem;color:var(--blue-dk);line-height:1.45}
.branch__tel{margin-top:12px;display:flex;align-items:center;gap:8px;font-size:.95rem;flex-wrap:wrap}
.branch__tel svg{color:var(--red);flex-shrink:0}
.branch__tel a{font-weight:700;color:var(--blue)}
.branch__dir{margin-top:18px;background:var(--paper-2);border-left:3px solid var(--red);border-radius:0 10px 10px 0;
  padding:14px 17px;font-size:.95rem;line-height:1.65;color:var(--muted)}
.branch__dir b{display:flex;align-items:center;gap:7px;color:var(--blue-dk);margin-bottom:6px;font-size:.92rem}
.branch__dir b svg,.branch__dir--empty svg{color:var(--red);flex-shrink:0}
.branch__dir--empty{border-left-color:var(--blue);display:flex;gap:9px;align-items:flex-start}
.branch__dir--empty svg{margin-top:3px}
.branch__actions{margin-top:auto;padding-top:22px;display:flex;gap:12px;flex-wrap:wrap}
.branch__actions .btn{padding:12px 20px;font-size:.92rem}
@media (max-width:760px){
  .branch,.branch:nth-child(even){grid-template-columns:1fr}
  .branch:nth-child(even) .branch__map{order:0}
  .branch__map{min-height:240px}
}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4vw,52px);align-items:start}
.map-embed{border-radius:14px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:var(--paper-2)}
.map-embed iframe{width:100%;height:100%;border:0;display:block}

/* tuyển dụng */
.joblist{display:grid;gap:16px;max-width:880px}
.job{display:flex;justify-content:space-between;align-items:center;gap:20px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:24px 28px;transition:.22s var(--ease)}
.job:hover{border-color:var(--blue);box-shadow:0 14px 30px rgba(20,44,107,.1)}
.job h3{font-size:1.2rem;margin-bottom:6px}
.job__meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.9rem}
.job__meta span{display:inline-flex;align-items:center;gap:6px}
.job__meta svg{color:var(--blue)}

/* lọc danh mục (catbar) */
.catbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px}
.catbar__chip{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border:1px solid var(--line);
  border-radius:50px;font-family:var(--font-display);font-weight:600;font-size:.92rem;color:var(--ink);background:#fff;transition:.2s var(--ease)}
.catbar__chip span{font-size:.78rem;color:var(--muted);background:var(--paper-2);border-radius:20px;padding:1px 8px}
.catbar__chip:hover{border-color:var(--blue);color:var(--blue)}
.catbar__chip.is-active{background:var(--blue);color:#fff;border-color:var(--blue)}
.catbar__chip.is-active span{background:rgba(255,255,255,.22);color:#fff}
/* badge danh mục + đọc tiếp trên card */
.pcard__media{position:relative;display:block}
.pcard__cat{position:absolute;left:14px;top:14px;background:var(--red);color:#fff;font-family:var(--font-display);
  font-weight:700;font-size:.74rem;padding:5px 12px;border-radius:40px;z-index:1}
.pcard__more{display:inline-flex;align-items:center;gap:7px;margin-top:12px;font-family:var(--font-display);
  font-weight:700;font-size:.9rem;color:var(--blue-2)}
.pcard__more svg{transition:transform .2s var(--ease)}
.pcard:hover .pcard__more svg{transform:translateX(3px)}

/* blog single */
.single .prose{margin-inline:auto}
.post-meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.9rem;margin-bottom:24px}
.post-meta span{display:inline-flex;align-items:center;gap:7px}
.post-meta svg{color:var(--red)}
.post-thumb{border-radius:16px;overflow:hidden;margin-bottom:30px;max-width:860px;margin-inline:auto}
.post-thumb img{width:100%;height:auto}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:48px}
.pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;padding:0 12px;border:1px solid var(--line);
  border-radius:9px;font-family:var(--font-display);font-weight:600;color:var(--ink);background:#fff}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* Landing hero (trang du học/đào tạo) */
.lhero{position:relative;background:var(--bg) center/cover no-repeat,var(--blue);color:#fff;overflow:hidden}
.lhero__ov{position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,28,55,.93) 0%,rgba(28,62,149,.82) 55%,rgba(28,62,149,.6) 100%)}
.lhero__in{position:relative;z-index:2;max-width:720px;padding:clamp(54px,7vw,104px) 0}
.lhero .crumb{margin-bottom:18px}
.lhero__kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:700;
  font-size:.82rem;letter-spacing:.04em;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  padding:8px 16px;border-radius:40px;margin-bottom:20px}
.lhero__kicker svg{color:#FFD9A0}
.lhero h1{color:#fff;font-size:clamp(2.3rem,4.8vw,3.7rem);font-weight:800;line-height:1.08;letter-spacing:-.02em}
.lhero h1 .r{color:#FFD9A0}
.lhero__sub{margin-top:18px;max-width:560px;font-size:1.1rem;color:rgba(255,255,255,.9)}
.lhero__cta{margin-top:30px;display:flex;gap:15px;flex-wrap:wrap}
.lhero__stats{margin-top:34px;display:flex;gap:34px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.16);padding-top:24px}
.lhero__stats b{display:block;font-family:var(--font-display);font-weight:900;font-size:1.8rem;line-height:1}
.lhero__stats span{font-size:.86rem;color:rgba(255,255,255,.78)}

/* tag pills (ngành học) */
.tags{display:flex;flex-wrap:wrap;gap:12px}
.tag-pill{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:50px;
  padding:12px 20px;font-family:var(--font-display);font-weight:600;font-size:.96rem;color:var(--ink);transition:.2s var(--ease)}
.tag-pill:hover{border-color:var(--blue-2);color:var(--blue-2);transform:translateY(-2px)}
.tag-pill svg{color:var(--red);flex:0 0 16px}

/* panel 2 cột: điều kiện + chi phí */
.split2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,48px);align-items:start}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 30px;box-shadow:var(--shadow-low,0 4px 14px rgba(20,44,107,.06))}
.panel h3{font-size:1.3rem;margin-bottom:16px}
.panel .ticks{display:grid;gap:13px}
.panel .ticks li{display:flex;gap:11px;align-items:flex-start}
.panel .ticks svg{color:var(--red);flex-shrink:0;margin-top:3px}
.price-note{margin-top:14px;font-size:.9rem;color:var(--muted);background:var(--paper-2);border-radius:10px;padding:12px 14px}

/* scholarship / info cards trên nền sáng */
.icards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.icard{display:grid;grid-template-columns:48px 1fr;gap:16px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 22px;transition:.2s var(--ease)}
.icard:hover{border-color:var(--blue-2);box-shadow:0 12px 28px rgba(20,44,107,.08)}
.icard--link{text-decoration:none;color:inherit}
.icard--link:hover{transform:translateY(-3px)}
.icard__more{display:inline-flex;align-items:center;gap:6px;margin-top:9px;color:var(--red);font-weight:700;font-size:.9rem;transition:gap .2s var(--ease)}
.icard--link:hover .icard__more{gap:10px}
.icard__ico{display:grid;place-items:center;width:48px;height:48px;border-radius:50%;background:rgba(21,61,139,.08);color:var(--blue-2)}
.icard__ico svg{width:24px;height:24px}
.icard b{font-family:var(--font-display);font-size:1.08rem;color:var(--ink)}
.icard p{color:var(--muted);font-size:.94rem;margin-top:3px}

/* ===== FROW: hàng ẢNH + TEXT + gạch đầu dòng (xen kẽ trái/phải) - phá nhịp lưới icards ===== */
.frow{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(26px,4.4vw,58px);align-items:center}
.frow__media{position:relative;margin:0}
.frow__media img{width:100%;display:block;border-radius:18px;aspect-ratio:4/3;object-fit:cover;
  box-shadow:0 16px 38px rgba(21,41,78,.16)}
.frow__media::after{content:"";position:absolute;width:104px;height:104px;border-radius:16px;z-index:-1;
  background:repeating-linear-gradient(45deg,rgba(238,32,15,.16) 0 7px,transparent 7px 14px)}
.frow:not(.frow--rev) .frow__media::after{right:-14px;bottom:-14px}
.frow--rev .frow__media::after{left:-14px;bottom:-14px}
.frow--rev .frow__media{order:2}
.frow__cap{position:absolute;left:14px;bottom:14px;background:var(--red);color:#fff;font-weight:600;font-size:.85rem;padding:6px 14px;border-radius:8px}
.frow__body .kk{margin-bottom:8px}
.frow__body h2,.frow__body h3{font-family:var(--font-display);color:var(--blue-2);font-weight:700;
  font-size:clamp(1.4rem,2.5vw,1.9rem);line-height:1.18;letter-spacing:-.01em;margin:0}
.frow__body>p{color:var(--muted);font-size:1.02rem;line-height:1.74;margin-top:14px}
.frow__list{display:grid;gap:13px;margin-top:20px}
.frow__list li{display:flex;gap:11px;align-items:flex-start;color:var(--ink);font-size:.99rem;line-height:1.5}
.frow__list li svg{color:var(--red);flex:0 0 19px;margin-top:3px}
.frow__list b{font-family:var(--font-display)}
.section--navy .frow__body h2,.section--navy .frow__body h3{color:#fff}
.section--navy .frow__body>p{color:rgba(255,255,255,.84)}
.section--navy .frow__list li{color:rgba(255,255,255,.92)}
.section--navy .frow__list li svg{color:#fff}
/* Ngành học gộp chung section với "Các hệ" (frow) */
.prog-majors{margin-top:clamp(40px,5vw,66px);padding-top:clamp(30px,3.6vw,46px);border-top:1px solid var(--line)}
.prog-majors__head{text-align:center;max-width:760px;margin:0 auto clamp(20px,2.4vw,28px)}
.prog-majors__head .kk{justify-content:center}
.prog-majors__head h3{font-family:var(--font-display);font-size:clamp(1.35rem,2.4vw,1.85rem);color:var(--blue-2);font-weight:700;margin:10px 0 0}
.prog-majors__head p{color:var(--muted);margin:10px auto 0;line-height:1.7}

/* ===== NSTEPS: các bước đánh số (timeline ngang) ===== */
.nsteps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:nstep}
.nstep{position:relative;background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 22px 22px;
  box-shadow:0 8px 22px rgba(20,44,107,.06);transition:.2s var(--ease)}
.nstep:hover{transform:translateY(-4px);border-color:var(--blue-2);box-shadow:0 16px 34px rgba(20,44,107,.12)}
.nstep::before{counter-increment:nstep;content:"0" counter(nstep);font-family:var(--font-display);font-weight:800;
  font-size:1.5rem;color:var(--red);display:block;margin-bottom:10px;line-height:1}
.nstep b{display:block;font-family:var(--font-display);font-size:1.06rem;color:var(--ink);margin-bottom:5px}
.nstep p{color:var(--muted);font-size:.92rem;line-height:1.6}
/* đường nối chấm giữa các bước (desktop) */
@media (min-width:861px){
  .nstep:not(:last-child)::after{content:"";position:absolute;right:-13px;top:38px;width:14px;height:2px;
    background:repeating-linear-gradient(90deg,var(--red) 0 4px,transparent 4px 7px)}
}

@media (max-width:860px){
  .split2{grid-template-columns:1fr}
  .icards{grid-template-columns:1fr}
  .lhero__stats{gap:22px}
  .frow{grid-template-columns:1fr;gap:24px}
  .frow--rev .frow__media{order:0}
  .frow__media img{aspect-ratio:16/10}
  .nsteps{grid-template-columns:1fr 1fr;gap:14px}
}
@media (max-width:480px){ .nsteps{grid-template-columns:1fr} }

/* prose: bảng, heading, link cho nội dung dài SEO */
.prose{max-width:none}
.prose h2{font-size:clamp(1.5rem,2.6vw,2rem);margin-top:44px;color:var(--blue-2)}
.prose h3{font-size:1.22rem;margin-top:26px;color:var(--blue)}
.prose strong{color:var(--ink);font-weight:700}
.prose table{width:100%;border-collapse:collapse;margin:8px 0;font-size:.96rem;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.prose thead th{background:var(--blue);color:#fff;font-family:var(--font-display);font-weight:700;text-align:left;padding:12px 14px;font-size:.92rem}
.prose tbody td{padding:11px 14px;border-top:1px solid var(--line)}
.prose tbody tr:nth-child(even){background:var(--paper-2)}
.prose>ul,.prose>ol{padding-left:20px}
.prose>ul li{margin-bottom:9px;padding-left:4px}
.prose>ul li::marker{color:var(--red)}
.prose h2+ul,.prose h2+p{margin-top:14px}
.prose .lead{font-size:1.12rem;color:var(--muted)}

/* FAQ accordion */
.faq{display:grid;gap:12px}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.2s var(--ease)}
.faq__item[open]{border-color:var(--blue-2);box-shadow:0 10px 26px rgba(20,44,107,.08)}
.faq__item summary{display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;
  padding:20px 22px;font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--ink);list-style:none}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary:hover{color:var(--blue-2)}
.faq__ico{position:relative;flex-shrink:0;width:20px;height:20px}
.faq__ico::before,.faq__ico::after{content:"";position:absolute;background:var(--red);border-radius:2px;transition:.25s var(--ease)}
.faq__ico::before{top:9px;left:0;width:20px;height:2.5px}
.faq__ico::after{top:0;left:9px;width:2.5px;height:20px}
.faq__item[open] .faq__ico::after{transform:rotate(90deg);opacity:0}
.faq__a{padding:0 22px 20px;color:var(--muted);line-height:1.7}
.faq__a p{margin-bottom:10px}

/* ---------- Reveal (fade-up + stagger) ---------- */
.has-fx .reveal{opacity:0;transform:translateY(30px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);will-change:opacity,transform}
.has-fx .reveal.in{opacity:1;transform:none}
/* biến thể zoomIn cho ảnh feature (kiểu sharingtaiwan) */
.has-fx .reveal-zoom{opacity:0;transform:scale(.93);transition:opacity .7s var(--ease),transform .7s var(--ease);will-change:opacity,transform}
.has-fx .reveal-zoom.in{opacity:1;transform:none}
.has-fx .reveal[data-delay="1"]{transition-delay:.1s}
.has-fx .reveal[data-delay="2"]{transition-delay:.2s}
.has-fx .reveal[data-delay="3"]{transition-delay:.3s}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .usp__grid{grid-template-columns:1fr}
  .svc__grid{grid-template-columns:1fr 1fr}
  .why{grid-template-columns:1fr}
  .why__media{min-height:0;aspect-ratio:5/6;max-height:72vh}
  .why__media img{object-position:50% 34%}
  .register__grid{grid-template-columns:1fr}
  .register__stage{display:none}
  .register__girl{display:none}
  .proc__track{grid-template-columns:1fr 1fr;gap:34px}
  .proc__track::before{display:none}
  .page-layout{grid-template-columns:1fr}
  .sidebar{position:static;grid-template-columns:1fr 1fr;display:grid}
  /* TOC mobile: xổ gọn ở đầu bài (sidebar TOC ẩn) */
  .post-toc{display:none}
  .sidebar .post-toc{grid-column:1/-1}
  .post-toc-m{display:block;background:#fff;border:1px solid var(--line);border-radius:12px;margin:0 0 22px;overflow:hidden}
  .post-toc-m summary{cursor:pointer;padding:13px 16px;font-family:var(--font-display);font-weight:700;color:var(--blue-2);font-size:.98rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
  .post-toc-m summary::-webkit-details-marker{display:none}
  .post-toc-m summary::after{content:"+";color:var(--red);font-size:1.2rem;line-height:1}
  .post-toc-m[open] summary::after{content:"\2212"}
  .post-toc-m ul{list-style:none;margin:0;padding:0 16px 12px}
  .post-toc-m li.lv2{padding-left:14px}
  .post-toc-m a{display:block;padding:8px 4px;color:var(--ink);font-size:.94rem;line-height:1.4;border-top:1px solid var(--paper-2)}
  .post-toc-m a:hover{color:var(--red)}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:860px){
  .nav-toggle{display:flex}
  .topbar__hide{display:none}
  .topbar .wrap{justify-content:center}.topbar__left{display:none}
  .primary-nav{position:fixed;inset:74px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
    padding:14px 6%;transform:translateY(-130%);transition:.3s var(--ease);box-shadow:0 18px 40px rgba(20,44,107,.12);margin:0}
  .primary-nav.open{transform:translateY(0)}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:2px}
  .primary-nav a{padding:13px 12px;border-radius:7px}
  .primary-nav a::after{display:none}
  .primary-nav .menu-item-has-children>a::before{display:none}
  .primary-nav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;
    border:none;border-left:2px solid var(--line);border-radius:0;margin:0 0 4px 14px;padding:0}
  .primary-nav .sub-menu a{color:var(--muted)}
  .header-actions .btn{display:none}
  .svc__grid,.tgrid,.posts,.page-layout .posts{grid-template-columns:1fr}
  .gallery__masonry{column-count:2}
  .gstats{grid-template-columns:1fr 1fr;gap:18px}
  .glb{padding:14px;gap:6px}
  .glb__nav{width:42px;height:42px;font-size:1.5rem}
  .glb__book{height:78vh}
  /* thẻ liên hệ GỌN: icon trái + chữ phải (hàng ngang), thấp hơn nhiều */
  .infocards{grid-template-columns:1fr;gap:12px;margin-bottom:32px}
  .infocard{display:grid;grid-template-columns:48px 1fr;gap:14px;align-items:center;text-align:left;padding:14px 16px}
  .infocard .ico{width:44px;height:44px;margin:0;border-radius:12px;grid-row:1/-1;align-self:center}
  .infocard h3{grid-column:2;margin-bottom:1px;font-size:1.04rem}
  .infocard a,.infocard p{grid-column:2;font-size:.92rem;line-height:1.4}
  .branch-grid{grid-template-columns:1fr}
  .figrow{grid-template-columns:1fr 1fr}
  .sidebar{grid-template-columns:1fr}
  .job{flex-direction:column;align-items:flex-start}
  /* Footer mobile: 3 cột -> 1 cột dọc, gọn lại */
  .site-footer{padding-top:34px} /* thoáng hơn, không sát mép sóng/section trên */
  .foot-grid{grid-template-columns:1fr;gap:22px;padding-top:8px;padding-bottom:30px}
  .foot-logo{padding:8px 14px;margin-bottom:14px}
  .foot-logo img{height:40px}
  .foot-h{font-size:1.06rem;margin-bottom:12px}
  .foot-addr{gap:10px;margin-bottom:14px}
  .foot-addr li{font-size:.88rem;line-height:1.5}
  .foot-reach{gap:9px}
  .foot-phone{font-size:1.12rem}
  .foot-ri{width:30px;height:30px}
  .foot-nav{gap:9px;margin-bottom:20px}
  .foot-soc{gap:10px}
  .foot-soc__ic{width:44px;height:44px}
  .foot-qh{font-size:.96rem;margin-bottom:10px}
  .foot-map,.foot-map iframe{min-height:240px}
  .foot-bottom .wrap{flex-direction:column;text-align:center;gap:6px}
}
@media (max-width:520px){
  body{font-size:1.02rem}
  .topbar{display:none}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{justify-content:center}
  .proc__track{grid-template-columns:1fr}
  .gallery__masonry{column-count:1}
  .branch__actions{flex-direction:column;align-items:stretch}
  .branch__actions .btn{justify-content:center}
}
/* Album lật ảnh - mobile */
@media (max-width:720px){
  .flipx__stage{gap:8px}
  .flipx__frame{width:min(86vw,560px);aspect-ratio:4/3}
  .flipx__nav{width:42px;height:42px;font-size:1.3rem}
  .flipx__face figcaption{font-size:.9rem;padding:30px 16px 13px}
  .flipx__thumb{width:78px;height:54px}
}
/* ---------- Mobile: ép grid co lại (đè inline style) ---------- */
@media (max-width:900px){
  .svc__grid{grid-template-columns:1fr 1fr!important}
  .icards{grid-template-columns:1fr 1fr!important}
  .about__grid{grid-template-columns:1fr!important}
  .proc__track{grid-template-columns:1fr 1fr!important;gap:30px 22px!important}
  .tags{justify-content:flex-start!important}
  /* pill full-width thành cột gọn, cùng lề trái phải - hết so le/lệch */
  .tags .tag-pill{width:100%;justify-content:flex-start}
}
@media (max-width:600px){
  .svc__grid{grid-template-columns:1fr!important}
  .icards{grid-template-columns:1fr!important}
  .proc__track{grid-template-columns:1fr!important}
  .flist{grid-template-columns:1fr!important}
  .lhero__stats{gap:18px 26px}
  .hero__inner>*{max-width:100%}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ============ INTERACTIVE COMPONENTS (pilot) ============ */
/* Calculator chi phí */
.calc{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-mid,0 4px 12px rgba(0,0,0,.1))}
.calc__form{padding:clamp(26px,3vw,40px);background:#fff;display:grid;gap:20px;align-content:start}
.calc__form label{display:grid;gap:8px;font-weight:600;color:var(--blue-dk);font-size:.95rem}
.calc__form select{padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:1rem;background:#fff;cursor:pointer;transition:.18s}
.calc__form select:focus{outline:none;border-color:var(--blue)}
.calc__out{padding:clamp(26px,3vw,40px);background:linear-gradient(150deg,var(--blue-dk),var(--blue));color:#fff;display:grid;gap:16px;align-content:center}
.calc__row{display:flex;justify-content:space-between;align-items:baseline;gap:14px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.18)}
.calc__row span{font-size:.96rem;color:rgba(255,255,255,.82)}
.calc__row b{font-family:var(--font-display);font-size:1.5rem;font-weight:800}
.calc__row--net b{font-size:2.1rem;color:#FFD7A6}
.calc__row--net{border-bottom:none}
.calc__note{font-size:.9rem;color:rgba(255,255,255,.85);line-height:1.6;min-height:2.6em}
.calc__out .btn{margin-top:6px;justify-content:center}
b.pop{animation:popnum .4s var(--ease)}
@keyframes popnum{0%{transform:scale(.7);opacity:.2}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}

/* Quiz */
.quiz{max-width:760px;margin-inline:auto;background:#fff;border:1px solid var(--line);border-radius:18px;padding:clamp(26px,3vw,44px);box-shadow:0 10px 30px rgba(20,44,107,.08)}
.quiz__progress{height:6px;border-radius:6px;background:var(--paper-2);overflow:hidden;margin-bottom:28px}
.quiz__progress i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--red));transition:width .4s var(--ease)}
.quiz__count{color:var(--red);font-weight:700;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px}
.quiz__q{font-size:clamp(1.2rem,2vw,1.5rem);color:var(--blue-dk);margin-bottom:22px}
.quiz__opts{display:grid;gap:12px}
.quiz__opt{text-align:left;padding:15px 20px;border:1.5px solid var(--line);border-radius:12px;background:#fff;font-family:inherit;font-size:1rem;cursor:pointer;transition:.18s var(--ease)}
.quiz__opt:hover{border-color:var(--blue);background:var(--paper-2);transform:translateX(4px)}
.quiz__result{text-align:center;animation:fadeUp .5s var(--ease)}
.quiz__badge{display:inline-block;background:var(--paper-2);color:var(--blue);font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;padding:6px 16px;border-radius:30px;margin-bottom:14px}
.quiz__result h3{font-size:clamp(1.5rem,3vw,2rem);color:var(--blue-dk);margin-bottom:12px}
.quiz__result p{color:var(--muted);max-width:540px;margin:0 auto 22px;line-height:1.7}
.quiz__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* Boarding pass timeline */
.boarding{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 4px 18px;scrollbar-width:thin}
.bpass{scroll-snap-align:start;flex:0 0 320px;display:flex;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 8px 24px rgba(20,44,107,.08);transition:.25s var(--ease);position:relative}
.bpass:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,44,107,.14);border-color:var(--blue)}
.bpass__stub{flex:0 0 76px;background:linear-gradient(160deg,var(--blue-dk),var(--blue));color:#fff;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;position:relative}
.bpass__stub::after{content:"";position:absolute;right:-6px;top:0;bottom:0;width:12px;
  background:radial-gradient(circle 6px at 6px 50%,transparent 5px,#fff 6px);background-size:12px 18px;background-repeat:repeat-y}
.bpass__no{font-family:var(--font-display);font-size:2rem;font-weight:900;line-height:1}
.bpass__ico{color:#FFD9A0}
.bpass__body{padding:20px 22px;display:grid;gap:7px;align-content:start}
.bpass__tag{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--red)}
.bpass__body h3{font-size:1.12rem;color:var(--blue-dk)}
.bpass__body p{color:var(--muted);font-size:.93rem;line-height:1.6}

/* Flight path map */
.flight{position:relative;border-radius:20px;overflow:hidden;background:linear-gradient(160deg,#234CA8,#2F5AC4);padding:clamp(30px,5vw,64px);color:#fff}/* royal sáng - bỏ navy thẫm */
.flight__grid{position:relative;display:grid;grid-template-columns:1.1fr 1fr;gap:30px;align-items:center}
.flight__text h2{color:#fff}
.flight__text .lead{color:rgba(255,255,255,.85)}
.flight__map{position:relative;aspect-ratio:4/3}
.flight__map svg{width:100%;height:100%;overflow:visible}
.flight__route{fill:none;stroke:#FFB36B;stroke-width:3;stroke-linecap:round;stroke-dasharray:2 11;opacity:0;transition:opacity .9s var(--ease)}
.flight__route--2{stroke:rgba(255,255,255,.55);stroke-width:2}
.flight__dot{fill:#fff;opacity:0;transform-box:fill-box;transform-origin:center;transition:opacity .5s var(--ease)}
.flight__dot--end{fill:#FFD9A0}
.flight__city{fill:#fff;font-size:13px;font-weight:700;font-family:var(--font-display);opacity:0;transition:opacity .6s var(--ease)}
.flight__plane{fill:#fff;opacity:0;offset-path:path('M70 230 Q160 120 250 120');offset-rotate:auto;offset-distance:0%}
.flight.is-flying .flight__route{opacity:.95}
.flight.is-flying .flight__dot,.flight.is-flying .flight__city{opacity:1}
.flight.is-flying .flight__plane{animation:fly 2.6s .3s var(--ease) forwards}
@keyframes fly{0%{opacity:0;offset-distance:0%}8%{opacity:1}92%{opacity:1}100%{opacity:1;offset-distance:100%}}

/* Compare flip cards */
.cmp{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cmp__card{perspective:1400px;min-height:340px;cursor:pointer}
.cmp__inner{position:relative;width:100%;height:100%;min-height:340px;transition:transform .7s cubic-bezier(.2,.7,.2,1);transform-style:preserve-3d}
.cmp__card:hover .cmp__inner,.cmp__card.is-flipped .cmp__inner{transform:rotateY(180deg)}
.cmp__face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:18px;padding:32px;display:flex;flex-direction:column;justify-content:center;border:1px solid var(--line)}
.cmp__front{background:#fff;align-items:center;text-align:center;gap:14px}
.cmp__flag{font-size:3.4rem;line-height:1}
.cmp__front h3{font-size:1.6rem;color:var(--blue-dk)}
.cmp__hint{font-size:.85rem;color:var(--muted)}
.cmp__back{transform:rotateY(180deg);background:linear-gradient(160deg,var(--blue-dk),var(--blue));color:#fff;gap:12px}
.cmp__back h4{color:#FFD7A6;font-size:1.15rem;margin-bottom:4px}
.cmp__back ul{display:grid;gap:9px}
.cmp__back li{display:flex;gap:9px;font-size:.95rem;color:rgba(255,255,255,.92)}
.cmp__back li b{color:#fff}

@media (max-width:820px){
  .calc{grid-template-columns:1fr}
  .flight__grid{grid-template-columns:1fr}
  .cmp{grid-template-columns:1fr}
  .bpass{flex-basis:280px}
}

/* Quy trình 4 bước - step cards sạch */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 26px 28px;
  transition:.25s var(--ease)}
.step:hover{border-color:var(--blue);box-shadow:0 18px 42px rgba(20,44,107,.12);transform:translateY(-5px)}
.step__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.step__ico{display:grid;place-items:center;width:54px;height:54px;border-radius:15px;background:var(--blue);color:#fff;
  box-shadow:0 10px 22px rgba(28,62,149,.26)}
.step:nth-child(1) .step__ico{background:var(--red);box-shadow:0 10px 22px rgba(211,47,47,.24)}
.step:nth-child(3) .step__ico{background:var(--blue-2)}
.step:nth-child(4) .step__ico{background:var(--blue-dk)}
.step__num{font-family:var(--font-display);font-weight:900;font-size:3rem;line-height:1;color:var(--paper-2)}
.step__label{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--red);margin-bottom:8px}
.step h3{font-size:1.16rem;color:var(--blue-dk);margin-bottom:9px;line-height:1.3}
.step p{color:var(--muted);font-size:.95rem;line-height:1.65}
/* đường nối chấm giữa các bước (desktop) */
.steps .step:not(:last-child)::after{content:"";position:absolute;top:57px;right:-15px;width:30px;height:0;
  border-top:2px dashed var(--line);z-index:1}
@media (max-width:980px){
  .steps{grid-template-columns:1fr 1fr}
  .steps .step:nth-child(2)::after,.steps .step:not(:last-child)::after{display:none}
}
@media (max-width:600px){
  .steps{grid-template-columns:1fr}
}

/* ============ MÁY BAY VÚT LÊN TRỜI theo scroll ============ */
.journey{position:fixed;left:30px;top:0;height:100vh;width:40px;z-index:400;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateX(-8px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.journey.is-active{opacity:1;transform:none}
.journey__track{position:relative;width:2px;flex:1;max-height:74vh;border-radius:2px}
/* vệt khói máy bay - mọc từ dưới lên theo máy bay */
.journey__trail{position:absolute;left:50%;bottom:0;width:3px;transform:translateX(-50%);height:0;border-radius:3px;
  background:linear-gradient(to top,transparent,rgba(211,47,47,.15) 30%,var(--red));transition:height .14s linear}
.journey__plane{position:absolute;left:50%;bottom:0;transform:translate(-50%,50%);color:var(--red);z-index:3;
  filter:drop-shadow(0 4px 8px rgba(211,47,47,.45));transition:bottom .14s linear}
.journey__plane svg{display:block}
@media (max-width:1240px){.journey{display:none}}
@media (prefers-reduced-motion:reduce){.journey{display:none}}

/* ============ CẤT CÁNH - scrollytelling ============ */
.takeoff{position:relative;height:200vh;background:#2F5AC4}
.takeoff__scene{position:sticky;top:0;height:100vh;overflow:hidden;display:grid;place-items:center}
.takeoff__sky{position:absolute;inset:0;background:radial-gradient(125% 90% at 80% 116%,#3A66D6 0%,#2F5AC4 46%,#234CA8 100%)}/* royal sáng - bỏ navy thẫm */
.takeoff__sky::after{content:"";position:absolute;inset:0;background:radial-gradient(55% 38% at 80% 16%,rgba(255,179,107,.20),transparent 70%)}
.takeoff__stars{position:absolute;inset:0;opacity:.55;background-image:
  radial-gradient(1.6px 1.6px at 18% 28%,#fff,transparent),
  radial-gradient(1.2px 1.2px at 62% 18%,rgba(255,255,255,.85),transparent),
  radial-gradient(1.6px 1.6px at 86% 36%,#fff,transparent),
  radial-gradient(1.1px 1.1px at 38% 56%,rgba(255,255,255,.75),transparent),
  radial-gradient(1.3px 1.3px at 74% 66%,#fff,transparent),
  radial-gradient(1px 1px at 50% 12%,rgba(255,255,255,.7),transparent)}
.takeoff__cloud{position:absolute;background:radial-gradient(closest-side,rgba(255,255,255,.16),transparent);border-radius:50%;filter:blur(10px)}
.takeoff__cloud--1{width:400px;height:170px;left:4%;top:62%}
.takeoff__cloud--2{width:320px;height:140px;right:8%;top:28%}
.takeoff__cloud--3{width:250px;height:120px;left:42%;top:80%}
.takeoff__svg{position:absolute;inset:0;width:100%;height:100%}
.takeoff__trail{fill:none;stroke:rgba(255,255,255,.5);stroke-width:3;stroke-linecap:round}
.takeoff__plane{position:absolute;left:0;top:0;color:#fff;z-index:3;will-change:transform;
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.4))}
.takeoff__plane svg{display:block}
.takeoff__copy{position:relative;z-index:4;max-width:580px;text-align:center;color:#fff;padding:0 24px;
  opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.takeoff.is-mid .takeoff__copy{opacity:1;transform:none}
.takeoff__copy h2{color:#fff;font-size:clamp(1.9rem,3.6vw,3rem)}
.takeoff__copy p{margin-top:16px;color:rgba(255,255,255,.86);font-size:1.08rem;max-width:520px;margin-inline:auto}
.takeoff__copy .btn{margin-top:26px}
.takeoff__dest{position:absolute;z-index:4;display:inline-flex;align-items:center;gap:7px;color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:.86rem;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.26);padding:7px 15px;border-radius:30px;backdrop-filter:blur(4px);
  opacity:0;transform:translateY(10px) scale(.9);transition:.5s var(--ease)}
.takeoff__dest svg{color:#FFD9A0}
.takeoff__dest--tw{right:20%;top:34%}
.takeoff__dest--jp{right:11%;top:18%}
.takeoff.is-arrived .takeoff__dest{opacity:1;transform:none}
.takeoff.is-arrived .takeoff__dest--jp{transition-delay:.12s}
@media (max-width:860px){
  .takeoff{height:auto;background:#2F5AC4}
  .takeoff__scene{position:relative;height:auto;padding:78px 0;min-height:0}
  .takeoff__svg,.takeoff__plane,.takeoff__cloud{display:none}
  .takeoff__copy{opacity:1;transform:none}
  .takeoff__dest{position:static;display:none}
}
@media (prefers-reduced-motion:reduce){
  .takeoff{height:auto}
  .takeoff__scene{position:relative;height:auto;padding:90px 0}
  .takeoff__plane{display:none}
  .takeoff__copy{opacity:1;transform:none}
}

/* ============ MÁY BAY BAY XUYÊN TRANG theo scroll ============ */
.skyfly{position:fixed;inset:0;z-index:500;pointer-events:none;opacity:0;transition:opacity .6s var(--ease)}
.skyfly.is-on{opacity:.4}
.skyfly__svg{position:absolute;inset:0;width:100%;height:100%}
.skyfly__plane{position:absolute;left:0;top:0;color:var(--red);will-change:transform;
  filter:drop-shadow(0 0 5px rgba(255,255,255,.9)) drop-shadow(0 4px 8px rgba(0,0,0,.18))}
.skyfly__plane svg{display:block}
/* vệt khói: đuôi mờ dần phía sau máy bay (máy bay mũi hướng lên → đuôi xuống) */
.skyfly__plane::before{content:"";position:absolute;left:50%;top:calc(100% - 4px);transform:translateX(-50%);
  width:3px;height:130px;border-radius:3px;
  background:linear-gradient(to bottom,rgba(211,47,47,.42),rgba(28,62,149,.14) 45%,transparent)}
/* Máy bay hiện trên MỌI thiết bị (mobile thu nhỏ chút cho gọn) */
@media (max-width:600px){.skyfly__plane svg{width:32px;height:32px}}
@media (prefers-reduced-motion:reduce){.skyfly{display:none}}

/* ============ CHƯƠNG TRÌNH DU HỌC (các hệ) ============ */
.progs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prog{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px;transition:.24s var(--ease)}
.prog:hover{border-color:var(--blue);box-shadow:0 16px 38px rgba(20,44,107,.1);transform:translateY(-4px)}
.prog__ico{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:var(--paper-2);color:var(--blue);margin-bottom:16px}
.prog:hover .prog__ico{background:var(--blue);color:#fff}
.prog h3{font-size:1.18rem;color:var(--blue-dk);margin-bottom:9px}
.prog p{color:var(--muted);font-size:.95rem;line-height:1.65}
@media (max-width:900px){.progs{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.progs{grid-template-columns:1fr}}

/* ============ TRƯỜNG ĐỐI TÁC ============ */
.logos{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;align-items:center}
.logo{display:grid;place-items:center;height:96px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;
  filter:grayscale(100%);opacity:.72;transition:.25s var(--ease)}
.logo:hover{filter:none;opacity:1;border-color:var(--blue);box-shadow:0 10px 24px rgba(20,44,107,.1)}
.logo img{max-width:100%;max-height:100%;object-fit:contain}
@media (max-width:900px){.logos{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.logos{grid-template-columns:repeat(2,1fr)}}
/* fallback khi chưa có logo */
.pnet{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.pnet__item{display:flex;gap:14px;background:var(--paper-2);border-radius:14px;padding:22px 20px}
.pnet__ico{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:#fff;color:var(--blue);flex-shrink:0;box-shadow:0 4px 12px rgba(20,44,107,.08)}
.pnet__item b{color:var(--blue-dk);font-size:1.02rem;display:block;margin-bottom:4px}
.pnet__item p{color:var(--muted);font-size:.92rem;line-height:1.55}
@media (max-width:900px){.pnet{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.pnet{grid-template-columns:1fr}}

/* ============ ĐỘI NGŨ ITC ============ */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.member{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 20px;text-align:center;transition:.22s var(--ease)}
.member:hover{border-color:var(--blue);box-shadow:0 16px 36px rgba(20,44,107,.1);transform:translateY(-4px)}
.member__photo{width:120px;height:120px;border-radius:50%;overflow:hidden;margin:0 auto 16px;border:3px solid var(--paper-2)}
.member__photo img{width:100%;height:100%;object-fit:cover}
.member h3{font-size:1.1rem;color:var(--blue-dk);margin-bottom:4px}
.member__role{font-size:.9rem;color:var(--red);font-weight:600}
/* fallback: dải ảnh đội ngũ */
.team-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.team-strip__item{position:relative;margin:0;border-radius:14px;overflow:hidden;aspect-ratio:3/4;box-shadow:0 8px 22px rgba(20,44,107,.08)}
.team-strip__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.team-strip__item:hover img{transform:scale(1.05)}
.team-strip__item figcaption{position:absolute;inset:auto 0 0 0;padding:26px 14px 12px;color:#fff;font-weight:600;font-size:.92rem;
  background:linear-gradient(to top,rgba(16,30,66,.85),transparent)}
@media (max-width:900px){.team,.team-strip{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.team{grid-template-columns:1fr 1fr}.team-strip{grid-template-columns:1fr 1fr}}

/* =========================================================
   TWN - BỐ CỤC SHARINGTAIWAN (giữ màu ITC: navy nền + đỏ nhấn)
   Header nav-pill + trang chủ theo thứ tự section sharingtaiwan.
   ========================================================= */
.twn-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;
  border-radius:40px;padding:12px 24px;cursor:pointer;border:0;white-space:nowrap;transition:.2s var(--ease)}
.twn-btn svg{transition:transform .22s var(--ease)}
.twn-btn:hover svg{transform:translateX(3px)}
.twn-btn--red{background:var(--red);color:#fff}
.twn-btn--red:hover{background:var(--blue-2)}
.twn-btn--white{background:#fff;color:var(--blue-dk)}
.twn-btn--white:hover{background:#EAF0FB}
.twn-btn--lg{padding:15px 32px;font-size:1.02rem}

/* ---------- HEADER: topbar + nav pill ---------- */
.twn-head{position:relative;z-index:600;background:#fff}
.twn-head{border-top:4px solid var(--red)}
.twn-top{border-bottom:1px solid var(--line);background:#fff}
.twn-top__in{display:flex;align-items:center;gap:18px;padding:13px 0}
.twn-logo{display:flex;align-items:center;flex:0 0 auto}
.twn-logo img{height:42px;width:auto;display:block}/* logo nhỏ gọn hơn (Hiếu chốt 2026-06-16) */
.twn-brand{display:flex;flex-direction:column;gap:0;padding-left:15px;border-left:3px solid var(--red);line-height:1.02}
.twn-brand__sub{font-family:var(--font-display);font-weight:600;font-size:clamp(.72rem,.92vw,.82rem);color:var(--red);letter-spacing:.02em;text-transform:uppercase}
.twn-brand__name{font-family:var(--font-display);font-weight:800;font-size:clamp(1.12rem,1.6vw,1.42rem);color:var(--blue-2);letter-spacing:.005em;text-transform:uppercase}
/* actions: socials + CTA ở góc phải */
.twn-actions{margin-left:auto;display:flex;align-items:center;gap:12px}
.twn-soc{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;color:#fff;transition:.2s var(--ease)}
.twn-socials .twn-soc--phone{background:var(--red)}
.twn-socials .twn-soc--phone:hover{background:var(--blue-2)}
.twn-socials .twn-soc--zalo{background:#0068FF}/* brand Zalo (xanh Zalo thật) */
.twn-socials .twn-soc--zalo:hover{filter:brightness(1.08)}
.twn-soc__zalo{font-family:var(--font-display);font-weight:800;font-size:.66rem;letter-spacing:.01em;color:#fff;line-height:1}
.twn-socials .twn-soc--fb{background:#1877F2}/* brand Facebook */
.twn-socials .twn-soc--fb:hover{filter:brightness(1.08)}
.twn-top__phone{margin-left:auto;display:inline-flex;align-items:center;gap:11px;border:2px solid var(--red);
  border-radius:40px;padding:7px 18px 7px 8px;font-family:var(--font-display);font-weight:800;color:var(--blue-dk);font-size:1.05rem}
.twn-top__phone .ic{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--red);color:#fff;flex-shrink:0}
.twn-top__phone small{display:block;font-size:.66rem;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.twn-top__zalo{border-color:var(--blue-2);color:var(--blue-2);transition:.2s var(--ease)}
.twn-top__zalo:hover{background:var(--blue-2);color:#fff}
.twn-top__zalo:hover small{color:rgba(255,255,255,.85)}
.twn-top__zalo .ic{background:var(--blue-2);font-family:var(--font-display);font-weight:800;font-size:1.15rem;line-height:1}
.twn-socials{display:flex;gap:8px}
.twn-socials a{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:var(--red);color:#fff;transition:.2s}
.twn-socials a:hover{background:var(--red-dk)}
.twn-search{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;border:1px solid var(--red);color:var(--red)}
/* nav pill (sticky) */
.twn-navwrap{position:sticky;top:0;z-index:600;background:transparent;padding:8px 0 14px;transition:.3s var(--ease)}
.twn-navwrap.scrolled{background:#fff;box-shadow:0 6px 24px rgba(20,44,107,.1)}
.twn-nav{background:#fff;border:1px solid var(--line);border-radius:44px;
  padding:5px 12px;box-shadow:0 8px 22px rgba(20,44,107,.08)}
.twn-nav ul{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:2px;margin:0;padding:0;list-style:none}
.twn-nav li{position:relative}
.twn-nav a{display:block;font-family:var(--font-display);font-weight:700;color:var(--blue-2);padding:12px 14px;border-radius:34px;
  font-size:.95rem;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;transition:.18s var(--ease)}
.twn-nav a:hover,.twn-nav .current-menu-item>a,.twn-nav .current-menu-parent>a{background:transparent;color:var(--red)}
.twn-nav .menu-item-has-children>a{padding-right:30px}
.twn-nav .menu-item-has-children>a::after{content:"";position:absolute;right:14px;top:50%;width:6px;height:6px;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-70%) rotate(45deg);opacity:.7}
.twn-nav .sub-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:230px;background:#fff;border-radius:12px;
  border:1px solid var(--line);box-shadow:0 16px 38px rgba(20,44,107,.18);padding:8px;display:grid;grid-template-columns:1fr;gap:2px;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s var(--ease);z-index:50}
.twn-nav .sub-menu::before{content:"";position:absolute;top:-8px;left:0;right:0;height:8px}
.twn-nav li:hover>.sub-menu,.twn-nav li:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.twn-nav .sub-menu a{color:var(--ink);padding:11px 14px;border-radius:8px;font-weight:600;font-size:.96rem}
.twn-nav .sub-menu a:hover{background:var(--paper-2);color:var(--blue)}
.twn-nav .sub-menu .menu-item-has-children>a::after{transform:translateY(-50%) rotate(-45deg);right:12px}
.twn-toggle{display:none;width:46px;height:42px;border:0;background:var(--red);border-radius:12px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px}
.twn-toggle span{width:20px;height:2px;background:#fff;border-radius:2px}

/* ---------- SECTION shell ---------- */
/* section TRONG SUỐT để nền hành trình ở body chạy xuyên suốt (liền mạch) */
.clx-sec{padding:clamp(64px,7vw,100px) 0;background-color:transparent}
.clx-sec--pale{background-color:rgba(21,61,139,.03)}

/* NỀN TỐI GIẢN - CAO CẤP: quầng sáng tròn mềm (soft orb) màu navy/đỏ rất loãng ở 1 góc mỗi section.
   Thanh, đủ thấy, đồng bộ toàn trang. Màu: orb-n (navy) / orb-r (đỏ). Góc: orb-tl/tr/bl/br. */
.has-orb{position:relative;overflow:hidden}
.has-orb::before{content:"";position:absolute;width:clamp(320px,42vw,560px);height:clamp(320px,42vw,560px);
  border-radius:50%;pointer-events:none;z-index:0}
.has-orb>*{position:relative;z-index:1}
.orb-n::before{background:radial-gradient(circle at center,rgba(21,61,139,.10),rgba(21,61,139,0) 68%)}
.orb-r::before{background:radial-gradient(circle at center,rgba(238,32,15,.09),rgba(238,32,15,0) 68%)}
.orb-tl::before{top:-16%;left:-10%}
.orb-tr::before{top:-16%;right:-10%}
.orb-bl::before{bottom:-16%;left:-10%}
.orb-br::before{bottom:-16%;right:-10%}
.clx-head{text-align:center;max-width:780px;margin:0 auto clamp(34px,4vw,54px)}
.clx-head .kk{display:inline-block;font-family:var(--font-display);font-weight:700;letter-spacing:.14em;
  color:var(--red);text-transform:uppercase;font-size:.8rem;margin-bottom:12px}
.clx-head h2{font-size:clamp(2rem,3.1vw,2.45rem);color:var(--blue-2);font-weight:700}
.clx-head h2 .u{color:var(--red)}
.clx-head p{color:var(--muted);margin-top:14px;font-size:1.05rem}

/* ---------- HERO (ảnh người cắt-rời + nền navy) ---------- */
.clx-hero{position:relative;z-index:1;margin-top:-22px;background:linear-gradient(160deg,#FFFFFF 0%,#FFF4F1 60%,#FFEFF0 100%);overflow:hidden;color:var(--ink)}
.clx-hero__skyline g{fill:rgba(238,32,15,.06)}
.clx-hero__plane path:first-child{stroke:rgba(238,32,15,.4)}
.clx-hero__deco{position:absolute;inset:auto 0 30px 0;height:56%;pointer-events:none;
  background:repeating-linear-gradient(90deg,rgba(238,32,15,.05) 0 44px,transparent 44px 52px);
  -webkit-mask:linear-gradient(to top,#000,transparent);mask:linear-gradient(to top,#000,transparent)}
.clx-hero__plane{position:absolute;top:26px;right:7%;width:clamp(80px,11vw,140px);z-index:2;opacity:.9}
.clx-hero__skyline{position:absolute;left:0;right:0;bottom:0;width:100%;height:62%;z-index:1;pointer-events:none}
.clx-hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr .92fr;gap:clamp(12px,2vw,30px);
  align-items:end;min-height:clamp(420px,37vw,500px)}
.clx-hero__person{align-self:end;justify-self:end}
.clx-hero__person img{width:100%;max-width:560px;margin-left:auto;filter:drop-shadow(0 18px 26px rgba(0,0,0,.32))}
.clx-hero__content{padding:clamp(38px,4.5vw,62px) 0 clamp(38px,4.5vw,64px)}
.clx-hero__flags{display:flex;gap:10px;margin-top:18px;font-size:1.7rem;line-height:1}
.clx-hero__kk{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--red);margin-bottom:16px;text-wrap:balance;max-width:30ch}
.clx-hero__big{color:var(--ink);font-family:var(--font-display);font-weight:800;font-size:clamp(1.85rem,3.7vw,3rem);
  line-height:1.08;letter-spacing:-.01em}
.clx-hero__big .r{color:var(--red)}
.clx-hero__script{display:block;font-family:'Lora',Georgia,serif;font-style:italic;font-weight:600;
  font-size:clamp(1.6rem,3.4vw,2.8rem);color:var(--blue-2);margin-top:8px}
.clx-hero__sub{margin-top:18px;max-width:520px;color:var(--muted);font-size:1.08rem}
.clx-hero__sub--tags{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--blue-2);letter-spacing:.01em;margin-top:14px}
.nw{white-space:nowrap}
.clx-hero__box{display:inline-flex;flex-direction:column;gap:4px;background:#fff;
  border:1px solid var(--line);border-radius:18px;padding:14px 26px;margin-top:24px;box-shadow:0 14px 34px rgba(238,32,15,.1)}
.clx-hero__box span{font-weight:600;color:var(--muted);font-size:.92rem}
.clx-hero__box a{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.3rem,2.2vw,1.9rem);color:var(--blue-2)}
.clx-hero__box a .ic{display:grid;place-items:center;width:50px;height:50px;border-radius:50%;background:var(--red);color:#fff;
  box-shadow:0 0 0 0 rgba(238,32,15,.5);animation:itc-ring 1.8s cubic-bezier(.66,0,0,1) infinite}
.clx-hero__box a .ic svg{width:26px;height:26px;fill:#fff}
@keyframes itc-ring{0%{box-shadow:0 0 0 0 rgba(238,32,15,.5)}70%{box-shadow:0 0 0 16px rgba(238,32,15,0)}100%{box-shadow:0 0 0 0 rgba(238,32,15,0)}}
@media (prefers-reduced-motion:reduce){.clx-hero__box a .ic{animation:none}}
.clx-hero__strip{position:relative;z-index:2;background:var(--paper-2);border-top:1px solid var(--line)}
.clx-hero__strip-in{display:flex;gap:30px;flex-wrap:wrap;justify-content:center;padding:13px 0;font-weight:600;color:var(--muted);font-size:.92rem}
.clx-hero__strip-in span{display:inline-flex;align-items:center;gap:8px}
.clx-hero__strip-in svg{color:var(--red)}
/* ---------- HERO SLIDER (auto 2 banner) ---------- */
.clx-hero--slider{position:relative;overflow:hidden}
/* trượt ngang mượt như sharingtaiwan (KHÔNG fade -> đỡ mỏi mắt) */
.clx-hero__viewport{position:relative;display:flex;transition:transform .9s var(--ease);will-change:transform}
.clx-hero__slide{position:relative;flex:0 0 100%;min-width:100%}
/* scrim sáng bên trái: chữ luôn trên nền sáng, không đè lên người/ảnh */
.clx-hero__slide::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.82) 30%,rgba(255,255,255,0) 58%)}
.clx-hero--photo .clx-hero__grid{position:relative;z-index:2}
.clx-hero__dots{position:absolute;left:0;right:0;bottom:64px;z-index:6;display:flex;gap:9px;justify-content:center}
.clx-hero__dots button{width:11px;height:11px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:rgba(20,20,30,.2);transition:.25s var(--ease)}
.clx-hero__dots button.is-active{background:var(--red);width:30px;border-radius:7px}
/* slide 2 đã có ảnh thật -> ẩn motif chữ tạm */
.clx-hero__lang{display:none}
.clx-hero__lang--legacy{position:absolute;right:5%;top:50%;transform:translateY(-50%);z-index:1;text-align:right;
  font-family:var(--font-display);font-weight:800;line-height:.92;pointer-events:none;user-select:none}
.clx-hero__lang b{display:block;font-size:clamp(4rem,13vw,11rem);color:rgba(238,32,15,.13)}
.clx-hero__lang i{display:block;font-style:normal;font-size:clamp(2rem,6vw,5rem);color:rgba(21,61,139,.16);margin-top:.1em}
@media (max-width:900px){
  .clx-hero__lang{right:50%;transform:translateX(50%);top:auto;bottom:7%;text-align:center}
  .clx-hero__lang b{font-size:clamp(3.4rem,26vw,7rem)}
}

@media (min-width:901px){
  /* Khung banner theo TỈ LỆ sharingtaiwan.vn = 2.755:1 (1440->523px, 1920->697px). Sàn 480px. */
  /* khung = tỉ lệ sharingtaiwan 2.755:1 (1440->523px, 1920->697px) */
  .clx-hero--photo{min-height:max(36.3vw,480px)}
  .clx-hero__slide{background-color:#FCEFEC;background-position:right top;background-size:cover;background-repeat:no-repeat}
  .clx-hero__slide--du{background-image:url(../images/hero-banner-desktop.jpg);background-position:right 14%;background-size:cover}
  .clx-hero__slide--nn{background-image:url(../images/hero-banner2-desktop.jpg);background-position:center 20%;background-size:cover}
  .clx-hero--photo .clx-hero__grid{grid-template-columns:1fr;min-height:max(36.3vw,480px);align-items:center}
  /* dàn rộng kiểu sharingtaiwan: tiêu đề 2 dòng to, countries 1 dòng ngang trải rộng */
  .clx-hero--photo .clx-hero__content{max-width:720px;padding-block:clamp(14px,1.6vw,26px)}
  .clx-hero--photo .clx-hero__kk{margin-bottom:16px;letter-spacing:.12em;font-size:.9rem}
  .clx-hero--photo .clx-hero__big{font-size:clamp(2.2rem,3.9vw,3.3rem);line-height:1.07}
  .clx-hero--photo .clx-hero__big .r{white-space:nowrap}
  .clx-hero--photo .clx-hero__script{margin-top:9px;font-size:clamp(1.6rem,2.2vw,2.2rem)}
  .clx-hero--photo .clx-hero__sub{margin-top:18px;max-width:560px;font-size:1.04rem;line-height:1.7}
  .clx-hero--photo .clx-hero__flags{margin-top:16px;font-size:1.5rem}
  .clx-hero--photo .clx-hero__box{margin-top:24px}
  /* nền trái SÁNG (chừa chữ) -> scrim trắng nhẹ đảm bảo chữ navy nổi; nửa phải đỏ giữ nguyên */
  .clx-hero--photo .clx-hero__slide::before{background:linear-gradient(90deg,rgba(255,255,255,.72) 0%,rgba(255,255,255,.32) 30%,rgba(255,255,255,0) 52%)}
  .clx-hero--photo .clx-hero__kk{color:var(--red)}
  /* nền sáng -> chữ NAVY thương hiệu cho nổi, tên nước nhấn đỏ */
  .clx-hero--photo .clx-hero__big{color:var(--blue-2);letter-spacing:-.01em}
  .clx-hero--photo .clx-hero__big .r{color:var(--red)}
  .clx-hero--photo .clx-hero__script{color:var(--blue-2)}
  .clx-hero--photo .clx-hero__sub{color:var(--muted)}
  /* hộp hotline trên thẻ trắng: label navy nhạt, số đỏ */
  .clx-hero--photo .clx-hero__box span{color:var(--muted)}
  .clx-hero--photo .clx-hero__box a{color:var(--blue-2)}
}
/* ẩn các phần poster-only ở desktop (giữ desktop nguyên) */
@media (min-width:901px){
  .clx-hero__emblem,.clx-hero__cta,.clx-hero__pills,.clx-hero__lm,.clx-hero__photo{display:none}
}
@media (max-width:900px){
  /* ===== POSTER MOBILE: panel trắng cong (chữ + 2 nút) trên cùng, ngay dưới là ảnh NGƯỜI THẬT (in-flow, không neo đáy -> không hở khoảng đỏ) ===== */
  .clx-hero__slide{background-repeat:no-repeat;background-position:center top;background-size:100% 100%}
  .clx-hero__slide--du{background-image:linear-gradient(180deg,#fff 0,#fff 32%,#FCE6E5 52%,#EE200F 100%)}
  .clx-hero__slide--nn{background-image:linear-gradient(180deg,#fff 0,#fff 36%,#FEE3E3 56%,#EE200F 100%)}
  .clx-hero__slide::before{display:none}
  .clx-hero--photo .clx-hero__sub,.clx-hero--photo .clx-hero__flags,
  .clx-hero--photo .clx-hero__box,.clx-hero--photo .clx-hero__strip,
  .clx-hero__pills,.clx-hero__lm{display:none}

  .clx-hero--photo .clx-hero__grid{display:block;padding:0;max-width:none;width:100%;margin:0;min-height:0}
  /* ẢNH người ngay dưới panel (theo luồng) */
  .clx-hero__photo{display:block;width:100%;position:relative;z-index:2;margin-top:-2px;
    background-position:center top;background-repeat:no-repeat;background-size:100% 100%}
  .clx-hero__photo--du{aspect-ratio:1122/792;background-image:url(../images/hero-poster-du.jpg)}
  .clx-hero__photo--nn{aspect-ratio:1122/724;background-image:url(../images/hero-poster-nn.jpg)}
  /* PANEL TRẮNG cong */
  .clx-hero--photo .clx-hero__content{position:relative;z-index:4;width:100%;max-width:none;background:#fff;
    display:flex;flex-direction:column;align-items:center;text-align:center;
    padding:clamp(16px,5vw,26px) 20px clamp(18px,5.5vw,28px);
    border-radius:0 0 50% 50%/0 0 30px 30px;box-shadow:0 12px 26px rgba(16,41,75,.13)}
  .clx-hero__emblem{display:grid;place-items:center;width:46px;height:46px;border-radius:50%;
    background:rgba(238,32,15,.08);color:var(--red);margin-bottom:8px}
  .clx-hero--photo .clx-hero__kk{color:var(--red);margin:0 0 7px;font-size:.7rem;letter-spacing:.05em;line-height:1.4}
  .clx-hero--photo .clx-hero__big{margin:0;font-size:clamp(1.55rem,6.8vw,2.2rem);line-height:1.04;color:var(--blue-2)}
  .clx-hero--photo .clx-hero__big .r{color:var(--red);white-space:nowrap}
  .clx-hero--photo .clx-hero__script{margin-top:4px;font-size:clamp(1.1rem,5vw,1.55rem);color:var(--blue-2)}
  /* CTA 2 nút */
  .clx-hero__cta{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin-top:13px}
  .hcta{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;
    font-size:.82rem;padding:8px 15px;border-radius:40px;transition:.2s var(--ease)}
  .hcta i{font-style:normal;display:grid;place-items:center;width:17px;height:17px;border-radius:50%;
    font-weight:800;font-size:.74rem;line-height:1}
  .hcta--red{background:var(--red);color:#fff;box-shadow:0 8px 16px rgba(238,32,15,.26)}
  .hcta--red i{background:#fff;color:var(--red)}
  .hcta--out{background:#fff;color:var(--blue-2);border:1.6px solid var(--blue-2)}
  .hcta--out i{background:var(--blue-2);color:#fff}
  /* PILLS trên vùng đỏ (góc trái, trên thân người) */
  .clx-hero__pills{position:absolute;left:11px;bottom:clamp(118px,33vw,200px);z-index:3;
    display:flex;flex-direction:column;gap:8px;margin:0;max-width:62%}
  .clx-hero__pills li{display:inline-flex;align-items:center;gap:8px;background:#fff;border-radius:40px;
    padding:6px 13px 6px 6px;font-size:.74rem;font-weight:600;color:var(--ink);
    box-shadow:0 5px 14px rgba(60,2,0,.22);width:fit-content}
  .clx-hero__pills li span{display:grid;place-items:center;width:25px;height:25px;border-radius:50%;
    background:var(--red);color:#fff;flex:0 0 25px}
  .clx-hero__pills li:nth-child(2) span{background:var(--blue-2)}
  /* danh thắng mờ trong vùng đỏ */
  .clx-hero__lm{position:absolute;z-index:1;color:rgba(255,255,255,.12);pointer-events:none;line-height:0}
  .clx-hero__lm--tower{right:4px;bottom:0}
  .clx-hero__lm--fuji,.clx-hero__lm--torii{left:2px;bottom:0}
  .clx-hero__dots{bottom:11px;z-index:5}
}

/* ---------- ABOUT (2 cột: ảnh trái - text phải, kiểu sharingtaiwan) ---------- */
/* tỉ lệ y hệt sharingtaiwan: container rộng 1300, 2 cột 50/50, căn giữa dọc, gap ~30px, padding section 100px (.clx-sec) */
.clx-about__grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(24px,2.4vw,40px);max-width:1300px}
.clx-about__mtitle{display:none}
.clx-about__grid>.clx-about__btn--m{display:none}
.clx-about__media{position:relative}
.clx-about__media img{width:100%;aspect-ratio:6/5;object-fit:cover;border-radius:18px;
  box-shadow:0 18px 44px rgba(20,44,107,.16);display:block}
.clx-about__media::after{content:"";position:absolute;left:-14px;bottom:-14px;width:96px;height:96px;border-radius:16px;
  background:repeating-linear-gradient(45deg,rgba(238,32,15,.16) 0 7px,transparent 7px 14px);z-index:-1}
.clx-about__body h2{font-size:clamp(1.9rem,3vw,2.375rem);color:var(--blue-2);font-weight:700;line-height:1.2;letter-spacing:-.01em}
.clx-about__body h2 .u{color:var(--red)}
.clx-about__body p{color:var(--muted);margin-top:18px;font-size:1.06rem;line-height:1.85;text-wrap:pretty}
.clx-about__btn{display:inline-flex;align-items:center;justify-content:center;margin-top:26px;
  font-family:var(--font-display);font-weight:700;font-size:1rem;color:#fff;background:var(--red);
  padding:11px 32px;border-radius:46px;transition:.22s var(--ease);box-shadow:0 10px 26px rgba(238,32,15,.22)}
.clx-about__btn:hover{background:var(--blue-2);transform:translateY(-2px);box-shadow:0 14px 30px rgba(21,61,139,.3)}
.clx-more{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-family:var(--font-display);font-weight:700;color:var(--red)}
.clx-more svg{transition:transform .2s var(--ease)}
.clx-more:hover svg{transform:translateX(4px)}

/* ---------- 3 CARD DỊCH VỤ ---------- */
.clx-svc{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.clx-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:36px 30px;text-align:center;
  box-shadow:0 14px 32px rgba(20,44,107,.07);transition:.25s var(--ease)}
.clx-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(20,44,107,.13);border-color:var(--blue)}
.clx-card__ic{display:grid;place-items:center;width:78px;height:78px;border-radius:50%;
  background:rgba(238,32,15,.08);color:var(--red);margin:0 auto 18px}
.clx-card h3{font-size:1.26rem;margin-bottom:10px;color:var(--blue-dk)}
.clx-card p{color:var(--muted);margin-bottom:16px;font-size:.97rem;line-height:1.7}
.clx-card__l{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;color:var(--red)}
.clx-card__l svg{transition:transform .2s var(--ease)}
.clx-card:hover .clx-card__l svg{transform:translateX(4px)}

/* ---------- 3 CARD NHỎ ĐÈ LÊN ẢNH LỚN (kiểu taiwan) ---------- */
/* section 3 rộng 1300 + card đè ảnh ~60px, khớp tỉ lệ sharingtaiwan */
.clx-svc2wrap{max-width:1300px;position:relative;z-index:1}
/* de-boring: kicker có 2 vạch hai bên + chấm trang trí góc */
.clx-svc2wrap .clx-head .kk{display:inline-flex;align-items:center;gap:12px}
.clx-svc2wrap .clx-head .kk::before,.clx-svc2wrap .clx-head .kk::after{content:"";width:30px;height:2px;border-radius:2px;background:var(--red)}
/* gạch chân tay-vẽ chỉ dưới chữ ITC, tự "vẽ" khi cuộn tới */
.clx-svc2wrap .clx-head h2 .u,.clx-road-sec .clx-head h2 .u,.clx-act--cards .clx-head h2 .u,.clx-head h2 .uw{position:relative;display:inline-block}
.clx-squiggle{position:absolute;left:-3px;right:-3px;bottom:-11px;width:auto;height:11px;color:var(--blue-2);overflow:visible}
/* band đỏ Hoạt động: chữ ITC vẫn trắng, gạch lượn navy thương hiệu */
.clx-act--cards .clx-head h2 .u{color:#fff}
.clx-act--cards .clx-squiggle{color:var(--blue-2)}
.clx-squiggle path{fill:none;stroke:currentColor;stroke-width:3.4;stroke-linecap:round;
  stroke-dasharray:78;stroke-dashoffset:78;transition:stroke-dashoffset .85s .25s var(--ease)}
.clx-head.in .clx-squiggle path{stroke-dashoffset:0}
@media (prefers-reduced-motion:reduce){.clx-squiggle path{transition:none;stroke-dashoffset:0}}
.clx-svc-sec{position:relative;overflow:hidden}
.clx-svc2{position:relative;display:flex;flex-direction:column;align-items:center}
.clx-svc2__cards{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
  width:min(96%,1210px);margin-bottom:-60px}
/* THẺ (img1): vùng trên ĐỎ gradient + vòng tròn TRẮNG icon navy, vùng dưới TRẮNG chữ navy */
.clx-svc2__card{position:relative;background:#fff;border:0;border-radius:22px;overflow:hidden;padding:0;text-align:center;min-height:312px;
  display:flex;flex-direction:column;box-shadow:0 18px 44px rgba(20,44,107,.10);transition:.3s var(--ease)}
/* nền đỏ nửa trên: gradient chéo + vân chéo trắng mảnh + motif đường bay (hết phẳng) */
.clx-svc2__card::before{content:"";position:absolute;top:0;left:0;right:0;height:45%;
  background:
    radial-gradient(150% 100% at 82% 6%,rgba(255,255,255,.22),transparent 56%),
    url("../images/svc-card-motif.svg") no-repeat right -6px bottom -8px / 200px auto,
    repeating-linear-gradient(125deg,rgba(255,255,255,.06) 0 1.5px,transparent 1.5px 11px),
    linear-gradient(135deg,#FF4A22 0%,var(--red) 46%,var(--red-dk) 100%)}
/* vệt sáng quét chéo khi hover (chỉ trong vùng đỏ) */
.clx-svc2__card::after{content:"";position:absolute;top:0;left:0;right:0;height:45%;pointer-events:none;
  background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.30) 50%,transparent 68%);
  transform:translateX(-130%);transition:transform .75s var(--ease)}
.clx-svc2__card:hover::after{transform:translateX(130%)}
@media(prefers-reduced-motion:reduce){.clx-svc2__card::after,.clx-svc2__card:hover::after{transition:none;transform:translateX(-130%)}}
.clx-svc2__card:hover{transform:translateY(-9px);box-shadow:0 32px 64px rgba(20,44,107,.20)}
/* vòng tròn trắng + glyph navy, nằm trong vùng đỏ */
.clx-svc2__ic{position:relative;z-index:2;display:grid;place-items:center;width:90px;height:90px;border-radius:50%;
  background:#fff;color:var(--blue-2);margin:32px auto 0;box-shadow:0 14px 30px rgba(120,10,4,.24);transition:.3s var(--ease)}
.clx-svc2__ic svg{width:40px;height:40px;stroke-width:1.7}
.clx-svc2__ic--img img{width:80%;height:80%;object-fit:contain;display:block}
.clx-svc2__card:hover .clx-svc2__ic{transform:translateY(-4px) scale(1.06)}
/* vùng chữ trắng nửa dưới */
.clx-svc2__body{position:relative;z-index:2;background:transparent;padding:30px 26px 30px;text-align:center;
  display:flex;flex-direction:column;gap:9px;flex:1 1 auto;margin-top:0}
.clx-svc2__card b{color:var(--blue-2);font-family:var(--font-display);font-size:1.22rem;font-weight:700}
.clx-svc2__desc{color:var(--muted);font-size:.92rem;line-height:1.55}
.clx-svc2__more{display:inline-flex;align-items:center;justify-content:center;gap:7px;margin-top:auto;padding-top:8px;
  font-family:var(--font-display);font-weight:700;font-size:.86rem;color:var(--red)}
.clx-svc2__more svg{transition:transform .2s var(--ease)}
.clx-svc2__card:hover .clx-svc2__more svg{transform:translateX(4px)}
.clx-svc2__l{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-weight:700;font-size:.86rem;color:var(--red)}
.clx-svc2__l svg{transition:transform .2s var(--ease)}
.clx-svc2__card:hover .clx-svc2__l svg{transform:translateX(4px)}
.clx-svc2__photo{margin:0;width:100%;border-radius:20px;overflow:hidden;aspect-ratio:13/7;box-shadow:0 20px 46px rgba(20,44,107,.16)}
.clx-svc2__photo img{width:100%;height:100%;object-fit:cover;object-position:50% 38%}
/* Ảnh ĐỘI NGŨ thật (dọc): đóng khung gọn giữa, KHÔNG crop mặt + caption thương hiệu */
.clx-svc2:has(.clx-svc2__photo--team) .clx-svc2__cards{margin-bottom:34px}
.clx-svc2__photo--team{width:min(92%,560px);margin:0 auto;aspect-ratio:auto;background:#fff;padding:10px 10px 0;
  border:1px solid var(--line);border-radius:20px;box-shadow:0 26px 60px rgba(20,44,107,.18)}
.clx-svc2__photo--team img{width:100%;height:auto;object-fit:contain;border-radius:12px;display:block}
.clx-svc2__cap{display:block;padding:13px 8px;text-align:center;font-family:var(--font-display);font-weight:700;
  font-size:.92rem;color:var(--blue-2)}

/* ============================================================
   DECO KIT - trang trí nền (blob đỏ/navy, chấm halftone, vòng tròn,
   bản đồ/đường bay, landmark mờ). Chỉ 3 màu. Theo mockup tham khảo.
   ============================================================ */
.clx-deco{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.clx-deco>*{position:absolute}
/* blob mềm hữu cơ */
.dco-blob{border-radius:46% 54% 57% 43%/52% 47% 53% 48%;filter:blur(.2px)}
.dco-blob--r{background:var(--red)}
.dco-blob--n{background:var(--blue-2)}
/* lưới chấm halftone */
.dco-dots{background-image:radial-gradient(currentColor 1.7px,transparent 1.9px);background-size:15px 15px}
.dco-dots--n{color:var(--blue-2);opacity:.16}
.dco-dots--r{color:var(--red);opacity:.16}
/* vòng tròn đồng tâm outline */
.dco-ring{border-radius:50%;border:1.6px solid currentColor;background:transparent}
/* host: section trên deco, nội dung trên cùng */
.clx-about,.clx-svc-sec{position:relative;overflow:hidden}
.clx-about__grid,.clx-svc2wrap{position:relative;z-index:1}

/* ---------- DECO: VỀ ITC (img3) - bản đồ chấm + đường bay + ghim + chấm góc ---------- */
.clx-deco--about .ab-map{position:absolute;top:9%;right:0;width:min(45%,520px);height:auto;opacity:.24}
.clx-deco--about .ab-fly{position:absolute;top:26%;right:2%;width:min(34%,372px);height:auto;opacity:.4}
.ab-fly .fa-arc{fill:none;stroke:var(--red);stroke-width:2;stroke-dasharray:2 8;stroke-linecap:round;opacity:.32}
.ab-fly .fa-pin-o{fill:none;stroke:var(--red);stroke-width:2}
.ab-fly .fa-pin-i{fill:var(--red)}
.ab-fly .fa-plane path{fill:var(--blue-2);opacity:.45}
.ab-dots{position:absolute;background-image:radial-gradient(currentColor 1.8px,transparent 2px);background-size:13px 13px}
.ab-dots--r{top:7%;left:0;width:92px;height:62px;color:var(--red);opacity:.24}
.ab-dots--n{bottom:11%;left:38%;width:80px;height:54px;color:var(--blue-2);opacity:.2}
/* blob ôm khung ảnh About */
.clx-about__media::before{content:"";position:absolute;top:-18px;left:-18px;width:104px;height:104px;z-index:-1;
  border-radius:46% 54% 57% 43%/52% 47% 53% 48%;background:var(--red);opacity:.26}
.clx-about__media::after{left:auto;right:-16px;bottom:-18px;width:104px;height:104px;border-radius:54% 46% 43% 57%/47% 53% 48% 52%;
  background:var(--blue-2);opacity:.28}
/* gạch dưới navy + chấm đỏ kiểu mockup */
.clx-about__body h2{position:relative}
.clx-about__body h2::after{content:"";display:block;margin-top:16px;width:66px;height:5px;border-radius:3px;
  background:linear-gradient(90deg,var(--blue-2) 0 74%,transparent 74% 82%,var(--red) 82% 100%)}

/* ---------- DECO: DỊCH VỤ ---------- */
.clx-deco--svc .dco-blob--n{top:-50px;left:-50px;width:150px;height:150px;opacity:.1}
.clx-deco--svc .dco-blob--r{bottom:-44px;right:-40px;width:140px;height:140px;opacity:.1}
.clx-deco--svc .dco-dots--n{bottom:30px;left:24px;width:84px;height:64px}
.clx-deco--svc .dco-dots--r{top:18px;right:24px;width:84px;height:64px}

/* ---------- DECO: LỘ TRÌNH (img2) ---------- */
.clx-road-sec{position:relative;overflow:hidden}
.clx-road-sec .wrap{position:relative;z-index:1}
.clx-rdg{z-index:1}
.clx-deco--road .dco-blob--n{top:-46px;left:-56px;width:150px;height:150px;opacity:.09}
.clx-deco--road .dco-blob--r{bottom:-50px;left:8%;width:120px;height:120px;opacity:.1}
.clx-deco--road .dco-blob--r.is-2{bottom:-40px;right:-46px;width:130px;height:130px}
.clx-deco--road .dco-dots--n{top:10px;left:30px;width:96px;height:72px}
.clx-deco--road .dco-ring{top:-30px;right:6%;width:130px;height:130px;color:var(--red);opacity:.12}
/* landmark line-art mờ góc phải dưới */
.clx-deco--road .dco-mark{right:3%;bottom:0;width:min(26%,300px);height:64%;color:var(--red);opacity:.1}
.dco-mark svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ---------- ƯU ĐIỂM (3 cột: số + tiêu đề + ảnh + bullets) ---------- */
.clx-adv{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px);align-items:start}
.clx-adv__col{display:flex;flex-direction:column}
/* ảnh trên -> số + tiêu đề cùng dòng -> bullet (kiểu sharingtaiwan) */
.clx-adv__head{display:flex;align-items:baseline;gap:14px;margin:18px 0 14px}
/* thống nhất: SỐ = navy, TIÊU ĐỀ = đỏ (mọi cột) */
.clx-adv__no{font-family:var(--font-display);font-weight:900;font-size:2.2rem;line-height:1;color:var(--blue-2);letter-spacing:-.02em;flex:0 0 auto}
.clx-adv__col h3{font-size:1.18rem;margin:0;color:var(--red);line-height:1.3}
.clx-adv__lead{color:var(--ink);font-size:.98rem;line-height:1.65;margin:0 0 14px;text-wrap:pretty}
.clx-adv__media{margin:0;border-radius:16px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 14px 32px rgba(20,44,107,.12);order:-1}
.clx-adv__cta{text-align:center;margin-top:clamp(34px,4vw,54px)}
.clx-adv__cta .clx-about__btn{gap:10px}
.clx-adv__media img{width:100%;height:100%;object-fit:cover;object-position:50% 38%;transition:.5s var(--ease)}
.clx-adv__col:hover .clx-adv__media img{transform:scale(1.05)}
.clx-adv__col ul{display:grid;gap:11px}
.clx-adv__col li{display:flex;gap:11px;color:var(--ink);font-size:.97rem;line-height:1.6}
.clx-adv__col li svg{color:var(--red);flex:0 0 auto;margin-top:3px}

/* ---------- LỘ TRÌNH (infographic: route line + node + caption) ---------- */
.clx-road{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-top:14px}
.clx-road__line{position:absolute;top:52px;left:12%;right:12%;height:4px;border-radius:4px;
  background:linear-gradient(90deg,var(--blue-2),var(--red));z-index:0}
.clx-road__line::before{content:"";position:absolute;left:-5px;top:50%;transform:translateY(-50%);
  width:11px;height:11px;border-radius:50%;background:var(--blue-2)}
.clx-road__line::after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);
  border:7px solid transparent;border-left:13px solid var(--red)}
.clx-road__s{position:relative;z-index:1;text-align:center}
.clx-road__ic{position:relative;display:grid;place-items:center;width:76px;height:76px;border-radius:50%;
  background:#fff;border:3px solid var(--blue-2);color:var(--blue-2);margin:0 auto 18px;
  box-shadow:0 8px 20px rgba(20,44,107,.12);transition:.25s var(--ease)}
.clx-road__s:hover .clx-road__ic{background:var(--blue-2);color:#fff}
.clx-road__s--end .clx-road__ic{border-color:var(--red);color:var(--red)}
.clx-road__s--end:hover .clx-road__ic{background:var(--red);color:#fff}
.clx-road__ic b{position:absolute;top:-6px;right:-6px;width:27px;height:27px;border-radius:50%;background:var(--red);
  color:#fff;font-family:var(--font-display);font-weight:800;font-size:.82rem;display:grid;place-items:center}
.clx-road__cap{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 18px;
  box-shadow:0 10px 26px rgba(20,44,107,.07)}
.clx-road__cap h3{font-size:1.06rem;margin-bottom:6px;color:var(--blue-dk)}
.clx-road__cap p{color:var(--muted);font-size:.92rem;line-height:1.6}

/* ---------- LỘ TRÌNH infographic (đường bay uốn 2 hàng, node đánh số xen kẽ navy/đỏ) ---------- */
.clx-rdg{position:relative;max-width:1160px;margin:0 auto;height:500px}
.clx-rdg__path{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.clx-rdg__path .rd-line{fill:none;stroke:#c7d2e8;stroke-width:2.5;stroke-dasharray:2 9;stroke-linecap:round}
.clx-rdg__path .rd-mk{fill:#fff;stroke:#c7d2e8;stroke-width:2.5}
.clx-rdg__path .rd-plane path{fill:#b9c6e0}
.clx-rdg__step{position:absolute;width:21%;transform:translateX(-50%);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:11px;
  opacity:0;translate:0 16px;transition:opacity .5s var(--ease),translate .5s var(--ease);transition-delay:calc(var(--d) * .08s)}
.clx-rdg.in .clx-rdg__step{opacity:1;translate:0 0}
.clx-rdg__dot{position:relative;z-index:0;display:grid;place-items:center;width:64px;height:64px;border-radius:50%;
  background:#fff;border:2.5px solid var(--blue-2);color:var(--blue-2);box-shadow:0 10px 24px rgba(20,44,107,.12);transition:.28s var(--ease)}
.clx-rdg__step--r .clx-rdg__dot{border-color:var(--red);color:var(--red)}
.clx-rdg__dot svg{width:26px;height:26px;stroke-width:1.8}
.clx-rdg__dot b{position:absolute;top:-7px;right:-7px;display:grid;place-items:center;width:25px;height:25px;border-radius:50%;
  background:var(--blue-2);color:#fff;font-family:var(--font-display);font-weight:800;font-size:.78rem;border:2px solid #fff}
.clx-rdg__step--r .clx-rdg__dot b{background:var(--red)}
.clx-rdg__step:hover .clx-rdg__dot{background:var(--blue-2);color:#fff;transform:scale(1.1)}
.clx-rdg__step--r:hover .clx-rdg__dot{background:var(--red)}
.clx-rdg__step h3{font-family:var(--font-display);font-size:1.02rem;font-weight:700;color:var(--blue-2);line-height:1.3}
.clx-rdg__step p{color:var(--muted);font-size:.88rem;line-height:1.5;max-width:200px}
@media (prefers-reduced-motion:reduce){.clx-rdg__step{opacity:1;translate:0 0;transition:none}}

/* ---------- HOẠT ĐỘNG (band navy) ---------- */
/* BAND ĐỎ THẬT có kiểm soát (60-30-10): nền đỏ đậm, chữ trắng contrast đạt */
.clx-act{background:radial-gradient(135% 110% at 50% -12%,#F0250F 0%,#D81607 42%,#A81006 100%);padding:clamp(56px,7vw,98px) 0;color:#fff}
/* quầng sáng spotlight sau thẻ giữa - làm nền đỏ bớt phẳng/choé, tạo chiều sâu */
.clx-act--cards::before{content:"";position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);
  width:min(700px,82%);height:560px;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse at center,rgba(255,255,255,.16),rgba(255,255,255,0) 66%)}
.clx-act .clx-head h2{color:#fff}
.clx-act .clx-head .kk{color:rgba(255,255,255,.82)}
.clx-act .clx-head p{color:rgba(255,255,255,.9)}
.clx-act .clx-gal--scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.55)}
.clx-act .clx-gal--scroll::-webkit-scrollbar-track{background:rgba(255,255,255,.15)}
.clx-gal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.clx-gal figure{margin:0;border-radius:14px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 12px 26px rgba(0,0,0,.22)}
.clx-gal img{width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}
.clx-gal figure:hover img{transform:scale(1.06)}
/* hoạt động: ảnh nhỏ lướt ngang (theo feedback khách) */
.clx-gal--scroll{display:flex;grid-template-columns:none;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;padding:4px 2px 16px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.5) transparent}
.clx-gal--scroll figure{flex:0 0 clamp(220px,24vw,300px);scroll-snap-align:start;aspect-ratio:4/3}
.clx-gal--scroll::-webkit-scrollbar{height:8px}
.clx-gal--scroll::-webkit-scrollbar-thumb{background:rgba(238,32,15,.4);border-radius:8px}
.clx-gal--scroll::-webkit-scrollbar-track{background:rgba(238,32,15,.1);border-radius:8px}

/* ---------- HOẠT ĐỘNG: thẻ ảnh + nhãn, thẻ giữa nổi (mockup band đỏ) ---------- */
.clx-act--cards{position:relative;overflow:hidden}
.clx-act--cards .wrap{position:relative;z-index:1}
.clx-deco--act .dco-dots--w{color:#fff;background-image:radial-gradient(rgba(255,255,255,.92) 2.3px,transparent 2.6px);background-size:18px 18px}
.clx-deco--act .dco-dots--w{top:46px;left:46px;width:168px;height:118px;opacity:.5}
.clx-deco--act .dco-dots--w.is-br{top:auto;left:auto;bottom:118px;right:50px;width:150px;height:104px;opacity:.42}
.clx-act--cards .clx-head .kk{display:inline-flex;align-items:center;gap:12px;color:rgba(255,255,255,.9)}
.clx-act--cards .clx-head .kk::before,.clx-act--cards .clx-head .kk::after{content:"";width:30px;height:2px;border-radius:2px;background:rgba(255,255,255,.7)}
.clx-acts{overflow:hidden;margin-top:24px;padding:12px 0}
.clx-acts__track{position:relative;display:flex;gap:20px;transition:transform .55s var(--ease);will-change:transform}
.clx-acts__card{cursor:pointer}
/* khung vừa phải để tổng band cỡ taiwan; thẻ giữa scale lên cho nổi */
.clx-acts__card{position:relative;flex:0 0 clamp(228px,20vw,268px);margin:0;border-radius:18px;overflow:hidden;aspect-ratio:3/4;
  box-shadow:0 16px 38px rgba(90,4,0,.3);opacity:.5;transform:scale(.9);
  transition:transform .5s var(--ease),opacity .5s var(--ease),box-shadow .5s var(--ease)}
.clx-acts__card img{width:100%;height:100%;object-fit:cover;display:block}
.clx-acts__card.is-active{opacity:1;transform:scale(1.07);box-shadow:0 28px 58px rgba(40,1,0,.48);border:4px solid #fff}
.clx-acts__card figcaption{position:absolute;left:10px;right:10px;bottom:10px;display:flex;align-items:center;gap:9px;
  background:#fff;border-radius:40px;padding:7px 13px;box-shadow:0 8px 18px rgba(0,0,0,.2)}
.clx-acts__ic{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--red);color:#fff;flex:0 0 auto}
.clx-acts__ic svg{width:16px;height:16px;stroke-width:2}
.clx-acts__card figcaption b{color:var(--blue-2);font-family:var(--font-display);font-size:.82rem;font-weight:700;line-height:1.2}
.clx-acts__dots{display:flex;justify-content:center;gap:9px;margin-top:34px}
.clx-acts__dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45);transition:.3s var(--ease);cursor:pointer}
.clx-acts__dots span.on{width:30px;border-radius:6px;background:#fff}
.clx-acts__cta{text-align:center;margin-top:26px}
/* nút mũi tên 2 đầu */
.clx-acts__wrap{position:relative}
.clx-acts__arw{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:46px;height:46px;border:0;border-radius:50%;
  background:#fff;color:var(--red);display:grid;place-items:center;cursor:pointer;box-shadow:0 8px 22px rgba(60,2,0,.3);transition:.2s var(--ease)}
.clx-acts__arw:hover{background:var(--red);color:#fff}
.clx-acts__arw svg{width:22px;height:22px}
.clx-acts__arw--prev{left:-6px}
.clx-acts__arw--next{right:-6px}
.clx-acts__arw[hidden]{display:none}

/* ---------- CẢM NGHĨ (slider kiểu sharingtaiwan: ảnh trái + thẻ màu overlap phải) ---------- */
.clx-tw{position:relative;max-width:1180px;margin:0 auto}
/* nền trang trí: quầng đỏ ấm sau thẻ + mảng chấm navy sau ảnh + khung kể chuyện hành trình */
.clx-tw::before{content:"";position:absolute;z-index:0;right:-30px;top:6%;width:58%;height:88%;
  background:radial-gradient(60% 58% at 72% 42%,rgba(238,32,15,.16),rgba(238,32,15,0) 70%);filter:blur(6px);pointer-events:none}
.clx-tw::after{content:"";position:absolute;z-index:0;left:-46px;top:-30px;width:200px;height:130px;
  background:url(../images/worldmap-dots.svg) left top/contain no-repeat;opacity:.16;pointer-events:none}
/* sân khấu lật trang (giở lưu bút) */
.clx-tw__viewport{overflow:hidden;position:relative;z-index:1;perspective:2200px;transition:height .5s var(--ease)}
.clx-tw__track{position:relative}
.clx-tw__slide{position:absolute;top:0;left:0;width:100%;
  display:grid;grid-template-columns:1.02fr .98fr;align-items:center;padding:18px 6px;
  transform-origin:left center;transform-style:preserve-3d;backface-visibility:hidden;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:transform .78s var(--ease),opacity .5s var(--ease)}
/* bóng gáy trang khi lật */
.clx-tw__slide::after{content:"";position:absolute;inset:8px;border-radius:18px;pointer-events:none;z-index:4;
  background:linear-gradient(95deg,rgba(8,20,48,0) 58%,rgba(8,20,48,.30) 100%);opacity:0;transition:opacity .5s var(--ease)}
.clx-tw__slide.is-active{opacity:1;visibility:visible;pointer-events:auto;z-index:2;transform:rotateY(0deg)}
.clx-tw__slide.is-under{z-index:1;opacity:1;visibility:visible;transform:rotateY(0deg)}
.clx-tw__slide.flip-out{z-index:3;transform:rotateY(-156deg);opacity:0}
.clx-tw__slide.flip-out::after{opacity:1}
.clx-tw__slide.flip-start{z-index:3;opacity:1;visibility:visible;transform:rotateY(-156deg)}
.clx-tw__slide.flip-start::after{opacity:1}
.clx-tw__slide.flip-in{z-index:3;transform:rotateY(0deg);opacity:1}
@media (prefers-reduced-motion:reduce){.clx-tw__slide{transition:opacity .25s}.clx-tw__slide,.clx-tw__slide.flip-out,.clx-tw__slide.flip-start,.clx-tw__slide.flip-in{transform:none}}
.clx-tw__img{position:relative;margin:0}
.clx-tw__img img{width:100%;aspect-ratio:4/3.4;max-height:520px;object-fit:cover;object-position:center 32%;border-radius:18px;box-shadow:0 18px 44px rgba(20,44,107,.18);background:#fff}
/* huy hiệu dấu nháy trắng góc trên-trái ảnh */
.clx-tw__qbadge{position:absolute;top:-20px;left:-14px;z-index:3;width:60px;height:60px;border-radius:50%;background:#fff;
  color:var(--red);display:grid;place-items:center;font-family:Georgia,serif;font-size:3rem;line-height:0;padding-top:18px;
  box-shadow:0 12px 26px rgba(20,44,107,.18)}
/* thẻ ĐỎ */
.clx-tw__card{position:relative;z-index:2;margin-left:-70px;color:#fff;border-radius:22px;padding:34px 40px;
  background:radial-gradient(130% 130% at 82% 0%,#F0250F,var(--red) 46%,#C0150A 100%);box-shadow:0 26px 56px rgba(120,8,2,.34)}
.clx-tw__who{display:flex;align-items:center;gap:15px;padding-bottom:18px;margin-bottom:18px;border-bottom:1px solid rgba(255,255,255,.28)}
.clx-tw__avatar{flex:0 0 auto;width:56px;height:56px;border-radius:50%;background:#fff;color:var(--red);display:grid;place-items:center}
.clx-tw__avatar svg{width:28px;height:28px}
.clx-tw__name{display:block;font-family:var(--font-display);font-weight:800;font-size:1.32rem;line-height:1.2}
.clx-tw__course{display:block;color:rgba(255,255,255,.85);font-size:.92rem;margin-top:3px}
.clx-tw__quote{position:relative;margin:0;padding-left:34px;font-size:1.05rem;line-height:1.75;color:#fff}
.clx-tw__quote::before{content:"\201C";position:absolute;left:-2px;top:-10px;font-family:Georgia,serif;font-size:3.2rem;line-height:1;color:rgba(255,255,255,.55)}
.clx-tw__arw{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:48px;height:48px;border:0;border-radius:50%;background:#fff;color:var(--red);
  display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 24px rgba(20,44,107,.16);transition:.2s var(--ease)}
.clx-tw__arw:hover{background:var(--red);color:#fff}
.clx-tw__arw svg{width:22px;height:22px}
.clx-tw__arw--prev{left:-16px}
.clx-tw__arw--next{right:-16px}
.clx-tw__arw:hover{transform:translateY(-50%) scale(1.08)}
.clx-tw__dots{display:flex;justify-content:center;gap:8px;margin-top:26px}
.clx-tw__dots button{width:9px;height:9px;border-radius:50%;border:0;padding:0;background:var(--line);cursor:pointer;transition:.3s var(--ease)}
.clx-tw__dots button.on{width:30px;border-radius:6px;background:var(--red)}

/* ---------- ĐỐI TÁC ---------- */
.clx-pt{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:960px;margin:0 auto}
.clx-pt div{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 28px;text-align:center}
.clx-pt b{display:block;font-family:var(--font-display);color:var(--red);font-size:1.15rem;margin-bottom:8px}
.clx-pt span{color:var(--muted);line-height:1.7}

/* ---------- TIN TỨC (1 bài lớn + 4 nhỏ, thumb phủ đỏ - taiwan) ---------- */
.clx-news2{display:grid;grid-template-columns:1.05fr 1fr;gap:24px;align-items:stretch}
.clx-news2__side{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.clx-news2__feat,.clx-news2__item{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:16px;overflow:hidden;box-shadow:0 12px 28px rgba(20,44,107,.07);transition:.25s var(--ease)}
.clx-news2__feat:hover,.clx-news2__item:hover{transform:translateY(-5px);box-shadow:0 22px 46px rgba(20,44,107,.14)}
.clx-news2__m{position:relative;display:block;overflow:hidden}
.clx-news2__feat>.clx-news2__m{aspect-ratio:16/9}
.clx-news2__item>.clx-news2__m{aspect-ratio:16/9}
.clx-news2__m img{width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}
.clx-news2__feat:hover .clx-news2__m img,.clx-news2__item:hover .clx-news2__m img{transform:scale(1.05)}
/* phủ đỏ thương hiệu lên thumbnail */
.clx-news2__m::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(155deg,rgba(238,32,15,.34),rgba(168,16,6,.5));mix-blend-mode:multiply}
/* thumb đã là banner thiết kế sẵn -> bỏ lớp phủ đỏ, giữ ảnh nguyên bản */
.clx-news2--tpl .clx-news2__m::after{display:none}
.clx-news2__b{padding:18px 22px 22px;display:flex;flex-direction:column;gap:7px;flex:1}
.clx-news2__item .clx-news2__b{padding:14px 16px 18px}
.clx-news2__feat h3{font-size:1.25rem;line-height:1.3;color:var(--blue-dk);margin:0}
.clx-news2__item h4{font-size:1rem;line-height:1.35;color:var(--blue-dk);margin:0;font-weight:700}
.clx-news2__feat h3 a:hover,.clx-news2__item h4 a:hover{color:var(--red)}
.clx-news2__feat p{color:var(--muted);font-size:.96rem;line-height:1.6;margin:0}
.clx-news2 .clx-post__d{font-size:.82rem;color:var(--red);font-weight:700;font-family:var(--font-display)}

/* ---------- TIN TỨC (cũ) ---------- */
.clx-news{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.clx-post{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 10px 24px rgba(20,44,107,.05);transition:.25s var(--ease)}
.clx-post:hover{transform:translateY(-5px);border-color:var(--blue);box-shadow:0 20px 42px rgba(20,44,107,.12)}
.clx-post__m{aspect-ratio:16/10;overflow:hidden;display:block}
.clx-post__m img{width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}
.clx-post:hover .clx-post__m img{transform:scale(1.05)}
.clx-post__b{padding:18px 22px 22px}
.clx-post__d{font-size:.82rem;color:var(--red);font-weight:700}
.clx-post h3{font-size:1.1rem;margin:7px 0 8px;color:var(--blue-dk)}
.clx-post h3 a:hover{color:var(--blue)}
.clx-post p{color:var(--muted);font-size:.93rem}

/* ---------- Page-hero trang con: dải breadcrumb gọn kiểu taiwan ---------- */
.page-hero--center{text-align:center;padding:clamp(46px,5.5vw,76px) 0}
.page-hero--center h1{font-size:clamp(2rem,4vw,3rem);font-weight:800}

/* ---------- RESPONSIVE (taiwan) ---------- */
@media (max-width:1040px){
  .clx-svc,.clx-news{grid-template-columns:1fr 1fr}
}
@media (max-width:1099px){
  /* Mobile/tablet (≤1099): chuyển hamburger - vì menu 8 mục + font Barlow chỉ vừa 1 dòng khi ≥1100 (rule menu 1 dòng) */
  /* Mobile: ghim thanh top (logo + nút menu); cuộn xuống tự ẩn, cuộn lên hiện lại */
  .twn-head{position:sticky;top:0;z-index:600;transition:transform .3s var(--ease)}
  .twn-head--hidden{transform:translateY(-100%)}
  .twn-top{box-shadow:0 4px 16px rgba(20,44,107,.08)}
  .twn-toggle{display:flex;margin-left:auto;order:5}
  /* Mobile: chỉ logo + chữ thương hiệu + menu (bỏ hotline/email/social trên cùng - theo feedback khách) */
  .twn-top__phone,.twn-socials,.twn-search,.twn-top .twn-btn,.twn-actions{display:none}
  .twn-brand{max-width:46vw;padding-left:12px}
  .twn-brand__sub{font-size:.6rem}
  .twn-brand__name{font-size:.88rem}
  .twn-navwrap{padding:0}
  .twn-nav{position:fixed;inset:0 0 auto 0;top:81px;border-radius:0;background:#fff;border:0;border-bottom:1px solid var(--line);
    padding:12px 6%;transform:translateY(-130%);transition:.32s var(--ease);box-shadow:0 18px 40px rgba(20,44,107,.14);
    max-height:calc(100vh - 81px);overflow-y:auto}
  .twn-nav.open{transform:translateY(0)}
  .twn-nav ul{flex-direction:column;align-items:stretch;gap:2px}
  .twn-nav a{padding:13px 16px;border-radius:9px}
  .twn-nav .menu-item-has-children>a::after{display:none}
  .twn-nav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;background:transparent;
    border:0;border-left:2px solid var(--line);border-radius:0;margin:0 0 4px 16px;padding:0}
  .twn-nav .sub-menu a{color:var(--muted)}
  .twn-nav .sub-menu a:hover{background:var(--red-soft);color:var(--red)}
  /* mobile: thứ tự TIÊU ĐỀ -> TEXT -> ẢNH -> NÚT (dưới cùng) */
  .clx-about__grid{display:flex;flex-direction:column;gap:18px;text-align:left}
  .clx-about__mtitle{display:block;order:0;font-family:var(--font-display);font-weight:700;font-size:1.7rem;
    line-height:1.2;color:var(--blue-2);letter-spacing:-.01em}
  .clx-about__mtitle .u{color:var(--red)}
  .clx-about__body{order:1}
  .clx-about__media{order:2;max-width:none;margin:0}
  .clx-about__grid>.clx-about__btn--m{display:inline-flex;order:3;align-self:center;margin-top:4px}
  .clx-about__btn--d{display:none}
  .clx-about__body h2{display:none}
  .clx-about__media img{aspect-ratio:6/5}
  .clx-about__media::before,.clx-about__media::after{display:none}
  .clx-about__body p{font-size:1rem;line-height:1.75;margin-top:0}
  .clx-adv{grid-template-columns:1fr;gap:30px}
  .clx-adv__media{aspect-ratio:4/3}
  .clx-adv__media img{object-position:50% 28%}
  /* mobile: 3 card 1 hàng, GIỮ VUÔNG (bỏ min-height desktop) */
  .clx-svc2__cards{grid-template-columns:repeat(3,1fr);gap:10px;width:100%;margin-bottom:-30px}
  .clx-svc2__card{border-radius:14px;min-height:0}
  .clx-svc2__card::before{height:54%}
  .clx-svc2__card::after{height:54%}
  .clx-svc2__ic{width:50px;height:50px;margin:16px auto 0}
  .clx-svc2__ic svg{width:23px;height:23px}
  .clx-svc2__body{padding:12px 5px 14px}
  .clx-svc2__card b{font-size:.78rem;line-height:1.25}
  .clx-svc2__desc,.clx-svc2__more{display:none}
  .clx-svc2__photo{aspect-ratio:4/5}
  .clx-svc2__photo--team{aspect-ratio:auto;width:min(94%,420px);padding:7px 7px 0}
  .clx-svc2__cap{font-size:.82rem;padding:10px 6px}
  .clx-road{grid-template-columns:1fr 1fr;gap:32px 18px;padding-top:0}.clx-road__line{display:none}
  .clx-road__ic{margin-top:0}
  /* roadmap mobile: mỗi bước = thẻ trắng bo góc, viền trái màu, icon vòng tròn tint + số badge,
     KHÔNG đường nối (đỡ rối). Bước --r = tô đỏ nhạt. */
  .clx-rdg{height:auto;max-width:560px;display:flex;flex-direction:column;gap:14px;padding-left:0;margin:0 auto}
  .clx-rdg__path{display:none}
  .clx-rdg__step{position:relative!important;left:auto!important;top:auto!important;width:100%;transform:none;display:grid;
    grid-template-columns:66px 1fr;column-gap:16px;align-items:center;text-align:left;
    background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue-2);border-radius:16px;
    box-shadow:0 8px 22px rgba(20,44,107,.06);padding:16px 20px 16px 14px}
  .clx-rdg__step--r{border-left-color:var(--red);background:#FFF6F5}
  .clx-rdg__step::before,.clx-rdg__step::after{display:none!important}
  /* icon trong vòng tròn ĐẶC màu thương hiệu + icon trắng (sạch, rõ - bỏ blob/tint mờ) */
  .clx-rdg__dot{grid-column:1;grid-row:1/3;justify-self:center;align-self:center;width:58px;height:58px;
    border:0;background:var(--blue-2);color:#fff;box-shadow:0 8px 18px rgba(20,44,107,.18)}
  .clx-rdg__step--r .clx-rdg__dot{background:var(--red);color:#fff;box-shadow:0 8px 18px rgba(238,32,15,.18)}
  .clx-rdg__dot svg{width:27px;height:27px}
  /* số badge: vòng TRẮNG + số màu thương hiệu, nổi rõ trên dot đặc */
  .clx-rdg__dot b{top:50%;right:-9px;transform:translateY(-50%);width:25px;height:25px;font-size:.8rem;
    background:#fff;color:var(--blue-2);border:2px solid var(--blue-2)}
  .clx-rdg__step--r .clx-rdg__dot b{background:#fff;color:var(--red);border-color:var(--red)}
  .clx-rdg__step h3{grid-column:2;grid-row:1;font-size:1.06rem;align-self:end;padding:0}
  .clx-rdg__step p{grid-column:2;grid-row:2;font-size:.92rem;line-height:1.5;max-width:none;text-align:left;padding:0;margin-top:3px}
  .clx-gal{grid-template-columns:repeat(2,1fr)}
  /* cảm nghĩ slider: ảnh trên, thẻ dưới (không overlap ngang), mũi tên ở cạnh ảnh */
  .clx-tw::before,.clx-tw::after{display:none} /* blob trang trí thò ra mép -> ẩn ở mobile cho khỏi tràn ngang */
  .clx-tw__slide{grid-template-columns:1fr;padding:6px 4px}
  .clx-tw__img img{aspect-ratio:4/5;max-height:none;object-position:center 14%}
  .clx-tw__card{margin:-28px 14px 0;padding:24px 22px}
  .clx-tw__arw{top:30%;bottom:auto}
  .clx-tw__arw--prev{left:4px}
  .clx-tw__arw--next{left:auto;right:4px}
  /* hoạt động: carousel center - thẻ nhỏ lại để 2 bên ló nhẹ */
  .clx-acts__track{gap:14px}
  .clx-acts__card{flex:0 0 80vw}
  .clx-acts__card.is-active{transform:scale(1.04)}
  .clx-acts__arw{width:40px;height:40px}
  .clx-acts__arw--prev{left:2px}
  .clx-acts__arw--next{right:2px}
  .clx-news2{grid-template-columns:1fr}
  .clx-pt{grid-template-columns:1fr}
}
@media (max-width:780px){
  .clx-hero__grid{grid-template-columns:1fr;text-align:center;min-height:0;gap:0}
  .clx-hero__person{order:2;max-width:280px;margin:24px auto 0}
  .clx-hero__box{margin-inline:auto}
  .clx-hero__plane{display:none}
}
@media (max-width:560px){
  .clx-svc,.clx-news{grid-template-columns:1fr}
  .clx-news2__side{grid-template-columns:1fr}
  .clx-gal{grid-template-columns:1fr 1fr}
  .twn-top__phone small{display:none}
}

/* =========================================================
   TRANG GIỚI THIỆU (clone bố cục sharingtaiwan · màu trang chủ)
   ========================================================= */
/* INTRO: text trái + ảnh phải (đúng sharingtaiwan) */
.gt-split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(28px,4vw,60px)}
.gt-split__media{position:relative;margin:0}
.gt-split__media img{width:100%;aspect-ratio:5/4;object-fit:cover;object-position:50% 32%;border-radius:18px;
  box-shadow:0 18px 44px rgba(20,44,107,.16);display:block;position:relative;z-index:1}
/* nền màu thương hiệu sau ảnh (khối navy bo góc lệch) */
.gt-split__media::before{content:"";position:absolute;z-index:0;left:-16px;top:-16px;width:62%;height:70%;border-radius:20px;
  background:var(--blue-2);opacity:.14}
.gt-split__media::after{content:"";position:absolute;right:-14px;bottom:-14px;width:92px;height:92px;border-radius:16px;z-index:0;
  background:repeating-linear-gradient(45deg,rgba(238,32,15,.18) 0 7px,transparent 7px 14px)}
.gt-split__kk{display:inline-block;font-family:var(--font-display);font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--red);font-size:.8rem;margin-bottom:12px}
.gt-split__body h2{font-size:clamp(1.9rem,2.8vw,2.4rem);color:var(--blue-2);line-height:1.2;font-weight:700}
.gt-split__body p{color:var(--muted);margin-top:14px;font-size:1.05rem;line-height:1.85;text-wrap:pretty}
.gt-mini{display:flex;flex-wrap:wrap;gap:clamp(22px,4vw,48px);margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.gt-mini__i b{display:block;font-family:var(--font-display);font-weight:900;font-size:clamp(1.8rem,3vw,2.3rem);
  color:var(--red);line-height:1;letter-spacing:-.02em}
.gt-mini__i span{display:block;margin-top:5px;color:var(--muted);font-size:.9rem;font-weight:600}

/* SỨ MỆNH & TẦM NHÌN: 2 cột, mỗi cột = ẢNH (trên nền màu thương hiệu) + chữ */
.gt-mv2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4vw,56px);align-items:start}
.gt-mv2__col{display:flex;flex-direction:column;gap:20px}
.gt-mv2__col--r .gt-mv2__photo{order:2}   /* Sứ mệnh: chữ trên, ảnh dưới */
.gt-mv2__photo{position:relative;margin:0;border-radius:18px;aspect-ratio:16/11}
.gt-mv2__photo img{width:100%;height:100%;object-fit:cover;object-position:50% 38%;border-radius:18px;display:block;
  position:relative;z-index:1;box-shadow:0 18px 44px rgba(20,44,107,.16)}
/* khối nền màu thương hiệu lệch sau ảnh */
.gt-mv2__photo::before{content:"";position:absolute;z-index:0;width:66%;height:74%;border-radius:20px}
.gt-mv2__col:nth-child(1) .gt-mv2__photo::before{right:-16px;bottom:-16px;background:var(--red);opacity:.16}
.gt-mv2__col:nth-child(2) .gt-mv2__photo::before{left:-16px;top:-16px;background:var(--blue-2);opacity:.16}
.gt-mv2__txt h3{font-size:clamp(1.4rem,2vw,1.7rem);color:var(--blue-2);margin-bottom:10px}
.gt-mv2__txt p{color:var(--muted);font-size:1.02rem;line-height:1.85;text-wrap:pretty}

/* GIÁ TRỊ CỐT LÕI - 3 card (tái dùng .clx-card) */
.gt-values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:clamp(34px,4vw,56px)}

@media (max-width:860px){
  .gt-split{grid-template-columns:1fr;gap:22px}
  .gt-split__media img{aspect-ratio:16/10}
  .gt-mv2{grid-template-columns:1fr;gap:34px}
  .gt-mv2__col--r .gt-mv2__photo{order:0}
}
@media (max-width:780px){
  .gt-values{grid-template-columns:1fr}
}

/* ============ TRANG GIỚI THIỆU - dựng theo sharingtaiwan (recolor đỏ/navy) ============ */
.clx-head--left{text-align:left;margin-left:0;margin-right:0;max-width:820px}
/* A. Intro: text trái + ảnh nhỏ phải */
.gtw-intro__body{display:grid;grid-template-columns:1.55fr .95fr;gap:clamp(26px,4vw,58px);align-items:start;margin-top:6px}
.gtw-intro__text p{color:var(--muted);font-size:1.05rem;line-height:1.78}
.gtw-intro__text p+p{margin-top:16px}
.gtw-intro__fig{position:relative;margin:0}
.gtw-intro__fig img{width:100%;border-radius:16px;display:block;box-shadow:0 14px 34px rgba(21,41,78,.14)}
.gtw-intro__fig figcaption{position:absolute;left:14px;bottom:14px;background:var(--red);color:#fff;font-weight:600;font-size:.85rem;padding:6px 14px;border-radius:8px}
.gtw-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:18px 22px;margin-top:24px}
.gtw-mini__i b{display:block;font-family:var(--font-display);font-size:1.9rem;font-weight:800;color:var(--red);line-height:1}
/* pop nhẹ khi số đếm xong - cho "sinh động" (K24/K33) */
[data-count].is-counted{animation:popcount .5s var(--ease)}
@keyframes popcount{0%{transform:scale(1)}40%{transform:scale(1.14)}100%{transform:scale(1)}}
.gtw-mini__i b[data-count]{display:inline-block}
.gtw-mini__i span{display:block;color:var(--muted);font-size:.92rem;margin-top:4px;line-height:1.35}
@media(max-width:520px){.gtw-mini{gap:12px 10px}.gtw-mini__i b{font-size:1.4rem}.gtw-mini__i span{font-size:.76rem}}
/* Dải ảnh lớp học lướt ngang (K30) - scroll-snap, không cần JS */
.imgrail{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 2px 14px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.imgrail figure{flex:0 0 clamp(220px,30vw,330px);scroll-snap-align:start;margin:0;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:0 10px 26px rgba(20,44,107,.1);background:#fff}
.imgrail img{display:block;width:100%;height:clamp(150px,20vw,215px);object-fit:cover}
.imgrail figcaption{padding:9px 13px;font-size:.84rem;color:var(--muted);font-family:var(--font-display);font-weight:600}
.imgrail::-webkit-scrollbar{height:8px}
.imgrail::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
/* mũi tên điều hướng dải ảnh (desktop); mobile dùng vuốt */
.imgrail-wrap{position:relative}
.imgrail-arw{position:absolute;top:calc(50% - 8px);transform:translateY(-50%);z-index:4;width:46px;height:46px;border:0;border-radius:50%;
  background:#fff;color:var(--red);display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 24px rgba(20,44,107,.18);transition:.2s var(--ease)}
.imgrail-arw:hover{background:var(--red);color:#fff;transform:translateY(-50%) scale(1.08)}
.imgrail-arw svg{width:22px;height:22px}
.imgrail-arw--prev{left:-14px}
.imgrail-arw--next{right:-14px}
.imgrail-arw[disabled]{opacity:.35;pointer-events:none}
@media (max-width:768px){.imgrail-arw{display:none}}
/* B. Tầm nhìn / Sứ mệnh so le */
.gtw-mv{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,3.5vw,52px);align-items:start}
.gtw-mv__col{position:relative;display:flex;flex-direction:column}
.gtw-mv figure{position:relative;margin:24px 0 16px;height:clamp(240px,26vw,340px)}
.gtw-mv figure img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;display:block;border-radius:16px;box-shadow:0 16px 36px rgba(21,41,78,.16)}
.gtw-mv figure::after{content:"";position:absolute;right:-16px;bottom:-16px;width:74%;height:74%;border-radius:16px;background:var(--red-soft);z-index:0}
.gtw-mv__col:nth-child(2) figure::after{background:rgba(21,61,139,.10)}
.gtw-mv__col:nth-child(2) figure img{object-position:center 26%}
.gtw-mv h3{font-size:clamp(1.3rem,2vw,1.55rem);color:var(--blue-2);margin-bottom:10px}
.gtw-mv p{color:var(--muted);line-height:1.78}
/* C/E. Cột icon */
.gtw-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,42px);text-align:center}
.gtw-cols--4{grid-template-columns:repeat(4,1fr)}
/* Giá trị cốt lõi: thẻ trắng, đều chiều cao, cân đối */
.gtw-cols--cards{align-items:stretch}
.gtw-cols--cards .gtw-col{display:flex;flex-direction:column;align-items:center;background:#fff;border:1px solid var(--line);
  border-radius:18px;padding:clamp(30px,3.2vw,40px) clamp(22px,2.4vw,30px);box-shadow:0 12px 30px rgba(21,41,78,.07);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.gtw-cols--cards .gtw-col:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(21,41,78,.12)}
.gtw-col--svc{text-decoration:none;color:inherit}
.gtw-col__more{margin-top:auto;display:inline-flex;align-items:center;gap:6px;color:var(--red);font-weight:700;font-size:.93rem;padding-top:10px;transition:gap .2s var(--ease)}
.gtw-col--svc:hover .gtw-col__more{gap:11px}
.lh-hours{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 24px;margin-top:20px}
.lh-hours span{display:inline-flex;align-items:center;gap:9px;background:rgba(21,61,139,.06);color:var(--ink);font-size:1rem;padding:11px 22px;border-radius:40px}
.lh-hours span svg{color:var(--red);flex-shrink:0}
.lh-hours b{color:var(--blue-2)}
/* icon PHẲNG sạch: nền tint đặc, viền mảnh, KHÔNG gradient/đổ bóng glow */
.gtw-col__ic{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;margin:0 auto 20px;
  background:var(--red-soft);color:var(--red);border:1.5px solid rgba(238,32,15,.20)}
.gtw-cols--4 .gtw-col:nth-child(even) .gtw-col__ic{background:rgba(21,61,139,.07);color:var(--blue-2);border-color:rgba(21,61,139,.20)}
.gtw-col__ic svg{width:36px;height:36px}
/* cột (ưu điểm 4) flex để nút Xem thêm canh đáy -> cân hàng */
.gtw-cols--4 .gtw-col{display:flex;flex-direction:column;align-items:center}
.gtw-cols--4 .gtw-col .btn{margin-top:auto}
.gtw-col h3{font-size:1.16rem;color:var(--blue-2);margin-bottom:8px}
.gtw-col p{color:var(--muted);font-size:.97rem;line-height:1.7}
.gtw-col .btn{margin-top:16px}
.btn-outline{border:1.5px solid var(--red);color:var(--red);background:#fff;border-radius:46px;padding:10px 26px}
.btn-outline:hover{background:var(--blue-2);color:#fff;border-color:var(--blue-2)}
/* D. Ban lãnh đạo */
.gtw-leaders{background:#F2F4F7}
.gtw-team{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(22px,3vw,34px);max-width:940px}
.gtw-mem{background:#fff;border-radius:18px;padding:clamp(26px,3vw,36px) clamp(24px,2.6vw,32px);box-shadow:0 12px 30px rgba(21,41,78,.08);text-align:center}
.gtw-mem__ph{width:160px;height:160px;border-radius:50%;overflow:hidden;margin:0 auto 18px;border:4px solid var(--red-soft)}
.gtw-mem__ph img{width:100%;height:100%;object-fit:cover}
.gtw-mem h3{font-size:1.3rem;color:var(--blue-2)}
.gtw-mem__role{display:block;color:var(--red);font-style:italic;margin:4px 0 16px;font-size:.95rem}
.gtw-mem ul{list-style:none;padding:0;margin:0;text-align:left}
.gtw-mem li{position:relative;padding-left:20px;margin-bottom:10px;color:var(--muted);font-size:.95rem;line-height:1.6}
.gtw-mem li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:var(--red)}
.gtw-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.gtw-strip figure{margin:0;border-radius:14px;overflow:hidden;position:relative;box-shadow:0 10px 26px rgba(21,41,78,.1)}
.gtw-strip img{width:100%;height:230px;object-fit:cover;display:block}
.gtw-strip figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 16px 12px;color:#fff;font-weight:600;font-size:.95rem;background:linear-gradient(transparent,rgba(16,25,45,.82))}
/* mobile: strip nhiều ảnh -> chỉ giữ 1 ảnh cho gọn */
@media(max-width:640px){.gtw-strip{grid-template-columns:1fr}.gtw-strip figure:nth-child(n+2){display:none}}
.gtw-team-photo{position:relative;margin:0;border-radius:18px;overflow:hidden;box-shadow:0 16px 40px rgba(21,41,78,.16);max-width:1000px}
.gtw-team-photo img{width:100%;height:clamp(280px,40vw,520px);object-fit:cover;object-position:center 30%;display:block}
.gtw-team-photo figcaption{position:absolute;left:0;right:0;bottom:0;padding:40px 26px 20px;color:#fff;font-weight:600;font-size:1.05rem;background:linear-gradient(transparent,rgba(16,25,45,.78))}
/* D2. Con người ITC - text + bộ phận + ảnh */
.gtw-people{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center;margin-bottom:clamp(26px,3vw,40px)}
.gtw-people__txt p{color:var(--muted);line-height:1.78}
.gtw-people__txt p+p{margin-top:14px}
.gtw-people__dept{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.gtw-people__dept-i{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;
  transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.gtw-people__dept-ic{flex:0 0 auto;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:rgba(21,61,139,.08);color:var(--blue-2);border:1.5px solid rgba(21,61,139,.16);
  transition:background .22s var(--ease),color .22s var(--ease),transform .22s var(--ease)}
.gtw-people__dept-ic svg{width:26px;height:26px;display:block}
/* hover chỉ áp cho thiết bị có chuột - tránh kẹt trạng thái navy khi chạm trên mobile */
@media(hover:hover){
  .gtw-people__dept-i:hover{transform:translateY(-4px);border-color:var(--blue-2);box-shadow:0 12px 26px rgba(21,41,78,.13)}
  .gtw-people__dept-i:hover .gtw-people__dept-ic{background:var(--blue-2);color:#fff;transform:scale(1.06)}
}
.gtw-people__dept-i b{display:block;color:var(--blue-2);font-size:1rem;margin-bottom:3px}
.gtw-people__dept-i span{display:block;color:var(--muted);font-size:.9rem;line-height:1.5}
.gtw-people__fig{position:relative;margin:0;border-radius:18px;overflow:hidden;box-shadow:0 16px 40px rgba(21,41,78,.16)}
.gtw-people__fig img{width:100%;height:clamp(280px,32vw,440px);object-fit:cover;object-position:center 28%;display:block}
.gtw-people__fig figcaption{position:absolute;left:0;right:0;bottom:0;padding:36px 22px 16px;color:#fff;font-weight:600;font-size:1rem;background:linear-gradient(transparent,rgba(16,25,45,.8))}
/* G. Cơ sở vật chất - hàng ảnh + text xen kẽ */
.gtw-fac{display:grid;grid-template-columns:1fr 1fr;gap:clamp(22px,3vw,34px)}
.gtw-fac__card{background:#fff;border-radius:18px;padding:clamp(16px,1.6vw,22px);box-shadow:0 12px 30px rgba(21,41,78,.08)}
.gtw-fac__imgs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gtw-fac__imgs img{width:100%;height:clamp(180px,17vw,240px);object-fit:cover;border-radius:12px;display:block}
.gtw-fac__card h3{font-size:clamp(1.25rem,1.8vw,1.45rem);color:var(--blue-2);margin:20px 0 10px}
.gtw-fac__card p{color:var(--muted);line-height:1.78}
@media(max-width:860px){
  .gtw-intro__body,.gtw-mv,.gtw-people{grid-template-columns:1fr}
  .gtw-cols,.gtw-cols--4{grid-template-columns:1fr 1fr}
  /* 3 thẻ Giá trị cốt lõi: KHÔNG để 2+1 lệch -> xếp dọc 1 cột, canh giữa */
  .gtw-cols--cards{grid-template-columns:1fr;max-width:430px;margin-inline:auto}
  .gtw-fac{grid-template-columns:1fr}
  .gtw-people__fig{order:-1}
}
@media(max-width:520px){.gtw-cols,.gtw-cols--4,.gtw-people__dept{grid-template-columns:1fr}.gtw-fac__imgs img{height:170px}}

/* ===== Post list - Trường tuyển sinh ===== */
.plist{display:flex;flex-direction:column}
.plist__item{display:grid;grid-template-columns:240px 1fr;gap:20px 32px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;transition:background .18s var(--ease),padding .18s var(--ease)}
.plist__item:first-child{border-top:1px solid var(--line)}
@media(hover:hover){.plist__item:hover{background:rgba(21,61,139,.03);padding-left:10px;padding-right:10px;border-radius:12px;margin-left:-10px;margin-right:-10px}}
.plist__thumb{margin:0;border-radius:12px;overflow:hidden;aspect-ratio:16/9;background:#f0f3fa;flex-shrink:0}
.plist__thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease)}
@media(hover:hover){.plist__item:hover .plist__thumb img{transform:scale(1.04)}}
.plist__body{min-width:0}
.plist__body h3{font-size:1.18rem;font-weight:700;color:var(--blue-2);margin:0 0 8px;text-wrap:balance;line-height:1.35}
.plist__body p{margin:0 0 12px;color:var(--muted);font-size:.93rem;line-height:1.58;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.plist__more{display:inline-flex;align-items:center;gap:6px;color:var(--red);font-weight:700;font-size:.9rem;transition:gap .2s var(--ease)}
@media(hover:hover){.plist__item:hover .plist__more{gap:10px}}
@media(max-width:640px){
  .plist__item{grid-template-columns:1fr;gap:12px}
  .plist__thumb{aspect-ratio:16/9}
}

/* ===== Sitemap (HTML, page-sitemap.php) ===== */
.itc-sitemap{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(28px,4vw,56px);margin-top:30px;align-items:start}
.smap-col{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 28px;box-shadow:var(--shadow-low,0 1px 2px rgba(0,0,0,.06))}
.smap-h{display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:700;color:var(--blue-2);margin:0 0 14px}
.smap-h svg{flex:0 0 auto}
.smap-sub{font-size:1rem;font-weight:700;margin:18px 0 8px;color:var(--ink)}
.smap-sub a{color:var(--ink);text-decoration:none}
.smap-sub a:hover{color:var(--red)}
.smap-count{display:inline-block;font-size:.72rem;font-weight:700;color:#fff;background:var(--red);border-radius:20px;padding:1px 9px;margin-left:4px;vertical-align:middle}
.smap-list{list-style:none;margin:0;padding:0;display:grid;gap:7px}
.smap-list li{position:relative;padding-left:18px}
.smap-list li::before{content:"";position:absolute;left:2px;top:9px;width:6px;height:6px;border-radius:50%;background:var(--red)}
.smap-list a{color:var(--blue-2);text-decoration:none;font-weight:600;transition:color .18s cubic-bezier(.22,.61,.36,1)}
.smap-list a:hover{color:var(--red);text-decoration:underline}
.smap-list--sub{padding-left:6px;margin-bottom:6px}
.smap-list--sub li::before{background:var(--blue-2);opacity:.45;width:5px;height:5px;top:9px}
.smap-list--sub a{font-weight:500;color:var(--ink)}
@media(max-width:860px){.itc-sitemap{grid-template-columns:1fr}}

/* Form đăng ký - thông báo kết quả */
.register__msg{display:none;padding:10px 14px;border-radius:8px;font-size:.9rem;font-weight:600;margin-bottom:10px}
.register__msg:not(:empty){display:block}
.register__msg--ok{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.register__msg--err{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}
