/* ==========================================================================
   WasilaDev 2026 — design system
   Brand: Poppins · blue #1D6BCD · navy #294363 · green #3EC301 (sparingly)
   ========================================================================== */
:root{
  --white:#FFFFFF; --blue:#1D6BCD; --blue-d:#175aad; --navy:#294363;
  --navy-d:#1b2e45; --green:#3EC301; --gray:#848484; --tint:#EFF4FC;
  --tint-2:#F7FAFE; --line:#E2E8F2; --ink:#20344c;
  --r:14px; --maxw:1180px;
  --sh:0 1px 2px rgba(41,67,99,.06),0 10px 30px rgba(41,67,99,.08);
  --sh-lift:0 8px 18px rgba(29,107,205,.10),0 24px 60px rgba(29,107,205,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Poppins,system-ui,sans-serif;color:var(--navy);
  background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.72rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--blue)}
.eyebrow .hex{width:11px;height:12px;flex:0 0 auto}
h1,h2,h3{margin:0;color:var(--navy);line-height:1.1;letter-spacing:-.02em}
h2.sec-title{font-size:clamp(1.9rem,3.2vw,2.7rem);font-weight:700;margin:.5rem 0 .7rem}
.sec-intro{color:var(--gray);max-width:640px;font-size:1.02rem}
.sec-head{margin-bottom:44px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-weight:600;
  font-size:.95rem;padding:13px 24px;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .18s,box-shadow .18s,background .18s,color .18s}
.btn:focus-visible{outline:3px solid rgba(29,107,205,.4);outline-offset:2px}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-2px);box-shadow:var(--sh-lift)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.btn-green{background:var(--green);color:#0f2a00}
.btn-green:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(62,195,1,.3)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.15)}
.arr{transition:transform .18s}
.btn:hover .arr{transform:translateX(3px)}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);
  backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:box-shadow .2s,border-color .2s}
.site-header.stuck{box-shadow:0 4px 20px rgba(41,67,99,.07);border-color:var(--line)}
.nav{display:flex;align-items:center;gap:28px;height:74px}
.logo img{height:26px;width:auto}
.nav-links{display:flex;gap:26px;margin-left:auto;font-weight:500;font-size:.94rem;
  list-style:none;padding:0;margin:0 0 0 auto}
.nav-links a{color:var(--ink);padding:4px 0;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;
  background:var(--blue);transition:width .2s}
.nav-links a:hover::after{width:100%}
.nav-cta{margin-left:4px}
.menu-btn{display:none;margin-left:auto;background:none;border:0;cursor:pointer;padding:8px}
.menu-btn span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0}

