:root{
  --primary:#2f43e6;       /* logo royal blue (brand accent) */
  --primary-dark:#2536c9;
  --accent:#0b1437;        /* deep space navy */
  --cyan:#19c8e6;          /* tech cyan highlight */
  --gold:#f5b921;          /* amber — used only for literal review stars */
  --navy:#0b1437;
  --navy-2:#16215f;
  --ink:#0a0e1f;
  --ink-2:#1a2238;
  --body:#5b6478;
  --muted:#9aa3b8;
  --line:#e7e9f5;
  --bg:#f7f8fc;            /* cool off-white — main background */
  --bg-soft:#eef0fb;       /* soft lavender — alternating sections */
  --bg-tint:#f1effe;
  --card:#ffffff;
  --radius:18px;
  --shadow-sm:0 4px 14px -6px rgba(20,24,55,.14);
  --shadow:0 18px 44px -18px rgba(20,24,55,.24);
  --shadow-lg:0 40px 90px -30px rgba(20,24,55,.42);
  --ring:0 0 0 4px rgba(47,67,230,.14);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px;-webkit-text-size-adjust:100%}
img,svg{max-width:100%;display:inline-block}
body{
  font-family:'Red Hat Display',system-ui,sans-serif;
  color:var(--body);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Red Hat Display',sans-serif;color:var(--ink);line-height:1.12;font-weight:800;letter-spacing:-.02em}
a{text-decoration:none;color:inherit}
.wrap{max-width:1240px;margin:0 auto;padding:0 24px}

/* ---------- buttons ---------- */
.btn-primary{background:linear-gradient(135deg,var(--primary),#6d5ef0);color:#fff;font-weight:700;padding:13px 24px;border-radius:12px;border:none;cursor:pointer;font-size:15px;font-family:inherit;transition:.22s;display:inline-block;box-shadow:0 10px 26px -10px rgba(47,67,230,.7)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px -12px rgba(47,67,230,.8)}
.btn-primary.block{width:100%}
.btn-outline{display:inline-block;padding:13px 24px;border-radius:12px;font-weight:700;font-size:15px;border:1.5px solid var(--line);color:var(--ink);background:#fff;transition:.22s;text-align:center}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-tint)}
.btn-outline.block{width:100%}
.btn-light{background:#fff;color:var(--primary);font-weight:800;padding:15px 30px;border-radius:12px;transition:.22s;display:inline-block;white-space:nowrap;box-shadow:var(--shadow)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}

/* ---------- header (over dark hero) ---------- */
.header{position:absolute;top:0;left:0;right:0;z-index:50;transition:.25s}
.header.scrolled{position:fixed;background:var(--navy);box-shadow:0 8px 30px -12px rgba(0,0,0,.5)}
.header-inner{display:flex;align-items:center;gap:22px;height:88px}
.logo{display:inline-flex;align-items:center;line-height:0;transition:.2s}
.logo:hover{transform:translateY(-1px)}
.logo img{height:54px;width:auto;display:block;border-radius:12px}
.sf-brand .logo img{height:72px;border-radius:16px}
.tech-pill{display:inline-block;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff;font-weight:700;font-size:16px;padding:3px 14px;border-radius:999px;margin:0 2px}
.nav{display:flex;align-items:center;gap:4px;margin-left:auto}
.consult-btn{background:var(--primary);color:#fff;font-weight:800;font-size:14px;padding:11px 18px;border-radius:8px;transition:.2s;white-space:nowrap}
.consult-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.nav-item{position:relative}
.nav-item>a{display:flex;align-items:center;gap:5px;padding:10px 13px;font-weight:600;font-size:14.5px;color:#eaf0fb;border-radius:10px;transition:.18s;white-space:nowrap}
.nav-item>a i{font-size:9px;color:#9fb2d6;font-style:normal}
.nav-item:hover>a{color:#fff;background:rgba(255,255,255,.1)}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:230px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(10px);transition:.2s}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:10px 13px;border-radius:9px;font-size:14px;font-weight:500;color:var(--body);transition:.15s}
.dropdown a:hover{background:var(--bg-tint);color:var(--primary);padding-left:18px}
.header-cta{display:flex;align-items:center;gap:10px}
.btn-login{padding:9px 24px;font-weight:700;font-size:14.5px;color:#fff;border:1.5px solid rgba(255,255,255,.5);border-radius:8px;transition:.2s}
.btn-login:hover{background:#fff;color:var(--navy)}
.hamburger{display:none;background:none;border:none;font-size:26px;cursor:pointer;color:#fff}

/* ---------- 1 · HERO (Zolvit-style) ---------- */
.hero{position:relative;background:linear-gradient(160deg,#0b1437 0%,#2f43e6 60%,#6c2bd9 135%);padding:130px 0 0;text-align:center;overflow:hidden}
.float-shape{position:absolute;border:1.5px solid rgba(255,255,255,.06);border-radius:8px;transform:rotate(45deg);pointer-events:none;background:rgba(255,255,255,.015)}
.float-shape.s1{width:70px;height:70px;top:160px;left:13%;animation:bob 7s ease-in-out infinite}
.float-shape.s2{width:90px;height:90px;top:140px;right:13%;animation:bob 8s ease-in-out infinite .6s}
.float-shape.s3{width:60px;height:60px;top:300px;left:20%;animation:bob 6.5s ease-in-out infinite .3s}
.float-shape.s4{width:80px;height:80px;top:280px;right:20%;animation:bob 7.5s ease-in-out infinite .9s}
.float-shape.s5{width:64px;height:64px;top:520px;left:9%;animation:bob 8.5s ease-in-out infinite .2s}
.float-shape.s6{width:76px;height:76px;top:540px;right:9%;animation:bob 7s ease-in-out infinite .7s}
@keyframes bob{0%,100%{transform:rotate(45deg) translateY(0)}50%{transform:rotate(45deg) translateY(-16px)}}
.hero-inner{position:relative;z-index:2}

/* reviews badge */
.reviews-badge{display:inline-flex;align-items:center;gap:10px;color:#fff;font-size:15px;margin-bottom:34px}
.g-logo{width:34px;height:34px;border-radius:50%;background:#fff;display:grid;place-items:center;font-weight:900;font-size:18px;background:conic-gradient(from -45deg,#ea4335,#fbbc05,#34a853,#4285f4,#ea4335);-webkit-background-clip:text;background-clip:text;color:transparent;border:none;position:relative}
.g-logo::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 2px #fff inset}
.avatars{display:flex}
.avatars span{width:30px;height:30px;border-radius:50%;border:2px solid var(--navy);background:linear-gradient(135deg,#2f43e6,#6c2bd9);display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;margin-left:-9px}
.avatars span:first-child{margin-left:0}
.reviews-badge .stars{color:var(--gold);letter-spacing:1px;font-size:17px;display:inline-flex;align-items:center;line-height:1}
.reviews-badge .half{opacity:.45}
.reviews-badge strong{font-weight:800;font-size:16px}
.rev-count{color:#cdd9ef}

.hero h1{font-size:60px;font-weight:800;color:#fff;letter-spacing:-.01em;margin-bottom:26px}
.hero h1 .brand{color:#fff}
.hero-sub{font-size:19px;color:#dbe5f7;font-weight:500;max-width:640px;margin:0 auto 40px;line-height:1.7}
.ai-pill{display:inline-block;background:linear-gradient(135deg,#2f43e6,#6c2bd9);color:#fff;font-weight:700;font-size:16px;padding:3px 14px;border-radius:999px;margin:0 2px}

/* primary CTA button */
.hero-actions{margin-bottom:24px}
.btn-hero{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--accent);font-weight:800;font-size:18px;padding:17px 40px;border-radius:12px;border:2px solid #fff;transition:.22s;box-shadow:0 18px 44px -14px rgba(0,0,0,.5)}
.btn-hero i{font-style:normal;transition:.2s}
.btn-hero:hover{transform:translateY(-2px);background:var(--cyan);border-color:var(--cyan);color:var(--accent);box-shadow:0 26px 56px -14px rgba(25,200,230,.6)}
.btn-hero:hover i{transform:translateX(5px)}
.btn-hero:hover i{transform:translateX(5px)}
.hero-chips{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;margin-bottom:74px}
.hero-chips a{border:1px solid rgba(255,255,255,.3);color:#eaf0fb;padding:9px 20px;border-radius:8px;font-weight:600;font-size:14px;transition:.18s}
.hero-chips a:hover{background:#fff;color:var(--navy);border-color:#fff}

/* three tilted overlapping cards */
.hero-cards{position:relative;z-index:1;display:flex;justify-content:center;align-items:flex-end;gap:0;max-width:1080px;margin:0 auto;height:300px}
.hcard{position:relative;width:360px;background:#fff;border-radius:20px;padding:30px 30px 0;box-shadow:0 30px 70px -24px rgba(0,0,0,.6);text-align:left;height:300px;overflow:hidden;transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s}
.hcard h3{font-size:25px;font-weight:800;color:var(--navy);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.hcard h3 i{color:var(--navy);font-style:normal;font-size:18px}
.hcard p{font-size:16px;color:#5b6478;line-height:1.55;max-width:280px}
.hcard-mini{margin-top:18px;background:#f4f6fd;border:1px solid var(--line);border-radius:12px 12px 0 0;padding:16px;font-weight:700;color:var(--ink);font-size:14px;display:flex;flex-direction:column;gap:2px}
.hcard-mini small{font-weight:500;color:var(--muted);font-size:12px;padding-left:26px}
.mini-row{display:flex;align-items:center;gap:8px;color:var(--ink)}
.mini-row svg{width:18px;height:18px;stroke-width:2.2;color:var(--primary)}
.hcard.left{transform:rotate(-7deg) translateY(34px);z-index:1}
.hcard.right{transform:rotate(7deg) translateY(34px);z-index:1}
.hcard.center{z-index:3;transform:translateY(-14px);box-shadow:0 40px 80px -22px rgba(0,0,0,.7)}
.hcard.left{margin-right:-46px}
.hcard.right{margin-left:-46px}

/* hover: lift the card up to reveal its hidden lower half */
.hcard:hover{z-index:6;box-shadow:0 50px 100px -20px rgba(0,0,0,.75)}
.hcard.left:hover{transform:rotate(-3deg) translateY(-150px)}
.hcard.right:hover{transform:rotate(3deg) translateY(-150px)}
.hcard.center:hover{transform:translateY(-185px)}

/* curved black divider band — rises up to clip the lower half of the cards */
.curve-band{position:relative;z-index:4;background:#000;margin-top:-150px;padding:200px 0 70px;border-radius:50% 50% 0 0/90px 90px 0 0}
.curve-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:30px}
.curve-quote{color:#fff}
.curve-quote p{font-size:19px;font-weight:600;line-height:1.5;margin-bottom:14px;max-width:330px}
.curve-quote span{color:#cdd9ef;font-size:15px}
.curve-quote a{color:#fff;text-decoration:underline;font-weight:700}
.award{text-align:center;color:#fff}
.laurel{display:inline-flex;align-items:center;gap:14px}
.laurel-l,.laurel-r{font-size:90px;color:#fff;line-height:.7;opacity:.92;font-family:Georgia,serif}
.award-text{display:flex;flex-direction:column;align-items:center;gap:3px}
.award-stars{color:var(--gold);font-size:22px;letter-spacing:2px}
.award-text small{font-size:12px;color:#dbe5f7;letter-spacing:.05em}
.award-text strong{font-size:16px;font-weight:800;line-height:1.25;letter-spacing:.04em}
.curve-google{display:flex;align-items:center;gap:14px;justify-self:end;color:#fff}
.g-circle{width:56px;height:56px;border-radius:50%;background:#fff;display:grid;place-items:center;font-weight:900;font-size:28px;background:conic-gradient(from -45deg,#ea4335,#fbbc05,#34a853,#4285f4,#ea4335);-webkit-background-clip:text;background-clip:text;color:transparent;position:relative;flex-shrink:0}
.g-circle::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 3px #fff inset}
.curve-google strong{font-size:18px;font-weight:700}
.cg-stars{color:var(--gold);font-size:16px;margin:2px 0}
.cg-stars b{color:#fff;font-size:15px}
.cg-stars .half{opacity:.45}
.curve-google small{color:#cdd9ef;font-size:13px}

/* ---------- 2 · categories + clients ---------- */
.stats-band{background:var(--bg);padding:54px 0 70px}
.cat-row{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-bottom:70px}
.cat-row.cat-row-3{grid-template-columns:repeat(3,1fr);max-width:880px;margin-left:auto;margin-right:auto}
.cat{display:flex;align-items:flex-start;gap:13px;padding:22px 20px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);transition:.22s}
.cat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.cat-ico{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:grid;place-items:center}
.cat-ico svg{width:20px;height:20px;stroke-width:2}
.cat-ico.green{background:#e7f5ec;color:#1f9d57}
.cat-ico.blue{background:#e7eefb;color:#2f43e6}
.cat-ico.purple{background:#efe9fb;color:#19c8e6}
.cat-ico.orange{background:#fdeede;color:#e0852b}
.cat-ico.teal{background:#e3f4f1;color:#13a99a}
.cat strong{display:block;font-size:16px;font-weight:800;color:var(--ink);margin-bottom:3px}
.cat span{font-size:13.5px;color:var(--muted);line-height:1.45}

.clients{text-align:center}
.clients .eyebrow{color:#8a93a6;margin-bottom:34px}
.clients-row{display:flex;align-items:center;gap:18px}
.client-logos{flex:1;display:flex;align-items:center;gap:54px;overflow:hidden;scroll-behavior:smooth}
.clogo{flex-shrink:0;font-weight:800;font-size:22px;color:#9aa3b8;letter-spacing:-.01em;white-space:nowrap;transition:.25s;filter:grayscale(1);opacity:.7}
.clogo:hover{filter:grayscale(0);opacity:1;color:var(--navy)}
.clients-next{flex-shrink:0;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);font-size:24px;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-sm);transition:.2s}
.clients-next:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ---------- section heads ---------- */
.eyebrow{display:inline-block;font-weight:800;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin-bottom:14px}
.section-head{text-align:center;max-width:680px;margin:0 auto 50px}
.section-head h2{font-size:40px;font-weight:800;margin-bottom:14px}
.section-head p{font-size:18px}

/* ---------- 3 · services ---------- */
.services{padding:96px 24px}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;transition:.25s;display:flex;flex-direction:column;overflow:hidden}
.service-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.25s}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.service-card:hover::before{opacity:1}
.service-card .ico{width:62px;height:62px;display:grid;place-items:center;background:linear-gradient(135deg,var(--bg-tint),#fff);border:1px solid var(--line);border-radius:16px;margin-bottom:18px;color:var(--primary)}
.service-card .ico svg{width:28px;height:28px;stroke-width:2}
.service-card h3{font-size:21px;margin-bottom:9px}
.service-card p{font-size:15px;flex:1}
.service-card .from{margin-top:18px;font-weight:800;color:var(--primary);font-size:15px;display:flex;align-items:center;gap:6px}
.service-card .from i{font-style:normal;transition:.2s}
.service-card:hover .from i{transform:translateX(5px)}

/* ---------- 4 · how ---------- */
.how{background:var(--bg-soft);padding:96px 0}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;transition:.25s}
.step:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.step .num{width:52px;height:52px;display:grid;place-items:center;border-radius:15px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:800;font-size:22px;margin-bottom:18px;box-shadow:0 10px 24px -8px rgba(47,67,230,.6)}
.step h3{font-size:21px;margin-bottom:9px}
.step p{font-size:15px}

/* ---------- zig-zag feature rows ---------- */
.zig{padding:40px 0 96px}
.zig-row{display:grid;grid-template-columns:1fr 1fr;gap:62px;align-items:center;margin-bottom:64px}
.zig-row:last-child{margin-bottom:0}
.zig-row.reverse .zig-visual{order:2}
.zig-visual{position:relative;border-radius:26px;min-height:340px;display:grid;place-items:center;overflow:hidden;box-shadow:var(--shadow)}
.zig-visual::after{content:"";position:absolute;bottom:-70px;left:-50px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.08)}
.zig-visual.v1{background:linear-gradient(155deg,var(--navy),#2f43e6)}
.zig-visual.v2{background:linear-gradient(155deg,#2f43e6,#19c8e6)}
.zig-visual.v3{background:linear-gradient(155deg,#0c1746,#13a99a)}
.zig-badge{position:absolute;top:22px;right:22px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--ink);font-weight:800;font-size:12.5px;padding:7px 14px;border-radius:999px;box-shadow:var(--shadow-sm)}
.zig-badge svg{width:14px;height:14px;color:#1f9d57}
.zig-mock{position:relative;z-index:1;background:#fff;border-radius:18px;padding:26px;width:74%;box-shadow:0 34px 70px -22px rgba(0,0,0,.5)}
.zm-ico{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),#6c2bd9);color:#fff;margin-bottom:16px}
.zm-ico svg{width:26px;height:26px}
.zig-mock strong{display:block;font-size:18px;color:var(--ink)}
.zm-sub{display:block;font-size:13px;color:var(--muted);margin:3px 0 18px}
.zm-bar{height:10px;border-radius:6px;background:var(--bg-soft);margin-bottom:9px}
.zm-bar.short{width:55%}
.zig-text .eyebrow{margin-bottom:12px}
.zig-text h2{font-size:34px;font-weight:800;margin-bottom:14px;line-height:1.15}
.zig-text>p{font-size:16.5px;margin-bottom:22px;max-width:520px}
.zig-list{list-style:none;margin-bottom:28px;display:grid;gap:12px}
.zig-list li{display:flex;align-items:center;gap:11px;font-size:15.5px;color:var(--ink-2);font-weight:600}
.zig-list li svg{width:20px;height:20px;flex-shrink:0;color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:6px;padding:3px}

@media(max-width:980px){
  .zig-row,.zig-row.reverse{grid-template-columns:1fr;gap:28px;margin-bottom:48px}
  .zig-row.reverse .zig-visual{order:0}
  .zig-visual{min-height:280px}
  .zig-text h2{font-size:28px}
}

/* ---------- AI-driven platform ---------- */
.ai-platform{padding:96px 0}
.ai-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.ai-visual{display:flex;justify-content:center}
.ai-orbit{position:relative;width:100%;max-width:440px;aspect-ratio:1}
.ai-ring{position:absolute;inset:13%;border:2px dashed #d4daf0;border-radius:50%}
.ai-ring.r2{inset:30%;border-color:#e3e7f6}
.ai-core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:86px;height:86px;border-radius:22px;background:linear-gradient(135deg,var(--primary),#6c2bd9);display:grid;place-items:center;color:#fff;box-shadow:0 24px 54px -12px rgba(47,67,230,.6);z-index:2}
.ai-core svg{width:40px;height:40px}
.ai-core::after{content:"";position:absolute;inset:-10px;border-radius:26px;background:radial-gradient(circle,rgba(47,67,230,.25),transparent 70%);z-index:-1}
.ai-node{position:absolute;width:56px;height:56px;border-radius:15px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--primary);box-shadow:var(--shadow-sm);transform:translate(-50%,-50%);animation:aifloat 6s ease-in-out infinite}
.ai-node svg{width:24px;height:24px}
.ai-node.n1{top:7%;left:50%;animation-delay:0s}
.ai-node.n2{top:27%;left:88%;animation-delay:.5s}
.ai-node.n3{top:73%;left:88%;animation-delay:1s}
.ai-node.n4{top:93%;left:50%;animation-delay:1.5s}
.ai-node.n5{top:73%;left:12%;animation-delay:2s}
.ai-node.n6{top:27%;left:12%;animation-delay:2.5s}
@keyframes aifloat{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 9px))}}
.ai-content .eyebrow{display:inline-flex;align-items:center;gap:7px}
.ai-content .eyebrow svg{width:16px;height:16px}
.ai-content h2{font-size:40px;font-weight:800;margin-bottom:16px;line-height:1.12}
.ai-content h2 .hl{color:var(--primary)}
.ai-lead{font-size:17px;margin-bottom:30px;max-width:540px}
.ai-features{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ai-feat{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:22px}
.ai-feat .af-ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);color:var(--primary);margin-bottom:14px}
.ai-feat .af-ico svg{width:21px;height:21px}
.ai-feat strong{display:block;font-size:16.5px;color:var(--ink);margin-bottom:7px}
.ai-feat p{font-size:14px;color:var(--body);margin:0}

/* ---------- 5 · why ---------- */
.why{padding:96px 24px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.why-copy h2{font-size:38px;font-weight:800;margin-bottom:14px}
.why-lead{font-size:17px;margin-bottom:26px}
.ticks{list-style:none;margin-bottom:30px}
.ticks li{position:relative;padding-left:38px;margin-bottom:16px;font-size:16px;color:var(--ink-2);font-weight:600}
.ticks li::before{content:"✓";position:absolute;left:0;top:1px;width:24px;height:24px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-radius:8px;display:grid;place-items:center;font-weight:800;font-size:13px}
.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;text-align:center;box-shadow:var(--shadow-sm);transition:.25s}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.stat strong{display:block;font-size:36px;font-weight:900;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px}
.stat span{font-size:13.5px;color:var(--muted)}

/* ---------- 6 · pricing ---------- */
.pricing{background:var(--bg-soft);padding:96px 0}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px 30px;display:flex;flex-direction:column;transition:.25s}
.price-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.price-card.featured{border:none;background:linear-gradient(180deg,var(--navy),#160e3d);color:#fff;box-shadow:var(--shadow-lg);transform:scale(1.04)}
.price-card.featured:hover{transform:scale(1.04) translateY(-5px)}
.price-card.featured h3,.price-card.featured .price{color:#fff}
.price-card.featured .price-desc{color:#aebbd6}
.price-card.featured ul li{color:#d4ddef}
.badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--primary),#6c2bd9);color:#fff;font-weight:800;font-size:12px;padding:6px 16px;border-radius:999px;box-shadow:0 8px 20px -6px rgba(47,67,230,.6)}
.price-card h3{font-size:22px;margin-bottom:6px}
.price-desc{font-size:14px;margin-bottom:20px;min-height:42px}
.price{font-size:38px;font-weight:900;color:var(--ink);margin-bottom:22px}
.price span{font-size:14px;font-weight:500;color:var(--muted)}
.price-card ul{list-style:none;margin-bottom:26px;flex:1}
.price-card ul li{position:relative;padding-left:26px;margin-bottom:12px;font-size:14.5px;color:var(--body)}
.price-card ul li::before{content:"✓";position:absolute;left:0;color:var(--primary);font-weight:800}
.price-card.featured ul li::before{color:#a5b4fc}

/* ---------- 7 · testimonials ---------- */
.testi{padding:96px 0}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;transition:.25s;box-shadow:var(--shadow-sm)}
.quote:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:14px;font-size:15px}
.quote p{font-size:16px;color:var(--ink-2);margin-bottom:22px;font-weight:500}
.quote figcaption{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted)}
.ava{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:800;font-size:17px}
.quote figcaption strong{display:block;color:var(--ink);font-weight:800;font-size:14.5px}

/* ---------- 8 · faq ---------- */
.faq{background:var(--bg-soft);padding:96px 0}
.faq-list{max-width:790px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:4px 24px;transition:.2s}
.faq-item[open]{border-color:#cfcaf8;box-shadow:var(--shadow-sm)}
.faq-item summary{display:flex;justify-content:space-between;align-items:center;gap:16px;cursor:pointer;list-style:none;padding:18px 0;font-weight:700;font-size:17px;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary i{font-style:normal;font-size:24px;color:var(--primary);transition:.25s;flex-shrink:0}
.faq-item[open] summary i{transform:rotate(45deg)}
.faq-item p{padding:0 0 20px;font-size:15px}

/* ---------- blog / articles ---------- */
.blog{padding:96px 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:.25s}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.blog-img{position:relative;height:168px;display:grid;place-items:center;color:rgba(255,255,255,.92)}
.blog-img svg{width:48px;height:48px}
.blog-img.g1{background:linear-gradient(135deg,var(--navy),#2f43e6)}
.blog-img.g2{background:linear-gradient(135deg,#2f43e6,#19c8e6)}
.blog-img.g3{background:linear-gradient(135deg,#0c1746,#13a99a)}
.blog-tag{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);color:var(--ink);font-size:12px;font-weight:800;padding:5px 12px;border-radius:999px}
.blog-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.blog-meta{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);margin-bottom:10px}
.blog-meta svg{width:15px;height:15px}
.blog-body h3{font-size:18.5px;line-height:1.3;margin-bottom:9px}
.blog-body p{font-size:14.5px;flex:1;margin-bottom:14px}
.blog-more{font-weight:800;color:var(--primary);font-size:14.5px;display:inline-flex;align-items:center;gap:6px}
.blog-more i{font-style:normal;transition:.2s}
.blog-card:hover .blog-more i{transform:translateX(5px)}

/* ---------- newsletter ---------- */
.newsletter{padding:0 0 90px}
.news-inner{background:linear-gradient(135deg,var(--navy),#16215f);border-radius:26px;padding:48px 52px;display:grid;grid-template-columns:1.3fr 1fr;gap:36px;align-items:center;color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.news-inner::before{content:"";position:absolute;top:-90px;right:-50px;width:280px;height:280px;border-radius:50%;background:rgba(47,67,230,.3)}
.news-copy{position:relative}
.news-eyebrow{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:#a9b6ff;margin-bottom:14px}
.news-eyebrow svg{width:15px;height:15px}
.news-copy h2{color:#fff;font-size:30px;font-weight:800;margin-bottom:10px;line-height:1.2}
.news-copy p{color:#c7cdf0;font-size:15.5px;max-width:480px}
.news-form{position:relative;display:flex;gap:10px;background:#fff;padding:8px;border-radius:14px;box-shadow:var(--shadow)}
.news-form input{flex:1;border:none;outline:none;padding:0 16px;font-size:15px;font-family:inherit;background:transparent;color:var(--ink)}
.news-form .btn-primary{white-space:nowrap}

@media(max-width:980px){
  .blog-grid{grid-template-columns:1fr 1fr}
  .news-inner{grid-template-columns:1fr;gap:24px;padding:38px 32px}
}
@media(max-width:760px){
  .blog-grid{grid-template-columns:1fr}
  .news-form{flex-direction:column}
  .news-form .btn-primary{width:100%}
  .news-copy h2{font-size:25px}
}

/* ---------- cta banner ---------- */
.cta-banner{padding:80px 0}
.cta-inner{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--navy),var(--primary) 90%);border-radius:28px;padding:54px;display:flex;justify-content:space-between;align-items:center;gap:32px;color:#fff;box-shadow:var(--shadow-lg)}
.cta-inner::before{content:"";position:absolute;top:-80px;right:-40px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.1)}
.cta-inner>div{position:relative}
.cta-inner h2{color:#fff;font-size:34px;font-weight:800;margin-bottom:6px}
.cta-inner p{color:rgba(255,255,255,.92);font-size:18px}
.cta-inner .btn-light{position:relative}

/* ---------- footer ---------- */
.footer{background:var(--ink);color:#9aa3c4;padding:66px 0 26px}
.footer .logo{color:#fff;flex-direction:row}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr 1fr;gap:34px;padding-bottom:42px;border-bottom:1px solid #1e2540}
.footer-brand p{font-size:14px;margin:16px 0 20px;max-width:290px;line-height:1.7}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;display:grid;place-items:center;background:#1a2138;border-radius:11px;color:#c3c9da;font-weight:700;transition:.2s}
.socials a:hover{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;transform:translateY(-2px)}
.footer-col h4{color:#fff;font-size:15px;margin-bottom:16px}
.footer-col a{display:block;font-size:14px;margin-bottom:11px;color:#9aa3c4;transition:.15s}
.footer-col a:hover{color:#fff;padding-left:4px}
.footer-bottom{display:flex;justify-content:space-between;padding-top:24px;font-size:13px;flex-wrap:wrap;gap:10px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:1100px){
  .nav{display:none}
  .hamburger{display:block}
  .nav.open{display:flex;position:absolute;top:88px;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--navy);padding:14px;gap:4px}
  .nav.open .nav-item>a{color:#eaf0fb}
  .nav.open .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:rgba(255,255,255,.05);margin-top:4px}
  .nav.open .dropdown a{color:#cdd9ef}
  .header-cta{margin-left:auto}
}
@media(max-width:980px){
  .hero h1{font-size:42px}
  .hero-cards{flex-direction:column;align-items:center;height:auto;gap:0;max-width:430px}
  .hcard{width:100%;max-width:none;height:auto;padding-bottom:26px;margin:0}
  .hcard.left{transform:rotate(-2.5deg);z-index:1}
  .hcard.center{transform:rotate(2deg);margin-top:-20px;z-index:3}
  .hcard.right{transform:rotate(-1.5deg);margin-top:-20px;z-index:2}
  /* keep the fan tilt on tap instead of the big desktop lift */
  .hcard.left:hover{transform:rotate(-2.5deg)}
  .hcard.center:hover{transform:rotate(2deg)}
  .hcard.right:hover{transform:rotate(-1.5deg)}
  .curve-band{margin-top:0;padding-top:80px}
  .curve-inner{grid-template-columns:1fr;text-align:center;gap:34px;justify-items:center}
  .curve-quote p{margin:0 auto 14px}
  .curve-google{justify-self:center}
  .service-grid,.steps,.testi-grid,.price-grid{grid-template-columns:1fr 1fr}
  .price-card.featured{transform:none}
  .price-card.featured:hover{transform:translateY(-5px)}
  .why{grid-template-columns:1fr;gap:42px}
  .ai-grid{grid-template-columns:1fr;gap:36px}
  .ai-visual{order:-1}
  .ai-orbit{max-width:360px}
  .ai-content h2{font-size:32px}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
  .cat-row{grid-template-columns:1fr 1fr 1fr;gap:24px}
  .cat:not(:last-child)::after{display:none}
}
@media(max-width:760px){
  .hero{padding-top:110px}
  .hero h1{font-size:32px}
  .hero-sub{font-size:16px}
  .reviews-badge{flex-wrap:wrap;justify-content:center;font-size:13px}
  .section-head h2{font-size:29px}
  .service-grid,.steps,.testi-grid,.price-grid,.footer-grid,.why-stats,.ai-features{grid-template-columns:1fr}
  .ai-content h2{font-size:27px}
  .cat-row{grid-template-columns:1fr 1fr;gap:20px}
  .cta-inner{flex-direction:column;text-align:center;padding:40px 26px}
  .float-shape{display:none}
}
@media(max-width:480px){
  .wrap{padding:0 16px}
  .header-inner{gap:12px}
  .logo img{height:46px}
  .hero{padding-top:96px}
  .hero h1{font-size:27px}
  .btn-hero{font-size:16px;padding:15px 28px}
  .hero-chips a{font-size:12.5px;padding:8px 14px}
  .reviews-badge .stars,.reviews-badge .rev-count{display:none}
  .section-head h2,.svc-sec .section-head h2,.zig-text h2,.why-copy h2,.ai-content h2{font-size:24px}
  .section-head p{font-size:16px}
  .cat-row{grid-template-columns:1fr;gap:14px}
  .blog-grid,.team{grid-template-columns:1fr}
  .stat-big strong{font-size:32px}
  .hcard h3{font-size:21px}
  .svc-hero-copy h1{font-size:30px}
  .cta-inner h2{font-size:26px}
  .float-wa,.float-chat{bottom:14px}
}

/* ============================================================
   SUBPAGES (About / Contact / Service detail)
   ============================================================ */
.header.solid{position:sticky;background:var(--navy);box-shadow:0 8px 30px -14px rgba(0,0,0,.4)}

.subhero{position:relative;background:linear-gradient(160deg,#0b1437 0%,#2f43e6 60%,#6c2bd9 140%);color:#fff;padding:140px 0 70px;text-align:center;overflow:hidden}
.subhero h1{color:#fff;font-size:48px;font-weight:800;margin-bottom:14px}
.subhero p{color:#dbe5f7;font-size:18px;max-width:640px;margin:0 auto}
.breadcrumb{display:flex;justify-content:center;gap:8px;font-size:14px;color:#aebbd6;margin-bottom:20px}
.breadcrumb a{color:#dbe5f7;font-weight:600}
.breadcrumb a:hover{color:#fff}

.page{padding:80px 0}
.page-narrow{max-width:820px;margin:0 auto;padding:0 24px}

/* About */
.about-lead{font-size:21px;line-height:1.7;color:var(--ink-2);font-weight:500;text-align:center;max-width:760px;margin:0 auto}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;padding:60px 0}
.about-grid h2{font-size:32px;margin-bottom:16px}
.about-grid p{font-size:16px;margin-bottom:14px}
.about-figure{background:linear-gradient(160deg,var(--navy),#2f43e6);border-radius:24px;min-height:330px;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.about-figure .big{font-size:60px;font-weight:900;letter-spacing:-.03em}
.about-figure .cap{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:#cdd9ef;font-size:14px}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:14px}
.value{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;transition:.25s}
.value:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.value .v-ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),#6c2bd9);color:#fff;margin-bottom:16px}
.value .v-ico svg{width:26px;height:26px}
.value h3{font-size:19px;margin-bottom:8px}
.value p{font-size:14.5px}
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:14px}
.member{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;text-align:center;transition:.25s}
.member:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.member .m-ava{width:80px;height:80px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;font-size:30px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent))}
.member strong{display:block;font-size:17px;color:var(--ink)}
.member span{font-size:13.5px;color:var(--muted)}

/* Founder card */
.founder-card{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:22px;padding:38px;box-shadow:var(--shadow-sm);max-width:880px;margin:0 auto}
.founder-ava{width:128px;height:128px;border-radius:24px;display:grid;place-items:center;font-size:46px;font-weight:900;color:#fff;background:linear-gradient(135deg,var(--primary),var(--cyan));box-shadow:0 18px 40px -16px rgba(47,67,230,.6)}
.founder-body h3{font-size:26px;margin-bottom:4px}
.founder-role{display:inline-block;font-weight:800;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:14px}
.founder-body p{font-size:16px;line-height:1.7}
@media(max-width:680px){.founder-card{grid-template-columns:1fr;text-align:center;justify-items:center;padding:30px 24px}}

/* Contact */
.contact-sec{padding:96px 0}
.hp-field{display:none}
.contact-wrap{display:grid;grid-template-columns:1fr 1.15fr;gap:40px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:18px}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;display:flex;gap:16px;align-items:flex-start;transition:.25s}
.info-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.info-card .i-ico{flex-shrink:0;width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--bg-tint);color:var(--primary)}
.info-card .i-ico svg{width:22px;height:22px}
.info-card strong{display:block;font-size:16px;color:var(--ink);margin-bottom:3px}
.info-card span{font-size:14.5px;color:var(--body)}
.contact-form{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:34px;box-shadow:var(--shadow-sm)}
.contact-form h3{font-size:23px;margin-bottom:6px}
.contact-form .muted{font-size:14.5px;color:var(--muted);margin-bottom:22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13.5px;font-weight:700;color:var(--ink-2);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:11px;font-size:15px;font-family:inherit;color:var(--ink);outline:none;background:var(--bg-soft);transition:.18s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.field textarea{resize:vertical;min-height:120px}
.form-success{text-align:center;padding:30px 8px}
.form-success .fs-ico{width:64px;height:64px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;background:#e7f5ec;color:#1f9d57}
.form-success .fs-ico svg{width:32px;height:32px}
.map-band{margin-top:50px;border-radius:20px;overflow:hidden;border:1px solid var(--line);height:300px;background:linear-gradient(135deg,#eef0fb,#dfe5fb);display:grid;place-items:center;color:var(--navy);font-weight:700}

/* Service detail */
.svc-layout{display:grid;grid-template-columns:1.6fr .9fr;gap:40px;align-items:start}
.svc-main h2{font-size:28px;margin:0 0 16px}
.svc-main h2:not(:first-child){margin-top:44px}
.svc-main p{font-size:16px;margin-bottom:14px}
.svc-features{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.svc-feature{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;gap:14px;align-items:flex-start}
.svc-feature .f-ico{flex-shrink:0;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),#6c2bd9);color:#fff}
.svc-feature .f-ico svg{width:20px;height:20px}
.svc-feature strong{display:block;font-size:16px;color:var(--ink);margin-bottom:3px}
.svc-feature span{font-size:14px;color:var(--body)}
.svc-docs{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.svc-docs li{position:relative;padding-left:30px;font-size:15.5px;color:var(--ink-2)}
.svc-docs li svg{position:absolute;left:0;top:2px;width:19px;height:19px;color:var(--primary)}
.svc-steps{display:flex;flex-direction:column;margin-top:8px}
.svc-step{display:flex;gap:18px;padding-bottom:26px;position:relative}
.svc-step:not(:last-child)::before{content:"";position:absolute;left:21px;top:46px;bottom:-4px;width:2px;background:var(--line)}
.svc-step .s-num{flex-shrink:0;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:800;z-index:1}
.svc-step h4{font-size:17px;margin-bottom:4px}
.svc-step p{font-size:14.5px;margin:0}
.svc-side{position:sticky;top:96px}
.price-box{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px;box-shadow:var(--shadow)}
.price-box .tag{font-size:13px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.08em}
.price-box .amt{font-size:40px;font-weight:900;color:var(--ink);margin:6px 0 2px}
.price-box .amt small{font-size:15px;font-weight:600;color:var(--muted)}
.price-box .note{font-size:13.5px;color:var(--muted);margin-bottom:20px}
.price-box ul{list-style:none;margin:0 0 22px}
.price-box ul li{position:relative;padding-left:26px;margin-bottom:11px;font-size:14.5px;color:var(--body)}
.price-box ul li svg{position:absolute;left:0;top:2px;width:18px;height:18px;color:#1f9d57}
.price-box .btn-primary{width:100%;text-align:center;margin-bottom:10px}
.price-box .reassure{text-align:center;font-size:12.5px;color:var(--muted)}

@media(max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:30px}
  .values{grid-template-columns:1fr}
  .team{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr}
  .svc-layout{grid-template-columns:1fr}
  .svc-side{position:static}
  .subhero h1{font-size:34px}
}
@media(max-width:760px){
  .svc-features,.svc-docs,.form-row,.team{grid-template-columns:1fr}
}

/* ============================================================
   MEGA FOOTER + floating buttons
   ============================================================ */
.site-footer{background:#080b14;color:#8b93a7;padding:62px 0 0;position:relative;overflow:hidden}
.sf-main{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr 1.15fr;gap:34px;padding-bottom:46px}
.sf-brand .logo{color:#fff;flex-direction:column}
.sf-brand .logo span{color:var(--primary)}
.sf-brand p{font-size:14px;margin:18px 0;max-width:290px;line-height:1.7}
.sf-rating{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#1a2238;border-radius:10px;padding:8px 14px;font-weight:800;font-size:14px;margin-bottom:20px}
.sf-rating .g{width:20px;height:20px;border-radius:50%;background:conic-gradient(from -45deg,#ea4335,#fbbc05,#34a853,#4285f4,#ea4335);-webkit-background-clip:text;background-clip:text;color:transparent;display:grid;place-items:center;font-weight:900;position:relative}
.sf-rating .g::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 1.5px #1a2238 inset}
.sf-rating .st{color:var(--gold);letter-spacing:1px;font-size:13px}
.sf-social{display:flex;gap:10px}
.sf-social a{width:38px;height:38px;border-radius:9px;background:#141a2a;display:grid;place-items:center;color:#aeb6c8;font-weight:700;font-size:15px;transition:.2s}
.sf-social a:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}
.sf-col h4{color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px;font-weight:800}
.sf-col a{display:block;font-size:14.5px;margin-bottom:13px;color:#8b93a7;transition:.15s}
.sf-col a:hover{color:#fff;padding-left:3px}
.sf-contact .ci{display:flex;gap:11px;align-items:flex-start;margin-bottom:15px;font-size:14.5px;color:#aeb6c8}
.sf-contact .ci svg{width:18px;height:18px;flex-shrink:0;color:var(--gold);margin-top:2px}
.sf-contact .ci a{color:#aeb6c8}
.sf-contact .ci a:hover{color:#fff}
.sf-maps{display:inline-flex;align-items:center;gap:8px;border:1px solid #2a3147;border-radius:9px;padding:9px 15px;color:#cdd3e0;font-size:13.5px;font-weight:600;margin-top:4px;transition:.2s}
.sf-maps svg{width:16px;height:16px}
.sf-maps:hover{border-color:var(--primary);color:#fff;background:#0f1422}
.sf-legal{border-top:1px solid #141a2a;padding:24px 0;font-size:13px;color:#6f7686;line-height:1.7}
.sf-disclaimer{border:1px solid #1a2133;border-radius:14px;padding:22px 26px;margin-bottom:22px}
.sf-disclaimer p{font-size:13px;color:#7a8295;line-height:1.75;margin-bottom:14px}
.sf-disclaimer p:last-child{margin-bottom:0}
.sf-disclaimer strong{color:#b3bacb}
.sf-disclaimer .hl{color:var(--gold);font-weight:700}
.sf-disclaimer a{color:var(--gold);text-decoration:underline}
.sf-agree{font-size:13px;color:#7a8295;padding-bottom:18px}
.sf-agree a{color:#9aa3b8;text-decoration:underline}
.sf-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #141a2a;padding:20px 0 24px;font-size:13px;color:#6f7686;flex-wrap:wrap;gap:14px}
.sf-badges{display:flex;gap:24px}
.sf-badge{display:flex;align-items:center;gap:7px;font-size:13px}
.sf-badge svg{width:16px;height:16px}
.sf-badge.v svg{color:#22c55e}
.sf-badge.m svg{color:var(--gold)}
.sf-watermark{text-align:center;font-weight:900;font-size:clamp(80px,18vw,230px);color:rgba(255,255,255,.022);line-height:.8;letter-spacing:-.05em;padding:6px 0 26px;user-select:none;pointer-events:none}
.sf-watermark b{color:rgba(47,67,230,.07)}

/* floating buttons */
.float-wa,.float-chat{position:fixed;bottom:24px;z-index:90;display:grid;place-items:center;border-radius:50%;box-shadow:0 14px 34px -10px rgba(0,0,0,.45);transition:.2s}
.float-wa{left:24px;width:56px;height:56px;background:#25d366;color:#fff}
.float-wa:hover{transform:scale(1.08)}
.float-wa svg{width:30px;height:30px}
.float-chat{right:24px;width:58px;height:58px;background:#fff;border:2px solid var(--primary);color:var(--navy);font-weight:900;font-size:13px;letter-spacing:-.02em}
.float-chat span b{color:var(--primary)}
.float-chat:hover{transform:scale(1.06)}

@media(max-width:980px){
  .sf-main{grid-template-columns:1fr 1fr;gap:30px 24px}
  .sf-brand{grid-column:1/-1}
  .sf-bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){
  .sf-main{grid-template-columns:1fr}
  .float-wa,.float-chat{width:50px;height:50px;bottom:18px}
  .float-wa{left:16px}.float-chat{right:16px;font-size:11px}
}

/* ============================================================
   SERVICE PAGE — long-form, tabbed
   ============================================================ */
.svc-hero{text-align:left;padding-bottom:64px}
.svc-hero .breadcrumb{justify-content:flex-start}
.svc-hero-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:48px;align-items:center}
.svc-hero-copy h1{font-size:42px;margin-bottom:14px}
.svc-hero-copy>p{color:#dbe5f7;font-size:18px;margin:0 0 22px;max-width:560px}
.svc-hero-points{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;margin-bottom:28px}
.svc-hero-points li{display:flex;align-items:center;gap:9px;color:#eaf0fb;font-weight:600;font-size:15px}
.svc-hero-points svg{width:18px;height:18px;color:#7dd87f;flex-shrink:0}
.svc-hero-cta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.svc-hero-price{color:#dbe5f7;font-size:15px}
.svc-hero-price strong{color:#fff;font-size:22px;font-weight:800;margin-left:4px}
.svc-hero-card{background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);padding:28px}
.svc-hero-card h3{font-size:21px;margin-bottom:4px}
.svc-hero-card .muted{font-size:14px;color:var(--muted);margin-bottom:18px}
.svc-hero-card form{display:flex;flex-direction:column;gap:12px}
.svc-hero-card input{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:11px;font-size:15px;font-family:inherit;color:var(--ink);outline:none;background:var(--bg-soft);transition:.18s}
.svc-hero-card input:focus{border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.svc-hero-card .reassure{text-align:center;font-size:12px;color:var(--muted)}

/* sticky tab bar */
.svc-tabs-wrap{position:sticky;top:88px;z-index:40;background:rgba(251,247,240,.9);backdrop-filter:blur(10px);padding:14px 0;border-bottom:1px solid var(--line)}
.svc-tabs{display:flex;gap:4px;background:var(--bg-tint);border:1px solid #e2e2fb;border-radius:14px;padding:6px;overflow-x:auto;scrollbar-width:none}
.svc-tabs::-webkit-scrollbar{display:none}
.svc-tabs a{flex-shrink:0;padding:10px 18px;border-radius:10px;font-weight:700;font-size:14.5px;color:var(--ink-2);white-space:nowrap;transition:.18s}
.svc-tabs a:hover{color:var(--primary)}
.svc-tabs a.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}

/* sections */
.svc-sec{padding:66px 0;scroll-margin-top:150px}
.svc-sec.alt{background:var(--bg-soft)}
.svc-sec .section-head{margin-bottom:38px}
.svc-sec .section-head h2{font-size:32px}

/* overview */
.overview-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:36px;align-items:start}
.overview-text p{font-size:16.5px;line-height:1.8;color:var(--body)}
.qf-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px 26px;box-shadow:var(--shadow-sm)}
.qf-card h4{font-size:17px;margin-bottom:14px}
.qf-table{width:100%;border-collapse:collapse}
.qf-table td{padding:11px 0;font-size:14.5px;border-bottom:1px solid var(--line);vertical-align:top}
.qf-table tr:last-child td{border-bottom:none}
.qf-table td:first-child{color:var(--muted);width:46%}
.qf-table td:last-child{color:var(--ink);font-weight:600;text-align:right}

/* pricing hero card */
.pricing-hero{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.ph-left{background:linear-gradient(165deg,var(--navy),#2a1c7a);color:#fff;padding:34px 32px}
.ph-left .tag{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#a9b6ff}
.ph-left .amt{font-size:42px;font-weight:900;margin:8px 0 4px;color:#fff}
.ph-left .amt small{font-size:15px;font-weight:600;color:#c7cdf0}
.ph-left .note{font-size:14px;color:#c7cdf0;margin-bottom:20px}
.ph-includes{list-style:none;margin:0 0 24px}
.ph-includes li{position:relative;padding-left:26px;margin-bottom:11px;font-size:14.5px;color:#e7ebfb}
.ph-includes li svg{position:absolute;left:0;top:2px;width:17px;height:17px;color:#7dd87f}
.ph-left .btn-primary{background:#fff;color:var(--navy);box-shadow:none}
.ph-left .btn-primary:hover{background:#f0f2ff}
.ph-right{background:var(--card);padding:34px 32px}
.ph-right h4{font-size:18px;margin-bottom:16px}
.cost-table{width:100%;border-collapse:collapse;margin-bottom:18px}
.cost-table td{padding:12px 0;font-size:14.5px;border-bottom:1px solid var(--line)}
.cost-table tr:last-child td{border-bottom:none}
.cost-table td:last-child{text-align:right;font-weight:700;color:var(--ink)}
.cost-table td:first-child{color:var(--body)}
.ph-right .reassure{font-size:12.5px;color:var(--muted);text-align:center}

/* wide steps (4 across) */
.svc-steps.wide{flex-direction:row;flex-wrap:wrap;gap:24px}
.svc-steps.wide .svc-step{flex:1;min-width:220px;flex-direction:column;padding-bottom:0}
.svc-steps.wide .svc-step::before{display:none}

/* tick lists */
.tick-list{list-style:none;display:grid;gap:14px}
.tick-list.two{grid-template-columns:1fr 1fr;gap:14px 32px}
.tick-list li{position:relative;padding-left:34px;font-size:15.5px;color:var(--ink-2);font-weight:500}
.tick-list li svg{position:absolute;left:0;top:2px;width:20px;height:20px;color:var(--primary)}

@media(max-width:980px){
  .svc-hero-grid{grid-template-columns:1fr;gap:32px}
  .svc-hero-card{max-width:460px}
  .overview-grid{grid-template-columns:1fr;gap:24px}
  .pricing-hero{grid-template-columns:1fr}
}
@media(max-width:760px){
  .svc-hero-points{grid-template-columns:1fr}
  .tick-list.two{grid-template-columns:1fr}
  .svc-sec{padding:48px 0}
  .svc-sec .section-head h2{font-size:26px}
}

/* ---------- thank-you page ---------- */
.ty-hero{padding:160px 0 100px}
.ty-icon{width:88px;height:88px;border-radius:50%;margin:0 auto 26px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff;box-shadow:0 24px 54px -14px rgba(47,67,230,.7)}
.ty-icon svg{width:44px;height:44px;stroke-width:3}
.ty-hero h1{font-size:44px}
.ty-hero p{max-width:620px;margin:14px auto 0}
.ty-hero p strong{color:#fff;font-weight:800}
.ty-actions{display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap;margin-top:32px}
.ty-link{color:#dbe5f7;font-weight:700;font-size:15px;text-decoration:underline;text-underline-offset:3px;transition:.18s}
.ty-link:hover{color:#fff}
@media(max-width:760px){.ty-hero{padding:130px 0 70px}.ty-hero h1{font-size:30px}}

/* ============================================================
   CUSTOM SERVICE PAGES (bespoke per service, brand-consistent)
   ============================================================ */
.sp-hero{position:relative;overflow:hidden;color:#fff;padding:150px 0 80px}
.sp-hero .wrap{position:relative;z-index:2}
.sp-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.sp-hero .breadcrumb{justify-content:flex-start}
.sp-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;font-weight:800;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;padding:7px 16px;border-radius:999px;margin-bottom:18px}
.sp-eyebrow svg{width:15px;height:15px}
.sp-hero h1{color:#fff;font-size:50px;line-height:1.08;margin-bottom:18px}
.sp-hero p.lead{color:#e7ecff;font-size:18px;max-width:560px;margin-bottom:26px}
.sp-hero-cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.sp-hero-points{list-style:none;display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:24px}
.sp-hero-points li{display:flex;align-items:center;gap:8px;color:#eaf0ff;font-weight:600;font-size:15px}
.sp-hero-points svg{width:18px;height:18px;color:var(--cyan);flex-shrink:0}

/* hero theme variants */
.sp-hero.theme-web{background:linear-gradient(160deg,#0b1437 0%,#1a3bd0 60%,#19c8e6 150%)}
.sp-hero.theme-mobile{background:linear-gradient(160deg,#0b1437 0%,#3b1f8f 55%,#6c2bd9 140%)}
.sp-hero.theme-software{background:linear-gradient(160deg,#070a1f 0%,#142a8f 60%,#2f43e6 145%)}

/* browser window mockup */
.mock-window{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid rgba(255,255,255,.25)}
.mock-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;background:#0f1733}
.mock-bar i{width:12px;height:12px;border-radius:50%;display:inline-block}
.mock-bar .r{background:#ff5f57}.mock-bar .y{background:#febc2e}.mock-bar .g{background:#28c840}
.mock-bar .url{margin-left:12px;flex:1;height:22px;border-radius:6px;background:#1c2750}
.mock-body{padding:22px}
.mock-hero-block{height:96px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--cyan));margin-bottom:16px}
.mock-line{height:12px;border-radius:6px;background:var(--bg-soft);margin-bottom:12px}
.mock-line.w70{width:70%}.mock-line.w45{width:45%}
.mock-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}
.mock-card{height:62px;border-radius:10px;background:var(--bg-tint);border:1px solid var(--line)}

/* phone mockup */
.phone-mock{width:262px;margin:0 auto;background:#0f1733;border-radius:38px;padding:13px;box-shadow:var(--shadow-lg);border:1px solid #26315f}
.phone-screen{position:relative;background:#fff;border-radius:26px;overflow:hidden;aspect-ratio:9/18.5}
.phone-notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:120px;height:24px;background:#0f1733;border-radius:0 0 16px 16px;z-index:3}
.phone-top{height:150px;background:linear-gradient(150deg,var(--primary),var(--cyan));display:flex;align-items:flex-end;padding:18px;color:#fff}
.phone-top strong{font-size:18px;font-weight:800}
.phone-content{padding:18px}
.phone-row{display:flex;align-items:center;gap:12px;padding:11px;border:1px solid var(--line);border-radius:12px;margin-bottom:11px}
.phone-row .pr-ico{width:34px;height:34px;border-radius:9px;background:var(--bg-tint);color:var(--primary);display:grid;place-items:center;flex-shrink:0}
.phone-row .pr-ico svg{width:18px;height:18px}
.phone-row .pr-lines{flex:1}
.phone-row .pr-lines span{display:block;height:8px;border-radius:5px;background:var(--bg-soft);margin-bottom:6px}
.phone-row .pr-lines span.s{width:55%;margin-bottom:0}

/* code / terminal mockup */
.code-mock{background:#0a1130;border-radius:14px;box-shadow:var(--shadow-lg);border:1px solid #1c264f;overflow:hidden}
.code-mock .mock-bar{background:#070c24}
.code-body{padding:22px 24px;font-family:'Courier New',monospace;font-size:13.5px;line-height:2;color:#aeb9e6}
.code-body .k{color:#7aa2ff}.code-body .s{color:var(--cyan)}.code-body .c{color:#5b6488}.code-body .f{color:#c792ea}
.code-body .ind{padding-left:22px}.code-body .ind2{padding-left:44px}

/* generic light service section wrapper */
.sp-sec{padding:90px 0}
.sp-sec.tint{background:var(--bg-soft)}
.sp-sec .section-head{margin-bottom:46px}

/* platform badges (mobile page) */
.plat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.plat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;text-align:center;transition:.25s}
.plat:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.plat .p-ico{width:60px;height:60px;border-radius:16px;margin:0 auto 16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff}
.plat .p-ico svg{width:28px;height:28px}
.plat h3{font-size:20px;margin-bottom:8px}
.plat p{font-size:14.5px}

@media(max-width:980px){
  .sp-hero-grid{grid-template-columns:1fr;gap:40px}
  .sp-hero{padding:130px 0 64px}
  .sp-hero h1{font-size:38px}
  .plat-row{grid-template-columns:1fr}
}
@media(max-width:760px){
  .sp-hero h1{font-size:30px}
  .sp-sec{padding:60px 0}
}

/* ============================================================
   LOCATION & INDUSTRY DIRECTORY / LANDING PAGES
   ============================================================ */
.dir-sec{padding:70px 0}
.dir-search{max-width:520px;margin:0 auto 36px;position:relative}
.dir-search input{width:100%;padding:15px 18px 15px 46px;border:1px solid var(--line);border-radius:12px;font-size:15px;font-family:inherit;color:var(--ink);background:#fff;outline:none;transition:.18s;box-shadow:var(--shadow-sm)}
.dir-search input:focus{border-color:var(--primary);box-shadow:var(--ring)}
.dir-search svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--muted)}
.dir-state{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 24px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.dir-state h3{font-size:18px;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.dir-state h3 svg{width:19px;height:19px;color:var(--primary)}
.dir-state h3 .count{font-size:12.5px;font-weight:700;color:var(--muted);margin-left:auto}
.city-links{display:flex;flex-wrap:wrap;gap:9px}
.city-links a{font-size:13.5px;font-weight:600;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line);padding:7px 14px;border-radius:8px;transition:.15s}
.city-links a:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px)}
.dir-empty{text-align:center;color:var(--muted);padding:40px;font-weight:600}

/* industry directory grid */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ind-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;transition:.25s;display:block}
.ind-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.ind-card .ico{width:58px;height:58px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff;margin-bottom:16px}
.ind-card .ico svg{width:27px;height:27px}
.ind-card h3{font-size:20px;margin-bottom:8px}
.ind-card p{font-size:14.5px;margin-bottom:14px}
.ind-card .more{font-weight:800;color:var(--primary);font-size:14px;display:inline-flex;align-items:center;gap:6px}

/* localized landing intro */
.loc-intro{max-width:820px;margin:0 auto;text-align:center;font-size:17.5px;line-height:1.8;color:var(--body)}
.nearby-links{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}
.nearby-links a{font-size:14px;font-weight:600;color:var(--primary);background:var(--bg-tint);border:1px solid #e2def8;padding:8px 16px;border-radius:8px;transition:.15s}
.nearby-links a:hover{background:var(--primary);color:#fff}

@media(max-width:980px){.ind-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.ind-grid{grid-template-columns:1fr}}

/* thank-you reference badge */
.ty-ref{display:inline-block;margin:18px auto 0;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:14.5px;padding:9px 18px;border-radius:999px}
.ty-ref strong{color:var(--cyan);letter-spacing:.04em}

/* ============================================================
   CHAT WIDGET (Gemini assistant + lead capture)
   ============================================================ */
.float-chat{font-family:inherit;cursor:pointer}
.float-chat.hidden{opacity:0;visibility:hidden;transform:scale(.6)}
.chat-panel{position:fixed;right:24px;bottom:24px;z-index:95;width:370px;max-width:calc(100vw - 32px);height:560px;max-height:calc(100vh - 48px);background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(20px) scale(.98);transform-origin:bottom right;transition:.25s}
.chat-panel.open{opacity:1;visibility:visible;transform:none}
.chat-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff}
.chat-head-id{display:flex;align-items:center;gap:12px}
.chat-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.2);display:grid;place-items:center;font-weight:900;font-size:18px}
.chat-head strong{display:block;font-size:15.5px}
.chat-head small{display:flex;align-items:center;gap:6px;font-size:12px;opacity:.92}
.chat-dot{width:8px;height:8px;border-radius:50%;background:#3ce07a;display:inline-block;box-shadow:0 0 0 3px rgba(60,224,122,.3)}
.chat-head-actions{display:flex;align-items:center;gap:2px}
.chat-reset{background:none;border:none;color:#fff;cursor:pointer;opacity:.85;transition:.2s;display:grid;place-items:center;padding:5px;border-radius:8px}
.chat-reset svg{width:18px;height:18px}
.chat-reset:hover{opacity:1;background:rgba(255,255,255,.18);transform:rotate(-45deg)}
.chat-close{background:none;border:none;color:#fff;font-size:26px;line-height:1;cursor:pointer;opacity:.85;transition:.15s;padding:0 4px}
.chat-close:hover{opacity:1;transform:scale(1.1)}
.chat-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:var(--bg)}
.chat-msg{max-width:82%;padding:11px 15px;border-radius:16px;font-size:14.5px;line-height:1.5;word-wrap:break-word}
.chat-msg.bot{align-self:flex-start;background:#fff;border:1px solid var(--line);color:var(--ink-2);border-bottom-left-radius:5px}
.chat-msg.user{align-self:flex-end;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-bottom-right-radius:5px}
.chat-msg.typing{color:var(--muted);letter-spacing:3px;font-size:18px}
.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:#fff}
.chat-input input{flex:1;border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:14.5px;font-family:inherit;outline:none;background:var(--bg);transition:.15s}
.chat-input input:focus{border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.chat-input button{width:46px;flex-shrink:0;border:none;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--cyan));color:#fff;display:grid;place-items:center;cursor:pointer;transition:.18s}
.chat-input button:hover{filter:brightness(1.08);transform:translateY(-1px)}
.chat-input button svg{width:20px;height:20px}
/* lead capture form inside chat */
.chat-lead{padding:6px 4px}
.chat-lead-h{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:4px}
.chat-lead-p{font-size:13.5px;color:var(--body);margin-bottom:14px}
.chat-lead input{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px 14px;font-size:14.5px;font-family:inherit;outline:none;background:var(--bg);margin-bottom:10px;transition:.15s}
.chat-lead input:focus{border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.chat-lead button{width:100%;border:none;border-radius:11px;padding:13px;font-size:15px;font-weight:800;font-family:inherit;color:#fff;background:linear-gradient(135deg,var(--primary),var(--cyan));cursor:pointer;transition:.18s}
.chat-lead button:hover{filter:brightness(1.08);transform:translateY(-1px)}
.chat-lead-err{color:#d23;font-size:12.5px;margin-top:8px;min-height:14px}
@media(max-width:480px){
  .chat-panel{right:10px;bottom:10px;height:calc(100vh - 90px)}
}

/* ============================================================
   HERO LEAD FORM (inside the black curve band)
   ============================================================ */
.hero-lead{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;text-align:left}
.hero-lead-copy{color:#fff;text-align:left}
.hl-eyebrow{display:inline-block;font-weight:800;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px}
.hero-lead-copy h2{color:#fff;font-size:34px;line-height:1.12;margin-bottom:14px}
.hero-lead-copy p{color:#c7cdf0;font-size:16.5px;line-height:1.7;max-width:440px;margin-bottom:22px}
.hl-points{list-style:none;display:grid;gap:12px}
.hl-points li{display:flex;align-items:center;gap:11px;color:#eaf0ff;font-weight:600;font-size:15px}
.hl-points li svg{width:20px;height:20px;flex-shrink:0;color:#fff;background:linear-gradient(135deg,var(--primary),var(--cyan));border-radius:6px;padding:3px}
.hero-lead-form{background:#fff;border-radius:20px;padding:30px;box-shadow:var(--shadow-lg)}
.hero-lead-form h3{font-size:21px;margin-bottom:18px}
.hlf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hero-lead-form input,.hero-lead-form select,.hero-lead-form textarea{width:100%;padding:13px 14px;border:1px solid var(--line);border-radius:11px;font-size:14.5px;font-family:inherit;color:var(--ink);outline:none;background:var(--bg);transition:.15s;margin-bottom:12px}
.hero-lead-form input:focus,.hero-lead-form select:focus,.hero-lead-form textarea:focus{border-color:var(--primary);background:#fff;box-shadow:var(--ring)}
.hero-lead-form textarea{resize:vertical;min-height:84px}
.hero-lead-form .btn-primary{margin-top:2px}
.hlf-note{text-align:center;font-size:12px;color:var(--muted);margin-top:12px}

@media(max-width:980px){
  .hero-lead{grid-template-columns:1fr;gap:30px}
  .hero-lead-copy{text-align:center}
  .hero-lead-copy p{margin-left:auto;margin-right:auto}
  .hl-points{max-width:340px;margin:0 auto}
}
@media(max-width:520px){
  .hlf-row{grid-template-columns:1fr}
  .hero-lead-copy h2{font-size:27px}
}

/* floating-button label bubbles */
.float-wa,.float-chat{position:fixed}
.fab-tip{position:absolute;top:50%;transform:translateY(-50%);background:#fff;color:var(--ink);font-weight:700;font-size:13px;line-height:1;padding:9px 14px;border-radius:10px;box-shadow:0 10px 28px -10px rgba(20,24,55,.4);white-space:nowrap;pointer-events:none;animation:fabBob 2.4s ease-in-out infinite}
.fab-tip::after{content:"";position:absolute;top:50%;transform:translateY(-50%);border:7px solid transparent}
.wa-tip{left:calc(100% + 14px)}
.wa-tip::after{right:100%;border-right-color:#fff}
.chat-tip{right:calc(100% + 14px)}
.chat-tip::after{left:100%;border-left-color:#fff}
@keyframes fabBob{0%,100%{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 4px))}}
@media(max-width:560px){.fab-tip{display:none}}

/* fix: 3-col capabilities row must collapse on small screens */
@media(max-width:760px){.cat-row.cat-row-3{grid-template-columns:1fr 1fr;max-width:520px}}
@media(max-width:480px){.cat-row.cat-row-3{grid-template-columns:1fr}}

/* 4-up process steps that collapse on small screens */
.steps.four{grid-template-columns:repeat(4,1fr)}
@media(max-width:880px){.steps.four{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps.four{grid-template-columns:1fr}}
