:root{--a:#7c3aed;--a2:color-mix(in srgb,#7c3aed 80%,#000 0%);--ink:#0b1220;--mut:#56627a;--line:#e6e9f0;--bg:#fff;--soft:#f6f8fc}
*{box-sizing:border-box}html{scroll-behavior:smooth}
html,body{overflow-x:hidden;max-width:100%}
body{margin:0;color:var(--ink);background:var(--bg);font:16px/1.65 "Be Vietnam Pro",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;-webkit-font-smoothing:antialiased}
button,input,select,textarea,.btn,.callbtn,.wm-name,h1,h2,h3,h4{font-family:"Be Vietnam Pro",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}
a{color:var(--a);text-decoration:none}a:hover{text-decoration:underline}
img{max-width:100%;height:auto;border-radius:16px}
h1{font-size:clamp(30px,5.2vw,50px);line-height:1.08;letter-spacing:-.025em;font-weight:800;margin:.15em 0}
h2{font-size:clamp(23px,3.2vw,32px);line-height:1.18;letter-spacing:-.02em;font-weight:780;margin:1.7em 0 .5em}
h3{font-size:19px;font-weight:700;letter-spacing:-.01em;margin:1.3em 0 .4em}p{margin:.7em 0}
/* wordmark — uppercase two-tone + subtitle rule */
.wm{display:flex;flex-direction:column;gap:3px;line-height:1}
.wm-row{display:flex;align-items:center;gap:9px}
.wm-mark{width:11px;height:25px;border-radius:3px;background:linear-gradient(180deg,var(--a),var(--a2));box-shadow:0 2px 8px #7c3aed55;flex:0 0 auto}
.wm-name{font-weight:900;font-size:19px;letter-spacing:.005em;white-space:nowrap}
.wm-1{color:var(--ink)}.wm-2{color:var(--a)}
.wm-sub{display:flex;align-items:center;gap:8px;font-size:9px;font-weight:800;letter-spacing:.26em;color:var(--mut);padding-left:20px}
.wm-sub i{height:1.5px;flex:1;min-width:12px;background:var(--line);border-radius:2px}
/* header */
header.site{position:sticky;top:0;z-index:30;background:#fffffff2;backdrop-filter:saturate(1.6) blur(8px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;gap:16px;height:76px;flex-wrap:nowrap}
.brand{display:flex;align-items:center;flex:0 0 auto}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;flex:0 0 auto}
.burger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.2s}
.menu{display:flex;align-items:center;gap:4px;flex:1 1 auto;justify-content:center;min-width:0;flex-wrap:nowrap;white-space:nowrap}
.menu>a,.droptop{color:var(--ink);font-weight:700;font-size:13.5px;letter-spacing:.03em;padding:10px 13px;border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.menu>a:hover,.drop:hover .droptop{color:var(--a);background:var(--soft);text-decoration:none}
.droptop em{font-style:normal;font-size:10px;opacity:.7}
.drop{position:relative;padding-bottom:6px;margin-bottom:-6px}
.submenu{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 48px -16px #0b122040;padding:10px 8px;min-width:250px;display:none;flex-direction:column;z-index:40}
.drop::after{content:"";position:absolute;top:100%;left:0;right:0;height:12px}
.drop:hover .submenu,.drop:focus-within .submenu{display:flex}
.submenu a{padding:11px 14px;border-radius:9px;font-size:14.5px;font-weight:600;color:var(--ink);white-space:nowrap}
.submenu a:hover{background:var(--soft);color:var(--a);text-decoration:none}
.callbtn{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(180deg,var(--a),var(--a2));color:#fff;padding:12px 18px;border-radius:12px;font-weight:800;white-space:nowrap;box-shadow:0 8px 20px #7c3aed45}
.callbtn:hover{text-decoration:none;transform:translateY(-1px)}
.dot{width:8px;height:8px;border-radius:50%;background:#7CFFB2;box-shadow:0 0 0 0 #7CFFB2;animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 #7cffb2aa}70%{box-shadow:0 0 0 7px #7cffb200}100%{box-shadow:0 0 0 0 #7cffb200}}
/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(180deg,var(--a),var(--a2));color:#fff;padding:14px 24px;border-radius:14px;font-weight:700;font-size:15.5px;box-shadow:0 10px 26px #7c3aed45;transition:transform .15s,box-shadow .15s}
.btn:hover{text-decoration:none;transform:translateY(-2px);box-shadow:0 16px 34px #7c3aed55}
.btn.ghost{background:#fff;color:var(--a);border:1.6px solid #7c3aed55;box-shadow:none}
.btn.ghost:hover{border-color:var(--a);background:var(--soft)}
.btn.light{background:#fff;color:var(--a);box-shadow:0 10px 26px #0003}
/* hero */
.hero{position:relative;background:radial-gradient(1200px 500px at 80% -10%,#7c3aed1f,transparent),linear-gradient(180deg,var(--soft),#fff);border-bottom:1px solid var(--line)}
.herogrid{display:grid;grid-template-columns:1.15fr .85fr;gap:52px;align-items:center;padding:64px 28px}
.eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--a);background:#7c3aed14;border:1px solid #7c3aed33;padding:6px 12px;border-radius:999px;margin-bottom:16px}
.lead{font-size:19.5px;color:var(--mut);max-width:54ch}
.cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:26px}
.trust{margin-top:20px;color:var(--mut);font-size:14px;font-weight:600}
.heroimg img{width:100%;height:auto;aspect-ratio:7/5;object-fit:cover;border-radius:22px;box-shadow:0 30px 60px -20px #0b122055}
/* content */
.content{padding:34px 28px 8px;max-width:1080px}
.content img{width:100%;max-height:380px;object-fit:cover;margin:18px 0;box-shadow:0 16px 34px -22px #0b122055}
.content ul{padding-left:20px}.content li{margin:.32em 0}
.content a[href^="tel:"]{font-weight:700}
.inlineband{background:linear-gradient(120deg,var(--a),var(--a2));color:#fff;border-radius:18px;padding:22px 26px;margin:26px 0;font-size:18px;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.inlineband a{color:#fff}
/* faq */
.faq{padding:18px 0 6px}.faq .wrap{max-width:920px}
.faq details{border:1px solid var(--line);border-radius:14px;padding:4px 18px;margin:10px 0;background:var(--soft)}
.faq summary{cursor:pointer;font-weight:700;padding:14px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--a);font-size:22px;line-height:1}
.faq details[open] summary::after{content:"–"}
/* map + band */
.mapsec{padding:46px 0;background:var(--soft)}.nap{color:var(--mut)}
.map{width:100%;height:400px;border:0;border-radius:18px;margin-top:14px}
.band{background:linear-gradient(120deg,var(--a),var(--a2));color:#fff;text-align:center;padding:54px 22px;margin-top:40px}
.band h2{margin:0 0 8px;color:#fff}.band p{opacity:.92;margin:0 0 20px;font-size:18px}
.bandcta{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.btn.ghostlight{background:transparent;color:#fff;border:1.7px solid #ffffff99;box-shadow:none}
.btn.ghostlight:hover{background:#ffffff22;border-color:#fff}
.bandtrust{color:#ffffffdd;font-size:14px;font-weight:600}
/* footer */
footer.site{background:#0b1220;color:#aab4c8;padding:46px 0 26px}
.footgrid{display:flex;justify-content:space-between;gap:28px;flex-wrap:wrap}
.fbrand .wm-1{color:#fff}.fbrand p{margin:12px 0 0;font-size:14px}footer a{color:#cdd6e6}
.fmenu{display:flex;gap:8px 18px;flex-wrap:wrap;align-items:flex-start}.fmenu a{display:inline-block;padding:7px 2px}
.copy{margin-top:24px;border-top:1px solid #1b2740;padding-top:16px;font-size:13px;color:#7a86a0}
/* cards (blog + service area) */
.section{padding:46px 0}.section .wrap{max-width:1080px}
.lede{font-size:18px;color:var(--mut);max-width:64ch}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px;margin-top:26px}
.card{display:block;border:1px solid var(--line);border-radius:16px;padding:22px;background:#fff;box-shadow:0 10px 26px -20px #0b122055;transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-3px);box-shadow:0 18px 36px -20px #0b122066;text-decoration:none}
.card h3{margin:.1em 0 .3em;color:var(--ink)}.card p{color:var(--mut);font-size:14.5px;margin:0}
.card .go{color:var(--a);font-weight:700;font-size:14px;margin-top:12px;display:inline-block}
.empty{border:1.5px dashed var(--line);border-radius:18px;padding:48px;text-align:center;color:var(--mut);background:var(--soft)}
.related{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:22px 28px;border-top:1px solid var(--line);padding-top:30px}
.related h3{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--mut)}
.related ul{list-style:none;padding:0;margin:0}.related li{margin:7px 0;font-size:14.5px;line-height:1.4}
.postmeta{color:var(--mut);font-size:14px;margin:6px 0 0}.tagrow{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}
.tag{font-size:12.5px;font-weight:600;color:var(--a);background:#7c3aed12;border:1px solid #7c3aed30;padding:5px 11px;border-radius:999px}
.post{max-width:760px}.post h2{margin-top:1.5em}.post ul{padding-left:20px}.post li{margin:.4em 0}
/* sticky mobile call */
.stickycall{display:none}
/* ≤999 — TABLET + MOBILE: hamburger nav; wordmark can shrink so the call button is never clipped */
@media(max-width:999px){
 .burger{display:flex}
 .menu{position:absolute;top:76px;left:0;right:0;display:none;flex-direction:column;align-items:stretch;gap:0;margin:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 24px 40px -16px #0b122033;padding:8px}
 body.navopen .menu{display:flex}
 .menu>a,.droptop{padding:15px 12px;font-size:15px}
 .drop{position:static;padding:0;margin:0}.drop::after{display:none}
 .submenu{position:static;display:flex;box-shadow:none;border:0;padding:0 0 6px 12px;min-width:0}
 .submenu a{padding:11px 12px;font-size:14px}
 .bar{gap:14px}
 .brand{flex:1 1 auto;min-width:0;overflow:hidden}
 .wm{min-width:0;max-width:100%}.wm-row{min-width:0}
 .wm-name{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
 .callbtn{flex:0 0 auto;margin-left:6px}
 .herogrid{grid-template-columns:1fr;padding:40px 22px}
}
/* ≤767 — MOBILE: compact ICON call button (always fully visible) + bottom sticky bar with the full number */
@media(max-width:767px){
 .wm-name{font-size:16px}
 .wm-sub{display:none}
 .callbtn{display:none}                 /* mobile: top call button removed — the bottom sticky bar handles calls, logo shows in full */
 h1{font-size:clamp(26px,7vw,38px)}
 .stickycall{display:flex;position:fixed;left:12px;right:12px;bottom:12px;z-index:50;justify-content:center;gap:8px;background:linear-gradient(180deg,var(--a),var(--a2));color:#fff;padding:15px;border-radius:16px;font-weight:800;box-shadow:0 14px 30px #7c3aed66}
 body{padding-bottom:80px}
}