/* section shells */
.section{padding:88px 0}
.section.tint{background:var(--tint-2)}
.section.dark{background:var(--navy-d);color:#dbe6f2}
.section.dark h2.sec-title{color:#fff}
.section.dark .eyebrow{color:#8fd0ff}
.section.dark .sec-intro{color:#a9bdd4}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
.crumb{display:flex;gap:8px;align-items:center;font-size:.82rem;color:var(--gray);margin-bottom:20px}
.crumb a:hover{color:var(--blue)}.crumb .sep{opacity:.5}
.mini-proof{display:flex;gap:22px;margin-top:34px;flex-wrap:wrap;font-size:.85rem;color:var(--gray)}
.mini-proof b{color:var(--navy)}

/* ---- HOME: hero ---- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 85% -10%,var(--tint) 0%,rgba(239,244,252,0) 55%),var(--white)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;padding:74px 0 88px}
.hero h1{font-size:clamp(2.5rem,4.6vw,4.1rem);font-weight:800;margin:18px 0 0}
.hero h1 .amp{color:var(--blue);font-weight:800}
.hero h1 .rot{color:var(--blue)}
.hero-sub{margin:22px 0 30px;font-size:1.12rem;color:var(--ink);max-width:520px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.proof-row{display:flex;gap:30px;margin-top:38px;flex-wrap:wrap}
.proof-row .p b{display:block;font-size:1.5rem;font-weight:700;color:var(--navy);line-height:1}
.proof-row .p span{font-size:.8rem;color:var(--gray)}

/* portfolio / capability panels (hero right) */
.panel,.cap{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--sh);
  padding:22px;position:relative}
.panel::before,.cap::before{content:"";position:absolute;inset:0;border-radius:20px;padding:1px;
  background:linear-gradient(160deg,rgba(29,107,205,.35),rgba(62,195,1,0) 42%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.panel-head,.cap-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.panel-head .lbl,.cap-head .lbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  font-weight:600;color:var(--gray)}
.cap-head .bdg{font-size:.72rem;font-weight:600;color:var(--green)}
.live-dot{display:inline-flex;align-items:center;gap:7px;font-size:.74rem;color:var(--green);font-weight:600}
.live-dot i{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(62,195,1,.45)}70%{box-shadow:0 0 0 7px rgba(62,195,1,0)}100%{box-shadow:0 0 0 0 rgba(62,195,1,0)}}
.prow,.crow{display:flex;align-items:center;gap:13px;padding:12px 8px;border-radius:12px;transition:background .16s}
.prow:hover,.crow:hover{background:var(--tint)}
.prow+.prow,.crow+.crow{border-top:1px solid var(--line)}
.prow .hx,.crow .hx{width:28px;height:31px;flex:0 0 auto}
.prow .nm,.crow .nm{font-weight:600;color:var(--navy);font-size:.96rem}
.prow .tg,.crow .tg{font-size:.76rem;color:var(--gray)}
.prow .go{margin-left:auto;color:var(--blue);font-size:.8rem;font-weight:600;opacity:0;transition:opacity .16s}
.prow:hover .go{opacity:1}
.cap-foot{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;
  align-items:center;justify-content:space-between;font-size:.85rem;color:var(--navy);font-weight:600}
.cap-foot a{color:var(--blue)}

/* product & card grids */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;display:flex;
  flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--sh-lift);border-color:rgba(29,107,205,.3)}
.pcard .top{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.pcard .mark{width:42px;height:46px;flex:0 0 auto}
.pcard .tag{font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--blue);background:var(--tint);padding:5px 10px;border-radius:999px}
.pcard h3{font-size:1.28rem;font-weight:700;margin-bottom:8px}
.pcard p{color:var(--gray);font-size:.95rem;margin:0 0 20px}
.pcard .link{margin-top:auto;font-weight:600;color:var(--blue);font-size:.9rem;display:inline-flex;gap:7px;align-items:center}

/* services cards (home dark band) */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.scard{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);
  padding:28px;transition:background .2s,border-color .2s,transform .2s}
