/* ══════════════════════════════════════════════
   FINSOVA — ABOUT PAGE
   Full design system match
══════════════════════════════════════════════ */
:root{
  --blue:#0454A3;
  --blue-mid:#0667C4;
  --blue-light:#E8F1FB;
  --blue-xlight:#F0F6FF;
  --blue-pale:#F7FAFF;
  --blue-glow:rgba(4,84,163,0.12);
  --blue-dim:rgba(4,84,163,0.06);

  --orange:#F97316;
  --orange-light:#FFF3EC;

  --green:#10B981;
  --green-light:#ECFDF5;

  --gold:#F59E0B;
  --gold-light:#FFFBEB;

  --ink:#0A1628;
  --ink2:#1E3050;
  --body:#4B607A;
  --muted:#8898AA;
  --border:#E2EBF5;
  --border2:#C8DAEE;

  --white:#FFFFFF;
  --surface:#F8FBFF;
  --surface2:#F0F6FF;

  --r-xs:8px;
  --r-sm:14px;
  --r-md:20px;
  --r-lg:28px;
  --r-xl:40px;
  --r-full:999px;

  --shadow-sm:0 2px 8px rgba(4,84,163,.08);
  --shadow-md:0 8px 32px rgba(4,84,163,.12);
  --shadow-lg:0 20px 60px rgba(4,84,163,.16);
  --shadow-xl:0 40px 100px rgba(4,84,163,.20);

  --font:'Plus Jakarta Sans',sans-serif;
  --serif:'Instrument Serif',serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
}

*,*::before,*::after{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
  width:100%;
  overflow-x:hidden !important;
}

body{
  font-family:var(--font);
  background:var(--white);
  color:var(--ink);
  overflow-x:hidden !important;
  width:100%;
}

*{
  max-width:100%;
}

img,svg{
  max-width:100%;
  height:auto;
}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:3px}

/* ── CURSOR ── */
.cur,.cur-ring{
  position:fixed;
  pointer-events:none;
  z-index:9999;
  border-radius:50%;
  transition:transform .2s var(--ease);
}
.cur{
  width:10px;
  height:10px;
  background:var(--blue);
  mix-blend-mode:multiply;
}
.cur-ring{
  width:38px;
  height:38px;
  border:2px solid rgba(4,84,163,.3);
  z-index:9998;
  transition:all .3s var(--ease);
}
@media(hover:none){
  .cur,.cur-ring{display:none}
}

/* ── PROGRESS ── */
.scroll-prog{
  position:fixed;
  top:0;
  left:0;
  height:3px;
  background:linear-gradient(90deg,var(--blue),var(--orange),var(--green));
  z-index:9999;
  width:0;
  border-radius:0 2px 2px 0;
}

/* ══════ NAVBAR ══════ */
.nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:2000;
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 5%;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(226,235,245,.8);
  transition:all .3s var(--ease);
}
.nav.scrolled{
  box-shadow:var(--shadow-md);
  background:rgba(255,255,255,.97);
}
.logo{
  display:flex;
  align-items:center;
  gap:11px;
  text-decoration:none;
}
.logo-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 16px rgba(4,84,163,.3);
  position:relative;
  overflow:hidden;
}
.logo-icon::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:50%;
  background:rgba(255,255,255,.15);
}
.logo-icon svg{
  width:22px;
  height:22px;
  fill:none;
  stroke:#fff;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
  position:relative;
  z-index:1;
}
.logo-name{
  font-size:20px;
  font-weight:800;
  color:var(--ink);
  letter-spacing:-.5px;
}
.logo-name span{color:var(--blue)}
.logo-tag{
  font-size:9px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
  display:block;
  line-height:1;
}

.nav-links{display:flex;gap:2px}
.nav-link{
  font-size:13.5px;
  font-weight:500;
  color:var(--body);
  padding:8px 15px;
  border-radius:var(--r-xs);
  text-decoration:none;
  transition:all .2s;
}
.nav-link:hover{
  background:var(--blue-light);
  color:var(--blue);
}
.nav-link.active{
  color:var(--blue);
  background:var(--blue-dim);
}

.nav-actions{
  display:flex;
  gap:10px;
  align-items:center;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--font);
  font-size:13.5px;
  font-weight:700;
  padding:10px 22px;
  border-radius:var(--r-full);
  cursor:pointer;
  text-decoration:none;
  border:none;
  transition:all .25s var(--ease);
}
.btn-ghost{
  background:var(--surface2);
  color:var(--blue);
  border:1.5px solid var(--border2);
}
.btn-ghost:hover{
  background:var(--blue-light);
  border-color:var(--blue);
}
.btn-blue{
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  color:#fff;
  box-shadow:0 4px 18px rgba(4,84,163,.35);
}
.btn-blue:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(4,84,163,.45);
}
.btn-lg{padding:15px 34px;font-size:15px}
.btn-xl{padding:18px 40px;font-size:16px}

.btn-white{
  background:#fff;
  color:var(--blue);
  font-weight:700;
  box-shadow:0 6px 24px rgba(0,0,0,.15);
}
.btn-white:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 36px rgba(0,0,0,.25);
}

.btn-outline-white{
  background:rgba(255,255,255,.1);
  color:#fff;
  border:1.5px solid rgba(255,255,255,.3);
}
.btn-outline-white:hover{
  background:rgba(255,255,255,.18);
}

.hamburger{
  display:none;
  position:relative;
  z-index:2100;
  background:var(--surface2);
  border:1.5px solid var(--border);
  border-radius:var(--r-xs);
  padding:8px 11px;
  font-size:16px;
  cursor:pointer;
  color:var(--ink);
}

