/* ================================================================
   BNSPIRE TECHNOLOGIES — HOME.CSS
   Redesigned referencing mindfire / mindtree / techtss
   Uses global :root variables + local extensions
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap');

/* ── Local token extensions ─────────────────────── */
:root {
  --fd :  sans-serif;
  --fb : 'DM Sans', sans-serif;
  --r  : 3px;
  --rs : 1px;
  --tr : 0.4s cubic-bezier(.4,0,.2,1);
  --sh : 0 4px 30px rgba(24,76,143,.10);
  --shh: 0 20px 60px rgba(24,76,143,.20);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--dark-text);overflow-x:hidden}
a{text-decoration:none}
img{max-width:100%}
.section-pad{padding:100px 0}
.bg-soft{background:var(--soft-bg)}
.mt-24{margin-top:24px}
.mt-32{margin-top:32px}

/* ── Section labels ─────────────────────────────── */
.section-tag{
  display:inline-block;
  background:rgba(24,76,143,.08);color:var(--primary1);
  font-family:var(--fd);font-size:.75rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:6px 16px;border-radius:100px;margin-bottom:14px;
}
.section-tag.light{background:rgba(255,255,255,.12);color:rgba(255,255,255,.85)}
.section-title{
  font-family:var(--fd);font-size:clamp(1.3rem,4vw,2rem);
  font-weight:700;line-height:1.15;color:var(--dark-text);margin-bottom:14px;
}

.section-title.white{color:#fff}
.section-desc{font-size:1.05rem;color:var(--muted);line-height:1.7;max-width:560px;margin:0 auto}
.section-header{margin-bottom:56px}

/* Gradients */
.text-gradient{
  background:linear-gradient(135deg,var(--primary4) 0%,#00b4d8 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.text-gradient-light{
  background:linear-gradient(135deg,#90e0ff 0%,#caf0f8 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ── Shared buttons ─────────────────────────────── */
.btn-outlined{
  display:inline-flex;align-items:center;gap:8px;
  border:2px solid var(--primary1);color:var(--primary1);
  font-family:var(--fd);font-weight:600;font-size:.9rem;
  padding:12px 26px;border-radius:var(--rs);
  transition:var(--tr);
}
.btn-outlined:hover{background:var(--primary1);color:#fff;transform:translateX(4px)}

/* ================================================================
   SCROLL REVEAL
   ================================================================ */
.reveal-up,.reveal-left,.reveal-right,.reveal-card{
  opacity:0;transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);
  transition-delay:var(--delay,0s);
}
.reveal-up   {transform:translateY(48px)}
.reveal-left {transform:translateX(-56px)}
.reveal-right{transform:translateX(56px)}
.reveal-card {transform:translateY(36px) scale(.96)}
.reveal-up.in-view,.reveal-left.in-view,.reveal-right.in-view,.reveal-card.in-view{
  opacity:1;transform:none;
}
.d1{--delay:.10s} .d2{--delay:.22s} .d3{--delay:.36s} .d4{--delay:.50s} .d5{--delay:.64s}

/* ================================================================
   HERO
   ================================================================ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  overflow:hidden;
  background:linear-gradient(158deg,#070f1e 0%,#0b1a36 45%,#0e2552 100%);
}
.hero__bg{position:absolute;inset:0;z-index:0}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%}
.hero__mesh{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(24,76,143,.12) 1px,transparent 1px),
    linear-gradient(90deg,rgba(24,76,143,.12) 1px,transparent 1px);
  background-size:56px 56px;
  animation:meshDrift 22s linear infinite;
}
@keyframes meshDrift{to{background-position:56px 56px}}

.hero__orb{position:absolute;border-radius:50%;filter:blur(80px);animation:orbFloat 9s ease-in-out infinite alternate}
.hero__orb--a{width:600px;height:600px;background:radial-gradient(circle,rgba(24,76,143,.55),transparent 70%);top:-200px;right:-120px;animation-delay:0s}
.hero__orb--b{width:400px;height:400px;background:radial-gradient(circle,rgba(0,180,216,.35),transparent 70%);bottom:0;left:8%;animation-delay:-3s}
.hero__orb--c{width:280px;height:280px;background:radial-gradient(circle,rgba(21,88,192,.4),transparent 70%);top:40%;left:45%;animation-delay:-6s}
@keyframes orbFloat{0%{transform:translate(0,0) scale(1)}100%{transform:translate(28px,-36px) scale(1.08)}}

.hero__inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  padding:100px 0 80px;
}

/* Left */
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.8);font-size:.82rem;
  padding:8px 18px;border-radius:100px;margin-bottom:24px;
  backdrop-filter:blur(8px);
}
.pulse-dot{
  width:8px;height:8px;background:#22d3ee;border-radius:50%;
  animation:pDot 2s ease-in-out infinite;
}
@keyframes pDot{0%,100%{box-shadow:0 0 0 0 rgba(34,211,238,.7)}50%{box-shadow:0 0 0 8px rgba(34,211,238,0)}}

.hero__heading{
  font-family:var(--fd);font-size:clamp(1.8rem,4vw,2.2rem);
  font-weight:700;color:#fff;line-height:1.8;margin-bottom:22px;
}
.hero__type-wrap{display:flex;align-items:center;gap:2px}
.hero__caret{color:#22d3ee;font-weight:300;animation:caretBlink 1s step-end infinite}
@keyframes caretBlink{0%,100%{opacity:1}50%{opacity:0}}
#heroType{
  background:linear-gradient(135deg,#60a5fa,#22d3ee);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.hero__sub{font-size:1.08rem;color:rgba(255,255,255,.62);line-height:1.75;max-width:560px;margin-bottom:36px}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}

.btn-hero-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,var(--primary4),#00b4d8);
  color:#fff;font-family:var(--fd);font-weight:700;
  padding:14px 30px;border-radius:var(--rs);font-size:.95rem;
  transition:var(--tr);position:relative;overflow:hidden;
  box-shadow:0 6px 24px rgba(12,74,148,.45);
}
.btn-hero-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.18),transparent);
  transform:translateX(-100%);transition:transform .4s ease;
}
.btn-hero-primary:hover::before{transform:translateX(0)}
.btn-hero-primary:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(12,74,148,.55);color:#fff}
.btn-hero-primary svg{width:18px;height:18px;transition:transform .3s}
.btn-hero-primary:hover svg{transform:translateX(4px)}