.scard:hover{background:rgba(255,255,255,.07);border-color:rgba(143,208,255,.4);transform:translateY(-4px)}
.scard .no{font-size:.8rem;font-weight:600;color:#8fd0ff;letter-spacing:.1em}
.scard h3{color:#fff;font-size:1.32rem;font-weight:700;margin:12px 0 10px}
.scard p{color:#a9bdd4;font-size:.96rem;margin:0}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.stat{text-align:left;padding:6px 0}
.stat .hx{width:22px;height:24px;margin-bottom:12px}
.stat b{display:block;font-size:2.5rem;font-weight:800;color:var(--navy);line-height:1;letter-spacing:-.02em}
.stat span{color:var(--gray);font-size:.92rem;margin-top:6px;display:block}

/* work strip */
.work-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.wcard{border:1px solid var(--line);border-radius:var(--r);padding:22px;background:#fff;
  transition:transform .2s,box-shadow .2s}
.wcard:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.wcard .k{font-weight:700;color:var(--navy);font-size:1.05rem}
.wcard .v{color:var(--gray);font-size:.85rem;margin-top:4px}

/* ---- PRODUCT single ---- */
.phero{background:radial-gradient(120% 90% at 88% -10%,var(--tint) 0%,rgba(239,244,252,0) 55%),var(--white);overflow:hidden}
.phero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center;padding:56px 0 80px}
.phero h1{font-size:clamp(2.3rem,4vw,3.5rem);font-weight:800;margin:16px 0 0}
.phero .sub{font-size:1.14rem;color:var(--ink);margin:20px 0 30px;max-width:520px}
.phero-cta{display:flex;gap:14px;flex-wrap:wrap}
.mockwrap{position:relative;display:flex;justify-content:center}
.mock{width:340px;max-width:100%;background:#fff;border:1px solid var(--line);border-radius:22px;
  box-shadow:var(--sh-lift);overflow:hidden;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.mock-top{display:flex;align-items:center;gap:11px;padding:14px 16px;background:var(--navy);color:#fff}
.mock-top .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--green));
  display:grid;place-items:center;font-weight:700;font-size:.85rem;color:#fff}
.mock-top .nm{font-weight:600;font-size:.9rem;line-height:1.1}
.mock-top .st{font-size:.7rem;color:#9fe08a;display:flex;align-items:center;gap:5px}
.mock-top .st i{width:6px;height:6px;border-radius:50%;background:var(--green)}
.mock-body{padding:18px 16px;display:flex;flex-direction:column;gap:10px;background:var(--tint-2);min-height:230px}
.bub{max-width:80%;padding:9px 13px;border-radius:14px;font-size:.86rem;line-height:1.35}
.bub.in{background:#fff;border:1px solid var(--line);color:var(--navy);align-self:flex-start;border-bottom-left-radius:4px}
.bub.out{background:var(--blue);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.bub.bot{background:#eaf7e4;color:#1f5e0a;align-self:flex-end;border-bottom-right-radius:4px;border:1px solid #cdecbe}
.bub .who{display:block;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;opacity:.7;margin-bottom:2px}
.mock-input{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--line);background:#fff}
.mock-input .fld{flex:1;height:34px;border-radius:999px;background:var(--tint);border:1px solid var(--line)}
.mock-input .snd{width:34px;height:34px;border-radius:50%;background:var(--blue);display:grid;place-items:center;color:#fff}
.mock-badge{position:absolute;bottom:6px;right:0;background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:7px 13px;font-size:.74rem;font-weight:600;color:var(--navy);box-shadow:var(--sh);display:flex;align-items:center;gap:7px}
.mock-badge .hx{width:13px;height:14px}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:transform .2s,box-shadow .2s,border-color .2s}
.feat:hover{transform:translateY(-5px);box-shadow:var(--sh-lift);border-color:rgba(29,107,205,.3)}
.feat .ic{width:44px;height:44px;border-radius:11px;background:var(--tint);display:grid;place-items:center;margin-bottom:16px}
.feat .ic svg{width:20px;height:22px}
.feat h3{font-size:1.15rem;font-weight:700;margin-bottom:8px}
.feat p{color:var(--gray);font-size:.93rem;margin:0}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.step{position:relative;padding-top:8px}
.step .no{font-size:.85rem;font-weight:700;color:#8fd0ff;letter-spacing:.1em}
.step h3{color:#fff;font-size:1.2rem;font-weight:700;margin:12px 0 8px}
.step p{color:#a9bdd4;font-size:.94rem;margin:0}
.step::after{content:"";position:absolute;top:22px;right:-13px;width:26px;height:1px;background:rgba(255,255,255,.2)}
.step:last-child::after{display:none}
.who-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.who{border:1px solid var(--line);border-radius:var(--r);padding:24px;background:#fff}
.who h3{font-size:1.08rem;font-weight:700;margin-bottom:8px}
.who p{color:var(--gray);font-size:.92rem;margin:0}
.family{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:18px;padding:22px 26px;background:var(--tint)}
.family .chips{display:flex;gap:10px;flex-wrap:wrap}
.family .chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:8px 14px;font-size:.86rem;font-weight:500;color:var(--navy)}
.family .chip .hx{width:12px;height:13px}

/* ---- SERVICES ---- */
.shero{background:radial-gradient(120% 90% at 88% -10%,var(--tint) 0%,rgba(239,244,252,0) 55%),var(--white);overflow:hidden}
.shero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:52px;align-items:center;padding:64px 0 84px}
.shero h1{font-size:clamp(2.4rem,4.2vw,3.7rem);font-weight:800;margin:16px 0 0}
.shero h1 em{font-style:normal;color:var(--blue)}
.shero .sub{font-size:1.14rem;color:var(--ink);margin:20px 0 30px;max-width:520px}
.shero-cta{display:flex;gap:14px;flex-wrap:wrap}
.svc2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.sd{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;transition:transform .2s,box-shadow .2s,border-color .2s}
.sd:hover{transform:translateY(-5px);box-shadow:var(--sh-lift);border-color:rgba(29,107,205,.3)}
.sd .ic{width:46px;height:46px;border-radius:12px;background:var(--tint);display:grid;place-items:center;margin-bottom:16px}
.sd .ic svg{width:22px;height:24px}
.sd h3{font-size:1.3rem;font-weight:700;margin-bottom:8px}
.sd .lead{color:var(--gray);font-size:.95rem;margin:0 0 16px}
.sd ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.sd li{display:flex;align-items:flex-start;gap:9px;font-size:.9rem;color:var(--ink)}
.sd li svg{width:16px;height:16px;flex:0 0 auto;margin-top:3px}
.diff{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.dcard{padding-top:8px}
.dcard .hx{width:26px;height:29px;margin-bottom:14px}
.dcard h3{color:#fff;font-size:1.22rem;font-weight:700;margin-bottom:10px}
.dcard p{color:#a9bdd4;font-size:.95rem;margin:0}
.proc{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.pstep{position:relative;padding-top:10px}
.pstep .no{font-size:.78rem;font-weight:700;color:var(--blue);letter-spacing:.1em}
.pstep h3{font-size:1.05rem;font-weight:700;margin:10px 0 6px}
.pstep p{color:var(--gray);font-size:.86rem;margin:0}
.pstep::after{content:"";position:absolute;top:24px;right:-11px;width:22px;height:1px;background:var(--line)}
.pstep:last-child::after{display:none}
.stack{display:flex;flex-wrap:wrap;gap:11px}
.stack .chip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:9px 16px;font-size:.9rem;font-weight:500;color:var(--navy)}
.stack .chip .dot{width:7px;height:7px;border-radius:50%;background:var(--blue)}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 130%);border-radius:24px;padding:56px;
  text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800}
.cta-band p{color:#cfe0f5;max-width:520px;margin:14px auto 28px}
.cta-band .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-band .hexwm{position:absolute;right:-40px;top:-40px;width:220px;opacity:.12;color:#fff}

/* footer */
.site-footer{background:var(--navy-d);color:#a9bdd4;padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot-brand img{height:24px;filter:brightness(0) invert(1);opacity:.95;margin-bottom:16px}
.foot-brand p{font-size:.9rem;max-width:280px}
.site-footer h4{color:#fff;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;margin:0 0 16px}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:.92rem}
.site-footer a:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:22px;display:flex;
  justify-content:space-between;font-size:.82rem;color:#7f95ad;flex-wrap:wrap;gap:8px}

/* responsive */
@media(max-width:960px){
  .hero-grid,.phero-grid,.shero-grid{grid-template-columns:1fr;gap:44px}
  .hero-grid{padding:48px 0 64px}.phero-grid{padding:40px 0 60px}.shero-grid{padding:44px 0 60px}
  .prod-grid,.feat-grid,.who-grid{grid-template-columns:repeat(2,1fr)}
  .svc2,.diff{grid-template-columns:1fr}
  .stats,.work-grid{grid-template-columns:repeat(2,1fr)}
  .proc{grid-template-columns:repeat(2,1fr)}
  .step::after,.pstep::after{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-links{display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:#fff;
    border-bottom:1px solid var(--line);padding:16px 24px;gap:14px;margin:0}
  .nav-links.open{display:flex}.nav-cta{display:none}.menu-btn{display:block}
  .prod-grid,.svc-grid,.stats,.work-grid,.feat-grid,.who-grid,.proc,.foot-grid{grid-template-columns:1fr}
  .cta-band{padding:40px 24px}.section{padding:60px 0}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.prow{opacity:1!important;transform:none!important}.mock{animation:none!important}
}

/* editor / blog body content */
.entry-content{font-size:1.05rem;color:var(--ink)}
.entry-content h2{font-size:1.7rem;font-weight:700;margin:1.8rem 0 .8rem}
.entry-content h3{font-size:1.3rem;font-weight:700;margin:1.4rem 0 .6rem}
.entry-content p{margin:0 0 1.1rem}
.entry-content a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}
.entry-content ul,.entry-content ol{margin:0 0 1.1rem;padding-left:1.3rem}
.entry-content li{margin:.4rem 0}
.entry-content img{border-radius:var(--r);margin:1.2rem 0}
.entry-content blockquote{border-left:3px solid var(--blue);padding-left:18px;margin:1.4rem 0;color:var(--navy);font-style:italic}
.pagination{display:flex;gap:8px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border:1px solid var(--line);border-radius:10px;color:var(--navy);font-weight:600;font-size:.9rem}
.pagination .page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue)}
.pagination a.page-numbers:hover{border-color:var(--blue);color:var(--blue)}
