﻿
:root {
  --navy:      #1a4a7a;
  --navy-dk:   #0f2f50;
  --red:       #c0392b;
  --red-lt:    #e74c3c;
  --silver:    #d0d7e0;
  --silver-lt: #edf0f5;
  --white:     #ffffff;
  --gray:      #4a5568;
  --dark:      #1a202c;
  --border:    rgba(26,74,122,0.12);
  --sh-sm:     0 2px 12px rgba(15,47,80,0.08);
  --sh-md:     0 8px 32px rgba(15,47,80,0.14);
  --sh-lg:     0 20px 60px rgba(15,47,80,0.2);
  --r:         6px;
  --tr:        0.3s ease;
  --fh:        'Rajdhani', sans-serif;
  --fb:        'Source Sans 3', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);color:var(--dark);background:var(--white);line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:var(--fh);font-weight:700;line-height:1.15}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}

/* CONTAINER */
.wrap{width:100%;max-width:1240px;margin:0 auto;padding:0 24px}

/* SECTION SPACING */
.sp{padding:88px 0}
.sp-sm{padding:56px 0}

/* LABELS */
.lbl{display:inline-flex;align-items:center;gap:9px;font-family:var(--fh);font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.lbl::before{content:'';width:28px;height:2px;background:var(--red);flex-shrink:0}
.ttl{font-size:clamp(1.8rem,4vw,2.9rem);color:var(--navy-dk);margin-bottom:14px}
.ttl span{color:var(--red)}
.sub{font-size:clamp(.93rem,2vw,1.06rem);color:var(--gray);max-width:620px;line-height:1.75}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:13px 28px;border-radius:var(--r);font-family:var(--fh);font-size:1rem;font-weight:600;letter-spacing:.04em;cursor:pointer;border:2px solid transparent;transition:var(--tr);white-space:nowrap}
.btn-red{background:var(--red);color:var(--white);border-color:var(--red)}
.btn-red:hover{background:var(--red-lt);border-color:var(--red-lt);transform:translateY(-2px);box-shadow:0 8px 22px rgba(192,57,43,.35)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:var(--white);color:var(--navy-dk);border-color:var(--white)}
.btn-navy{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-dk);transform:translateY(-2px);box-shadow:var(--sh-md)}
.btn-white{background:var(--white);color:var(--red);border-color:var(--white)}
.btn-white:hover{background:transparent;color:var(--white)}

/* ====================================================
   TOPBAR
==================================================== */
#topbar{background:var(--navy-dk);padding:8px 0;font-size:.8rem;color:var(--silver)}
#topbar .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.tb-left{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.tb-left a{color:var(--silver);display:flex;align-items:center;gap:6px;transition:color var(--tr);white-space:nowrap}
.tb-left a:hover{color:var(--white)}
.tb-right{display:flex;gap:8px}
.soc{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--silver);transition:background var(--tr),color var(--tr)}
.soc:hover{background:var(--red);color:var(--white)}

/* ====================================================
   NAVBAR
==================================================== */
#nav{position:sticky;top:0;z-index:1000;background:var(--white);border-bottom:1px solid var(--border);transition:box-shadow var(--tr)}
#nav.scrolled{box-shadow:var(--sh-md)}
#nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.logo img{height:46px;width:auto}
.logo-txt strong{font-family:var(--fh);font-size:1.1rem;font-weight:700;color:var(--navy-dk);display:block;line-height:1.1}
.logo-txt span{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--red);font-weight:600}
.nav-links{display:flex;align-items:center;gap:2px}
.chakra-menu,.chakra-footer-menu{list-style:none;margin:0;padding:0}
.chakra-menu{display:flex;align-items:center;gap:2px}
.chakra-menu li{display:flex}
.chakra-menu a{font-family:var(--fh);font-size:.94rem;font-weight:600;color:var(--navy-dk);padding:7px 12px;border-radius:var(--r);letter-spacing:.02em;transition:color var(--tr);position:relative;white-space:nowrap}
.chakra-menu a::after{content:'';position:absolute;bottom:3px;left:12px;right:12px;height:2px;background:var(--red);transform:scaleX(0);transition:transform var(--tr)}
.chakra-menu a:hover{color:var(--red)}
.chakra-menu a:hover::after{transform:scaleX(1)}
.nav-cta{background:var(--red)!important;color:var(--white)!important;padding:9px 20px!important;margin-left:10px}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--red-lt)!important}
/* Hamburger */
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;-webkit-tap-highlight-color:transparent}
.ham span{display:block;width:24px;height:2px;background:var(--navy-dk);border-radius:2px;transition:var(--tr)}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ====================================================
   HERO