/* ── REVEAL ── */
.reveal,.reveal-left,.reveal-right{
  opacity:0;
  transform:translateY(36px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
}
.reveal-left{transform:translateX(-40px)}
.reveal-right{transform:translateX(40px)}
.reveal.vis,.reveal-left.vis,.reveal-right.vis{
  opacity:1;
  transform:none;
}

/* ── KEYFRAMES ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.7)}
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
@keyframes ctaRing{
  0%,100%{opacity:.5}
  50%{opacity:1}
}
@keyframes scrollDown{
  0%{opacity:1;transform:translateY(0)}
  100%{opacity:0;transform:translateY(12px)}
}
@keyframes counterPop{
  0%{transform:scale(.9);opacity:0}
  100%{transform:scale(1);opacity:1}
}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero{
  min-height:100vh;
  padding:120px 5% 0;
  background:linear-gradient(160deg,#040E1E 0%,#0A1E40 45%,#0454A3 100%);
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
}
.hero-grid{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(4,84,163,.12) 1px,transparent 1px),
    linear-gradient(90deg,rgba(4,84,163,.12) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 100%);
}
.hero-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  pointer-events:none;
}
.orb1{width:500px;height:500px;background:rgba(4,84,163,.25);top:-100px;right:-80px}
.orb2{width:350px;height:350px;background:rgba(249,115,22,.1);bottom:-60px;left:-60px}
.orb3{width:250px;height:250px;background:rgba(16,185,129,.07);top:40%;left:35%}

.india-bg{
  position:absolute;
  right:0;
  bottom:0;
  top:0;
  width:55%;
  opacity:.04;
  pointer-events:none;
  max-width:100vw;
}

.hero-inner{
  max-width:1280px;
  margin:0 auto;
  width:100%;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:64px;
  align-items:center;
  position:relative;
  z-index:2;
  padding-bottom:80px;
}

.breadcrumb{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:600;
  color:rgba(255,255,255,.45);
  margin-bottom:20px;
}
.breadcrumb a{
  color:rgba(255,255,255,.65);
  text-decoration:none;
}
.breadcrumb a:hover{color:#fff}
.bc-sep{color:rgba(255,255,255,.25)}

.hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  background:rgba(4,84,163,.35);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r-full);
  padding:7px 18px;
  font-size:12px;
  font-weight:700;
  color:rgba(255,255,255,.9);
  letter-spacing:.5px;
  margin-bottom:24px;
  backdrop-filter:blur(10px);
}
.ey-dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:#4ade80;
  animation:pulse 2s infinite;
}

.hero h1{
  font-size:clamp(40px,5.5vw,76px);
  font-weight:800;
  letter-spacing:-3px;
  color:#fff;
  line-height:1.03;
  margin-bottom:26px;
}
.hero h1 .serif{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  color:rgba(255,255,255,.75);
}
.hero h1 .accent{
  background:linear-gradient(90deg,#4ade80,#34d399);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero-sub{
  font-size:17px;
  color:rgba(255,255,255,.68);
  line-height:1.8;
  max-width:500px;
  margin-bottom:40px;
}
.hero-btns{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:48px;
}

/* Scroll indicator */
.scroll-cue{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.sc-line{
  width:1px;
  height:40px;
  background:linear-gradient(180deg,rgba(255,255,255,.5),transparent);
  position:relative;
}
.sc-dot{
  position:absolute;
  top:0;
  left:50%;
  width:5px;
  height:5px;
  border-radius:50%;
  background:#fff;
  transform:translateX(-50%);
  animation:scrollDown 1.6s ease-in-out infinite;
}
.sc-lbl{
  font-size:10px;
  font-weight:600;
  letter-spacing:2px;
  color:rgba(255,255,255,.4);
  text-transform:uppercase;
}

/* ── Hero right ── */
.hero-card-wrap{
  position:relative;
  animation:fadeUp .9s .2s both;
}
.mission-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:28px;
  padding:40px;
  backdrop-filter:blur(20px);
  box-shadow:0 30px 80px rgba(0,0,0,.4);
}
.mc-tag{
  font-size:10px;
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.4);
  margin-bottom:20px;
  display:flex;
  align-items:center;
  gap:8px;
}
.mc-tag::before{
  content:'';
  width:16px;
  height:2px;
  background:var(--orange);
  border-radius:2px;
}
.mc-quote{
  font-family:var(--serif);
  font-size:clamp(18px,2.2vw,26px);
  font-style:italic;
  color:#fff;
  line-height:1.55;
  margin-bottom:28px;
  font-weight:400;
}
.mc-author{
  display:flex;
  align-items:center;
  gap:14px;
}
.mc-avatar{
  width:52px;
  height:52px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  font-weight:800;
  color:#fff;
  flex-shrink:0;
  border:2px solid rgba(255,255,255,.2);
  box-shadow:0 4px 16px rgba(4,84,163,.4);
}
.mc-name{font-size:14px;font-weight:700;color:#fff;margin-bottom:2px}
.mc-role{font-size:12px;color:rgba(255,255,255,.5)}

.hero-float{
  position:absolute;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(12px);
  border-radius:14px;
  padding:12px 16px;
  white-space:nowrap;
}
.hf1{top:-24px;right:16px;animation:float 4.5s ease-in-out infinite}
.hf2{bottom:40px;left:-16px;animation:float 5.5s 2s ease-in-out infinite}
.hf-inner{display:flex;align-items:center;gap:10px}
.hf-ico{font-size:22px}
.hf-val{font-size:15px;font-weight:800;color:#fff}
.hf-lbl{font-size:10px;color:rgba(255,255,255,.55)}

.hero-wave{
  position:absolute;
  bottom:-1px;
  left:0;
  right:0;
  line-height:0;
  z-index:3;
  max-width:100vw;
}
.hero-wave svg{
  display:block;
  width:100%;
}

/* ══════════════════════════════════════
   MISSION
══════════════════════════════════════ */
.mission-sec{background:var(--surface);padding:96px 5%}
.container{max-width:1280px;margin:0 auto;width:100%}
.tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:11px;
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:18px;
}
.tag::before{
  content:'';
  width:20px;
  height:2px;
  background:var(--blue);
  border-radius:2px;
}
.sec-title{
  font-size:clamp(28px,4vw,50px);
  font-weight:800;
  letter-spacing:-1.5px;
  color:var(--ink);
  line-height:1.1;
  margin-bottom:18px;
}
.sec-title .accent{color:var(--blue)}
.sec-title .serif{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
}
.sec-sub{
  font-size:17px;
  color:var(--body);
  line-height:1.75;
  max-width:560px;
}
.tc{text-align:center}
.tc .sec-sub{margin:0 auto}

.mission-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  margin-top:64px;
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.mission-pillar{
  padding:52px 40px;
  background:#fff;
  position:relative;
  overflow:hidden;
  transition:all .35s var(--ease);
}
.mission-pillar:hover{
  transform:translateY(-4px);
  z-index:2;
  box-shadow:var(--shadow-lg);
}
.mission-pillar::after{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s var(--ease);
}
.mp-blue::after{background:linear-gradient(90deg,var(--blue),var(--blue-mid))}
.mp-orange::after{background:linear-gradient(90deg,var(--orange),#fb923c)}
.mp-green::after{background:linear-gradient(90deg,var(--green),#059669)}
.mission-pillar:hover::after{transform:scaleX(1)}

.mp-icon{
  width:64px;
  height:64px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
  margin-bottom:24px;
}
.mpi-blue{background:var(--blue-light)}
.mpi-orange{background:var(--orange-light)}
.mpi-green{background:var(--green-light)}
.mp-eyebrow{
  font-size:10px;
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:8px;
}
.mp-title{
  font-size:22px;
  font-weight:800;
  color:var(--ink);
  letter-spacing:-.5px;
  margin-bottom:14px;
}
.mp-text{
  font-size:14.5px;
  color:var(--body);
  line-height:1.75;
}

/* ══════════════════════════════════════
   STORY
══════════════════════════════════════ */
.story-sec{background:#fff;padding:96px 5%;overflow:hidden}

.story-intro{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:center;
  margin-bottom:96px;
}
.story-big-num{
  font-size:clamp(100px,12vw,180px);
  font-weight:800;
  letter-spacing:-8px;
  font-family:var(--serif);
  font-style:italic;
  background:linear-gradient(135deg,var(--blue-light),rgba(4,84,163,.03));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  line-height:.85;
  margin-bottom:-16px;
}
.story-left .tag{margin-top:8px}
.story-left h2{
  font-size:clamp(28px,4vw,48px);
  font-weight:800;
  letter-spacing:-1.5px;
  color:var(--ink);
  margin-bottom:20px;
  line-height:1.1;
}
.story-left p{
  font-size:15.5px;
  color:var(--body);
  line-height:1.8;
  margin-bottom:16px;
}
.story-problem-box{
  background:linear-gradient(135deg,var(--blue-pale),var(--blue-xlight));
  border:1.5px solid rgba(4,84,163,.15);
  border-radius:20px;
  padding:28px;
  display:flex;
  gap:18px;
  align-items:flex-start;
  margin-top:28px;
}
.spb-ico{font-size:36px;flex-shrink:0;margin-top:2px}
.spb-label{
  font-size:13px;
  font-weight:800;
  color:var(--blue);
  letter-spacing:.5px;
  text-transform:uppercase;
  margin-bottom:6px;
}
.spb-text{font-size:14px;color:var(--body);line-height:1.7}

.story-visual{position:relative}
.story-map-card{
  background:linear-gradient(145deg,#040E1E,#0454A3);
  border-radius:28px;
  padding:40px;
  box-shadow:var(--shadow-xl);
  position:relative;
  overflow:hidden;
}
.smc-glow{
  position:absolute;
  top:-40px;
  right:-40px;
  width:150px;
  height:150px;
  border-radius:50%;
  background:rgba(255,255,255,.06);
}
.story-stat-row{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:12px;
  margin-top:20px;
  position:relative;
  z-index:1;
}
.ssr{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:16px;
  text-align:center;
  transition:all .3s var(--ease);
}
.ssr:hover{
  background:rgba(255,255,255,.14);
  transform:translateY(-3px);
}
.ssr-val{
  font-size:clamp(18px,2vw,26px);
  font-weight:800;
  color:#fff;
  letter-spacing:-1px;
  display:block;
  margin-bottom:4px;
}
.ssr-lbl{
  font-size:10px;
  color:rgba(255,255,255,.55);
  line-height:1.4;
}

/* Timeline */
.story-timeline{
  position:relative;
  border-left:2px solid var(--border);
  padding-left:56px;
  display:flex;
  flex-direction:column;
  gap:0;
  max-width:900px;
  margin:0 auto;
}
.tl-event{position:relative;padding:0 0 56px}
.tl-event:last-child{padding-bottom:0}

.tl-marker{
  position:absolute;
  left:-68px;
  top:0;
  width:24px;
  height:24px;
  border-radius:50%;
  border:3px solid #fff;
  box-shadow:var(--shadow-sm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  font-weight:800;
}
.tm-blue{background:var(--blue);color:#fff}
.tm-orange{background:var(--orange);color:#fff}
.tm-green{background:var(--green);color:#fff}
.tm-gold{background:var(--gold);color:#fff}
.tm-ink{background:var(--ink);color:#fff}

.tl-year{
  font-size:11px;
  font-weight:800;
  letter-spacing:2px;
  color:var(--muted);
  text-transform:uppercase;
  margin-bottom:8px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.tl-year .yr-badge{
  display:inline-block;
  padding:3px 10px;
  border-radius:var(--r-full);
  font-size:10px;
  font-weight:800;
}
.yrb-blue{background:var(--blue-light);color:var(--blue)}
.yrb-orange{background:var(--orange-light);color:var(--orange)}
.yrb-green{background:var(--green-light);color:var(--green)}
.yrb-gold{background:var(--gold-light);color:#92400E}
.yrb-ink{background:var(--surface2);color:var(--ink)}

.tl-title{
  font-size:clamp(18px,2.2vw,24px);
  font-weight:800;
  color:var(--ink);
  letter-spacing:-.5px;
  margin-bottom:10px;
}
.tl-text{
  font-size:14.5px;
  color:var(--body);
  line-height:1.75;
  max-width:580px;
}
.tl-card{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:16px;
  padding:18px 22px;
  margin-top:14px;
  display:inline-flex;
  align-items:center;
  gap:12px;
  transition:all .3s var(--ease);
  max-width:100%;
}
.tl-card:hover{
  border-color:var(--blue);
  box-shadow:var(--shadow-sm);
  transform:translateX(6px);
}
.tl-card-ico{font-size:24px}
.tl-card-val{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:2px}
.tl-card-lbl{font-size:11px;color:var(--muted)}

/* ══════════════════════════════════════
   IMPACT
══════════════════════════════════════ */
.impact-sec{
  background:linear-gradient(160deg,#040E1E 0%,#0A1E40 60%,#0454A3 100%);
  padding:96px 5%;
  position:relative;
  overflow:hidden;
}
.impact-sec::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:28px 28px;
}
.impact-inner{
  max-width:1280px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.impact-header{text-align:center;margin-bottom:72px}
.impact-header h2{
  font-size:clamp(30px,4.5vw,56px);
  font-weight:800;
  letter-spacing:-2px;
  color:#fff;
  margin-bottom:14px;
}
.impact-header p{
  font-size:17px;
  color:rgba(255,255,255,.6);
  max-width:500px;
  margin:0 auto;
}

.bento{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto;
  gap:16px;
}
.bento-cell{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;
  padding:36px;
  transition:all .35s var(--ease);
  position:relative;
  overflow:hidden;
}
.bento-cell:hover{
  background:rgba(255,255,255,.09);
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.2);
}
.bc-wide{grid-column:span 2}
.bc-tall{grid-row:span 2}
.bc-glow::before{
  content:'';
  position:absolute;
  top:-40px;
  right:-40px;
  width:140px;
  height:140px;
  border-radius:50%;
  background:rgba(4,84,163,.3);
  filter:blur(40px);
}
.bc-glow-orange::before{background:rgba(249,115,22,.25)}
.bc-glow-green::before{background:rgba(16,185,129,.2)}

.bento-ico{font-size:44px;margin-bottom:16px;display:block}
.bento-num{
  font-size:clamp(48px,5vw,72px);
  font-weight:800;
  letter-spacing:-3px;
  color:#fff;
  line-height:.9;
  margin-bottom:10px;
  font-family:var(--serif);
}
.bn-unit{
  font-size:.45em;
  font-weight:600;
  color:rgba(255,255,255,.55);
  letter-spacing:-1px;
  font-family:var(--font);
}
.bento-label{
  font-size:15px;
  color:rgba(255,255,255,.65);
  font-weight:500;
  line-height:1.6;
}
.bento-sublabel{
  font-size:12px;
  color:rgba(255,255,255,.35);
  margin-top:6px;
}

.live-row{
  display:flex;
  gap:20px;
  align-items:stretch;
  margin-top:24px;
  flex-wrap:wrap;
}
.live-item{
  flex:1;
  min-width:100px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px;
  padding:18px 14px;
  text-align:center;
}
.li-val{
  font-size:clamp(20px,2.5vw,28px);
  font-weight:800;
  color:#fff;
  letter-spacing:-1px;
  display:block;
  margin-bottom:4px;
}
.li-lbl{font-size:11px;color:rgba(255,255,255,.45)}

/* ══════════════════════════════════════
   VALUES
══════════════════════════════════════ */
.values-sec{background:var(--surface);padding:96px 5%}
.values-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:64px;
}
.value-card{
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:22px;
  padding:36px 28px;
  transition:all .35s var(--ease);
  cursor:default;
  position:relative;
  overflow:hidden;
}
.value-card::before{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:4px;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s var(--ease);
}
.vc-blue::before{background:linear-gradient(90deg,var(--blue),var(--blue-mid))}
.vc-orange::before{background:linear-gradient(90deg,var(--orange),#fb923c)}
.vc-green::before{background:linear-gradient(90deg,var(--green),#059669)}
.vc-gold::before{background:linear-gradient(90deg,var(--gold),#d97706)}
.value-card:hover::before{transform:scaleX(1)}
.value-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-xl);
  border-color:rgba(4,84,163,.2);
}
.vc-ico{
  width:60px;
  height:60px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  margin-bottom:22px;
}
.vci-blue{background:var(--blue-light)}
.vci-orange{background:var(--orange-light)}
.vci-green{background:var(--green-light)}
.vci-gold{background:var(--gold-light)}
.vc-title{
  font-size:18px;
  font-weight:800;
  color:var(--ink);
  margin-bottom:12px;
  letter-spacing:-.3px;
}
.vc-text{
  font-size:14px;
  color:var(--body);
  line-height:1.75;
}

/* ══════════════════════════════════════
   TEAM
══════════════════════════════════════ */
.team-sec{background:#fff;padding:96px 5%}
.team-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:64px;
}
.team-card{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:24px;
  overflow:hidden;
  transition:all .35s var(--ease);
}
.team-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-xl);
  border-color:var(--blue);
}
.team-card-top{
  height:220px;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  padding:24px;
}
.tc-bg-1{background:linear-gradient(145deg,#E8F1FB,#C8DAEE)}
.tc-bg-2{background:linear-gradient(145deg,#FFF3EC,#FFE0C8)}
.tc-bg-3{background:linear-gradient(145deg,#ECFDF5,#D1FAE5)}
.tc-bg-4{background:linear-gradient(145deg,#FFFBEB,#FDE68A)}

.team-avatar-svg{
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:80px;
  opacity:.18;
}
.team-name-badge{
  position:relative;
  z-index:1;
  background:rgba(255,255,255,.8);
  backdrop-filter:blur(8px);
  border-radius:12px;
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.6);
}
.tnb-name{font-size:14px;font-weight:800;color:var(--ink)}
.tnb-role{font-size:11px;color:var(--muted)}

.team-card-body{padding:24px}
.tc-bio{
  font-size:13.5px;
  color:var(--body);
  line-height:1.7;
  margin-bottom:18px;
}
.tc-socials{display:flex;gap:8px}
.tc-soc{
  width:32px;
  height:32px;
  border-radius:9px;
  background:var(--surface2);
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  font-size:13px;
  text-decoration:none;
  transition:all .2s;
}
.tc-soc:hover{
  background:var(--blue);
  border-color:var(--blue);
  color:#fff;
}
.tc-expertise{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:14px;
}
.tce{
  font-size:10px;
  font-weight:700;
  padding:4px 10px;
  border-radius:var(--r-full);
  border:1px solid;
}
.tce-blue{color:var(--blue);background:var(--blue-light);border-color:rgba(4,84,163,.15)}
.tce-orange{color:var(--orange);background:var(--orange-light);border-color:rgba(249,115,22,.15)}
.tce-green{color:var(--green);background:var(--green-light);border-color:rgba(16,185,129,.15)}
.tce-gold{color:#92400E;background:var(--gold-light);border-color:rgba(245,158,11,.15)}

.team-more{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:16px;
  margin-top:24px;
  padding:28px;
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:22px;
}
.tm-member{display:flex;align-items:center;gap:12px}
.tm-ava{
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  font-weight:800;
  color:#fff;
  flex-shrink:0;
}
.tm-name{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:2px}
.tm-title{font-size:11px;color:var(--muted)}

/* ══════════════════════════════════════
   COMPLIANCE
══════════════════════════════════════ */
.compliance-sec{background:var(--surface);padding:96px 5%}
.comp-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
}
.comp-badges{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.comp-badge{
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:20px;
  padding:28px 22px;
  text-align:center;
  transition:all .3s var(--ease);
  cursor:default;
}
.comp-badge:hover{
  border-color:var(--blue);
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.cb-ico{font-size:44px;margin-bottom:14px;display:block}
.cb-title{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px}
.cb-sub{font-size:12px;color:var(--muted);line-height:1.5}
.cb-badge-num{
  font-size:11px;
  font-weight:700;
  color:var(--blue);
  margin-top:8px;
  display:block;
  font-family:monospace;
}

.tech-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:24px;
}
.tech-pill{
  display:flex;
  align-items:center;
  gap:8px;
  background:var(--surface2);
  border:1.5px solid var(--border2);
  border-radius:var(--r-full);
  padding:8px 16px;
  font-size:12px;
  font-weight:700;
  color:var(--body);
  transition:all .2s;
}
.tech-pill:hover{
  background:var(--blue-light);
  border-color:var(--blue);
  color:var(--blue);
}
.tech-pill span{font-size:16px}

/* ══════════════════════════════════════
   AWARDS
══════════════════════════════════════ */
.awards-sec{background:#fff;padding:72px 5%}
.awards-inner{max-width:1280px;margin:0 auto}
.awards-scroll{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:48px;
}
.award-card{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:20px;
  padding:24px 28px;
  display:flex;
  align-items:center;
  gap:16px;
  transition:all .3s var(--ease);
  flex:1;
  min-width:220px;
}
.award-card:hover{
  border-color:var(--gold);
  box-shadow:0 8px 32px rgba(245,158,11,.15);
  transform:translateY(-3px);
}
.award-ico{font-size:40px}
.award-name{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:3px}
.award-by{font-size:12px;color:var(--muted)}
.award-year{font-size:11px;font-weight:700;color:var(--gold);margin-top:4px}

/* ══════════════════════════════════════
   PRESENCE
══════════════════════════════════════ */
.presence-sec{
  padding:96px 5%;
  background:linear-gradient(155deg,var(--white) 0%,var(--blue-xlight) 50%,var(--blue-light) 100%);
  position:relative;
  overflow:hidden;
}
.presence-sec::before{
  content:'';
  position:absolute;
  top:-80px;
  right:-80px;
  width:400px;
  height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(4,84,163,.07),transparent 70%);
}
.pres-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:72px;
  align-items:center;
  max-width:1280px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.office-cards{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-top:40px;
}
.office-card{
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:20px;
  padding:24px;
  display:flex;
  gap:18px;
  align-items:flex-start;
  transition:all .3s var(--ease);
}
.office-card:hover{
  border-color:var(--blue);
  box-shadow:var(--shadow-md);
  transform:translateX(8px);
}
.oc-ico{
  width:52px;
  height:52px;
  border-radius:14px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
}
.oci-blue{background:var(--blue-light)}
.oci-orange{background:var(--orange-light)}
.oci-green{background:var(--green-light)}
.oc-city{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:4px}
.oc-type{
  font-size:11px;
  font-weight:700;
  color:var(--blue);
  text-transform:uppercase;
  letter-spacing:.5px;
  margin-bottom:8px;
}
.oc-addr{font-size:13px;color:var(--body);line-height:1.6}

.india-coverage-card{
  background:linear-gradient(145deg,#040E1E,#0454A3);
  border-radius:28px;
  padding:40px;
  box-shadow:var(--shadow-xl);
  position:relative;
  overflow:hidden;
}
.icc-glow{
  position:absolute;
  top:-60px;
  right:-60px;
  width:200px;
  height:200px;
  border-radius:50%;
  background:rgba(255,255,255,.06);
}
.icc-title{
  font-size:14px;
  font-weight:700;
  color:rgba(255,255,255,.6);
  margin-bottom:6px;
  position:relative;
  z-index:1;
}
.icc-stat{
  font-size:clamp(36px,4vw,52px);
  font-weight:800;
  color:#fff;
  letter-spacing:-2px;
  margin-bottom:4px;
  position:relative;
  z-index:1;
}
.icc-sub{
  font-size:13px;
  color:rgba(255,255,255,.5);
  margin-bottom:28px;
  position:relative;
  z-index:1;
}

.state-coverage{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:8px;
  position:relative;
  z-index:1;
}
.sc-state{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;
  padding:10px 6px;
  text-align:center;
  transition:all .3s;
  cursor:default;
}
.sc-state:hover{
  background:rgba(255,255,255,.16);
  transform:translateY(-2px);
}
.sc-state.active{
  background:rgba(74,222,128,.15);
  border-color:rgba(74,222,128,.3);
}
.scs-name{
  font-size:9px;
  font-weight:700;
  color:rgba(255,255,255,.6);
  display:block;
  margin-top:4px;
}
.scs-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(255,255,255,.2);
  margin:0 auto;
}
.sc-state.active .scs-dot{
  background:#4ade80;
  animation:pulse 2s infinite;
}

/* ══════════════════════════════════════
   CAREERS
══════════════════════════════════════ */
.careers-sec{background:var(--surface);padding:72px 5%}
.careers-inner{
  max-width:1280px;
  margin:0 auto;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:28px;
  padding:56px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
  box-shadow:var(--shadow-sm);
}
.careers-left .tag{margin-bottom:16px}
.careers-left h2{
  font-size:clamp(26px,3.5vw,44px);
  font-weight:800;
  letter-spacing:-1.5px;
  color:var(--ink);
  margin-bottom:16px;
  line-height:1.1;
}
.careers-left p{
  font-size:15.5px;
  color:var(--body);
  line-height:1.75;
  margin-bottom:28px;
}
.perks{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.perk{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:14px;
  color:var(--body);
}
.perk-ico{
  width:36px;
  height:36px;
  border-radius:10px;
  background:var(--blue-light);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:17px;
  flex-shrink:0;
}
.open-roles{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.role-card{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:16px;
  padding:20px 22px;
  display:flex;
  align-items:center;
  gap:14px;
  transition:all .3s var(--ease);
  text-decoration:none;
}
.role-card:hover{
  border-color:var(--blue);
  transform:translateX(6px);
  box-shadow:var(--shadow-sm);
}
.rc-dept{
  font-size:10px;
  font-weight:800;
  letter-spacing:1px;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:4px;
}
.rc-title{
  font-size:15px;
  font-weight:700;
  color:var(--ink);
}
.rc-loc{
  font-size:12px;
  color:var(--muted);
  margin-top:2px;
}
.rc-arrow{
  width:32px;
  height:32px;
  border-radius:9px;
  background:var(--blue-light);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue);
  font-size:16px;
  margin-left:auto;
  flex-shrink:0;
  transition:all .3s;
}
.role-card:hover .rc-arrow{
  background:var(--blue);
  color:#fff;
}

/* ══════════════════════════════════════
   CTA + FOOTER
══════════════════════════════════════ */
.cta-sec{background:#fff;padding:80px 5%}
.cta-box{
  max-width:1280px;
  margin:0 auto;
  background:linear-gradient(135deg,var(--blue) 0%,#0B6EC9 50%,#0454A3 100%);
  border-radius:var(--r-xl);
  padding:80px 60px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-box::before{
  content:'';
  position:absolute;
  top:-80px;
  left:-80px;
  width:300px;
  height:300px;
  border-radius:50%;
  background:rgba(255,255,255,.06);
}
.cta-box::after{
  content:'';
  position:absolute;
  bottom:-60px;
  right:-60px;
  width:240px;
  height:240px;
  border-radius:50%;
  background:rgba(255,255,255,.04);
}
.cta-ring{
  position:absolute;
  top:50%;
  left:50%;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.06);
  transform:translate(-50%,-50%);
  animation:ctaRing 6s ease-in-out infinite;
}
.cta-content{position:relative;z-index:1}
.cta-box h2{
  font-size:clamp(28px,4.5vw,52px);
  font-weight:800;
  letter-spacing:-1.5px;
  color:#fff;
  margin-bottom:16px;
}
.cta-box p{
  font-size:17px;
  color:rgba(255,255,255,.78);
  margin-bottom:40px;
  line-height:1.6;
}
.cta-btns{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

footer{background:var(--ink);padding:72px 5% 0}
.footer-grid{
  max-width:1280px;
  margin:0 auto;
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1.2fr;
  gap:52px;
  padding-bottom:56px;
  border-bottom:1px solid rgba(255,255,255,.08);
  width:100%;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:11px;
  text-decoration:none;
  margin-bottom:18px;
}
.footer-logo-icon{
  width:40px;
  height:40px;
  border-radius:11px;
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  display:flex;
  align-items:center;
  justify-content:center;
}
.footer-logo-icon svg{
  width:20px;
  height:20px;
  fill:none;
  stroke:#fff;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.footer-logo-name{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px}
.footer-brand-desc{
  font-size:13.5px;
  color:rgba(255,255,255,.5);
  line-height:1.7;
  max-width:280px;
  margin-bottom:26px;
}
.footer-socials{display:flex;gap:9px}
.fsoc{
  width:37px;
  height:37px;
  border-radius:9px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.6);
  font-size:14px;
  text-decoration:none;
  transition:all .2s;
}
.fsoc:hover{
  background:var(--blue);
  border-color:var(--blue);
  color:#fff;
  transform:translateY(-2px);
}
.footer-col h5{font-size:13px;font-weight:700;color:#fff;margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col li a{
  font-size:13px;
  color:rgba(255,255,255,.5);
  text-decoration:none;
  transition:color .2s;
}
.footer-col li a:hover{color:rgba(255,255,255,.9)}

.footer-bottom{
  max-width:1280px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:24px 0;
  flex-wrap:wrap;
  gap:14px;
  width:100%;
}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.35)}
.footer-legal{display:flex;gap:18px;flex-wrap:wrap}
.footer-legal a{
  font-size:12px;
  color:rgba(255,255,255,.35);
  text-decoration:none;
  transition:color .2s;
}
.footer-legal a:hover{color:#fff}

/* ══════════════════════════════════════
   DROPDOWN
══════════════════════════════════════ */
.nav-item{position:relative}
.dropdown-menu{
  position:absolute;
  top:120%;
  left:0;
  min-width:240px;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:16px;
  box-shadow:var(--shadow-lg);
  padding:8px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:.22s ease;
  z-index:999;
}
.dropdown-menu a{
  display:block;
  padding:12px 18px;
  font-size:14px;
  font-weight:600;
  color:var(--ink);
  text-decoration:none;
  transition:.18s ease;
}
.dropdown-menu a:hover{
  background:var(--surface);
  color:var(--blue);
}
.nav-item:hover .dropdown-menu{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.nav-item .arrow{
  display:inline-block;
  transition:.2s ease;
}
.nav-item:hover .arrow{transform:rotate(180deg)}

/* ══════════════════════════════════════
   MOBILE DRAWER
══════════════════════════════════════ */
.drawer-bg{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(10,22,40,.55);
  z-index:2101;
  opacity:0;
  transition:opacity .28s var(--ease);
  backdrop-filter:blur(6px);
}
.drawer-bg.show{
  display:block;
  opacity:1;
}

.drawer{
  position:fixed;
  top:0;
  right:-330px;
  bottom:0;
  width:310px;
  max-width:86vw;
  background:rgba(255,255,255,.96);
  z-index:2102;
  overflow-y:auto;
  border-left:1.5px solid var(--border);
  box-shadow:var(--shadow-xl);
  transition:right .33s var(--ease);
  backdrop-filter:blur(16px) saturate(160%);
}
.drawer.open{right:0}

.drawer::-webkit-scrollbar{width:6px}
.drawer::-webkit-scrollbar-thumb{background:rgba(4,84,163,.35);border-radius:10px}
.drawer::-webkit-scrollbar-track{background:transparent}

.drawer-header{
  position:sticky;
  top:0;
  z-index:2;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 16px;
  background:rgba(255,255,255,.97);
  border-bottom:1px solid rgba(226,235,245,.9);
}

.drawer .logo{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.drawer .logo-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 14px rgba(4,84,163,.25);
  position:relative;
  overflow:hidden;
}
.drawer .logo-icon::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:55%;
  background:rgba(255,255,255,.14);
}
.drawer .logo-name{
  font-weight:900;
  color:var(--ink);
  letter-spacing:-.4px;
}
.drawer .logo-name span{color:var(--blue)}

.drawer-x{
  width:40px;
  height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--surface2);
  border:1.5px solid var(--border);
  border-radius:12px;
  cursor:pointer;
  font-size:16px;
  color:var(--body);
  transition:all .2s var(--ease);
}
.drawer-x:hover{
  background:var(--blue-light);
  border-color:rgba(4,84,163,.25);
  color:var(--blue);
  transform:translateY(-1px);
}

.drawer-links{
  padding:14px 12px 18px;
  display:flex;
  flex-direction:column;
}
.dsec{
  padding:14px 12px 6px;
  font-size:10px;
  font-weight:900;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
}
.dl,
.drawer-links a:not(.btn){
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 12px;
  margin:2px 6px;
  border-radius:14px;
  font-size:14px;
  font-weight:700;
  color:var(--ink2);
  text-decoration:none;
  transition:all .18s var(--ease);
  border:1px solid transparent;
}
.dl:hover,
.drawer-links a:not(.btn):hover{
  background:var(--blue-light);
  color:var(--blue);
  border-color:rgba(4,84,163,.18);
  transform:translateX(3px);
}
.dl{line-height:1}
.dl::first-letter{font-size:16px}

.drawer-footer{
  position:sticky;
  bottom:0;
  background:rgba(255,255,255,.97);
  border-top:1px solid rgba(226,235,245,.9);
  padding:14px 14px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.drawer-footer .btn{
  width:100%;
  justify-content:center;
  padding:14px 14px;
  border-radius:999px;
  font-weight:900;
}

.drawer-footer .btn[style*="background:#25D366"]{
  box-shadow:0 6px 18px rgba(37,211,102,.25);
}
.drawer-footer .btn[style*="background:#25D366"]:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 26px rgba(37,211,102,.35);
}

/* ══════════════════════════════════════
   MOBILE STICKY BAR
══════════════════════════════════════ */
.mob-bar{
  display:none;
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:1200;
  background:rgba(255,255,255,.97);
  border-top:1px solid var(--border);
  padding:12px 16px;
  gap:10px;
  backdrop-filter:blur(20px);
  box-shadow:0 -4px 24px rgba(4,84,163,.1);
}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width:1100px){
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .team-more{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}

@media (max-width:900px){
  .nav-links,
  .nav-actions .btn:not(.btn-blue){
    display:none !important;
  }

  .hamburger{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    width:42px;
    height:42px;
    padding:0;
    border-radius:12px;
    font-size:18px;
  }

  .nav{
    height:64px;
    padding:0 12px;
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(18px) saturate(160%);
  }

  .logo-name{font-size:18px}
  .logo-tag{display:none}

  .nav-actions .btn-blue{
    padding:10px 14px;
    font-size:13px;
    border-radius:999px;
    white-space:nowrap;
  }

  .hero{
    padding:84px 12px 0 !important;
    min-height:auto;
  }

  .hero-inner{
    grid-template-columns:1fr !important;
    gap:18px;
    max-width:100%;
    width:100%;
    padding-bottom:56px;
  }

  .hero-card-wrap{
    order:-1;
    width:100%;
  }

  .hero h1{
    font-size:36px;
    letter-spacing:-1.5px;
    line-height:1.1;
    margin-bottom:14px;
  }

  .hero-sub{
    font-size:15px;
    line-height:1.75;
    max-width:100%;
    margin-bottom:18px;
  }

  .hero-btns{
    gap:10px;
    margin-bottom:20px;
  }

  .hero-btns .btn{
    width:100%;
    justify-content:center;
    padding:14px 16px;
  }

  .hf1,.hf2{
    display:none;
  }

  .mission-card{
    padding:24px 18px;
    border-radius:22px;
  }

  .mc-quote{
    font-size:20px;
    line-height:1.5;
  }

  .mission-grid{grid-template-columns:1fr}
  .story-intro{grid-template-columns:1fr}
  .story-visual{display:none}
  .bento{grid-template-columns:1fr}
  .bc-wide,.bc-tall{grid-column:1;grid-row:auto}
  .comp-grid{grid-template-columns:1fr}
  .pres-grid{grid-template-columns:1fr}
  .careers-inner{
    grid-template-columns:1fr;
    padding:36px 24px;
  }
  .cta-box{padding:48px 24px}
  .awards-scroll{flex-direction:column}
  .state-coverage{grid-template-columns:repeat(4,1fr)}
  .story-stat-row{grid-template-columns:1fr 1fr}
  .mob-bar{display:flex}
  footer{padding-bottom:90px}
}

@media (max-width:640px){
  .hero{
    padding:78px 12px 0 !important;
  }

  .hero-inner{
    gap:16px !important;
    padding-bottom:48px;
  }

  .hero-card-wrap{
    max-width:100% !important;
  }

  .hero h1{
    font-size:32px !important;
    letter-spacing:-1px !important;
    line-height:1.15 !important;
    margin-bottom:12px !important;
  }

  .hero-sub{
    font-size:15px !important;
    max-width:100% !important;
    margin-bottom:16px !important;
  }

  .hero-btns{
    display:flex !important;
    flex-direction:column;
  }

  .mission-sec,
  .story-sec,
  .impact-sec,
  .values-sec,
  .team-sec,
  .compliance-sec,
  .presence-sec,
  .careers-sec,
  .cta-sec{
    padding-left:12px !important;
    padding-right:12px !important;
  }

  .mission-pillar{padding:30px 20px}
  .story-problem-box{
    flex-direction:column;
    padding:20px 16px;
  }

  .story-timeline{
    padding-left:34px;
  }
  .tl-marker{
    left:-46px;
  }
  .tl-card{
    width:100%;
    padding:16px;
  }

  .bento-cell{
    padding:22px 18px;
    border-radius:18px;
  }

  .live-row{
    gap:10px;
  }
  .live-item{
    min-width:calc(50% - 5px);
    padding:14px 10px;
  }

  .values-grid,
  .team-grid,
  .comp-badges{
    grid-template-columns:1fr;
  }

  .team-more{
    grid-template-columns:1fr;
    padding:18px;
  }

  .office-card{
    padding:18px 16px;
  }

  .india-coverage-card{
    padding:22px 16px;
  }

  .state-coverage{
    grid-template-columns:repeat(4,1fr);
    gap:6px;
  }

  .careers-inner{
    padding:24px 16px;
    border-radius:20px;
  }

  .cta-btns{
    flex-direction:column;
  }
  .cta-btns .btn{
    width:100%;
    justify-content:center;
  }

  .footer-grid{
    grid-template-columns:1fr;
    gap:22px;
  }

  .mob-bar{
    display:flex !important;
    gap:12px !important;
    padding:12px 12px !important;
  }
  .mob-bar .btn{
    flex:1;
    justify-content:center;
    padding:14px 14px !important;
    border-radius:999px !important;
    font-size:14px !important;
    font-weight:900 !important;
  }
}

@media (max-width:420px){
  .nav-actions .btn-blue{
    padding:9px 12px !important;
    font-size:12.5px !important;
  }

  .hero h1{
    font-size:28px !important;
  }

  .story-big-num{
    font-size:72px;
    letter-spacing:-4px;
  }

  .bento-num{
    font-size:40px;
  }

  .state-coverage{
    grid-template-columns:repeat(3,1fr);
  }
}

/* Desktop only: drawer hidden */
@media (min-width:901px){
  .drawer,
  .drawer-bg{
    display:none !important;
  }
}