@import url('https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700;800;900&display=swap'); :root{--blue:#004098;--blue2:#0758cc;--ink:#0f172a;--muted:#64748b;--line:#e5e7eb;--bg:#f6f8fc;--soft:#edf4ff;--green:#16a34a;--shadow:0 16px 45px rgba(15,23,42,.10);--max:1220px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:'Be Vietnam Pro','SVN-Gilroy','Segoe UI',Arial,Helvetica,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{text-decoration:none;color:inherit}.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(14px);border-bottom:1px solid #e7edf6;box-shadow:0 6px 20px rgba(15,23,42,.04)}
.nav{height:82px;display:flex;align-items:center;gap:18px;justify-content:space-between}.brand img{height:42px;width:auto;display:block}.links{display:flex;align-items:center;gap:2px}.links a{font-weight:850;color:#1e293b;font-size:14px;padding:29px 10px 27px;border-bottom:3px solid transparent}.links a:hover,.links a.active{color:var(--blue);border-bottom-color:var(--blue)}
.lang{border:1px solid #dbe3ef;background:#f8fafc;border-radius:999px;padding:5px;display:flex;gap:4px}.lang a{border-radius:999px;padding:8px 12px;font-weight:900;color:#475569}.lang a.active{background:var(--blue);color:white}.hamb{display:none;border:0;background:var(--soft);color:var(--blue);width:44px;height:44px;border-radius:14px;font-size:26px}
.hero{background:radial-gradient(circle at 80% 20%,#dbeafe 0,#f8fbff 34%,#eef4ff 70%,#fff 100%);border-bottom:1px solid var(--line);overflow:hidden}.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center;min-height:620px;padding:82px 0}.eyebrow{display:inline-flex;padding:7px 13px;border:1px solid #cfe1ff;border-radius:999px;background:#fff;color:var(--blue);font-size:13px;font-weight:900;margin-bottom:18px}h1{font-size:clamp(36px,5vw,66px);line-height:1.03;margin:0 0 20px;letter-spacing:-1.6px}.lead{font-size:18px;color:#475569;margin:0 0 26px;max-width:720px}.hero-card{background:#0b1220;color:white;border-radius:28px;padding:24px;box-shadow:var(--shadow)}.hero-card img{width:100%;border-radius:18px;background:white;padding:12px;margin-bottom:16px}.row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.13);padding:12px 0}.row:last-child{border-bottom:0}.row b{color:#93c5fd}
.btns{display:flex;flex-wrap:wrap;gap:12px}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:12px 18px;font-weight:900}.primary{background:var(--blue);color:white;box-shadow:0 12px 24px rgba(0,64,152,.22)}.ghost{background:white;color:var(--blue);border:1px solid var(--line)}section{padding:72px 0}.section-head{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:28px}.section-head h2{font-size:clamp(28px,4vw,44px);line-height:1.1;margin:0;letter-spacing:-1px}.section-head p{margin:0;color:var(--muted);max-width:650px}
.metrics{margin-top:-36px;position:relative;z-index:2}.metric-panel{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;background:#fff;border:1px solid #dbe7ff;border-radius:24px;padding:16px;box-shadow:0 18px 48px rgba(15,23,42,.10)}.metric{padding:16px;border-radius:18px;background:linear-gradient(180deg,#f8fbff,#fff);border:1px solid #e7eefb}.metric strong{display:block;color:var(--blue);font-size:24px;line-height:1;margin-bottom:6px}.metric span{display:block;font-weight:900}.metric small{display:block;color:var(--muted);font-weight:700}
.grid{display:grid;gap:18px}.services{grid-template-columns:repeat(3,1fr)}.card{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:0 12px 34px rgba(15,23,42,.06);padding:24px}.card:hover{box-shadow:var(--shadow);border-color:#c7dafe}.icon{font-size:30px;width:56px;height:56px;border-radius:18px;background:var(--soft);display:grid;place-items:center;margin-bottom:16px}.card h3{margin:0 0 8px;font-size:22px}.card p{margin:0;color:var(--muted)}.card-link{display:inline-flex;margin-top:16px;color:var(--blue);font-weight:900}
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.plan{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:0 12px 34px rgba(15,23,42,.06);overflow:hidden;display:flex;flex-direction:column}.plan-head{padding:22px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fbff)}.plan h3{margin:0}.price{font-size:42px;color:var(--blue);font-weight:950;letter-spacing:-1.2px;margin:8px 0 0}.period{color:var(--muted);font-weight:800}.plan ul{list-style:none;margin:0;padding:20px 22px}.plan li{position:relative;padding:7px 0 7px 24px;color:#334155}.plan li:before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:900}.plan .btn{margin:auto 22px 22px}
.band{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.pill-list{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0 0 24px;list-style:none}.pill-list li{background:var(--soft);color:var(--blue);font-weight:850;border-radius:999px;padding:8px 12px;font-size:13px}
.dc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.dc-card .badge{display:inline-flex;gap:8px;align-items:center;background:var(--soft);color:var(--blue);border-radius:999px;padding:7px 10px;font-weight:900;font-size:12px;margin-bottom:12px}.dc-card h3{font-size:22px;line-height:1.25;margin:0 0 8px}.dc-card ul{margin:12px 0 0;padding-left:18px;color:#334155}
.cta{background:linear-gradient(135deg,#003a8c,#0b65e5);border-radius:28px;padding:34px;color:white;display:grid;grid-template-columns:1.2fr auto;gap:20px;align-items:center;box-shadow:0 22px 54px rgba(0,64,152,.22)}.cta h2{margin:0 0 8px;font-size:34px}.cta p{margin:0;color:#dbeafe}.cta .ghost{background:transparent;color:white;border-color:rgba(255,255,255,.35)}
.contact{background:linear-gradient(135deg,var(--blue),#0b65e5);color:white}.contact .card{color:var(--ink)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:center}.contact h2{font-size:42px;line-height:1.1;margin:0 0 14px}.contact p{color:#dbeafe}
footer{background:#07111f;color:#cbd5e1;padding:42px 0}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:22px}footer h4{color:white;margin:0 0 12px}footer a{display:block;color:#cbd5e1;margin:7px 0}.copyright{border-top:1px solid rgba(255,255,255,.1);margin-top:26px;padding-top:20px;color:#94a3b8;font-size:14px}
@media(max-width:1080px){.links{position:absolute;left:22px;right:22px;top:82px;background:white;border:1px solid var(--line);border-radius:18px;display:none;flex-direction:column;align-items:stretch;padding:12px;box-shadow:var(--shadow)}.links.open{display:flex}.links a{padding:13px 12px;border-bottom:0;border-radius:12px}.hamb{display:block}.hero-grid,.contact-grid,.cta{grid-template-columns:1fr}.metric-panel{grid-template-columns:repeat(2,1fr)}.services,.plan-grid,.dc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.wrap{padding:0 16px}.brand img{height:34px;max-width:180px}.hero-grid{min-height:auto;padding:52px 0}.metric-panel,.services,.plan-grid,.dc-grid,.footer-grid{grid-template-columns:1fr}.section-head{display:block}.dc-card{padding:18px}.dc-card h3{font-size:22px}.cta{padding:24px;border-radius:22px}.cta h2{font-size:28px}section{padding:54px 0}} .clean-head{display:block;text-align:center;margin-bottom:32px}
.clean-head h2{text-transform:uppercase;letter-spacing:.04em;margin-left:auto;margin-right:auto}
.clean-head p{display:none}
.section-head.clean-head{align-items:center;justify-content:center}
@media(max-width:640px){.clean-head{text-align:center;margin-bottom:22px}.clean-head h2{font-size:30px}} /* ================= Hero polish v6 ================= */
.hero{background:linear-gradient(135deg,#f8fbff 0%,#eef5ff 48%,#ffffff 100%);border-bottom:1px solid #e5edf8}
.hero-grid{min-height:560px;padding:72px 0;grid-template-columns:1.02fr .98fr;gap:48px}
.eyebrow{font-size:12px;letter-spacing:.02em;background:#fff;border-color:#d8e8ff;color:#004098;box-shadow:0 8px 22px rgba(0,64,152,.06)}
h1{font-size:clamp(34px,4.25vw,56px);line-height:1.12;letter-spacing:-1.35px;font-weight:900;color:#0f172a;max-width:760px}
.lead{font-size:17px;line-height:1.85;color:#475569;max-width:680px}
.hero-card{background:#ffffff;color:#0f172a;border:1px solid #dbe7ff;border-radius:28px;padding:26px;box-shadow:0 24px 70px rgba(15,23,42,.10)}
.hero-card img{width:100%;max-width:420px;margin:0 auto 18px;display:block;border-radius:18px;background:#fff;padding:8px}
.hero-card .row{border-bottom:1px solid #e7eef8;color:#334155;font-weight:700}
.hero-card .row b{color:#004098;font-weight:900}
.hero-card:before{content:"Bảng giá nhanh";display:inline-flex;background:#edf4ff;color:#004098;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:900;margin-bottom:10px}
.btn{font-family:inherit}
.btn.primary{background:#004098}
.btn.ghost{background:#fff;border-color:#d7e2f3;color:#004098}
.topbar{font-family:'Be Vietnam Pro','Segoe UI',Arial,sans-serif}
.links a{font-weight:800}
.price{font-family:'Be Vietnam Pro','Segoe UI',Arial,sans-serif}
@media(max-width:1080px){ .hero-grid{grid-template-columns:1fr;min-height:auto;padding:54px 0} .hero-card{max-width:620px}
}
@media(max-width:640px){ h1{font-size:34px;line-height:1.15;letter-spacing:-.9px} .lead{font-size:15.5px;line-height:1.75} .hero-card{padding:18px;border-radius:22px} .hero-card img{max-width:280px}
} /* ================= Menu v7 - đủ URL dịch vụ ================= */
.links{gap:0;flex:1;justify-content:flex-end;min-width:0}
.links a{font-size:13px;padding-left:8px;padding-right:8px}
@media(max-width:1280px){ .links a{font-size:12px;padding-left:6px;padding-right:6px}
}
@media(max-width:1160px){ .links{position:absolute;left:22px;right:22px;top:82px;background:white;border:1px solid var(--line);border-radius:18px;display:none;flex-direction:column;align-items:stretch;padding:12px;box-shadow:var(--shadow)} .links.open{display:flex} .links a{padding:13px 12px;border-bottom:0;border-radius:12px;font-size:14px} .hamb{display:block}
} /* ================= v8: grouped menu + service layout polish ================= */
.links{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:1;min-width:0}
.links>a,.menu-trigger{font-family:inherit;font-size:14px;font-weight:850;color:#1e293b;padding:28px 10px 26px;border:0;border-bottom:3px solid transparent;background:transparent;cursor:pointer;line-height:1.15}
.links>a:hover,.links>a.active,.menu-group:hover>.menu-trigger,.menu-group:focus-within>.menu-trigger{color:var(--blue);border-bottom-color:var(--blue)}
.menu-group{position:relative}
.menu-trigger{display:inline-flex;align-items:center;gap:6px}
.menu-trigger:after{content:"▾";font-size:10px;color:#64748b;margin-top:2px}
.dropdown{display:none;position:absolute;top:100%;left:0;min-width:270px;background:#fff;border:1px solid #dbe7ff;border-radius:18px;box-shadow:0 22px 60px rgba(15,23,42,.16);padding:10px;z-index:100}
.menu-group:hover .dropdown,.menu-group:focus-within .dropdown{display:block}
.dropdown a{display:grid;gap:2px;padding:11px 12px;border-radius:13px;color:#1e293b;font-weight:850;white-space:nowrap}
.dropdown a:hover{background:#edf4ff;color:var(--blue)}
.dropdown small{font-size:12px;color:#64748b;font-weight:700;white-space:normal}
.plan-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch}
.plan{min-height:100%;border-radius:22px}
.plan-head{min-height:155px}
.plan ul{padding-bottom:14px}
.service-hero-card{background:#fff;color:#0f172a;border:1px solid #dbe7ff;border-radius:28px;padding:28px;box-shadow:0 24px 70px rgba(15,23,42,.10)}
.service-hero-card img{width:100%;max-width:360px;margin:0 auto 20px;display:block;border-radius:18px;background:#fff;padding:8px}
.service-hero-card h2{margin:0 0 10px;font-size:26px;line-height:1.18;color:#0f172a}
.service-hero-card p{margin:0 0 18px;color:#64748b}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px}
.hero-badges span{display:inline-flex;align-items:center;border-radius:999px;padding:7px 11px;background:#edf4ff;color:#004098;font-weight:900;font-size:12px}
.hero-dc-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}
.hero-dc-list li{display:flex;align-items:center;gap:9px;padding:10px 12px;background:#f8fbff;border:1px solid #e7eefb;border-radius:14px;color:#334155;font-weight:750}
.hero-dc-list li:before{content:"●";color:#004098;font-size:10px}
@media(max-width:1160px){ .links{position:absolute;left:22px;right:22px;top:82px;background:white;border:1px solid var(--line);border-radius:18px;display:none;flex-direction:column;align-items:stretch;padding:12px;box-shadow:var(--shadow);gap:4px} .links.open{display:flex} .links>a,.menu-trigger{width:100%;text-align:left;justify-content:space-between;padding:13px 12px;border-bottom:0;border-radius:12px;font-size:14px} .menu-group{width:100%} .dropdown{position:static;display:block;box-shadow:none;border-color:#eef2f7;background:#f8fbff;margin:4px 0 8px;min-width:0} .dropdown a{white-space:normal}
}
@media(max-width:980px){ .plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){ .plan-grid{grid-template-columns:1fr} .plan-head{min-height:auto} .service-hero-card{padding:20px;border-radius:22px} .service-hero-card img{max-width:260px}
} /* ================= v9: Featured pricing full list ================= */
.featured-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch}
.featured-grid .plan-head{min-height:148px}
@media(max-width:980px){.featured-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.featured-grid{grid-template-columns:1fr}} /* ================= v10: Internal featured links + datacenter + button hover ================= */
.btn{ position:relative; overflow:hidden; transition:transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease, color .22s ease;
}
.btn:before{ content:""; position:absolute; top:0; left:-120%; width:80%; height:100%; background:linear-gradient(120deg,transparent,rgba(255,255,255,.34),transparent); transform:skewX(-18deg); transition:left .55s ease;
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 18px 34px rgba(0,64,152,.24);
}
.btn:hover:before{left:140%}
.btn.primary:hover{ background:#0758cc; color:#fff;
}
.btn.ghost:hover{ border-color:#004098; background:#edf4ff; color:#004098; box-shadow:0 14px 28px rgba(0,64,152,.12);
}
.card-link{ transition:transform .2s ease,color .2s ease;
}
.card-link:hover{ color:#0758cc; transform:translateX(4px);
}
.links a,.menu-trigger{ transition:color .2s ease,border-color .2s ease,background .2s ease;
}
.dropdown a{ transition:background .2s ease,color .2s ease,transform .2s ease;
}
.dropdown a:hover{ transform:translateX(3px);
}
.featured-grid .plan .btn{ margin-top:auto;
}
.home-dc-grid{ grid-template-columns:repeat(3,minmax(0,1fr));
}
.home-dc-card{ min-height:100%;
}
.home-dc-card ul{ margin-top:12px;
}
@media(max-width:980px){ .home-dc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){ .home-dc-grid{grid-template-columns:1fr} .btn:hover{transform:none}
} /* ================= v11: remove + datacenter location cards + reviews ================= */
.location-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.location-card{position:relative;min-height:235px;border-radius:24px;overflow:hidden;border:1px solid #dbe7ff;background:linear-gradient(135deg,#0b1220,#003a8c);box-shadow:0 18px 44px rgba(15,23,42,.12);padding:24px;color:white;display:flex;flex-direction:column;justify-content:flex-end}
.location-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 10%,rgba(34,211,238,.35),transparent 35%),linear-gradient(180deg,rgba(2,6,23,.1),rgba(2,6,23,.82));z-index:0}
.location-card>*{position:relative;z-index:1}
.location-card .region{display:inline-flex;align-self:flex-start;align-items:center;gap:8px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(10px);border-radius:999px;padding:7px 11px;font-size:12px;font-weight:900;margin-bottom:auto;color:#dbeafe}
.location-card h3{font-size:24px;line-height:1.18;margin:0 0 8px;color:white}
.location-card p{margin:0;color:#dbeafe;font-weight:650}
.location-card .btn{margin-top:18px;align-self:flex-start;background:#21e6b2;color:#052016;box-shadow:0 16px 30px rgba(33,230,178,.22)}
.location-card .btn:hover{background:#10d7a2;color:#041b14}
.reviews-section{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.review-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.review-card{background:#fff;border:1px solid #dbe7ff;border-radius:24px;padding:24px;box-shadow:0 14px 36px rgba(15,23,42,.06)}
.review-stars{color:#f59e0b;font-size:18px;letter-spacing:2px;margin-bottom:12px}
.review-card p{color:#475569;margin:0 0 18px}
.review-user{display:flex;align-items:center;gap:12px}
.avatar{width:44px;height:44px;border-radius:999px;background:linear-gradient(135deg,#004098,#38bdf8);color:white;display:grid;place-items:center;font-weight:900}
.review-user strong{display:block;color:#0f172a}
.review-user span{display:block;color:#64748b;font-size:13px;font-weight:700}
.trust-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:24px}
.trust-item{background:#f8fbff;border:1px solid #dbe7ff;border-radius:18px;padding:16px;text-align:center}
.trust-item strong{display:block;color:#004098;font-size:24px}
.trust-item span{font-weight:850;color:#334155;font-size:13px}
@media(max-width:980px){.location-grid,.review-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.trust-row{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.location-grid,.review-grid,.trust-row{grid-template-columns:1fr}.location-card{min-height:210px}} /* ================= v12: Restore services + remove child datacenter ================= */
.services{grid-template-columns:repeat(4,minmax(0,1fr))}
.services .card{min-height:100%}
@media(max-width:1100px){.services{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.services{grid-template-columns:1fr}} /* ================= v13: Center child page pricing cards ================= */
.plan-grid{ display:flex !important; flex-wrap:wrap; justify-content:center; align-items:stretch; gap:22px;
}
.plan{ flex:0 1 340px; max-width:360px; width:100%;
}
.featured-grid .plan{ flex:0 1 340px;
}
.plan-head{ min-height:150px;
}
.plan .btn{ width:calc(100% - 44px);
}
section .wrap > .plan-grid{ margin-left:auto; margin-right:auto;
}
.clean-head{ text-align:center;
}
.clean-head h2{ text-align:center; width:100%;
}
@media(max-width:900px){ .plan{ flex:0 1 calc(50% - 14px); max-width:none; }
}
@media(max-width:640px){ .plan-grid{ gap:16px; } .plan{ flex:0 1 100%; max-width:none; } .plan-head{ min-height:auto; }
} /* ================= v14: Datacenter center + contact readability ================= */
.location-grid{ display:flex !important; flex-wrap:wrap; justify-content:center; align-items:stretch; gap:22px;
}
.location-card{ flex:0 1 360px; max-width:380px; width:100%; text-align:left;
}
.location-card .btn{ color:#052016 !important;
}
.contact .card{ background:#ffffff; color:#0f172a !important; border:1px solid rgba(255,255,255,.55);
}
.contact .card h3{ color:#0f172a !important;
}
.contact .card p{ color:#334155 !important; font-weight:700; margin:8px 0;
}
.contact .card b{ color:#004098 !important; font-weight:900;
}
.contact .card a{ color:#004098 !important; font-weight:900;
}
.contact p{ color:#eaf2ff;
}
@media(max-width:640px){ .location-card{ flex:0 1 100%; max-width:none; }
} /* ================= v17: More customer reviews ================= */
.review-grid-more{ grid-template-columns:repeat(3,minmax(0,1fr));
}
.review-grid-more .review-card{ min-height:100%;
}
@media(max-width:980px){ .review-grid-more{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){ .review-grid-more{grid-template-columns:1fr}
} /* ================= v18: Footer logo + favicon ================= */
.footer-logo{ display:block; width:190px; max-width:100%; height:auto; margin:0 0 14px;
}
footer .footer-brand p{ margin-top:8px;
}
@media(max-width:640px){ .footer-logo{ width:170px; }
} /* ================= v19: mobile top padding fix ================= */
@media (max-width: 640px){ .topbar{ padding-top:max(8px, env(safe-area-inset-top)); } .nav{ min-height:74px; padding-top:6px; padding-bottom:6px; } .hero{ padding-top:10px; } .hero-grid{ padding-top:72px !important; } .eyebrow{ margin-top:6px; }
} /* ================= v20: mobile menu scroll + hero padding ================= */
@media (max-width:1160px){ .links.open{ max-height:calc(100dvh - 118px); overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; overscroll-behavior:contain; padding-bottom:18px; } .links.open::-webkit-scrollbar{ width:6px; } .links.open::-webkit-scrollbar-thumb{ background:#cbd5e1; border-radius:999px; }
} @media (max-width:640px){ .wrap{ padding-left:24px; padding-right:24px; } .hero-grid{ padding-left:0; padding-right:0; } .hero h1, .hero .lead, .hero .eyebrow, .hero .btns{ max-width:100%; } .hero .lead{ margin-right:0; } .links{ left:16px !important; right:16px !important; top:86px !important; max-height:calc(100dvh - 106px); }
} @media (max-width:430px){ .wrap{ padding-left:22px; padding-right:22px; } .hero h1{ font-size:32px; } .hero .lead{ font-size:15px; line-height:1.78; }
} /* ================= v21: Featured pricing mobile spacing fix ================= */
@media (max-width:640px){ .band{ padding-top:34px; padding-bottom:34px; } .band .wrap{ padding-left:22px; padding-right:22px; } .band .section-head.clean-head{ margin-bottom:22px; } .band .section-head.clean-head h2{ margin-top:0; } .services + .band, section + .band{ margin-top:0; }
} /* ================= v22: stronger mobile featured pricing spacing ================= */
@media (max-width:640px){ /* Tạo khoảng nghỉ rõ giữa DỊCH VỤ CHÍNH và BẢNG GIÁ NỔI BẬT */ main > section.band{ padding-top:56px !important; padding-bottom:56px !important; } main > section.band .wrap{ padding-left:24px !important; padding-right:24px !important; } main > section.band .section-head.clean-head{ margin-bottom:30px !important; padding-left:4px; padding-right:4px; } main > section.band .section-head.clean-head h2{ display:block; margin:0 auto !important; line-height:1.22 !important; text-align:center !important; } main > section.band .plan-grid{ padding-top:4px !important; gap:20px !important; } main > section.band .plan{ margin-left:auto !important; margin-right:auto !important; } /* Giảm cảm giác card dịch vụ phía trên dính vào section giá */ .services{ margin-bottom:18px !important; }
} @media (max-width:430px){ main > section.band{ padding-top:62px !important; } main > section.band .section-head.clean-head{ margin-bottom:34px !important; }
} /* ================= v23: final mobile menu + featured spacing ================= */ /* Mobile/tablet menu: fixed panel, own scroll, not clipped */
@media (max-width:1160px){ .topbar{ z-index:9999 !important; } .links{ position:fixed !important; left:18px !important; right:18px !important; top:92px !important; bottom:auto !important; max-height:calc(100dvh - 112px) !important; overflow-y:auto !important; overflow-x:hidden !important; -webkit-overflow-scrolling:touch; overscroll-behavior:contain; background:#fff !important; border:1px solid #dbe7ff !important; border-radius:20px !important; padding:18px !important; box-shadow:0 28px 70px rgba(15,23,42,.22) !important; z-index:9998 !important; } .links:not(.open){ display:none !important; } .links.open{ display:flex !important; flex-direction:column !important; align-items:stretch !important; gap:10px !important; } .links.open::-webkit-scrollbar{ width:7px; } .links.open::-webkit-scrollbar-thumb{ background:#b9c7d9; border-radius:999px; } .links > a, .menu-trigger{ min-height:44px !important; padding:12px 14px !important; border-radius:13px !important; border-bottom:0 !important; background:#fff !important; } .links > a:hover, .menu-trigger:hover{ background:#edf4ff !important; } .menu-group{ width:100% !important; } .dropdown{ position:static !important; display:block !important; min-width:0 !important; width:100% !important; margin:6px 0 8px !important; padding:10px !important; background:#f8fbff !important; border:1px solid #e7eefb !important; border-radius:17px !important; box-shadow:none !important; } .dropdown a{ padding:12px 14px !important; white-space:normal !important; }
} @media (max-width:640px){ .links{ left:14px !important; right:14px !important; top:88px !important; max-height:calc(100dvh - 102px) !important; padding:14px !important; border-radius:18px !important; } .dropdown{ padding:8px !important; }
} /* Featured pricing spacing: applies to mobile AND small tablet */
@media (max-width:980px){ main > section.band{ padding-top:72px !important; padding-bottom:72px !important; } main > section.band .section-head.clean-head{ margin-bottom:38px !important; } main > section.band .section-head.clean-head h2{ margin:0 auto !important; text-align:center !important; line-height:1.18 !important; } main > section.band .plan-grid{ padding-top:0 !important; gap:24px !important; } main > section.band .plan{ margin-left:auto !important; margin-right:auto !important; } .services{ margin-bottom:26px !important; }
} @media (max-width:640px){ main > section.band{ padding-top:64px !important; padding-bottom:64px !important; } main > section.band .wrap{ padding-left:24px !important; padding-right:24px !important; } main > section.band .section-head.clean-head{ margin-bottom:32px !important; } main > section.band .plan-grid{ gap:22px !important; }
} @media (max-width:430px){ main > section.band{ padding-top:68px !important; } main > section.band .section-head.clean-head{ margin-bottom:34px !important; }
} /* ================= v24: bigger header logo + Vietnamese menu labels ================= */
.brand img{ height:58px !important; max-width:260px !important; width:auto !important; object-fit:contain;
} .nav{ min-height:92px !important;
} .topbar .wrap.nav{ align-items:center;
} @media(max-width:1160px){ .brand img{ height:50px !important; max-width:230px !important; } .nav{ min-height:86px !important; }
} @media(max-width:640px){ .brand img{ height:44px !important; max-width:205px !important; } .nav{ min-height:78px !important; } .links{ top:94px !important; max-height:calc(100dvh - 108px) !important; }
} @media(max-width:390px){ .brand img{ height:40px !important; max-width:185px !important; }
}

/* ================= v40 promo features ================= */
.trust-section,.features-section{padding:72px 0;background:#fff}
.trust-section{border-top:1px solid rgba(15,23,42,.08)}
.features-section{background:linear-gradient(180deg,#f8fbff 0%,#fff 100%)}
.trust-grid,.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;margin-top:34px}
.trust-card,.feature-box{background:#fff;border:1px solid rgba(15,23,42,.09);border-radius:22px;padding:28px;box-shadow:0 18px 45px rgba(15,23,42,.07)}
.trust-icon,.feature-icon{width:54px;height:54px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:#eef5ff;font-size:26px;margin-bottom:18px}
.trust-card h3,.feature-box h3{margin:0 0 10px;font-size:22px;line-height:1.25;color:#06132b}
.trust-card p,.feature-box p{margin:0;color:#52637a;line-height:1.65}
@media(max-width:980px){.trust-grid,.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.trust-section,.features-section{padding:48px 0}.trust-grid,.feature-grid{grid-template-columns:1fr}.trust-card,.feature-box{padding:22px}}

/* ================= v41 trust copy/visual polish ================= */
.trust-section{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 15% 10%, rgba(0,64,152,.14), transparent 34%),
    radial-gradient(circle at 85% 15%, rgba(46,116,255,.12), transparent 30%),
    linear-gradient(180deg,#f7fbff 0%,#ffffff 100%) !important;
}

.trust-section:before{
  content:"";
  position:absolute;
  inset:0;
  background-image:linear-gradient(rgba(0,64,152,.045) 1px, transparent 1px),linear-gradient(90deg, rgba(0,64,152,.045) 1px, transparent 1px);
  background-size:42px 42px;
  pointer-events:none;
}

.trust-section .wrap{
  position:relative;
  z-index:1;
}

.trust-card{
  min-height:285px;
  position:relative;
}

.trust-card-featured{
  border-color:rgba(0,64,152,.28) !important;
  box-shadow:0 24px 60px rgba(0,64,152,.14) !important;
  transform:translateY(-8px);
}

.trust-proof{
  margin-top:26px;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}

.trust-proof div{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;
  padding:18px 20px;
  box-shadow:0 12px 30px rgba(15,23,42,.055);
}

.trust-proof strong{
  display:block;
  font-size:24px;
  line-height:1;
  color:#004098;
  margin-bottom:8px;
}

.trust-proof span{
  color:#52637a;
  font-weight:700;
  font-size:14px;
}

@media(max-width:980px){
  .trust-card-featured{
    transform:none;
  }
  .trust-proof{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:560px){
  .trust-proof{
    grid-template-columns:1fr;
  }
}

/* ================= v42 layout trust/features/cta fix ================= */
.trust-section,
.features-section{
  padding:70px 0 !important;
  background:#fff !important;
}

.trust-section{
  border-top:1px solid rgba(15,23,42,.07);
  background:linear-gradient(180deg,#ffffff 0%,#f7faff 100%) !important;
}

.features-section{
  background:#f7f9fc !important;
}

.trust-section:before{
  display:none !important;
}

.trust-grid,
.feature-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  margin-top:34px;
}

.trust-card,
.feature-box{
  background:#fff !important;
  border:1px solid rgba(15,23,42,.08) !important;
  border-radius:20px !important;
  padding:28px !important;
  min-height:auto !important;
  box-shadow:0 14px 36px rgba(15,23,42,.06) !important;
  transform:none !important;
}

.trust-icon,
.feature-icon{
  width:52px;
  height:52px;
  border-radius:16px;
  background:#eef5ff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:25px;
  margin-bottom:16px;
}

.trust-card h3,
.feature-box h3{
  margin:0 0 10px;
  color:#06132b;
  font-size:21px;
  line-height:1.28;
}

.trust-card p,
.feature-box p{
  margin:0;
  color:#52637a;
  line-height:1.65;
}

.trust-proof{
  margin-top:24px;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}

.trust-proof div{
  background:#fff;
  border:1px solid rgba(0,64,152,.13);
  border-radius:18px;
  padding:18px 20px;
  text-align:center;
  box-shadow:0 10px 28px rgba(15,23,42,.045);
}

.trust-proof strong{
  display:block;
  color:#004098;
  font-size:25px;
  line-height:1;
  margin-bottom:8px;
}

.trust-proof span{
  color:#52637a;
  font-weight:800;
  font-size:14px;
}

.cta-section{
  padding:74px 0;
  background:linear-gradient(135deg,#00347c 0%,#0056bd 100%);
}

.cta-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);
  border-radius:26px;
  padding:34px;
  color:#fff;
  box-shadow:0 22px 60px rgba(0,28,75,.24);
}

.cta-card .eyebrow,
.cta-card h2,
.cta-card p{
  color:#fff !important;
}

.cta-card h2{
  margin:6px 0 10px;
  font-size:36px;
  line-height:1.15;
}

.cta-card p{
  margin:0;
  max-width:760px;
  opacity:.92;
  line-height:1.65;
}

.cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
  flex:0 0 auto;
}

.cta-section .btn.primary{
  background:#fff !important;
  color:#004098 !important;
  border-color:#fff !important;
  box-shadow:0 14px 30px rgba(0,0,0,.18);
}

.cta-section .btn.ghost{
  background:transparent !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.55) !important;
}

@media(max-width:980px){
  .trust-grid,
  .feature-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .trust-proof{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .cta-card{
    align-items:flex-start;
    flex-direction:column;
  }
  .cta-actions{
    justify-content:flex-start;
  }
}

@media(max-width:640px){
  .trust-section,
  .features-section,
  .cta-section{
    padding:48px 0 !important;
  }
  .trust-grid,
  .feature-grid,
  .trust-proof{
    grid-template-columns:1fr;
  }
  .cta-card{
    padding:24px;
    border-radius:22px;
  }
  .cta-card h2{
    font-size:28px;
  }
}

/* ================= v43 cleanup blank CTA/orphan button ================= */
main > a.btn,
main > .btn{
  display:none !important;
}
section:empty{
  display:none !important;
}
.features-section .section-head h2{
  text-transform:uppercase;
}

/* ================= v44 final cleanup ================= */
/* Hide any leftover ticket-only orphan section if browser still sees it */
section > .btns:only-child{
  display:none !important;
}
section:has(> .btns:only-child){
  display:none !important;
}

/* CTA label must be readable, not white-on-white */
.cta-section .eyebrow,
.cta-section .cta-eyebrow{
  display:inline-flex !important;
  align-items:center;
  width:auto !important;
  height:auto !important;
  min-width:0 !important;
  padding:8px 14px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.16) !important;
  border:1px solid rgba(255,255,255,.34) !important;
  color:#ffffff !important;
  font-size:13px !important;
  font-weight:900 !important;
  letter-spacing:.08em !important;
  line-height:1 !important;
  text-indent:0 !important;
  overflow:visible !important;
}

.cta-section .eyebrow:before,
.cta-section .eyebrow:after{
  display:none !important;
  content:none !important;
}

.features-section .feature-box h3{
  color:#06132b !important;
}


/* ================= v45 mobile menu full-view fix ================= */
body.mobile-menu-open{
  overflow:hidden;
}
@media (max-width:1160px){
  .links{
    top:92px !important;
    bottom:12px !important;
    max-height:none !important;
    min-height:0 !important;
    height:auto !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    padding-bottom:calc(18px + env(safe-area-inset-bottom)) !important;
    scrollbar-gutter:stable;
    overscroll-behavior-y:contain !important;
  }
  .links.open{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:10px !important;
  }
}
@media (max-width:640px){
  .links{
    left:12px !important;
    right:12px !important;
    top:88px !important;
    bottom:10px !important;
    border-radius:18px !important;
    padding:14px !important;
  }
}
@media (max-width:390px){
  .links{
    top:84px !important;
    bottom:8px !important;
    left:10px !important;
    right:10px !important;
    padding:12px !important;
  }
}

/* ================= v46 real mobile menu scrolling fix ================= */
@media (max-width:1160px){
  html.menu-is-open,
  body.mobile-menu-open{
    overflow:hidden !important;
    height:100% !important;
  }

  .topbar{
    position:sticky !important;
    top:0 !important;
    z-index:10000 !important;
  }

  .links{
    position:fixed !important;
    left:12px !important;
    right:12px !important;
    top:calc(86px + env(safe-area-inset-top)) !important;
    bottom:calc(10px + env(safe-area-inset-bottom)) !important;
    height:auto !important;
    max-height:none !important;
    min-height:0 !important;
    display:none !important;
    overflow-y:scroll !important;
    overflow-x:hidden !important;
    -webkit-overflow-scrolling:touch !important;
    overscroll-behavior:contain !important;
    touch-action:pan-y !important;
    padding:14px 14px 34px !important;
    background:#fff !important;
    border:1px solid #dbe7ff !important;
    border-radius:20px !important;
    box-shadow:0 28px 70px rgba(15,23,42,.26) !important;
    z-index:10001 !important;
  }

  .links.open{
    display:block !important;
  }

  .links > a,
  .links .menu-trigger{
    width:100% !important;
    min-height:48px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    padding:13px 14px !important;
    margin:0 0 8px !important;
    border-radius:14px !important;
    border-bottom:0 !important;
    background:#fff !important;
    font-size:16px !important;
    line-height:1.25 !important;
  }

  .menu-group{
    width:100% !important;
    margin:0 0 12px !important;
  }

  .dropdown{
    position:static !important;
    display:block !important;
    width:100% !important;
    min-width:0 !important;
    margin:0 0 10px !important;
    padding:10px !important;
    background:#f8fbff !important;
    border:1px solid #e7eefb !important;
    border-radius:18px !important;
    box-shadow:none !important;
  }

  .dropdown a{
    display:block !important;
    padding:13px 14px !important;
    margin:0 0 8px !important;
    border-radius:13px !important;
    white-space:normal !important;
    line-height:1.32 !important;
    font-size:15px !important;
  }

  .dropdown a:last-child{
    margin-bottom:0 !important;
  }

  .dropdown small{
    display:block !important;
    margin-top:5px !important;
    line-height:1.35 !important;
  }

  .links:after{
    content:"";
    display:block;
    height:34px;
  }
}

@media (max-width:430px){
  .links{
    top:calc(80px + env(safe-area-inset-top)) !important;
    left:10px !important;
    right:10px !important;
    bottom:calc(8px + env(safe-area-inset-bottom)) !important;
    padding:12px 12px 36px !important;
  }
}

/* ================= v47 mobile menu non-fixed scroll fix ================= */
/* Không dùng fixed panel nữa vì một số mobile/browser không kéo được menu.
   Menu sẽ xổ xuống trong header, body scroll tự nhiên để xem hết. */
html.menu-is-open,
body.mobile-menu-open{
  overflow:auto !important;
  height:auto !important;
  position:static !important;
}

@media (max-width:1160px){
  .topbar{
    position:sticky !important;
    top:0 !important;
    z-index:10000 !important;
    overflow:visible !important;
  }

  .topbar .wrap.nav{
    display:flex !important;
    align-items:center !important;
    flex-wrap:wrap !important;
    gap:10px !important;
    overflow:visible !important;
  }

  .brand{
    flex:1 1 auto !important;
  }

  .lang{
    flex:0 0 auto !important;
  }

  .hamb{
    flex:0 0 auto !important;
  }

  .links{
    order:99 !important;
    flex:0 0 100% !important;
    width:100% !important;
    position:static !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    bottom:auto !important;
    height:auto !important;
    max-height:none !important;
    min-height:0 !important;
    display:none !important;
    overflow:visible !important;
    overflow-y:visible !important;
    overflow-x:visible !important;
    touch-action:auto !important;
    -webkit-overflow-scrolling:auto !important;
    overscroll-behavior:auto !important;
    margin:10px 0 0 !important;
    padding:14px !important;
    background:#fff !important;
    border:1px solid #dbe7ff !important;
    border-radius:20px !important;
    box-shadow:0 18px 50px rgba(15,23,42,.18) !important;
    z-index:auto !important;
  }

  .links.open{
    display:block !important;
  }

  .links > a,
  .links .menu-trigger{
    width:100% !important;
    min-height:48px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    padding:13px 14px !important;
    margin:0 0 8px !important;
    border-radius:14px !important;
    border-bottom:0 !important;
    background:#fff !important;
    font-size:16px !important;
    line-height:1.25 !important;
  }

  .menu-group{
    width:100% !important;
    margin:0 0 12px !important;
  }

  .dropdown{
    position:static !important;
    display:block !important;
    width:100% !important;
    min-width:0 !important;
    margin:0 0 10px !important;
    padding:10px !important;
    background:#f8fbff !important;
    border:1px solid #e7eefb !important;
    border-radius:18px !important;
    box-shadow:none !important;
  }

  .dropdown a{
    display:block !important;
    padding:13px 14px !important;
    margin:0 0 8px !important;
    border-radius:13px !important;
    white-space:normal !important;
    line-height:1.32 !important;
    font-size:15px !important;
  }

  .dropdown a:last-child{
    margin-bottom:0 !important;
  }

  .dropdown small{
    display:block !important;
    margin-top:5px !important;
    line-height:1.35 !important;
  }

  .links:after{
    content:none !important;
    display:none !important;
  }
}

@media (max-width:430px){
  .topbar .wrap.nav{
    padding-left:14px !important;
    padding-right:14px !important;
  }

  .links{
    padding:12px !important;
    border-radius:18px !important;
  }
}

/* ================= v48 real mobile drawer ================= */
html.drawer-open,
body.drawer-open{
  overflow:hidden !important;
  height:100% !important;
}

.mobile-drawer{
  display:none;
}

@media(max-width:1160px){
  /* Old nav is desktop/tablet source only; drawer JS clones it */
  .links.open{
    display:none !important;
  }

  .mobile-drawer{
    position:fixed;
    inset:0;
    z-index:2147483000;
    display:none;
    background:rgba(2,10,26,.64);
    padding:14px;
  }

  .mobile-drawer.open{
    display:block;
  }

  .mobile-drawer-panel{
    height:calc(100dvh - 28px);
    max-height:calc(100dvh - 28px);
    width:min(94vw, 520px);
    margin:0 auto;
    background:#fff;
    border:1px solid #dbe7ff;
    border-radius:24px;
    box-shadow:0 30px 90px rgba(0,0,0,.32);
    display:flex;
    flex-direction:column;
    overflow:hidden;
  }

  .mobile-drawer-head{
    flex:0 0 auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:18px 20px;
    border-bottom:1px solid #e7eefb;
    background:#fff;
  }

  .mobile-drawer-head strong{
    color:#06132b;
    font-size:22px;
    font-weight:900;
  }

  .mobile-drawer-close{
    width:44px;
    height:44px;
    border:0;
    border-radius:14px;
    background:#eef5ff;
    color:#004098;
    font-size:34px;
    line-height:1;
    cursor:pointer;
  }

  .mobile-drawer-body{
    flex:1 1 auto;
    min-height:0;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    -webkit-overflow-scrolling:touch !important;
    overscroll-behavior:contain !important;
    touch-action:pan-y !important;
    padding:16px 18px 36px;
  }

  .mobile-drawer-body > a,
  .mobile-drawer-body .menu-trigger{
    width:100%;
    min-height:50px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:14px 14px;
    margin:0 0 10px;
    border:0;
    border-radius:15px;
    background:#fff;
    color:#172033;
    text-decoration:none;
    font-size:18px;
    font-weight:900;
    line-height:1.25;
  }

  .mobile-drawer-body .menu-group{
    margin:0 0 18px;
  }

  .mobile-drawer-body .dropdown{
    position:static !important;
    display:block !important;
    width:100% !important;
    min-width:0 !important;
    margin:0 !important;
    padding:12px !important;
    background:#f8fbff !important;
    border:1px solid #e7eefb !important;
    border-radius:18px !important;
    box-shadow:none !important;
  }

  .mobile-drawer-body .dropdown a{
    display:block !important;
    padding:14px 14px !important;
    margin:0 0 10px !important;
    border-radius:14px !important;
    color:#172033 !important;
    text-decoration:none !important;
    white-space:normal !important;
    line-height:1.32 !important;
    font-size:17px !important;
    font-weight:900 !important;
  }

  .mobile-drawer-body .dropdown a:last-child{
    margin-bottom:0 !important;
  }

  .mobile-drawer-body .dropdown small{
    display:block !important;
    margin-top:6px !important;
    color:#64748b !important;
    font-size:14px !important;
    line-height:1.35 !important;
    font-weight:750 !important;
  }

  .mobile-drawer-body:after{
    content:"";
    display:block;
    height:70px;
  }
}

@media(max-width:430px){
  .mobile-drawer{
    padding:10px;
  }

  .mobile-drawer-panel{
    height:calc(100dvh - 20px);
    max-height:calc(100dvh - 20px);
    width:100%;
    border-radius:22px;
  }

  .mobile-drawer-head{
    padding:16px;
  }

  .mobile-drawer-body{
    padding:14px 14px 34px;
  }
}

/* ================= v49 final mobile drawer, no nav.links.open ================= */
html.drawer-open,
body.drawer-open{
  overflow:hidden !important;
  height:100% !important;
}

/* Kill old mobile menu behavior completely */
@media(max-width:1160px){
  nav.links.open,
  #links.links.open{
    display:none !important;
  }
}

.mobile-drawer{
  display:none;
}

@media(max-width:1160px){
  .mobile-drawer{
    position:fixed !important;
    inset:0 !important;
    z-index:2147483647 !important;
    background:rgba(2,10,26,.68) !important;
    padding:12px !important;
  }

  .mobile-drawer.open{
    display:block !important;
  }

  .mobile-drawer-panel{
    width:min(94vw,520px) !important;
    height:calc(100dvh - 24px) !important;
    max-height:calc(100dvh - 24px) !important;
    margin:0 auto !important;
    background:#ffffff !important;
    border:1px solid #dbe7ff !important;
    border-radius:24px !important;
    box-shadow:0 30px 100px rgba(0,0,0,.36) !important;
    display:flex !important;
    flex-direction:column !important;
    overflow:hidden !important;
  }

  .mobile-drawer-head{
    flex:0 0 auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:12px !important;
    padding:16px 18px !important;
    border-bottom:1px solid #e7eefb !important;
    background:#fff !important;
  }

  .mobile-drawer-head strong{
    color:#06132b !important;
    font-size:22px !important;
    font-weight:950 !important;
  }

  .mobile-drawer-close{
    width:46px !important;
    height:46px !important;
    border:0 !important;
    border-radius:15px !important;
    background:#eef5ff !important;
    color:#004098 !important;
    font-size:36px !important;
    line-height:1 !important;
    cursor:pointer !important;
  }

  .mobile-drawer-body{
    flex:1 1 auto !important;
    min-height:0 !important;
    height:100% !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    -webkit-overflow-scrolling:touch !important;
    overscroll-behavior:contain !important;
    touch-action:pan-y !important;
    padding:16px 18px 80px !important;
  }

  .mobile-drawer-body > a,
  .mobile-drawer-body .menu-trigger{
    width:100% !important;
    min-height:52px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    padding:14px !important;
    margin:0 0 10px !important;
    border:0 !important;
    border-radius:15px !important;
    background:#fff !important;
    color:#172033 !important;
    text-decoration:none !important;
    font-size:18px !important;
    font-weight:950 !important;
    line-height:1.25 !important;
    text-align:left !important;
  }

  .mobile-drawer-body .menu-group{
    width:100% !important;
    margin:0 0 18px !important;
  }

  .mobile-drawer-body .dropdown{
    position:static !important;
    display:block !important;
    width:100% !important;
    min-width:0 !important;
    margin:0 !important;
    padding:12px !important;
    background:#f8fbff !important;
    border:1px solid #e7eefb !important;
    border-radius:18px !important;
    box-shadow:none !important;
  }

  .mobile-drawer-body .dropdown a{
    display:block !important;
    padding:14px !important;
    margin:0 0 10px !important;
    border-radius:14px !important;
    color:#172033 !important;
    text-decoration:none !important;
    white-space:normal !important;
    line-height:1.32 !important;
    font-size:17px !important;
    font-weight:950 !important;
  }

  .mobile-drawer-body .dropdown a:last-child{
    margin-bottom:0 !important;
  }

  .mobile-drawer-body .dropdown small{
    display:block !important;
    margin-top:6px !important;
    color:#64748b !important;
    font-size:14px !important;
    line-height:1.35 !important;
    font-weight:750 !important;
  }

  .mobile-drawer-body:after{
    content:"";
    display:block;
    height:96px;
  }
}

@media(max-width:430px){
  .mobile-drawer{
    padding:8px !important;
  }

  .mobile-drawer-panel{
    width:100% !important;
    height:calc(100dvh - 16px) !important;
    max-height:calc(100dvh - 16px) !important;
    border-radius:22px !important;
  }

  .mobile-drawer-head{
    padding:14px 16px !important;
  }

  .mobile-drawer-body{
    padding:14px 14px 90px !important;
  }
}

/* ================= v51 PURE CSS mobile menu - no JS, no fixed ================= */
.mobile-menu-check{
  display:none !important;
}

@media(max-width:1160px){
  html,
  body,
  html.menu-is-open,
  body.mobile-menu-open,
  html.drawer-open,
  body.drawer-open{
    overflow:auto !important;
    height:auto !important;
    position:static !important;
    touch-action:auto !important;
  }

  .mobile-drawer,
  .mobile-drawer.open{
    display:none !important;
  }

  .topbar{
    position:sticky !important;
    top:0 !important;
    z-index:9999 !important;
    overflow:visible !important;
    background:#fff !important;
  }

  .topbar .wrap.nav{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    gap:10px !important;
    overflow:visible !important;
  }

  .brand{
    order:1 !important;
    flex:1 1 auto !important;
    min-width:0 !important;
  }

  .lang{
    order:2 !important;
    flex:0 0 auto !important;
  }

  .hamb{
    order:3 !important;
    flex:0 0 auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    cursor:pointer !important;
    user-select:none !important;
  }

  nav#links.links{
    order:4 !important;
    flex:0 0 100% !important;
    width:100% !important;
    position:static !important;
    inset:auto !important;
    height:auto !important;
    min-height:0 !important;
    max-height:none !important;
    display:none !important;
    overflow:visible !important;
    margin:8px 0 0 !important;
    padding:14px !important;
    background:#fff !important;
    border:1px solid #dbe7ff !important;
    border-radius:20px !important;
    box-shadow:0 18px 50px rgba(15,23,42,.20) !important;
    z-index:auto !important;
  }

  .mobile-menu-check:checked ~ nav#links.links{
    display:block !important;
  }

  nav#links.links.open{
    display:none !important;
  }

  .mobile-menu-check:checked ~ nav#links.links.open{
    display:block !important;
  }

  nav#links.links > a,
  nav#links.links .menu-trigger{
    width:100% !important;
    min-height:48px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    padding:13px 14px !important;
    margin:0 0 8px !important;
    border-radius:14px !important;
    border:0 !important;
    background:#fff !important;
    color:#172033 !important;
    font-size:16px !important;
    font-weight:900 !important;
    line-height:1.25 !important;
    text-align:left !important;
  }

  nav#links.links .menu-group{
    width:100% !important;
    margin:0 0 12px !important;
  }

  nav#links.links .dropdown{
    position:static !important;
    display:block !important;
    width:100% !important;
    min-width:0 !important;
    max-height:none !important;
    overflow:visible !important;
    margin:0 0 10px !important;
    padding:10px !important;
    background:#f8fbff !important;
    border:1px solid #e7eefb !important;
    border-radius:18px !important;
    box-shadow:none !important;
  }

  nav#links.links .dropdown a{
    display:block !important;
    padding:13px 14px !important;
    margin:0 0 8px !important;
    border-radius:13px !important;
    white-space:normal !important;
    line-height:1.32 !important;
    font-size:15px !important;
    font-weight:900 !important;
  }

  nav#links.links .dropdown small{
    display:block !important;
    margin-top:5px !important;
    color:#64748b !important;
    line-height:1.35 !important;
  }
}

@media(max-width:430px){
  .topbar .wrap.nav{
    padding-left:14px !important;
    padding-right:14px !important;
  }

  .brand img{
    max-width:190px !important;
  }

  nav#links.links{
    padding:12px !important;
    border-radius:18px !important;
  }
}

/* ================= v61 price anchor ================= */
html{
  scroll-behavior:smooth;
}

#bang-gia-noi-bat{
  scroll-margin-top:110px;
}

.anchor-offset{
  display:block;
  position:relative;
  top:-110px;
  visibility:hidden;
}

/* ================= v62 service price anchors ================= */
html{
  scroll-behavior:smooth;
}

section[id^="bang-gia-"]{
  scroll-margin-top:110px;
}

.anchor-offset{
  display:block;
  position:relative;
  top:-110px;
  visibility:hidden;
}

/* ================= v63 no popup anchor ================= */
section[id^="bang-gia-"],
#bang-gia-noi-bat{
  scroll-margin-top:110px;
}

/* ================= v64 price focus offset fix ================= */
section[id^="bang-gia-"],
#bang-gia-noi-bat{
  scroll-margin-top:190px !important;
}

.anchor-offset{
  top:-190px !important;
}

/* ================= v65 price focus stronger offset ================= */
section[id^="bang-gia-"],
#bang-gia-noi-bat{
  scroll-margin-top:280px !important;
}

.anchor-offset{
  top:-280px !important;
}

/* ================= v66 hidden price anchor spacer ================= */
.price-anchor-spacer{
  display:block !important;
  height:210px !important;
  margin-top:-210px !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

section[id^="bang-gia-"],
#bang-gia-noi-bat{
  scroll-margin-top:0 !important;
}



/* ================= v80 clean wrap padding system ================= */
/* Chuẩn container: dùng padding-left/right cho .wrap, không dùng width calc trùng lặp */
:root{
  --container-max:1180px;
  --wrap-x:32px;
}

.wrap{
  width:100% !important;
  max-width:var(--container-max) !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:var(--wrap-x) !important;
  padding-right:var(--wrap-x) !important;
  box-sizing:border-box !important;
}

/* Header dùng cùng chuẩn container */
.topbar .wrap.nav{
  width:100% !important;
  max-width:var(--container-max) !important;
  padding-left:var(--wrap-x) !important;
  padding-right:var(--wrap-x) !important;
}

/* Section/hero không tự tạo padding ngang nữa */
main > section,
section.hero{
  padding-left:0 !important;
  padding-right:0 !important;
  box-sizing:border-box !important;
}

/* Trang chủ + page con dùng cùng hero-grid */
section.hero{
  padding-top:78px !important;
  padding-bottom:74px !important;
  overflow:hidden !important;
  background:linear-gradient(135deg,#f8fbff 0%,#eef6ff 52%,#ffffff 100%) !important;
  border-bottom:1px solid rgba(15,23,42,.06) !important;
}

section.hero > .wrap.hero-grid,
section.hero .wrap.hero-grid{
  display:grid !important;
  grid-template-columns:minmax(0, 1fr) minmax(340px, 460px) !important;
  gap:56px !important;
  align-items:center !important;
}

section.hero .hero-copy,
section.hero > .wrap.hero-grid > div:first-child{
  min-width:0 !important;
  max-width:680px !important;
  box-sizing:border-box !important;
}

section.hero h1{
  max-width:680px !important;
  margin:0 0 20px !important;
  font-size:clamp(44px, 4.7vw, 66px) !important;
  line-height:1.06 !important;
  letter-spacing:-.05em !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
}

section.hero .lead,
section.hero p{
  max-width:650px !important;
  font-size:19px !important;
  line-height:1.7 !important;
}

section.hero .btns,
section.hero .actions{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:14px !important;
  margin-top:26px !important;
}

section.hero .hero-card{
  width:100% !important;
  max-width:460px !important;
  justify-self:end !important;
  box-sizing:border-box !important;
}

/* Desktop nhỏ / tablet ngang */
@media (max-width:1240px){
  :root{
    --wrap-x:44px;
  }

  section.hero{
    padding-top:68px !important;
    padding-bottom:64px !important;
  }

  section.hero > .wrap.hero-grid,
  section.hero .wrap.hero-grid{
    grid-template-columns:minmax(0, 1fr) minmax(320px, 420px) !important;
    gap:44px !important;
  }

  section.hero h1{
    font-size:clamp(40px, 4.2vw, 56px) !important;
  }

  section.hero .lead,
  section.hero p{
    font-size:18px !important;
  }
}

/* Tablet dọc / mobile lớn */
@media (max-width:900px){
  :root{
    --wrap-x:32px;
  }

  section.hero{
    padding-top:58px !important;
    padding-bottom:56px !important;
  }

  section.hero > .wrap.hero-grid,
  section.hero .wrap.hero-grid{
    grid-template-columns:1fr !important;
    gap:28px !important;
  }

  section.hero .hero-copy,
  section.hero > .wrap.hero-grid > div:first-child,
  section.hero .hero-card{
    max-width:100% !important;
    justify-self:stretch !important;
  }

  section.hero h1{
    max-width:100% !important;
    font-size:clamp(36px, 7vw, 50px) !important;
    line-height:1.1 !important;
  }

  section.hero .lead,
  section.hero p{
    max-width:100% !important;
    font-size:17px !important;
  }
}

/* Mobile: theo cấu hình bạn đưa */
@media (max-width:640px){
  :root{
    --wrap-x:24px;
  }

  .wrap{
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .topbar .wrap.nav{
    padding-left:24px !important;
    padding-right:24px !important;
  }
}

/* Mobile nhỏ */
@media (max-width:520px){
  :root{
    --wrap-x:22px;
  }

  .wrap{
    padding-left:22px !important;
    padding-right:22px !important;
  }

  .topbar .wrap.nav{
    padding-left:22px !important;
    padding-right:22px !important;
  }

  section.hero{
    padding-top:48px !important;
    padding-bottom:46px !important;
  }

  section.hero h1{
    font-size:32px !important;
    line-height:1.12 !important;
    letter-spacing:-.035em !important;
  }

  section.hero .lead,
  section.hero p{
    font-size:16px !important;
  }
}

/* Máy nhỏ hơn */
@media (max-width:380px){
  :root{
    --wrap-x:17px;
  }

  .wrap{
    padding-left:17px !important;
    padding-right:17px !important;
  }

  .topbar .wrap.nav{
    padding-left:17px !important;
    padding-right:17px !important;
  }
}

/* Đảm bảo grid/card không vượt container */
main .cards,
main .pricing-grid,
main .service-grid,
main .feature-grid,
main .trust-grid,
main .location-grid,
main .review-grid,
main .stats-grid,
main .grid,
main .hero-grid{
  max-width:100% !important;
  box-sizing:border-box !important;
}

main .card,
main .price-card,
main .feature-box,
main .trust-card,
main .location-card,
main .review-card,
main .hero-card{
  min-width:0 !important;
  box-sizing:border-box !important;
}

/* ================= v81 hero columns balance ================= */
/* Giữ padding .wrap chuẩn v80, chỉ cân lại khoảng cách 2 cột hero */
body > main > section.hero:first-child > .wrap.hero-grid{
  max-width:1080px !important;
  grid-template-columns:minmax(0, 1fr) 420px !important;
  gap:42px !important;
}

body > main > section.hero:first-child .hero-copy{
  max-width:610px !important;
}

body > main > section.hero:first-child h1{
  max-width:610px !important;
  font-size:clamp(44px, 4.4vw, 62px) !important;
}

body > main > section.hero:first-child .lead{
  max-width:590px !important;
}

body > main > section.hero:first-child .hero-card{
  max-width:420px !important;
  justify-self:start !important;
}

/* Desktop nhỏ / tablet ngang: giữ 2 cột nhưng không kéo xa */
@media (max-width:1240px) and (min-width:901px){
  body > main > section.hero:first-child > .wrap.hero-grid{
    max-width:980px !important;
    grid-template-columns:minmax(0, 1fr) 380px !important;
    gap:36px !important;
  }

  body > main > section.hero:first-child .hero-copy{
    max-width:560px !important;
  }

  body > main > section.hero:first-child h1{
    max-width:560px !important;
    font-size:clamp(40px, 4vw, 54px) !important;
  }

  body > main > section.hero:first-child .lead{
    max-width:540px !important;
  }

  body > main > section.hero:first-child .hero-card{
    max-width:380px !important;
  }
}

/* 900px trở xuống về 1 cột theo v80 */
@media (max-width:900px){
  body > main > section.hero:first-child > .wrap.hero-grid{
    max-width:720px !important;
    grid-template-columns:1fr !important;
    gap:28px !important;
  }

  body > main > section.hero:first-child .hero-copy,
  body > main > section.hero:first-child .hero-card,
  body > main > section.hero:first-child h1,
  body > main > section.hero:first-child .lead{
    max-width:100% !important;
  }
}

/* ================= v82 wide desktop container ================= */
/* Màn hình lớn: mở rộng container để không bị dư 2 bên quá nhiều */
@media (min-width:1241px){
  :root{
    --container-max:1320px;
    --wrap-x:32px;
  }

  .wrap,
  .topbar .wrap.nav{
    max-width:1320px !important;
  }

  body > main > section.hero:first-child > .wrap.hero-grid{
    max-width:1280px !important;
    grid-template-columns:minmax(0, 680px) 440px !important;
    gap:74px !important;
  }

  body > main > section.hero:first-child .hero-copy{
    max-width:680px !important;
  }

  body > main > section.hero:first-child h1{
    max-width:680px !important;
    font-size:clamp(54px, 4.2vw, 72px) !important;
  }

  body > main > section.hero:first-child .lead{
    max-width:650px !important;
    font-size:20px !important;
  }

  body > main > section.hero:first-child .hero-card{
    max-width:440px !important;
  }
}

/* Màn rất lớn: không bung quá đà nhưng vẫn thoáng hơn bản cũ */
@media (min-width:1600px){
  :root{
    --container-max:1360px;
  }

  .wrap,
  .topbar .wrap.nav{
    max-width:1360px !important;
  }

  body > main > section.hero:first-child > .wrap.hero-grid{
    max-width:1320px !important;
    grid-template-columns:minmax(0, 700px) 460px !important;
    gap:82px !important;
  }

  body > main > section.hero:first-child .hero-card{
    max-width:460px !important;
  }
}

/* ================= v83 scroll to top ================= */
.scroll-top-btn{
  position:fixed;
  right:22px;
  bottom:24px;
  width:48px;
  height:48px;
  border:0;
  border-radius:999px;
  background:#004098;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  font-weight:900;
  line-height:1;
  box-shadow:0 18px 42px rgba(0,64,152,.28);
  cursor:pointer;
  opacity:0;
  visibility:hidden;
  transform:translateY(12px);
  transition:opacity .22s ease, transform .22s ease, visibility .22s ease, background .22s ease;
  z-index:9998;
}

.scroll-top-btn.is-visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.scroll-top-btn:hover{
  background:#00347c;
}

.scroll-top-btn:focus{
  outline:3px solid rgba(0,64,152,.22);
  outline-offset:3px;
}

@media(max-width:640px){
  .scroll-top-btn{
    right:16px;
    bottom:18px;
    width:46px;
    height:46px;
    font-size:21px;
  }
}