==================================================== */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--navy-dk);overflow:hidden;padding:90px 0 200px}
.hero-bg{position:absolute;inset:0;background-image:var(--chakra-hero-bg-image);background-size:cover;background-position:center;opacity:.18}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px}
.hero-grad{position:absolute;inset:0;background:linear-gradient(135deg,var(--navy-dk) 0%,rgba(15,47,80,.88) 55%,transparent 100%)}
.hero-geo{position:absolute;right:-40px;top:50%;transform:translateY(-50%);width:min(480px,55vw);height:min(480px,55vw);opacity:.06;pointer-events:none}
.hero-geo svg{width:100%;height:100%}
.hero-body{position:relative;z-index:2;max-width:680px;width:100%}
.hero-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(192,57,43,.2);border:1px solid rgba(192,57,43,.4);color:#ff8a7a;padding:5px 14px;border-radius:40px;font-size:.73rem;font-family:var(--fh);font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:22px}
#hero h1{font-size:clamp(2.1rem,6vw,4.1rem);color:var(--white);line-height:1.06;margin-bottom:20px}
#hero h1 .acc{color:var(--red-lt)}
.hero-p{font-size:clamp(.93rem,2vw,1.08rem);color:rgba(255,255,255,.75);max-width:540px;margin-bottom:32px;line-height:1.8}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
/* Stats */
.hero-stats{position:absolute;bottom:0;left:0;right:0;z-index:2;background:rgba(255,255,255,.04);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.08)}
.stats-row{display:flex}
.hstat{flex:1;text-align:center;padding:22px 10px;border-right:1px solid rgba(255,255,255,.1)}
.hstat:last-child{border-right:none}
.hstat .n{font-family:var(--fh);font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700;color:var(--white);line-height:1;margin-bottom:4px}
.hstat .n em{color:var(--red-lt);font-style:normal}
.hstat p{font-size:.7rem;color:rgba(255,255,255,.5);letter-spacing:.05em;text-transform:uppercase;line-height:1.3}

/* ====================================================
   PARTNERS
==================================================== */
#partners{background:var(--silver-lt);padding:26px 0;border-bottom:1px solid var(--border)}
#partners .wrap{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.p-lbl{font-family:var(--fh);font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);white-space:nowrap;padding-right:20px;border-right:1px solid var(--border);flex-shrink:0}
.p-logos{display:flex;align-items:center;gap:28px;flex-wrap:wrap;flex:1}
.pbadge{display:flex;align-items:center;gap:9px;opacity:.62;transition:opacity var(--tr)}
.pbadge:hover{opacity:1}
.pbadge img{height:30px;width:auto}
.pbadge strong{font-family:var(--fh);font-size:.9rem;font-weight:700;color:var(--navy-dk);display:block;line-height:1.1}
.pbadge small{font-size:.58rem;color:var(--gray);letter-spacing:.07em;text-transform:uppercase;font-weight:600}