.btn-hero-ghost{
  display:inline-flex;align-items:center;
  color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.2);
  font-weight:500;padding:14px 26px;border-radius:var(--rs);font-size:.95rem;
  transition:var(--tr);backdrop-filter:blur(6px);
}
.btn-hero-ghost:hover{color:#fff;border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.07)}

.hero__trust{}
.trust-label{display:block;color:rgba(255,255,255,.4);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.trust-badges{display:flex;gap:10px;flex-wrap:wrap}
.trust-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.7);font-size:.78rem;
  padding:6px 14px;border-radius:100px;
}
.trust-badge i{color:#22d3ee}

/* Right visual */
.hero__visual{position:relative;display:flex;align-items:center;justify-content:center;height:480px}
.hero__blob{
  position:absolute;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(24,76,143,.3),rgba(0,180,216,.15),transparent 70%);
  animation:blobPulse 6s ease-in-out infinite alternate;
}
@keyframes blobPulse{0%{transform:scale(1)}100%{transform:scale(1.12)}}
.vc-rings{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}
.vc-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.1)}
.r1{width:200px;height:200px;animation:spinRing 18s linear infinite}
.r2{width:150px;height:150px;border-color:rgba(34,211,238,.2);animation:spinRing 12s linear infinite reverse}
.r3{width:100px;height:100px;animation:spinRing 8s linear infinite}
@keyframes spinRing{to{transform:rotate(360deg)}}
.vc-core{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary1),#00b4d8);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 40px rgba(0,180,216,.4);
  animation:coreGlow 3s ease-in-out infinite alternate;
}
@keyframes coreGlow{0%{box-shadow:0 0 30px rgba(0,180,216,.3)}100%{box-shadow:0 0 60px rgba(0,180,216,.6)}}
.vc-core i{font-size:1.8rem;color:#fff}

.float-card{
  position:absolute;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(14px);border-radius:14px;
  padding:14px 18px;display:flex;align-items:center;gap:12px;
  color:#fff;
}
.float-card i{font-size:1.5rem;color:#22d3ee}
.float-card strong{font-family:var(--fd);font-size:1.6rem;font-weight:800;line-height:1}
.float-card sup{font-size:.85rem;font-weight:700;color:#22d3ee;vertical-align:super}
.float-card small{display:block;font-size:.72rem;color:rgba(255,255,255,.5);margin-top:2px}
.fc-a{top:50px;right:-10px;animation:floatCard 5s ease-in-out infinite alternate}
.fc-b{bottom:80px;left:-10px;animation:floatCard 6s ease-in-out 1s infinite alternate}
.fc-c{top:50%;right:-30px;transform:translateY(-50%);animation:floatCard 7s ease-in-out 2s infinite alternate}
@keyframes floatCard{0%{transform:translateY(0)}100%{transform:translateY(-12px)}}
.fc-c{animation-name:floatCard2}
@keyframes floatCard2{0%{transform:translateY(-50%)}100%{transform:translateY(calc(-50% - 12px))}}

/* Scroll hint */
.hero__scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:rgba(255,255,255,.35);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;z-index:3;
  animation:fadeInUp 1s 1.5s both;
}
.scroll-mouse{width:22px;height:36px;border:2px solid rgba(255,255,255,.25);border-radius:11px;display:flex;align-items:flex-start;justify-content:center;padding-top:6px}
.scroll-wheel{width:3px;height:8px;background:rgba(255,255,255,.5);border-radius:2px;animation:scrollW 2s ease-in-out infinite}
@keyframes scrollW{0%{transform:translateY(0);opacity:1}100%{transform:translateY(12px);opacity:0}}
@keyframes fadeInUp{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ================================================================
   MARQUEE
   ================================================================ */
.marquee{
  background:linear-gradient(135deg,var(--primary1),var(--primary4));
  padding:15px 0;overflow:hidden;
}
.marquee__track{display:flex;width:max-content;animation:marquee 30s linear infinite}
.marquee__track:hover{animation-play-state:paused}
.marquee__item{
  display:inline-flex;align-items:center;gap:18px;
  color:rgba(255,255,255,.8);font-family:var(--fd);font-weight:600;font-size:.82rem;
  padding:0 24px;white-space:nowrap;letter-spacing:.04em;
}
.marquee__item i{font-size:5px;color:rgba(255,255,255,.3)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ================================================================
   ABOUT STRIP
   ================================================================ */
.about__inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about__left p{font-size:1rem;color:var(--muted);line-height:1.75;margin-bottom:32px}
.about__pillars{display:flex;gap:32px}
.pillar{display:flex;flex-direction:column;gap:4px}
.p-num{font-family:var(--fd);font-size:2rem;font-weight:800;color:var(--primary1)}
.p-label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}

.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ab-box{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r);padding:28px 24px;
  transition:var(--tr);
}
.ab-box:hover{border-color:rgba(24,76,143,.25);transform:translateY(-6px);box-shadow:var(--shh)}
.ab-box i{font-size:1.5rem;margin-bottom:12px;display:block;
  background:linear-gradient(135deg,var(--primary1),#00b4d8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.ab-box h4{font-family:var(--fd);font-weight:700;font-size:.95rem;margin-bottom:8px;color:var(--dark-text)}
.ab-box p{font-size:.85rem;color:var(--muted);line-height:1.6}

/* ================================================================
   SERVICES GRID
   ================================================================ */
.svc-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:22px;
}
.svc-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r);padding:34px 30px 28px;
  position:relative;overflow:hidden;
  transition:var(--tr);
}
.svc-card:hover{border-color:rgba(24,76,143,.2);transform:translateY(-8px);box-shadow:var(--shh);background: var(--primary1);}
.svc-card__bar{
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary1),#00b4d8);
  transform:scaleX(0);transform-origin:left;transition:transform .4s ease;
}
.svc-card:hover .svc-card__bar{transform:scaleX(1)}
.svc-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.svc-icon{
  width:52px;height:52px;border-radius:13px;
  background:linear-gradient(135deg,rgba(24,76,143,.1),rgba(0,180,216,.1));
  display:flex;align-items:center;justify-content:center;
  transition:var(--tr);
}
.svc-icon i{font-size:1.4rem;background:linear-gradient(135deg,var(--primary1),#00b4d8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.svc-card:hover .svc-icon{background:linear-gradient(135deg,var(--primary1),#00b4d8);transform:rotate(-6deg) scale(1.05)}
.svc-card:hover .svc-icon i{background:none;-webkit-text-fill-color:#fff}
.svc-no{font-family:var(--fd);font-size:2.5rem;font-weight:800;color:rgba(24,76,143,.06);line-height:1;transition:var(--tr)}
.svc-card:hover .svc-no{color:rgba(24,76,143,.1)}
.svc-card h3{font-family:var(--fd);font-size:1.05rem;font-weight:700;margin-bottom:10px;color:var(--dark-text)}
.svc-card p{font-size:.88rem;color:var(--muted);line-height:1.65;margin-bottom:16px}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.svc-tags span{
  background:rgba(24,76,143,.07);color:var(--primary1);
  font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:100px;
}
.svc-link{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--primary1);font-size:.85rem;font-weight:700;
  transition:gap .3s;
}
.svc-link svg{width:16px;height:16px;transition:transform .3s}
.svc-link:hover{gap:12px;color:var(--primary4)}
.svc-link:hover svg{transform:translateX(4px)}

.svc-card:hover .svc-link{color:#fff}
.svc-card:hover h3{color:#fff}
.svc-card:hover .svc-tags span{background:rgba(255,255,255,.2);color:#fff}
.svc-card:hover .svc-no{color:rgba(255,255,255,.1)}
.svc-card:hover p{color:rgba(255,255,255,.85)}
.svc-card:hover .svc-icon i{background:none;-webkit-text-fill-color:#fff}

/* ================================================================
   INDUSTRIES
   ================================================================ */
.industries__hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px;flex-wrap:wrap;gap:20px}
.ind-wrap{border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.ind-tabs{
  display:flex;flex-wrap:wrap;
  background:var(--soft-bg);border-bottom:1px solid var(--border);
}
.ind-tab{
  background:none;border:none;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  color:var(--muted);font-family:var(--fd);font-size:.85rem;font-weight:600;
  padding:18px 24px;border-bottom:3px solid transparent;
  transition:var(--tr);
}
.ind-tab i{font-size:1rem}
.ind-tab.active,.ind-tab:hover{color:var(--primary1);border-bottom-color:var(--primary1);background:var(--white)}
.ind-panels{padding:40px 48px}
.ind-panel{display:none;animation:panelIn .4s ease}
.ind-panel.active{display:flex;gap:36px;align-items:flex-start}
@keyframes panelIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.ind-panel__icon{
  width:72px;height:72px;flex-shrink:0;border-radius:18px;
  background:linear-gradient(135deg,rgba(24,76,143,.1),rgba(0,180,216,.1));
  display:flex;align-items:center;justify-content:center;
}
.ind-panel__icon i{font-size:2rem;background:linear-gradient(135deg,var(--primary1),#00b4d8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ind-panel__body h3{font-family:var(--fd);font-size:1.3rem;font-weight:800;margin-bottom:12px;color:var(--dark-text)}
.ind-panel__body p{color:var(--muted);line-height:1.7;margin-bottom:20px;font-size:.95rem}
.ind-stack{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.ind-stack span{
  background:var(--soft-bg);border:1px solid var(--border);
  color:var(--dark-text);font-size:.8rem;font-weight:500;
  padding:6px 14px;border-radius:100px;
  transition:var(--tr);
}
.ind-stack span:hover{background:var(--primary1);color:#fff;border-color:var(--primary1)}

/* ================================================================
   NUMBERS PARALLAX
   ================================================================ */
.numbers{position:relative;padding:90px 0;overflow:hidden}
.numbers__bg{
  position:absolute;inset:-60px;will-change:transform;
  background:
    linear-gradient(rgba(8,18,40,.91),rgba(12,28,56,.94)),
    url('https://images.unsplash.com/photo-1522071820081-009f0129c71c?w=1800&auto=format&fit=crop') center/cover no-repeat;
}
.numbers__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(24,76,143,.3),rgba(0,150,199,.15))}
.numbers__inner{
  position:relative;z-index:2;
  display:flex;align-items:center;justify-content:space-around;flex-wrap:wrap;gap:40px;
}
.nb-stat{display:flex;flex-direction:column;align-items:center;text-align:center}
.nb-num{font-family:var(--fd);font-size:3.5rem;font-weight:800;color:#fff;line-height:1}
.nb-suf{font-family:var(--fd);font-size:2rem;font-weight:800;color:#22d3ee;vertical-align:top;margin-top:8px}
.nb-label{font-size:.8rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.08em;margin-top:8px}
.nb-div{width:1px;height:60px;background:rgba(255,255,255,.1)}

/* ================================================================
   TECH STACK
   ================================================================ */
.techstack{
  background:
    radial-gradient(circle at 82% 18%,rgba(24,76,143,.24),transparent 31%),
    radial-gradient(circle at 12% 82%,rgba(0,180,216,.14),transparent 27%),
    linear-gradient(135deg,#061126 0%,#0b2450 52%,#061126 100%);
  overflow:hidden;
  position:relative;
}
.techstack::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(34,211,238,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(34,211,238,.05) 1px,transparent 1px);
  background-size:64px 64px;opacity:.5;pointer-events:none;
}
.techstack .container{position:relative;z-index:1}
.techstack .section-title{color:#fff}
.techstack .section-tag{background:rgba(24,76,143,.22);color:#93c5fd;border-color:rgba(147,197,253,.26)}
.ts-shell{
  background:#071a3d;
  border:1px solid rgba(147,197,253,.18);
  border-radius:18px;
  display:grid;
  grid-template-columns:minmax(260px,44%) 1fr;
  min-height:390px;
  overflow:hidden;
}
.ts-tabs{
  background: var(--primary1);
  display:flex;
  flex-direction:column;
  gap:16px;
  padding:26px 24px;
  position:relative;
}
.ts-tabs::after{
  content:"";position:absolute;right:-1px;top:0;bottom:0;width:12px;
  background:#3f8cff;
  box-shadow:0 0 28px rgba(63,140,255,.42);
}
.ts-tab{
  align-items:center;
  background:transparent;
  border:0;
  border-radius:12px;
  color:#fff;
  cursor:pointer;
  display:flex;
  font-family:var(--fd);
  font-size:1.05rem;
  font-weight:800;
  gap:10px;
  min-height:48px;
  padding:10px 12px;
  position:relative;
  text-align:left;
  transition:var(--tr);
  width:100%;
}
.ts-tab > i:first-child{color:#bfdbfe;font-size:1.15rem}
.ts-tab-arrow{
  align-items:center;
  background:#dbeafe;
  border-radius:50%;
  color:#184c8f;
  display:none;
  height:32px;
  justify-content:center;
  margin-left:auto;
  width:32px;
}
.ts-tab.active,.ts-tab:hover{
  background:rgba(255,255,255,.14);
  box-shadow:0 8px 22px rgba(0,0,0,.22);
}
.ts-tab.active .ts-tab-arrow{display:flex}
.ts-content{
  background:#071a3d;
  padding:32px 38px;
}
.ts-panel{
  animation:tabIn .35s ease;
  display:none;
  gap:18px 20px;
  grid-template-columns:repeat(3,minmax(160px,1fr));
}
.ts-panel.active{display:grid}
@keyframes tabIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.ts-item{
  align-items:center;
  background:rgba(232,240,255,.14);
  border:1px solid rgba(147,197,253,.14);
  border-radius:10px;
  color:#fff;
  display:flex;
  gap:12px;
  min-height:58px;
  padding:10px 13px;
  transition:var(--tr);
}
.ts-item:hover{background:rgba(63,140,255,.22);border-color:rgba(147,197,253,.32);transform:translateY(-3px)}
.ts-icon{
  align-items:center;
  background:#e8f0ff;
  border-radius:8px;
  color:#184c8f;
  display:flex;
  flex:0 0 auto;
  height:38px;
  justify-content:center;
  width:38px;
}
.ts-icon i{font-size:1.25rem}
.ts-item span{color:#fff;font-size:.86rem;font-weight:700;line-height:1.25}

/* ================================================================
   PROCESS
   ================================================================ */
.proc-flow{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.proc-step{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative}
.proc-step__node{display:flex;flex-direction:column;align-items:center}
.psn-circle{
  width:80px;height:80px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary1),#00b4d8);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 28px rgba(24,76,143,.25);
  position:relative;transition:var(--tr);z-index:1;
}
.psn-circle::before{
  content:'';position:absolute;inset:-5px;
  border:2px dashed rgba(24,76,143,.2);border-radius:50%;
  animation:spinDash 14s linear infinite;
}
@keyframes spinDash{to{transform:rotate(360deg)}}
.proc-step:hover .psn-circle{transform:scale(1.1);box-shadow:0 12px 40px rgba(24,76,143,.35)}
.psn-circle i{font-size:1.4rem;color:#fff}
.psn-num{
  font-family:var(--fd);font-size:.72rem;font-weight:700;
  color:var(--primary1);letter-spacing:.08em;margin-top:8px;
}
.psn-line{
  width:2px;height:28px;
  background:linear-gradient(180deg,var(--primary1),#00b4d8);
  margin:8px auto;
}
.proc-step__body{margin-top:12px;padding:0 8px}
.proc-step__body h4{font-family:var(--fd);font-weight:700;font-size:.95rem;color:var(--dark-text);margin-bottom:8px}
.proc-step__body p{font-size:.83rem;color:var(--muted);line-height:1.6}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.testi__hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:20px}
.testi-nav{display:flex;align-items:center;gap:12px}
.tn-btn{
  width:42px;height:42px;background:var(--white);border:1px solid var(--border);
  border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:.95rem;color:var(--dark-text);transition:var(--tr);
}
.tn-btn:hover{background:var(--primary1);border-color:var(--primary1);color:#fff;transform:scale(1.1)}
.tn-dots{display:flex;gap:7px}
.tn-dot{
  width:8px;height:8px;border-radius:100px;
  background:var(--border);border:none;cursor:pointer;transition:all .4s ease;
}
.tn-dot.active{width:26px;background:var(--primary1)}

.testi-slider{overflow:hidden}
.testi-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1);will-change:transform}
.testi-slide{min-width:100%;padding:0 10px}
.testi-card{
  max-width:780px;margin:0 auto;
  background:var(--white);border:1px solid var(--border);border-radius:24px;
  padding:50px 52px 42px;position:relative;box-shadow:var(--sh);
  transition:var(--tr);
}
.testi-card:hover{box-shadow:var(--shh)}
.testi-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.tc-stars{display:flex;gap:4px}
.tc-stars i{color:#fbbf24;font-size:.9rem}
.tc-result{
  display:flex;align-items:center;gap:8px;
  background:rgba(24,76,143,.07);color:var(--primary1);
  font-size:.8rem;font-weight:700;padding:6px 14px;border-radius:100px;
}
.tc-result i{font-size:.9rem}
.testi-card blockquote{
  font-size:1.05rem;color:var(--dark-text);line-height:1.75;
  font-style:italic;margin-bottom:30px;
  border-left:3px solid var(--primary4);padding-left:20px;
}
.testi-author{display:flex;align-items:center;gap:14px}
.ta-avatar{
  width:48px;height:48px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--primary1),#00b4d8);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--fd);font-weight:700;font-size:.82rem;
}
.testi-author strong{display:block;font-family:var(--fd);font-weight:700;font-size:.9rem;color:var(--dark-text)}
.testi-author span{font-size:.8rem;color:var(--muted)}

/* ================================================================
   WHY BNSPIRE
   ================================================================ */
.why__inner{display:grid;grid-template-columns:1fr 1.4fr;gap:72px;align-items:start}
.why__left p{font-size:1rem;color:var(--muted);line-height:1.75;margin-bottom:8px}
.why__grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.why-item{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r);padding:22px 20px;
  transition:var(--tr);
}
.why-item:hover{border-color:rgba(24,76,143,.2);transform:translateY(-4px);box-shadow:var(--shh)}
.wi-icon{
  width:42px;height:42px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(24,76,143,.1),rgba(0,180,216,.1));
  display:flex;align-items:center;justify-content:center;transition:var(--tr);
}
.wi-icon i{font-size:1.1rem;background:linear-gradient(135deg,var(--primary1),#00b4d8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.why-item:hover .wi-icon{background:linear-gradient(135deg,var(--primary1),#00b4d8)}
.why-item:hover .wi-icon i{background:none;-webkit-text-fill-color:#fff}
.why-item h4{font-family:var(--fd);font-weight:700;font-size:.88rem;margin-bottom:6px;color:var(--dark-text)}
.why-item p{font-size:.82rem;color:var(--muted);line-height:1.6}

/* ================================================================
   CTA BAND
   ================================================================ */
.cta-band{
  position:relative;padding:110px 0;
  background:linear-gradient(155deg,#070f1e 0%,#0b1a36 50%,#0e2552 100%);
  overflow:hidden;
}
.cta-band__bg{position:absolute;inset:0;z-index:0}
.cta-orb{position:absolute;border-radius:50%;filter:blur(90px);animation:orbFloat 10s ease-in-out infinite alternate}
.o1{width:500px;height:500px;background:radial-gradient(circle,rgba(24,76,143,.55),transparent 70%);top:-150px;left:-80px}
.o2{width:380px;height:380px;background:radial-gradient(circle,rgba(0,180,216,.35),transparent 70%);bottom:-100px;right:-50px;animation-delay:-5s}
.cta-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(24,76,143,.1) 1px,transparent 1px),
    linear-gradient(90deg,rgba(24,76,143,.1) 1px,transparent 1px);
  background-size:60px 60px;
  animation:meshDrift 20s linear infinite;
}
.cta-band__inner{
  position:relative;z-index:2;
  display:flex;align-items:center;gap:80px;flex-wrap:wrap;
}
.cta-band__text{flex:1;min-width:280px}
.cta-band__text h2{
  font-family:var(--fd);font-size:clamp(2rem,5vw,3.2rem);
  font-weight:800;color:#fff;line-height:1.15;margin-bottom:16px;
}
.cta-band__text p{font-size:1rem;color:rgba(255,255,255,.58);line-height:1.7}
.cta-band__actions{display:flex;flex-direction:column;gap:14px;align-items:flex-start;flex-shrink:0}
.btn-cta-white{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;color:var(--primary1);
  font-family:var(--fd);font-weight:700;font-size:.95rem;
  padding:15px 30px;border-radius:var(--rs);
  transition:var(--tr);box-shadow:0 6px 24px rgba(0,0,0,.2);
}
.btn-cta-white:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(0,0,0,.3);color:var(--primary1)}
.btn-cta-white svg{width:18px;height:18px;transition:transform .3s}
.btn-cta-white:hover svg{transform:translateX(4px)}
.btn-cta-ghost{
  display:inline-flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.2);
  font-weight:600;font-size:.9rem;
  padding:13px 26px;border-radius:var(--rs);
  transition:var(--tr);
}
.btn-cta-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.45);color:#fff}
.cta-reassure{display:flex;flex-direction:column;gap:8px}
.cta-reassure span{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.5);font-size:.82rem}
.cta-reassure i{color:#22d3ee}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1100px){
  .hero__inner{grid-template-columns:1fr;gap:40px}
  .hero__visual{height:320px}
  .about__inner{grid-template-columns:1fr;gap:48px}
  .why__inner{grid-template-columns:1fr;gap:48px}
  .cta-band__inner{gap:48px}
  .ts-shell{grid-template-columns:260px 1fr}
  .ts-panel{grid-template-columns:repeat(2,minmax(150px,1fr))}
}
@media(max-width:900px){
  .section-pad{padding:72px 0}
  .proc-flow{grid-template-columns:repeat(2,1fr)}
  .why__grid{grid-template-columns:1fr}
  .numbers__inner{gap:28px}
  .nb-div{display:none}
  .ts-shell{grid-template-columns:1fr}
  .ts-tabs{padding:18px}
  .ts-tabs::after{display:none}
  .ts-content{padding:24px}
}
@media(max-width:768px){
  .hero__inner{padding:70px 20px}
  .hero__ctas{flex-direction:column}
  .svc-grid{grid-template-columns:1fr}
  .about__grid{grid-template-columns:1fr}
  .ind-panels{padding:28px 24px}
  .ind-panel.active{flex-direction:column}
  .testi-card{padding:32px 24px}
  .industries__hd{flex-direction:column;align-items:flex-start}
  .industries__hd .section-desc{text-align:left}
  .ts-tabs{gap:8px}
  .ts-tab{font-size:.92rem;min-height:44px}
  .ts-panel{grid-template-columns:1fr}
}
@media(max-width:540px){
  .hero__heading{font-size:2.5rem}
  .proc-flow{grid-template-columns:1fr}
  .about__pillars{flex-wrap:wrap}
  .cta-band__inner{flex-direction:column}
  .cta-band__actions{width:100%}
  .btn-cta-white{width:100%;justify-content:center}
  .float-card{font-size:.75rem;padding:10px 12px}
  .ts-content{padding:18px}
  .ts-tabs{padding:14px}
}