/* ====================================================
   ABOUT
==================================================== */
#about{background:var(--white)}
.about-g{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.img-wrap{position:relative}
.img-geo{position:absolute;top:-16px;left:-16px;width:80px;height:80px;background:var(--red);border-radius:var(--r);z-index:0;opacity:.13}
.img-main{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-lg);position:relative;z-index:1}
.img-main img{width:100%;height:440px;object-fit:cover}
.img-acc{position:absolute;bottom:-24px;right:-24px;width:176px;height:176px;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-md);border:4px solid var(--white);z-index:2}
.img-acc img{width:100%;height:100%;object-fit:cover}
.about-feats{display:flex;flex-direction:column;gap:16px;margin:24px 0 32px}
.afeat{display:flex;gap:14px;align-items:flex-start}
.afeat-ico{width:42px;height:42px;border-radius:var(--r);background:var(--navy);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:.93rem;flex-shrink:0;margin-top:2px}
.afeat h4{font-size:.96rem;font-weight:700;color:var(--navy-dk);margin-bottom:2px}
.afeat p{font-size:.87rem;color:var(--gray)}

/* ====================================================
   CREDENTIALS
==================================================== */
#creds{background:var(--navy-dk);padding:46px 0}
.creds-g{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.cred{text-align:center;padding:26px 16px;background:rgba(255,255,255,.03);border-radius:var(--r);transition:background var(--tr)}
.cred:hover{background:rgba(255,255,255,.07)}
.cred i{font-size:1.85rem;color:var(--red-lt);margin-bottom:10px;display:block}
.cred h4{font-family:var(--fh);font-size:.95rem;color:var(--white);margin-bottom:5px}
.cred p{font-size:.78rem;color:rgba(255,255,255,.5)}

/* ====================================================
   SERVICES
==================================================== */
#services{background:var(--silver-lt)}
.svc-hdr{text-align:center;margin-bottom:52px}
.svc-hdr .sub{margin:0 auto}
.svc-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.scard{background:var(--white);border-radius:var(--r);overflow:hidden;border:1px solid var(--border);transition:box-shadow var(--tr),transform var(--tr);display:flex;flex-direction:column}
.scard:hover{box-shadow:var(--sh-lg);transform:translateY(-5px)}
.scard-img{height:188px;overflow:hidden;position:relative;background:var(--navy-dk)}
.scard-img img{width:100%;height:100%;object-fit:cover;opacity:.82;transition:transform .5s ease,opacity var(--tr)}
.scard:hover .scard-img img{transform:scale(1.06);opacity:1}
.scard-ico{position:absolute;bottom:12px;left:16px;width:46px;height:46px;background:var(--red);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.15rem;box-shadow:0 4px 14px rgba(192,57,43,.4)}
.scard-body{padding:24px;flex:1;display:flex;flex-direction:column}
.scard-body h3{font-size:1.22rem;color:var(--navy-dk);margin-bottom:10px}
.scard-body > p{font-size:.89rem;color:var(--gray);line-height:1.7;margin-bottom:16px;flex:1}
.sfeat{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.sfeat li{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--gray)}
.sfeat li i{color:var(--red);font-size:.62rem;flex-shrink:0}
.slink{display:inline-flex;align-items:center;gap:7px;font-family:var(--fh);font-size:.87rem;font-weight:700;color:var(--navy);transition:color var(--tr),gap var(--tr)}
.slink:hover{color:var(--red);gap:12px}
/* Featured Ajax card */
.scard.feat{grid-column:span 3;display:grid;grid-template-columns:1fr 1.7fr;border-color:var(--navy)}
.scard.feat .scard-img{height:100%;min-height:258px}
.scard.feat .scard-body{padding:36px}
.ajax-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(192,57,43,.08);border:1px solid rgba(192,57,43,.25);color:var(--red);padding:4px 12px;border-radius:40px;font-size:.7rem;font-family:var(--fh);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.sfeat-g{display:grid;grid-template-columns:1fr 1fr;gap:6px 16px;margin-bottom:22px}

/* ====================================================
   WHY US
==================================================== */
#why{background:var(--white)}
.why-g{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.why-img{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-lg)}
.why-img img{width:100%;height:450px;object-fit:cover}
.why-pts{display:flex;flex-direction:column;gap:18px;margin-top:28px}
.wpt{display:flex;gap:16px;align-items:flex-start;padding:18px;border-radius:var(--r);border:1px solid var(--border);transition:border-color var(--tr),box-shadow var(--tr)}
.wpt:hover{border-color:var(--navy);box-shadow:var(--sh-sm)}
.wpt-n{font-family:var(--fh);font-size:1.75rem;font-weight:700;color:var(--silver);line-height:1;min-width:36px;flex-shrink:0}
.wpt h4{font-size:.98rem;color:var(--navy-dk);margin-bottom:3px}
.wpt p{font-size:.87rem;color:var(--gray)}

/* ====================================================
   AJAX FEATURE
==================================================== */
#ajaxfeat{background:var(--navy-dk);position:relative;overflow:hidden}
.ajax-bg-img{position:absolute;inset:0;background-image:url('../images/hero-bg.jpg');background-size:cover;background-position:center;opacity:.06}
.ajax-g{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.ajax-lbl{color:#ff8a7a!important}
.ajax-lbl::before{background:#ff8a7a!important}
.ajax-ttl{color:var(--white)!important}
.ajax-sub{color:rgba(255,255,255,.65);margin-bottom:28px}
.ajax-caps{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.acap{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:var(--r);padding:18px;transition:background var(--tr)}
.acap:hover{background:rgba(255,255,255,.09)}
.acap i{font-size:1.25rem;color:var(--red-lt);margin-bottom:8px;display:block}
.acap h4{font-size:.9rem;color:var(--white);margin-bottom:3px}
.acap p{font-size:.78rem;color:rgba(255,255,255,.5)}
.ajax-vis img{border-radius:var(--r);box-shadow:0 24px 80px rgba(0,0,0,.5);width:100%}

/* ====================================================
   TESTIMONIALS
==================================================== */
#testi{background:var(--silver-lt)}
.testi-hdr{text-align:center;margin-bottom:48px}
.testi-hdr .sub{margin:0 auto}
.testi-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{background:var(--white);border-radius:var(--r);padding:30px;border:1px solid var(--border);position:relative}
.tcard::before{content:'"';position:absolute;top:14px;right:22px;font-family:var(--fh);font-size:4.5rem;font-weight:700;color:var(--silver);line-height:1}
.tstars{margin-bottom:12px}
.tstars i{color:#f59e0b;font-size:.8rem}
.tcard p{font-size:.9rem;color:var(--gray);line-height:1.75;margin-bottom:20px;font-style:italic}
.tauthor{display:flex;align-items:center;gap:11px}
.tavat{width:40px;height:40px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;color:var(--white);font-family:var(--fh);font-weight:700;font-size:.92rem;flex-shrink:0}
.tauthor h5{font-size:.9rem;color:var(--navy-dk);margin-bottom:1px}
.tauthor span{font-size:.74rem;color:var(--red)}

/* ====================================================
   CTA BANNER
==================================================== */
#cta{background:linear-gradient(135deg,var(--red) 0%,#922b21 100%);padding:70px 0;text-align:center;position:relative;overflow:hidden}
#cta::before{content:'';position:absolute;top:-80px;right:-80px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.05)}
#cta::after{content:'';position:absolute;bottom:-100px;left:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.04)}
#cta h2{font-size:clamp(1.6rem,4vw,2.6rem);color:var(--white);margin-bottom:12px;position:relative;z-index:1}
#cta p{color:rgba(255,255,255,.8);font-size:1.04rem;margin-bottom:30px;position:relative;z-index:1}
.cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ====================================================
   CONTACT
==================================================== */
#contact{background:var(--white)}
.con-hdr{text-align:center;margin-bottom:50px}
.con-hdr .sub{margin:0 auto}
.con-g{display:grid;grid-template-columns:1fr 1.4fr;gap:52px;align-items:start}
.con-info h3{font-size:1.45rem;color:var(--navy-dk);margin-bottom:12px}
.con-info > p{color:var(--gray);margin-bottom:28px;line-height:1.75}
.con-items{display:flex;flex-direction:column;gap:18px}
.citem{display:flex;align-items:flex-start;gap:14px}
.cico{width:44px;height:44px;background:var(--navy-dk);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:.93rem;flex-shrink:0}
.citem h5{font-size:.73rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:3px}
.citem p,.citem a{font-size:.92rem;color:var(--dark);line-height:1.5}
.citem a:hover{color:var(--red)}
.con-form{background:var(--silver-lt);border-radius:var(--r);padding:38px;border:1px solid var(--border)}
.con-form h3{font-size:1.38rem;color:var(--navy-dk);margin-bottom:22px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fg label{font-family:var(--fh);font-size:.76rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--navy-dk)}
.fg input,.fg select,.fg textarea{padding:11px 13px;border:1px solid var(--border);border-radius:var(--r);font-family:var(--fb);font-size:.92rem;color:var(--dark);background:var(--white);outline:none;width:100%;transition:border-color var(--tr),box-shadow var(--tr)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(26,74,122,.1)}
.fg textarea{resize:vertical;min-height:108px}
.fg select{-webkit-appearance:none;appearance:none;cursor:pointer}
.f-ok{display:none;background:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:var(--r);padding:13px;text-align:center;font-weight:600;margin-top:12px}
.f-ok.is-visible{display:block}
.f-warn{display:none;background:#fff3cd;color:#856404;border:1px solid #ffe69c;border-radius:var(--r);padding:13px;text-align:center;font-weight:600;margin-top:12px}
.f-warn.is-visible{display:block}
.f-error{display:none;background:#fdecea;color:#8a1f17;border:1px solid #f5c6cb;border-radius:var(--r);padding:13px;text-align:center;font-weight:600;margin-top:12px}
.f-error.is-visible{display:block}

/* ====================================================
   MAP
==================================================== */
#mapbox{height:360px;background:var(--silver-lt);overflow:hidden}
#mapbox iframe{width:100%;height:100%;border:none;display:block}

/* ====================================================
   FOOTER
==================================================== */
#footer{background:var(--navy-dk);color:rgba(255,255,255,.7);padding:68px 0 0}
.foot-g{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.3fr;gap:44px;margin-bottom:52px}
.fbrand img{height:46px;width:auto;margin-bottom:16px}
.fbrand p{font-size:.85rem;line-height:1.75;margin-bottom:20px}
.fsoc{display:flex;gap:8px}
.fsoc a{width:34px;height:34px;border-radius:var(--r);background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);font-size:.8rem;transition:background var(--tr),color var(--tr)}
.fsoc a:hover{background:var(--red);color:var(--white)}
.fcol h4{font-family:var(--fh);font-size:.95rem;font-weight:700;color:var(--white);letter-spacing:.05em;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--red);display:inline-block}
.flinks{display:flex;flex-direction:column;gap:8px}
.flinks a{font-size:.85rem;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:8px;transition:color var(--tr),gap var(--tr)}
.flinks a::before{content:'';width:6px;height:1px;background:var(--red);display:block;flex-shrink:0;transition:width var(--tr)}
.flinks a:hover{color:var(--white);gap:12px}
.flinks a:hover::before{width:12px}
.chakra-footer-menu li + li{margin-top:8px}
.fci{display:flex;gap:10px;align-items:flex-start;margin-bottom:11px}
.fci i{color:var(--red-lt);margin-top:3px;font-size:.8rem;flex-shrink:0}
.fci a,.fci span{font-size:.85rem;color:rgba(255,255,255,.6);transition:color var(--tr)}
.fci a:hover{color:var(--white)}
.foot-bot{border-top:1px solid rgba(255,255,255,.08);padding:20px 0}
.foot-bot .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.foot-bot p{font-size:.78rem;color:rgba(255,255,255,.4)}
.fleg{display:flex;gap:18px;flex-wrap:wrap}
.fleg a{font-size:.78rem;color:rgba(255,255,255,.4);transition:color var(--tr)}
.fleg a:hover{color:var(--white)}

/* ====================================================
   FLOATING BUTTONS
==================================================== */
#scrolltop{position:fixed;bottom:20px;right:20px;width:44px;height:44px;background:var(--red);color:var(--white);border:none;border-radius:var(--r);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(192,57,43,.45);opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity var(--tr),transform var(--tr);z-index:900}
#scrolltop.on{opacity:1;pointer-events:all;transform:translateY(0)}
#scrolltop:hover{background:var(--red-lt)}
.wa{position:fixed;bottom:74px;right:20px;z-index:900}
.wa a{width:50px;height:50px;background:#25d366;color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 6px 18px rgba(37,211,102,.45);transition:transform var(--tr),box-shadow var(--tr)}
.wa a:hover{transform:scale(1.1);box-shadow:0 10px 28px rgba(37,211,102,.55)}

/* ====================================================
   WORDPRESS CONTENT
==================================================== */
.chakra-page{background:var(--white);min-height:60vh}
.chakra-entry,.chakra-post-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh-sm)}
.chakra-entry{padding:36px}
.chakra-entry-header{margin-bottom:24px}
.chakra-entry-content{color:var(--gray);line-height:1.85}
.chakra-entry-content > * + *{margin-top:18px}
.chakra-entry-content h2,.chakra-entry-content h3,.chakra-entry-content h4{color:var(--navy-dk)}
.chakra-entry-content a{color:var(--red)}
.chakra-entry-content ul,.chakra-entry-content ol{padding-left:22px}
.chakra-post-list{display:grid;gap:22px}
.chakra-post-card{padding:26px}
.chakra-post-card-image{margin:-26px -26px 18px;overflow:hidden;border-radius:var(--r) var(--r) 0 0}
.chakra-post-card-image img{display:block;width:100%;height:220px;object-fit:cover}
.chakra-post-card-title{font-family:var(--fh);font-size:1.45rem;line-height:1.2;margin-bottom:8px}
.chakra-post-card-title a{color:var(--navy-dk)}
.chakra-post-card-title a:hover{color:var(--red)}
.chakra-post-card-meta{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.chakra-post-card-excerpt{color:var(--gray);line-height:1.75}
.chakra-entry-image{margin:0 0 22px;overflow:hidden;border-radius:var(--r)}
.chakra-entry-image img{display:block;width:100%;height:auto}
.chakra-empty-state{text-align:center;padding:60px 30px}
.nav-links .chakra-menu{display:flex;align-items:center;gap:2px}
.flinks .chakra-footer-menu{display:flex;flex-direction:column;gap:8px}
.pagination,.nav-links .chakra-menu,.flinks .chakra-footer-menu{padding:0;margin:0}
.pagination{display:flex;justify-content:center;gap:8px;list-style:none;margin-top:10px}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:var(--r);color:var(--navy-dk);background:var(--white);transition:background var(--tr),color var(--tr),border-color var(--tr)}
.pagination .page-numbers.current,
.pagination .page-numbers:hover{background:var(--navy);border-color:var(--navy);color:var(--white)}

/* ====================================================
   RESPONSIVE - 1100px
==================================================== */
@media(max-width:1100px){
  .svc-g{grid-template-columns:repeat(2,1fr)}
  .scard.feat{grid-column:span 2}
  .testi-g{grid-template-columns:repeat(2,1fr)}
  .foot-g{grid-template-columns:1fr 1fr;gap:34px}
  .ajax-g{gap:44px}
  .why-g{gap:44px}
  .about-g{gap:44px}
}

/* ====================================================
   RESPONSIVE - 900px (mobile nav activates)
==================================================== */
@media(max-width:900px){
  /* Show hamburger */
  .ham{display:flex}
  /* Full screen slide-down menu */
  .nav-links{
    position:fixed;top:70px;left:0;right:0;
    background:var(--white);
    flex-direction:column;align-items:stretch;gap:0;
    padding:10px 0 20px;
    border-bottom:1px solid var(--border);
    box-shadow:var(--sh-md);
    transform:translateY(-110%);opacity:0;
    transition:transform .35s ease,opacity .35s ease;
    z-index:999;
    overflow-y:auto;max-height:calc(100vh - 70px)
  }
  .nav-links.open{transform:translateY(0);opacity:1}
  .chakra-menu{flex-direction:column;align-items:stretch;gap:0}
  .chakra-menu li{display:block}
  .chakra-menu a{padding:13px 22px;border-radius:0;display:block}
  .chakra-menu a::after{display:none}
  .nav-cta{margin:10px 22px 0!important;border-radius:var(--r)!important;display:flex!important}
  /* Layout */
  .sp{padding:62px 0}
  .about-g,.why-g,.ajax-g,.con-g{grid-template-columns:1fr;gap:34px}
  .why-g .why-img-col{order:1}
  .why-g .why-cnt{order:2}
  .why-img img{height:300px}
  .img-main img{height:320px}
  .img-acc{display:none}
  .creds-g{grid-template-columns:repeat(2,1fr)}
  .ajax-caps{grid-template-columns:1fr 1fr}
  /* Stats 2x2 */
  .stats-row{flex-wrap:wrap}
  .hstat{flex:0 0 50%;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .hstat:nth-child(odd){border-right:1px solid rgba(255,255,255,.1)}
  .hstat:nth-last-child(-n+2){border-bottom:none}
}

/* ====================================================
   RESPONSIVE - 640px
==================================================== */
@media(max-width:640px){
  html{font-size:15px}
  .wrap{padding:0 16px}
  .sp{padding:50px 0}
  /* Topbar: hide address */
  .tb-addr{display:none}
  /* Hero */
  #hero{padding-bottom:185px}
  .hero-geo{display:none}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .hero-btns .btn{width:100%;max-width:280px}
  /* Partners */
  #partners .wrap{flex-direction:column;align-items:flex-start;gap:12px}
  .p-lbl{border-right:none;padding-right:0;width:100%}
  .p-logos{gap:18px}
  .pbadge img{height:24px}
  /* Services */
  .svc-g{grid-template-columns:1fr}
  .scard.feat{grid-column:span 1;display:flex;flex-direction:column}
  .scard.feat .scard-img{height:210px;min-height:unset}
  .scard.feat .scard-body{padding:22px}
  .sfeat-g{grid-template-columns:1fr}
  /* Ajax */
  .ajax-caps{grid-template-columns:1fr}
  /* Testimonials */
  .testi-g{grid-template-columns:1fr}
  /* Contact */
  .frow{grid-template-columns:1fr}
  .con-form{padding:22px 16px}
  /* Footer */
  .foot-g{grid-template-columns:1fr;gap:28px}
  /* Credentials */
  .creds-g{grid-template-columns:1fr 1fr}
  /* CTA */
  .cta-row{flex-direction:column;align-items:center}
  .cta-row .btn{width:100%;max-width:300px}
  /* Map */
  #mapbox{height:270px}
  /* Floating buttons */
  #scrolltop{bottom:16px;right:16px}
  .wa{bottom:68px;right:16px}
}

/* ====================================================
   RESPONSIVE - 380px
==================================================== */
@media(max-width:380px){
  html{font-size:14px}
  .logo-txt{display:none}
  .creds-g{grid-template-columns:1fr}
  .hstat{flex:0 0 50%}
}



