/* ══ TOKENS ═══════════════════════════════════════════════════════ */
:root{
  --void:   #050810;   /* near-black background */
  --void2:  #0a0f1e;
  --void3:  #0d1428;
  --void4:  #111b35;
  --void5:  #162040;
  --surface:#0f1830;
  --white:  #F0F4FF;   /* slightly blue-tinted white */
  --white2: #C8D8FF;
  --muted:  rgba(200,216,255,.4);
  --muted2: rgba(200,216,255,.18);

  --blue:   #1E90FF;   /* electric blue */
  --blue2:  #3AABFF;   /* lighter electric */
  --blue3:  #57C0FF;   /* sky */
  --blue-glow: rgba(30,144,255,.22);
  --blue-dark: #0B5FCC;

  --border:  rgba(30,144,255,.12);
  --border2: rgba(30,144,255,.22);
  --border3: rgba(30,144,255,.4);

  --amber: #F5A623;
  --green: #22D3A0;
  --red:   #FF5E7A;

  --fd:'Syne',sans-serif;
  --fb:'DM Sans',sans-serif;
  --fi:'Playfair Display',serif;
  --max:1240px;
  --ease:cubic-bezier(.16,1,.3,1);
}

/* ══ RESET ════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--fb);
  background:var(--void);
  color:var(--white);
  overflow-x:hidden;cursor:none;
  -webkit-font-smoothing:antialiased;
  line-height:1.65;
}
a{text-decoration:none;color:inherit}

/* ══ NOISE + GRID BG ══════════════════════════════════════════════ */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(30,144,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(30,144,255,.03) 1px,transparent 1px);
  background-size:80px 80px;
}
body::after{
  content:'';position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(30,144,255,.08),transparent 70%);
}

/* ══ CURSOR ═══════════════════════════════════════════════════════ */
.cur{
  position:fixed;width:8px;height:8px;
  background:var(--blue);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .2s var(--ease),height .2s var(--ease);
  box-shadow:0 0 12px var(--blue);
}
.cur-ring{
  position:fixed;width:36px;height:36px;
  border:1.5px solid rgba(30,144,255,.5);
  border-radius:50%;pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform .08s,width .25s var(--ease),height .25s var(--ease),border-color .25s;
}

/* ══ SCROLL PROGRESS ══════════════════════════════════════════════ */
#prog{
  position:fixed;top:0;left:0;height:2px;z-index:8000;
  background:linear-gradient(90deg,var(--blue),var(--blue2));
  width:0%;transition:width .1s linear;
  box-shadow:0 0 10px var(--blue);
}

/* ══ NAV ══════════════════════════════════════════════════════════ */
.nav-logo{
  display:flex;align-items:center;gap:12px;height:100%;
}
.logo-img{
  height:48px;width:auto;object-fit:contain;
  transition:transform .3s ease;
}
.nav-logo:hover .logo-img{transform:scale(1.05);}
.foot-logo{margin-bottom:24px;}
.logo-img-foot{
  height:80px;width:auto;object-fit:contain;
}
nav{
  position:fixed;top:0;left:0;right:0;z-index:700;
  height:64px;display:flex;align-items:center;
  justify-content:space-between;padding:0 5%;
  background:rgba(5,8,16,.88);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
  transition:background .3s;
}
/* ─ Navbar Links Alignment Fix ─ */
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{
  font-size:13px;font-weight:500;color:var(--muted);
  letter-spacing:.03em;transition:color .2s;position:relative;
}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--blue2)}
.nav-links a::after{
  content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;
  background:var(--blue);transition:width .25s var(--ease);
  box-shadow:0 0 6px var(--blue);
}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  display:flex;align-items:center;gap:8px;
  background:var(--blue);color:#fff;
  font-family:var(--fd);font-size:13px;font-weight:700;
  padding:9px 20px;border-radius:100px;
  transition:transform .2s var(--ease),box-shadow .2s;
  letter-spacing:.02em;
  box-shadow:0 0 24px rgba(30,144,255,.35);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 0 36px rgba(30,144,255,.55)}

/* ══ TECH STACK ═════════════════════════════════════════════════════ */
.tech-card{
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:24px;
  padding:40px;
  display:grid;grid-template-columns:1fr 1.5fr;gap:40px;
  align-items:center;
  backdrop-filter:blur(10px);
}
.tech-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;
}
.tech-item{
  background:rgba(255,255,255,0.02);
  padding:16px 20px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.05);
  transition:all 0.3s ease;
}
.tech-item:hover{
  background:rgba(255,255,255,0.05);
  border-color:var(--blue2);
  transform:translateY(-2px);
}
.tech-item span{
  display:block;
  font-size:10px;font-weight:700;letter-spacing:1px;
  color:var(--blue2);margin-bottom:6px;text-transform:uppercase;
}
.tech-item h4{font-size:14px;color:var(--white);font-weight:600;}

@media (max-width:992px){
  .tech-card{grid-template-columns:1fr;padding:32px;gap:32px}
  .tech-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:480px){
  .tech-grid{grid-template-columns:1fr}
}
.hero{
  min-height:80vh;
  display:grid;grid-template-columns:1.5fr 1fr;gap:40px;
  align-items:center;padding:100px 5% 40px;
  overflow:hidden;position:relative;
  max-width:var(--max);margin:0 auto;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--blue2);margin-bottom:16px;
  animation:fadeUp .8s .1s var(--ease) both;
}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--blue2);box-shadow:0 0 6px var(--blue)}
.hero h1{
  font-family:var(--fd);
  font-size:clamp(32px,3.8vw,52px);
  font-weight:700;letter-spacing:-1px;line-height:1.2;
  color:var(--white);margin-bottom:16px;
  max-width:100%;
  animation:fadeUp .8s .2s var(--ease) both;
}
.hero h1 .blue{color:var(--blue);text-shadow:0 0 40px rgba(30,144,255,.5)}
.hero h1 .it{font-family:var(--fi);font-style:italic;font-weight:400;color:var(--blue2);letter-spacing:-2px}
.hero h1 .dim{color:var(--muted)}
.hero-desc{
  font-size:clamp(14px,0.9vw,16px);color:var(--muted);line-height:1.5;max-width:440px;
  margin-bottom:28px;font-weight:400;
  animation:fadeUp .8s .35s var(--ease) both;
}
.hero-actions{
  display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px;
  animation:fadeUp .8s .45s var(--ease) both;
}
.hero-proof{
  display:flex;gap:18px;margin-top:24px;flex-wrap:wrap;
  animation:fadeUp .8s .5s var(--ease) both;
}
.hp-item{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:rgba(255,255,255,0.7);font-weight:500;
}
.hp-item span{color:var(--blue2);font-weight:800;font-size:16px;}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue);color:#fff;
  font-family:var(--fd);font-size:14px;font-weight:700;
  padding:14px 28px;border-radius:100px;border:none;cursor:none;
  transition:transform .2s var(--ease),box-shadow .2s;letter-spacing:.02em;
  box-shadow:0 0 32px rgba(30,144,255,.4);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 48px rgba(30,144,255,.6)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--white);
  font-family:var(--fd);font-size:14px;font-weight:600;
  padding:14px 28px;border-radius:100px;cursor:none;
  border:1.5px solid var(--border2);
  transition:border-color .2s,background .2s;letter-spacing:.02em;
}
.btn-ghost:hover{border-color:var(--blue);background:rgba(30,144,255,.07)}
.hero-proof{
  display:flex;gap:32px;
  animation:fadeUp .8s .55s var(--ease) both;
}
.proof-item .pn{
  font-family:var(--fd);font-size:30px;font-weight:800;
  color:var(--blue);letter-spacing:-1.5px;line-height:1;
  text-shadow:0 0 20px rgba(30,144,255,.4);
}
.proof-item .pl{font-size:12px;color:var(--muted);margin-top:4px;letter-spacing:.03em}
.proof-divider{width:1px;background:var(--border2);align-self:stretch}

/* Hero right */
.hero-right{position:relative;animation:fadeUp .9s .3s var(--ease) both;z-index:2}
.hero-card-stack{position:relative;height:480px}
.hcard{
  position:absolute;
  background:rgba(13,20,40,.9);
  border:1px solid var(--border2);
  border-radius:20px;padding:26px;
  backdrop-filter:blur(12px);
  box-shadow:0 0 40px rgba(30,144,255,.08),inset 0 1px 0 rgba(30,144,255,.1);
}
.hcard-main{width:100%;top:0;left:0;right:0}
.hcard-label{
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue2);margin-bottom:14px;display:flex;align-items:center;gap:6px;
}
.hcard-label::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);animation:pulse 2s infinite;box-shadow:0 0 8px var(--blue)}
.hcard h3{
  font-family:var(--fd);font-size:17px;font-weight:700;
  letter-spacing:-.3px;margin-bottom:8px;color:var(--white);
}
.hcard p{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:18px}
.hcard-metrics{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.hm{
  background:rgba(30,144,255,.08);border-radius:10px;padding:12px;text-align:center;
  border:1px solid var(--border);
}
.hm-v{font-family:var(--fd);font-size:18px;font-weight:800;color:var(--blue2);line-height:1}
.hm-l{font-size:10px;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.06em}
.hcard-award{
  background:linear-gradient(135deg,rgba(245,166,35,.12),rgba(245,166,35,.04));
  border-color:rgba(245,166,35,.25);
  bottom:-16px;left:16px;right:16px;
  display:flex;align-items:center;gap:14px;padding:18px 20px;
}
.award-text strong{font-family:var(--fd);font-size:13px;font-weight:700;display:block;margin-bottom:3px;color:var(--amber)}
.award-text span{font-size:11px;color:rgba(245,166,35,.55)}
.hero-badge-float{
  position:absolute;top:-18px;right:-10px;
  background:rgba(13,20,40,.95);border:1px solid var(--border2);
  border-radius:100px;padding:8px 16px;
  display:flex;align-items:center;gap:7px;
  font-size:12px;font-weight:600;white-space:nowrap;
  animation:float 3s ease-in-out infinite;
  box-shadow:0 0 24px rgba(30,144,255,.2);
}
.hero-badge-float .dot{width:7px;height:7px;border-radius:50%;background:var(--blue);animation:pulse 1.5s infinite;box-shadow:0 0 8px var(--blue)}

/* ══ MARQUEE ══════════════════════════════════════════════════════ */
.marquee-strip{
  position:relative;z-index:2;
  background:rgba(10,15,30,.95);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  overflow:hidden;white-space:nowrap;padding:14px 0;
}
.marquee-inner{display:inline-flex;animation:marquee 30s linear infinite}
.mitem{
  font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);padding:0 48px;display:inline-flex;align-items:center;gap:16px;
}
.mdot{width:4px;height:4px;border-radius:50%;background:var(--blue);opacity:.7}
.mitem.hi{color:var(--blue2)}

/* ══ SECTION SHARED ═══════════════════════════════════════════════ */
.sec{padding:100px 0;position:relative;z-index:2}
.wrap{max-width:var(--max);margin:0 auto;padding:0 5%}
.eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue2);margin-bottom:14px;display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:'';width:20px;height:1.5px;background:var(--blue);box-shadow:0 0 6px var(--blue);opacity:.8}
.sec-title{
  font-family:var(--fd);font-size:clamp(28px,3.8vw,52px);
  font-weight:800;letter-spacing:-2px;line-height:1.06;color:var(--white);
}
.sec-title .blue{color:var(--blue);text-shadow:0 0 30px rgba(30,144,255,.4)}
.sec-title .it{font-family:var(--fi);font-style:italic;font-weight:400;color:var(--muted)}
.sec-sub{font-size:16px;color:var(--muted);margin-top:16px;max-width:520px;line-height:1.78;font-weight:300}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.on{opacity:1;transform:none}
.rd1{transition-delay:.1s}.rd2{transition-delay:.2s}.rd3{transition-delay:.3s}.rd4{transition-delay:.4s}

/* ══ TRUST BAR ════════════════════════════════════════════════════ */
.trust-sec{
  background:rgba(10,15,30,.8);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:48px 0;
}
.trust-inner{max-width:var(--max);margin:0 auto;padding:0 5%}
.trust-stats{display:grid;grid-template-columns:repeat(4,1fr);margin-bottom:40px}
.ts{text-align:center;padding:28px 20px;border-right:1px solid var(--border)}
.ts:last-child{border-right:none}
.ts-v{font-family:var(--fd);font-size:clamp(36px,4vw,56px);font-weight:800;letter-spacing:-2px;color:var(--blue);text-shadow:0 0 30px rgba(30,144,255,.35);line-height:1}
.ts-l{font-size:12px;color:var(--muted);margin-top:6px;text-transform:uppercase;letter-spacing:.06em}
.trust-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);text-align:center;margin-bottom:20px}
.trust-logos{display:flex;justify-content:center;align-items:center;gap:40px;flex-wrap:wrap}
.tl{
  font-family:var(--fd);font-size:13px;font-weight:600;color:var(--muted);
  display:flex;align-items:center;gap:8px;transition:color .2s;
}
.tl::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);opacity:.6}
.tl:hover{color:var(--blue2)}

/* ══ SERVICES ═════════════════════════════════════════════════════ */
.srv-sec{background:rgba(10,15,30,.5)}
.srv-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px;gap:40px}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.srv-card{
  background:var(--void2);padding:0;
  transition:background .25s,transform .3s var(--ease),box-shadow .3s;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  border-radius:12px;
}
.srv-img-wrapper{
  width:100%;height:180px;position:relative;overflow:hidden;
  background:radial-gradient(circle at 50% 50%,rgba(30,144,255,.12),transparent 75%);
}
.srv-img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.srv-card:hover .srv-img{transform:scale(1.08)}
.srv-card-body{padding:28px;flex:1;display:flex;flex-direction:column}
.srv-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(30,144,255,.06),transparent 60%);
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.srv-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);
  opacity:0;transition:opacity .3s;
}
.srv-num{font-family:var(--fd);font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--muted2);margin-bottom:12px}
.srv-card:hover{background:var(--void3);box-shadow:0 12px 40px rgba(30,144,255,0.1)}
.srv-card:hover::before,.srv-card:hover::after{opacity:1}
.srv-card h3{font-family:var(--fd);font-size:17px;font-weight:700;letter-spacing:-.3px;margin-bottom:10px;color:var(--white)}
.srv-card p{font-size:13.5px;color:var(--muted);line-height:1.72;margin-bottom:18px}
.srv-tags{display:flex;flex-wrap:wrap;gap:6px}
.srv-tag{
  font-size:10px;font-weight:600;padding:4px 10px;border-radius:100px;
  background:rgba(30,144,255,.08);color:var(--blue2);border:1px solid var(--border);
  letter-spacing:.04em;transition:background .2s,border-color .2s;
}
.srv-card:hover .srv-tag{background:rgba(30,144,255,.14);border-color:var(--border2)}
.srv-arrow{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;color:var(--blue2);margin-top:auto;padding-top:18px;
  transition:gap .2s;
}
.srv-card:hover .srv-arrow{gap:10px}
.ai-card{background:var(--void)!important;border:1px solid var(--border2);grid-column:span 3;padding:0!important}
.ai-card .srv-img-wrapper{height:260px}
.ai-card-inner{display:grid;grid-template-columns:1.2fr 1.8fr;gap:0;align-items:stretch}

/* ══ INDUSTRIES ═══════════════════════════════════════════════════ */
.ind-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.ind-tab{border-top:1px solid var(--border);padding:26px 0;position:relative}
.ind-tab:last-child{border-bottom:1px solid var(--border)}
.ind-tab-head{display:flex;align-items:center;justify-content:space-between;cursor:none}
.ind-tab-left{display:flex;align-items:center;gap:16px}
.ind-num{font-size:10px;font-weight:700;color:var(--muted2);letter-spacing:.08em;width:26px}
.ind-ico{font-size:20px}
.ind-title{font-family:var(--fd);font-size:20px;font-weight:700;letter-spacing:-.3px;color:var(--white);transition:color .2s}
.ind-tab.active .ind-title{color:var(--blue)}
.ind-plus{font-size:20px;color:var(--muted);transition:transform .3s var(--ease),color .2s;flex-shrink:0}
.ind-tab.active .ind-plus{transform:rotate(45deg);color:var(--blue)}
.ind-body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.ind-tab.active .ind-body{max-height:400px}
.ind-body-inner{padding:18px 0 8px 42px}
.ind-body p{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:18px;font-weight:300}
.ind-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;border-radius:100px;font-size:12px;font-weight:700;
  margin-bottom:14px;letter-spacing:.03em;
  background:rgba(30,144,255,.1);color:var(--blue2);border:1px solid var(--border2);
}
.ind-pill.amber{background:rgba(245,166,35,.1);color:var(--amber);border-color:rgba(245,166,35,.2)}
.ind-pill.green{background:rgba(34,211,160,.1);color:var(--green);border-color:rgba(34,211,160,.2)}
.ind-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--blue2);transition:gap .2s}
.ind-link:hover{gap:10px}
.ind-visual{position:sticky;top:84px}
.ind-vis{
  height:440px;background:var(--void3);border-radius:24px;
  border:1px solid var(--border);position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px;
}
.ind-vis-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0.6;transition:opacity .5s ease, transform .8s ease;
  z-index:1;
}
.ind-vis.changing .ind-vis-img{opacity:0;transform:scale(1.05);}
.ind-vis-content{position:relative;z-index:2;max-width:360px;}
.vis-emoji{
  display:block;font-size:56px;margin-bottom:20px;
  filter:drop-shadow(0 0 20px rgba(30,144,255,0.4));
}
.vis-title{font-family:var(--fd);font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--white);margin-bottom:8px}
.vis-sub{font-size:13px;color:var(--muted);line-height:1.6;max-width:240px;margin:0 auto 20px}
.vis-badge{
  background:rgba(30,144,255,.12);backdrop-filter:blur(12px);
  border:1px solid var(--border2);border-radius:100px;
  padding:8px 18px;font-size:12px;font-weight:700;color:var(--blue2);
}

/* ══ CASE STUDIES ═════════════════════════════════════════════════ */
.cases-sec{background:rgba(10,15,30,.5)}
.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:52px}
.case-card{
  border-radius:20px;overflow:hidden;position:relative;
  display:flex;flex-direction:column;
  border:1px solid var(--border);
  transition:border-color .25s,transform .3s var(--ease),box-shadow .3s;cursor:none;
}
.case-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 20px 60px rgba(30,144,255,.12)}
.case-img{height:220px;position:relative;overflow:hidden;flex-shrink:0}
.case-img-bg{position:absolute;inset:0;transition:transform .5s var(--ease)}
.case-card:hover .case-img-bg{transform:scale(1.05)}
.case-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,8,16,.75),transparent)}
.case-tag{
  position:absolute;top:16px;left:16px;
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;color:#fff;
}
.tag-edu{background:var(--amber)}
.tag-sec{background:var(--blue)}
.tag-fnb{background:var(--green);color:var(--void)}
.case-body{background:var(--void2);padding:26px;flex:1;border-top:none}
.case-cat{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:7px}
.cat-edu{color:var(--amber)}.cat-sec{color:var(--blue2)}.cat-fnb{color:var(--green)}
.case-body h3{font-family:var(--fd);font-size:17px;font-weight:700;letter-spacing:-.3px;margin-bottom:9px;color:var(--white);line-height:1.3}
.case-body p{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:18px;font-weight:300}
.case-nums{display:flex;gap:24px;padding-top:16px;border-top:1px solid var(--border)}
.cn-v{font-family:var(--fd);font-size:20px;font-weight:800;color:var(--blue2);line-height:1}
.cn-l{font-size:10px;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.06em}
.case-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--blue2);margin-top:16px;transition:gap .2s}
.case-link:hover{gap:10px}
.case-full{grid-column:span 2}
.cbg-edu{background:linear-gradient(135deg,#1a0b3d,#3a0f7a)}
.cbg-sec{background:linear-gradient(135deg,#050f28,#0a2260)}
.cbg-fnb{background:linear-gradient(135deg,#061a15,#0a3d2e)}
.case-emoji{position:absolute;top:50%;left:50%;transform:translate(-50%,-58%);font-size:80px;opacity:.12;pointer-events:none}

/* ══ PROCESS ══════════════════════════════════════════════════════ */
.proc-sec{background:var(--void)}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;margin-top:60px}
.proc-line{
  position:absolute;top:28px;
  left:calc(12.5% + 14px);right:calc(12.5% + 14px);
  height:1px;background:linear-gradient(90deg,var(--blue),rgba(30,144,255,.1));
  box-shadow:0 0 8px rgba(30,144,255,.3);
}
.proc-step{text-align:center;padding:0 20px;position:relative;z-index:1}
.proc-circle{
  width:56px;height:56px;border-radius:50%;
  background:var(--void3);border:1.5px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-size:13px;font-weight:800;color:var(--white);
  margin:0 auto 24px;transition:background .3s,border-color .3s,box-shadow .3s;
}
.proc-step:first-child .proc-circle{
  background:var(--blue);border-color:var(--blue);color:#fff;
  box-shadow:0 0 24px rgba(30,144,255,.5);
}
.proc-step:hover .proc-circle{background:rgba(30,144,255,.15);border-color:var(--blue);box-shadow:0 0 20px rgba(30,144,255,.3)}
.proc-tag{font-size:10px;font-weight:700;color:var(--muted2);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.proc-step h3{font-family:var(--fd);font-size:17px;font-weight:700;color:var(--white);margin-bottom:10px;letter-spacing:-.3px}
.proc-step p{font-size:13px;color:var(--muted);line-height:1.72;font-weight:300}

/* ══ TESTIMONIALS ═════════════════════════════════════════════════ */
.testi-sec{background:rgba(10,15,30,.5)}
.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:52px}
.testi-card{
  background:var(--void2);border:1px solid var(--border);border-radius:20px;
  padding:34px;position:relative;
  transition:border-color .25s,box-shadow .25s;
}
.testi-card:hover{border-color:var(--border2);box-shadow:0 0 40px rgba(30,144,255,.08)}
.testi-q{position:absolute;top:20px;right:24px;font-family:var(--fi);font-size:72px;color:var(--blue);opacity:.07;line-height:1}
.testi-stars{display:flex;gap:3px;margin-bottom:16px}
.testi-stars span{color:var(--amber);font-size:14px}
blockquote{font-family:var(--fi);font-style:italic;font-size:16px;color:var(--white2);line-height:1.82;margin-bottom:24px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-av{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-size:14px;font-weight:800;color:#fff;
}
.av-edu{background:var(--amber)}.av-fnb{background:var(--green);color:var(--void)}.av-sec{background:var(--blue)}
.testi-name{font-family:var(--fd);font-weight:700;font-size:14px;color:var(--white)}
.testi-role{font-size:12px;color:var(--muted);margin-top:2px}
.testi-result{margin-top:16px;padding-top:16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600}

/* ══ BOTTOM CTA ═══════════════════════════════════════════════════ */
.cta-sec{
  background:var(--void);padding:100px 5%;text-align:center;position:relative;overflow:hidden;
}
.cta-sec::before{
  content:'';position:absolute;top:-120px;left:50%;transform:translateX(-50%);
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(30,144,255,.1),transparent 70%);
  pointer-events:none;
}
.cta-sec::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--blue),transparent);
}
.cta-sec h2{
  font-family:var(--fd);font-size:clamp(30px,4.5vw,60px);
  font-weight:800;letter-spacing:-2.5px;line-height:1.04;
  color:var(--white);margin-bottom:16px;position:relative;
}
.cta-sec h2 .it{font-family:var(--fi);font-style:italic;color:var(--muted);font-weight:400}
.cta-sec p{font-size:17px;color:var(--muted);max-width:480px;margin:0 auto 40px;line-height:1.75;font-weight:300;position:relative}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}

/* ══ FOOTER ═══════════════════════════════════════════════════════ */
footer{
  background:var(--void2);border-top:1px solid var(--border);
  padding:72px 5% 32px;font-family:var(--fb);position:relative;z-index:2;
}
.foot-inner{max-width:var(--max);margin:0 auto}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:52px;border-bottom:1px solid var(--border);margin-bottom:32px}
.foot-logo{font-family:var(--fd);font-weight:800;font-size:20px;letter-spacing:-.4px;margin-bottom:14px;display:flex;align-items:center;gap:10px;color:var(--white)}
.foot-logo-mark{
  width:30px;height:30px;
  background:linear-gradient(135deg,var(--blue),var(--blue-dark));
  border-radius:7px;display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:13px;color:#fff;font-family:var(--fd);
  box-shadow:0 0 16px var(--blue-glow);
}
.foot-logo span{color:var(--blue2)}
.foot-brand p{font-size:14px;color:var(--muted);line-height:1.75;max-width:280px;margin-bottom:20px;font-weight:300}
.foot-soc{display:flex;gap:8px}
.foot-soc a{
  width:36px;height:36px;border:1px solid var(--border2);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:var(--muted);
  transition:border-color .2s,color .2s,box-shadow .2s;text-decoration:none;cursor:none;
}
.foot-soc a:hover{border-color:var(--blue);color:var(--blue2);box-shadow:0 0 12px rgba(30,144,255,.25)}
.foot-col h4{font-family:var(--fd);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted2);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:14px;color:var(--muted);transition:color .2s;cursor:none}
.foot-col a:hover{color:var(--blue2)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot-bottom p{font-size:13px;color:var(--muted2)}
.tbadges{display:flex;gap:16px;align-items:center}
.tbadge{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted2)}

/* ══ KEYFRAMES ════════════════════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.75)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes floatE{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ══ MOBILE ═══════════════════════════════════════════════════════ */
/* ══ MOBILE NAVIGATION ══════════════════════════════════════════ */
.nav-toggle {
  display: none;
  width: 30px;
  height: 20px;
  position: relative;
  cursor: pointer;
  z-index: 10001;
  transition: transform .3s var(--ease);
}
.nav-toggle span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--white);
  border-radius: 4px;
  position: absolute;
  transition: transform .4s cubic-bezier(.6,-.28,.1,1.15), opacity .3s;
}
.nav-toggle span:nth-child(1) { top: 0; }
.nav-toggle span:nth-child(2) { top: 50%; transform: translateY(-50%); }
.nav-toggle span:nth-child(3) { bottom: 0; }

.nav-toggle.active span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.nav-toggle.active span:nth-child(2) { opacity: 0; transform: translateX(-20px); }
.nav-toggle.active span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

@media(max-width:960px){
  .cur,.cur-ring{display:none}body{cursor:auto}
  
  /* Hamburger Show */
  .nav-toggle { display: block; }
  
  /* Navigation Links as Side Drawer */
  nav .nav-links {
    position: fixed; top: 0; right: -100%; width: 320px; height: 100vh;
    background: rgba(5,8,16,.96); backdrop-filter: blur(25px);
    border-left: 1px solid rgba(255,255,255,.05);
    flex-direction: column; align-items: flex-start;
    padding: 100px 40px; gap: 24px; transition: right .5s cubic-bezier(.77,0,.175,1);
    z-index: 10000; box-shadow: -20px 0 60px rgba(0,0,0,.5);
  }
  nav .nav-links.active { right: 0; }
  nav .nav-links li { animation: fadeRight .5s both; animation-delay: .2s; }
  nav .nav-links li:nth-child(2) { animation-delay: .25s; }
  nav .nav-links li:nth-child(3) { animation-delay: .3s; }
  nav .nav-links li:nth-child(4) { animation-delay: .35s; }
  nav .nav-links li:nth-child(5) { animation-delay: .4s; }
  nav .nav-links li:nth-child(6) { animation-delay: .45s; }
  nav .nav-links li:nth-child(7) { animation-delay: .5s; }
  
  @keyframes fadeRight { from {opacity: 0; transform: translateX(20px);} to {opacity: 1; transform: none;} }
  
  nav .nav-links a { font-size: 20px; font-weight: 700; color: #fff; width: 100%; }
  nav .nav-links a::after { display: none; }
  nav .nav-links a.active { color: var(--blue2); }
  
  /* Move CTA inside drawer or hide it in nav and show in drawer */
  nav .nav-cta { display: none; } /* Hide in original nav bar */
  
  /* Inject specialized mobile CTA style */
  .mobile-cta { margin-top: 32px; width: 100%; }

  .hero{grid-template-columns:1fr;padding:120px 5% 60px;gap:48px;min-height:auto; text-align: center;}
  .hero-right{display:none}
  .hero-actions{justify-content: center;}
  .hero h1 { font-size: clamp(32px, 8vw, 48px); }
  .hero-proof { justify-content: center; }
  
  .trust-stats{grid-template-columns:1fr 1fr}
  .ind-layout,.cases-grid,.testi-grid{grid-template-columns:1fr}
  .case-full{grid-column:auto}
  .srv-grid{grid-template-columns:1fr;gap:20px; padding-top: 40px;}
  .ai-card{grid-column:auto}.ai-card-inner{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr; gap:40px;}
  .proc-line{display:none}
  .foot-top{grid-template-columns:1fr 1fr;gap:48px}
  .ind-visual{display:none}
}
@media(max-width:600px){
  .foot-top{grid-template-columns:1fr}
  .trust-stats{grid-template-columns:1fr}
  .trust-logos { justify-content: center; }
  .sec-title { font-size: clamp(32px, 8vw, 44px); }
}

/* = TEAM SECTION = */
.tm-sec{background:var(--void2);border-top:1px solid var(--border);padding:100px 5%}
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.tm-card{position:relative;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:transform .4s var(--ease),border-color .4s;cursor:pointer}
.tm-card:hover{transform:translateY(-10px);border-color:var(--blue2);background:rgba(30,144,255,.05)}
.tm-img-wrapper{width:100%;aspect-ratio:4/5;overflow:hidden;position:relative}
.tm-img-wrapper::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--void) 0%,transparent 30%);opacity:0.6}
.tm-img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .8s var(--ease);filter:none}
.tm-card:hover .tm-img{transform:scale(1.08)}
.tm-info{padding:24px;position:relative}
.tm-info h4{font-family:var(--fs);font-size:22px;margin-bottom:4px;letter-spacing:-.03em}
.tm-info .tm-role{font-size:13px;color:var(--blue2);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.tm-info p{font-size:14px;color:var(--muted);line-height:1.6}

/* = FOUNDER SECTION = */
.founder-card{
  display:grid;grid-template-columns:400px 1fr;gap:40px;
  background:rgba(255,255,255,.02);border:1px solid var(--border);
  border-radius:24px;overflow:hidden;margin-bottom:60px;
  align-items:center;transition:border-color .4s;
}
.founder-card:hover{border-color:var(--blue2);}
.founder-img-wrapper{
  width:100%;height:100%;position:relative;
}
.founder-img-wrapper img{
  width:100%;aspect-ratio:1/1;object-fit:cover;object-position:top;
  filter:none;transition:transform .5s;
}
.founder-card:hover .founder-img-wrapper img{transform:scale(1.05);}
.founder-info{padding:60px 60px 60px 0;display:flex;flex-direction:column;justify-content:center;}
.founder-info h3{font-family:var(--fs);font-size:40px;margin-bottom:12px;letter-spacing:-.03em;line-height:1.1;}
.founder-info .tm-role{font-size:14px;color:var(--blue2);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;}
.founder-info p{font-size:16px;color:var(--muted);line-height:1.7;margin-bottom:24px;}
.founder-quote{font-style:italic;font-size:18px;color:var(--white);border-left:2px solid var(--blue2);padding-left:16px;line-height:1.5;}

/* = ABOUT PAGE HERO = */
.about-hero{padding:180px 5% 100px;text-align:center;background:radial-gradient(circle at 50% 0,rgba(30,144,255,.1) 0%,transparent 50%)}
.about-hero h1{font-size:clamp(40px,8vw,80px);margin-bottom:24px;line-height:.95}
.about-hero p{max-width:700px;margin:0 auto;font-size:18px;color:var(--muted)}

/* = STORY SECTION = */
.story-sec{padding:100px 5%}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-content h2{font-size:48px;margin-bottom:24px;line-height:1}
.story-content p{font-size:16px;margin-bottom:20px;color:var(--muted);line-height:1.6}
.story-visual{position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--border);aspect-ratio:16/10}
.story-visual img{width:100%;height:100%;object-fit:cover}

/* = CONTACT SECTION = */
.contact-hero { padding: 180px 5% 80px; text-align: center; background: radial-gradient(circle at 50% 0, rgba(30,144,255,.1) 0%, transparent 50%); }
.contact-hero h1 { font-size: clamp(40px, 8vw, 80px); margin-bottom: 24px; line-height: .95; }
.contact-hero p { max-width: 600px; margin: 0 auto; font-size: 18px; color: var(--muted); }

.contact-sec { padding: 40px 5% 120px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: start; }
.contact-info-block { margin-bottom: 40px; }
.contact-info-block h3 { font-size: 20px; margin-bottom: 12px; font-family:var(--fs); letter-spacing:-.02em; }
.contact-info-block p { font-size: 16px; color: var(--muted); margin-bottom: 8px; }
.contact-socials { display: flex; gap: 16px; margin-top: 16px; }
.contact-socials a { width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; transition: background .3s, border-color .3s, color .3s; }
.contact-socials a:hover { background: rgba(30,144,255,.1); border-color: var(--blue2); color: var(--blue2); }

.contact-form { background: rgba(255,255,255,.02); border: 1px solid var(--border); border-radius: 24px; padding: 48px; position:relative; overflow:hidden;}
.contact-form::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(30,144,255,.5),transparent);}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
.form-group { margin-bottom: 24px; }
.form-label { display: block; font-size: 13px; color: var(--muted); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.form-control { width: 100%; background: rgba(0,0,0,.3); border: 1px solid var(--border); border-radius: 12px; padding: 16px; color: var(--white); font-family: var(--fb); font-size: 16px; transition: border-color .3s, box-shadow .3s; outline: none; }
.form-control:focus { outline:none; border-color:var(--blue2); box-shadow:0 0 15px rgba(30,144,255,.15); }

/* Validation Styles */
.error-msg {
  font-family: var(--fb);
  font-size: 11px;
  color: #ff4d4d;
  margin-top: 6px;
  display: block;
  animation: slideIn 0.3s var(--ease);
}

@keyframes slideIn {
  from { opacity: 0; transform: translateY(-5px); }
  to { opacity: 1; transform: translateY(0); }
}

input.is-invalid, select.is-invalid, textarea.is-invalid {
  border-color: #ff4d4d !important;
  box-shadow: 0 0 10px rgba(255,77,77,0.1) !important;
}
textarea.form-control { resize: vertical; min-height: 150px; }
.submit-btn { width: 100%; border: none; cursor: pointer; text-align: center; font-size:16px; justify-content:center; }

/* = BLOG SECTION = */
.blog-hero { padding: 180px 5% 80px; text-align: center; background: radial-gradient(circle at 50% 0, rgba(30,144,255,.1) 0%, transparent 50%); }
.blog-hero h1 { font-size: clamp(40px, 8vw, 80px); margin-bottom: 24px; line-height: .95; font-family:var(--fs); }
.blog-hero p { max-width: 700px; margin: 0 auto; font-size: 18px; color: var(--muted); }

.blog-sec { padding: 40px 5% 120px; }
.featured-post { display: grid; grid-template-columns: 1.2fr 1fr; gap: 0; background: rgba(255,255,255,.02); border: 1px solid var(--border); border-radius: 24px; overflow: hidden; margin-bottom: 80px; align-items: stretch; transition: border-color .4s; text-decoration: none; color: inherit; }
.featured-post:hover { border-color: var(--blue2); }
.featured-img-wrap { width: 100%; height: 100%; min-height: 400px; position: relative; overflow: hidden; }
.featured-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.featured-post:hover .featured-img-wrap img { transform: scale(1.05); }
.featured-content { padding: 60px; display: flex; flex-direction: column; justify-content: center; }
.post-meta { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }
.post-tag { color: var(--blue2); background: rgba(30,144,255,.1); padding: 4px 12px; border-radius: 100px; }
.post-time { color: var(--muted); }
.featured-content h2 { font-size: 36px; margin-bottom: 16px; line-height: 1.2; font-family:var(--fs); letter-spacing:-.02em; transition: color .3s; }
.featured-post:hover .featured-content h2 { color: var(--blue2); }
.featured-content p { font-size: 16px; color: var(--muted); line-height: 1.6; margin-bottom: 32px; }
.read-more { font-weight: 600; font-size: 14px; display: inline-flex; align-items: center; gap: 8px; transition: gap .3s; color: var(--white); }
.featured-post:hover .read-more { gap: 12px; color: var(--blue2); }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.blog-card { display: flex; flex-direction: column; background: rgba(255,255,255,.02); border: 1px solid var(--border); border-radius: 16px; overflow: hidden; transition: transform .4s var(--ease), border-color .4s; text-decoration: none; color: inherit; }
.blog-card:hover { transform: translateY(-10px); border-color: var(--blue2); }
.blog-img-wrap { width: 100%; aspect-ratio: 16/10; overflow: hidden; position: relative; }
.blog-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.blog-card:hover .blog-img-wrap img { transform: scale(1.1); }
.blog-card-content { padding: 32px; display: flex; flex-direction: column; flex-grow: 1; }
.blog-card h3 { font-size: 22px; margin-bottom: 12px; line-height: 1.3; font-family:var(--fs); letter-spacing:-.02em; transition: color .3s; }
.blog-card:hover h3 { color: var(--blue2); }
.blog-card p { font-size: 15px; color: var(--muted); line-height: 1.6; margin-bottom: 32px; flex-grow: 1; }

/* = ADVANCED ARTICLE DETAIL SECTION = */
.article-hero-adv { position: relative; min-height: 85vh; display: flex; align-items: flex-end; padding-bottom: 80px; padding-top: 150px; }
.hero-bg-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -2; overflow: hidden; }
.hero-bg-img img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); animation: slowZoom 20s infinite alternate linear; }
@keyframes slowZoom { 0% {transform: scale(1); } 100% {transform: scale(1.1); } }
.hero-overlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: -1; background: linear-gradient(180deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.8) 60%, var(--void) 100%); }
.hero-content-wrapper { position: relative; z-index: 2; width: 100%; }

.reading-col { max-width: 800px !important; margin: 0 auto; width: 100%; }
.article-hero-adv h1 { font-size: clamp(36px, 6vw, 64px); margin-bottom: 32px; line-height: 1.1; font-family:var(--fs); letter-spacing: -.02em; text-shadow: 0 4px 20px rgba(0,0,0,0.5); }
.article-author-row { display: flex; align-items: center; gap: 16px; border-top: 1px solid rgba(255,255,255,0.15); padding-top: 24px; margin-top: 24px; }
.author-avatar { width: 48px; height: 48px; background: rgba(255,255,255,0.1); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,0.2); color: #fff; font-family: var(--fs); font-weight: 700; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 16px; box-shadow: 0 0 15px rgba(30,144,255,.2); }
.author-info { display: flex; flex-direction: column; }
.author-info strong { font-size: 16px; color: var(--white); font-weight: 600; }
.author-info span { font-size: 14px; color: rgba(255,255,255,0.6); margin-top: 4px; }

.article-body { padding: 40px 5% 100px; position:relative; }
.relative-wrapper { position: relative; }
.share-container { position: absolute; left: -100px; top: 0; bottom: 0; width: 60px; }
.sticky-share { position: sticky; top: 120px; display: flex; flex-direction: column; gap: 12px; align-items: center; height: max-content; }
.share-label { font-size: 11px; text-transform: uppercase; color: var(--muted); letter-spacing: 2px; transform: rotate(-90deg); margin-bottom: 24px; margin-top:20px; }
.share-icon { width: 44px; height: 44px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.1); display: flex; justify-content: center; align-items: center; color: var(--muted); transition: all 0.3s var(--ease); text-decoration: none; font-family: var(--fb); font-weight:600;}
.share-icon:hover { background: rgba(30,144,255,.1); border-color: var(--blue2); color: var(--blue2); transform: translateY(-3px); box-shadow: 0 4px 15px rgba(30,144,255,.2); }

.article-content { font-size: 19px; line-height: 1.8; color: #d1d5db; }
.article-content p { margin-bottom: 28px; }
.dropcap { float: left; font-size: 80px; line-height: 60px; padding-top: 4px; padding-right: 12px; font-family: var(--fs); color: var(--blue2); text-shadow: 0 0 20px rgba(30,144,255,0.4); }
.article-content p.lead { font-size: 24px; color: var(--white); line-height: 1.6; font-weight: 300; margin-bottom: 48px; }
.article-content h2 { font-size: 34px; color: var(--white); font-family:var(--fs); margin: 60px 0 24px; line-height: 1.2; letter-spacing: -.02em; }

.advanced-quote { margin: 60px 0; padding: 40px; font-size: 28px; line-height: 1.4; color: var(--white); font-style: italic; border-left: 4px solid var(--blue2); background: linear-gradient(90deg, rgba(30,144,255,0.1) 0%, rgba(255,255,255,.02) 100%); border-radius: 0 24px 24px 0; font-family: var(--fs); position: relative; overflow:hidden;}
.advanced-quote::before { content: '"'; position: absolute; top: -20px; left: 20px; font-size: 120px; color: rgba(30,144,255,0.1); font-family: var(--fs); pointer-events:none;}
.advanced-quote p { margin: 0; position:relative; z-index:2;}

.custom-ul ul { list-style: none; padding: 0; margin-bottom: 40px;}
.custom-ul li { position: relative; padding-left: 32px; margin-bottom: 16px; }
.custom-ul li::before { content: '→'; position: absolute; left: 0; top: 2px; color: var(--blue2); font-weight: bold; }

.article-inline-image { margin: 60px 0; width: 100%; border-radius: 20px; overflow: hidden; border: 1px solid rgba(255,255,255,0.1); }
.article-inline-image img { width: 100%; height: auto; display: block; }
.article-inline-image figcaption { padding: 16px; text-align: center; font-size: 14px; color: var(--muted); background: rgba(0,0,0,0.5); }

.inline-link { color: var(--blue2); text-decoration: none; border-bottom: 1px dashed var(--blue2); transition: all 0.3s var(--ease); }
.inline-link:hover { color: var(--white); border-bottom-style: solid; text-shadow: 0 0 10px rgba(30,144,255,0.5); }

.author-box-adv { margin-top: 80px; padding: 56px; position:relative; border-radius: 24px; text-align: center; overflow:hidden; border: 1px solid rgba(255,255,255,0.1);}
.author-box-bg { position:absolute; top:0; left:0; width:100%; height:100%; background: radial-gradient(circle at 50% 100%, rgba(30,144,255,.15) 0%, rgba(255,255,255,0.02) 100%); z-index:-1;}
.author-box-icon { font-size: 32px; color: var(--blue2); margin-bottom: 16px; animation: float 4s ease-in-out infinite; }
@keyframes float { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-10px);} }
.author-box-adv h3 { font-size: 32px; color: var(--white); font-family:var(--fs); margin-bottom: 16px; letter-spacing:-.02em;}
.author-box-adv p { font-size: 16px; color: var(--muted); line-height: 1.6; max-width: 600px; margin: 0 auto; }

/* Tags & Similar Posts */
.article-tags { display: flex; gap: 12px; margin-top: 60px; padding-top: 40px; border-top: 1px solid rgba(255,255,255,0.1); flex-wrap: wrap; align-items: center; }
.article-tags-label { font-size: 14px; color: var(--muted); text-transform: uppercase; letter-spacing: 2px; margin-right: 8px; font-family:var(--fs);}
.post-tag-pill { padding: 8px 20px; border: 1px solid rgba(255,255,255,0.1); border-radius: 30px; font-size: 14px; text-decoration: none; color: var(--white); transition: all 0.3s var(--ease); background: rgba(255,255,255,0.02); }
.post-tag-pill:hover { border-color: var(--blue2); background: rgba(30,144,255,0.1); color: var(--blue2); transform: translateY(-2px); }

.similar-posts { padding: 0 5% 100px; }
.similar-posts h2 { font-size: 36px; font-family: var(--fs); margin-bottom: 48px; letter-spacing: -.02em; text-align:center;}

/* = PACKAGES & PRICING SECTION = */
.pricing-hero { padding: 180px 5% 80px; text-align: center; background: radial-gradient(circle at 50% 0, rgba(30,144,255,.1) 0%, transparent 60%); }
.pricing-hero h1 { font-size: clamp(40px, 8vw, 80px); margin-bottom: 24px; line-height: .95; font-family:var(--fs); }
.pricing-hero p { max-width: 650px; margin: 0 auto; font-size: 18px; color: var(--muted); line-height: 1.6; }

.pricing-sec { padding: 40px 5% 100px; }
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; align-items: start; }
.pricing-card { background: rgba(255,255,255,.02); border: 1px solid var(--border); border-radius: 24px; padding: 48px; display: flex; flex-direction: column; position: relative; transition: transform .4s var(--ease), border-color .4s, box-shadow .4s; }
.pricing-card:hover { transform: translateY(-10px); border-color: rgba(30,144,255,.3); }

/* The 'Most Popular' middle tier */
.pricing-card.popular { border-color: var(--blue2); background: linear-gradient(180deg, rgba(30,144,255,.05) 0%, rgba(255,255,255,.02) 100%); transform: scale(1.05); z-index: 2; box-shadow: 0 20px 40px rgba(0,0,0,0.5), 0 0 40px rgba(30,144,255,.1);border-width: 2px;}
.pricing-card.popular:hover { transform: scale(1.05) translateY(-10px); box-shadow: 0 20px 40px rgba(0,0,0,0.5), 0 0 60px rgba(30,144,255,.2); }
.popular-badge { position: absolute; top: -16px; left: 50%; transform: translateX(-50%); background: var(--blue2); color: #fff; padding: 6px 16px; border-radius: 20px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; box-shadow: 0 4px 15px rgba(30,144,255,.4); }

.card-top { margin-bottom: 32px; border-bottom: 1px solid rgba(255,255,255,0.05); padding-bottom: 32px; }
.card-top h3 { font-size: 24px; font-family: var(--fs); color: var(--white); margin-bottom: 16px; }
.card-top .price { font-size: 48px; font-family: var(--fs); font-weight: 700; color: var(--white); display: flex; align-items: baseline; gap:4px; margin-bottom: 16px; letter-spacing:-.02em;}
.card-top .price span { font-size: 24px; color: var(--blue2); }
.card-top .price .dur { font-size: 16px; color: var(--muted); font-weight: 400; font-family: var(--fb); letter-spacing:0;}
.card-top p { font-size: 15px; color: var(--muted); line-height: 1.6; }

.card-features { margin-bottom: 40px; flex-grow: 1; }
.card-features ul { list-style: none; padding: 0; }
.card-features li { position: relative; padding-left: 28px; margin-bottom: 16px; font-size: 15px; color: #d1d5db; line-height: 1.5; }
.card-features li::before { content: '→'; position: absolute; left: 0; top: 0px; color: var(--blue2); font-weight: bold; }

/* FAQ Section */
.faq-sec { padding: 80px 5% 100px; background: rgba(255,255,255,0.01); border-top: 1px solid rgba(255,255,255,0.05); }
.faq-header { text-align: center; margin-bottom: 64px; }
.faq-header h2 { font-size: clamp(32px, 5vw, 48px); font-family: var(--fs); margin-bottom: 16px; letter-spacing: -.02em;}
.faq-header p { font-size: 18px; color: var(--muted); max-width: 600px; margin: 0 auto; }
.faq-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; }
.faq-item { background: rgba(255,255,255,.02); border: 1px solid var(--border); border-radius: 16px; padding: 32px; transition: border-color .3s; }
.faq-item:hover { border-color: rgba(30,144,255,.3); }
.faq-item h4 { font-size: 20px; font-family: var(--fs); color: var(--white); margin-bottom: 16px; line-height: 1.4; }
.faq-item p { font-size: 15px; color: var(--muted); line-height: 1.7; }

@media (max-width:1200px){
  .pricing-card.popular { transform: scale(1.02); }
  .pricing-card.popular:hover { transform: scale(1.02) translateY(-10px); }
}@media (max-width:992px){
  .tm-grid{grid-template-columns:repeat(2,1fr)}
  .story-grid{grid-template-columns:1fr;gap:40px}
  .founder-card{grid-template-columns:1fr;}
  .founder-info{padding:40px;}
  .contact-grid{grid-template-columns:1fr;gap:60px;}
  .contact-form{padding:32px;}
  .featured-post{grid-template-columns:1fr;}
  .featured-content{padding:32px;}
  .featured-img-wrap{min-height:300px;}
  .blog-grid{grid-template-columns:repeat(2,1fr);}
  .article-hero-adv{min-height: 60vh; padding-top: 120px;}
  .sticky-share{display:none;} /* Hide sticky share on mobile/tablet to save space */
  
  .pricing-grid{grid-template-columns:repeat(2,1fr); gap:24px;}
  .pricing-card.popular{transform: scale(1);} /* Disable lifting on tablet to prevent grid breakage */
  .pricing-card.popular:hover{transform: translateY(-10px);}
}
@media (max-width:640px){
  .tm-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .article-hero-adv{padding-top: 100px; min-height: 50vh;}
  .author-box-adv{padding: 32px 24px;}
  .dropcap{font-size: 60px; line-height: 45px;}
  
  .pricing-grid{grid-template-columns:1fr;}
  .faq-grid{grid-template-columns:1fr;}
  .pricing-card{padding:32px;}
}

/* ══ CONSULTATION MODAL ═════════════════════════════════════════════ */
.consult-backdrop {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  opacity: 0; pointer-events: none;
  transition: opacity .35s ease;
}
.consult-backdrop.open { opacity: 1; pointer-events: all; }

.consult-modal {
  width: 100%; max-width: 540px;
  background: linear-gradient(145deg,#0d1428,#050810);
  border: 1px solid rgba(30,144,255,.25);
  border-radius: 24px; padding: 48px 40px 40px;
  position: relative;
  transform: translateY(30px) scale(.97);
  transition: transform .4s ease;
  box-shadow: 0 40px 80px rgba(0,0,0,.8), 0 0 60px rgba(30,144,255,.1);
}
.consult-backdrop.open .consult-modal { transform: translateY(0) scale(1); }

.consult-close {
  position: absolute; top: 20px; right: 20px;
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.1);
  background: transparent; color: rgba(200,216,255,.4);
  font-size: 18px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .3s;
}
.consult-close:hover { background: rgba(255,255,255,.06); color: #F0F4FF; }

.consult-eyebrow { font-size: 12px; text-transform: uppercase; letter-spacing: 2px; color: #3AABFF; margin-bottom: 10px; }
.consult-modal h2 { font-size: 26px; font-family: var(--fs); color: #F0F4FF; margin-bottom: 6px; letter-spacing: -.02em; }
.consult-sub { font-size: 14px; color: rgba(200,216,255,.4); margin-bottom: 28px; line-height: 1.5; }

.consult-form { display: flex; flex-direction: column; gap: 14px; }
.consult-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.consult-field { display: flex; flex-direction: column; gap: 5px; }
.consult-field label { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: rgba(200,216,255,.4); }
.consult-field input,
.consult-field select,
.consult-field textarea {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px; padding: 12px 14px; color: #F0F4FF;
  font-size: 14px; transition: border-color .3s, box-shadow .3s; outline: none; width: 100%;
}
.consult-field input::placeholder, .consult-field textarea::placeholder { color: rgba(200,216,255,.2); }
.consult-field input:focus, .consult-field select:focus, .consult-field textarea:focus {
  border-color: #3AABFF; box-shadow: 0 0 0 3px rgba(30,144,255,.12);
}
.consult-field select { appearance: none; cursor: pointer; }
.consult-field textarea { resize: none; min-height: 80px; }
.consult-field select option { background: #0d1428; }

.btn-wa {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 15px 24px; background: linear-gradient(135deg,#25D366,#128C7E);
  color: #fff; font-size: 15px; font-weight: 700;
  border: none; border-radius: 12px; cursor: pointer; width: 100%; margin-top: 6px;
  transition: transform .3s ease, box-shadow .3s;
  box-shadow: 0 8px 24px rgba(37,211,102,.25);
}
.btn-wa:hover { transform: translateY(-3px); box-shadow: 0 16px 32px rgba(37,211,102,.35); }
.btn-wa svg { width: 20px; height: 20px; fill: #fff; flex-shrink: 0; }
.consult-note { font-size: 12px; color: rgba(200,216,255,.35); text-align: center; margin-top: 10px; }

.consult-success { display: none; flex-direction: column; align-items: center; text-align: center; gap: 14px; padding: 16px 0; }
.consult-success.show { display: flex; }
.consult-form-wrap.hidden { display: none; }
.success-icon { width: 68px; height: 68px; border-radius: 50%; background: linear-gradient(135deg,#25D366,#128C7E); display: flex; align-items: center; justify-content: center; font-size: 30px; box-shadow: 0 12px 32px rgba(37,211,102,.3); }
.consult-success h3 { font-size: 22px; font-family: var(--fs); color: #F0F4FF; }
.consult-success p { font-size: 14px; color: rgba(200,216,255,.4); line-height: 1.6; }

@media(max-width:640px){
  .consult-modal { padding: 36px 20px 28px; }
  .consult-row { grid-template-columns: 1fr; }
}

/* ══ PORTFOLIO / WORK PAGE ══════════════════════════════════════════════ */

/* Hero */
.portfolio-hero { padding: 180px 5% 80px; text-align:center; position:relative; overflow:hidden; }
.port-hero-bg { position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0, rgba(30,144,255,.12) 0%, transparent 65%);pointer-events:none; }
.port-hero-inner { position:relative;z-index:2; }
.portfolio-hero h1 { font-size:clamp(52px,10vw,100px); font-family:var(--fs); line-height:.9; letter-spacing:-.03em; margin:16px 0 24px; }
.port-hero-sub { font-size:18px; color:var(--muted); max-width:600px; margin:0 auto 56px; line-height:1.6; }

.port-stats { display:flex; align-items:center; justify-content:center; gap:0; background:rgba(255,255,255,.02); border:1px solid var(--border); border-radius:20px; padding:32px 48px; max-width:780px; margin:0 auto; flex-wrap:wrap; gap:0; }
.port-stat { text-align:center; padding:0 32px; }
.port-stat-num { font-size:36px; font-family:var(--fs); font-weight:700; color:var(--white); letter-spacing:-.02em; }
.port-stat-label { font-size:13px; color:var(--muted); margin-top:4px; text-transform:uppercase; letter-spacing:1px; }
.port-stat-divider { width:1px; height:56px; background:rgba(255,255,255,.06); }

/* Filter bar */
.port-filter-sec { padding:0 5% 48px; }
.port-filter-bar { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.port-filter-btn { padding:10px 22px; border-radius:30px; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.02); color:var(--muted); font-size:14px; font-family:var(--fb); cursor:pointer; transition:all .3s; }
.port-filter-btn:hover { border-color:rgba(30,144,255,.4); color:var(--white); }
.port-filter-btn.active { background:var(--blue2); border-color:var(--blue2); color:#fff; font-weight:600; box-shadow:0 4px 16px rgba(30,144,255,.3); }

/* Tech Stack Styles */
.tech-sec { padding: 40px 5% 80px; }
.tech-card { background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 24px; padding: 48px; backdrop-filter: blur(10px); }
.tech-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; margin-top: 40px; }
.tech-item { padding: 24px; border-radius: 16px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.05); transition: all 0.3s ease; }
.tech-item:hover { border-color: var(--blue2); transform: translateY(-5px); background: rgba(30,144,255,0.05); }
.tech-item span { font-size: 11px; color: var(--blue2); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.tech-item h4 { font-size: 15px; color: var(--white); margin-top: 8px; }
@media(max-width:992px){ .tech-grid { grid-template-columns: repeat(3, 1fr); } }
@media(max-width:640px){ .tech-grid { grid-template-columns: 1fr; } }

.port-sec { padding:0 5% 80px; }

/* Award banner */
.award-banner { display:flex; align-items:center; gap:20px; background:linear-gradient(90deg,rgba(245,166,35,.08),rgba(30,144,255,.06)); border:1px solid rgba(245,166,35,.2); border-radius:16px; padding:20px 28px; margin-bottom:48px; }
.award-banner-icon { font-size:32px; flex-shrink:0; }
.award-banner strong { display:block; font-size:16px; color:var(--white); font-family:var(--fs); margin-bottom:4px; }
.award-banner span { font-size:14px; color:var(--muted); }

/* Featured project */
.port-featured { display:grid; grid-template-columns:1fr 1fr; border:1px solid var(--border); border-radius:24px; overflow:hidden; margin-bottom:48px; background:rgba(255,255,255,.02); transition:box-shadow .4s; }
.port-featured:hover { box-shadow:0 20px 60px rgba(0,0,0,.5), 0 0 40px rgba(30,144,255,.08); }
.port-feat-img { min-height:500px; position:relative; display:flex; align-items:flex-end; padding:32px; }
.port-feat-overlay { position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,8,16,0) 30%,rgba(5,8,16,.7) 100%); }
.port-feat-badge { position:relative;z-index:2;padding:8px 18px;border-radius:20px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px; }
.port-feat-emoji { position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:100px;opacity:.15;pointer-events:none;user-select:none; }
.port-feat-content { padding:48px; display:flex; flex-direction:column; justify-content:center; }
.port-feat-cat { font-size:13px; text-transform:uppercase; letter-spacing:1px; margin-bottom:16px; font-family:var(--fs); font-weight:700; }
.port-feat-title { font-size:clamp(24px,3vw,36px); font-family:var(--fs); color:var(--white); letter-spacing:-.02em; margin-bottom:16px; line-height:1.1; }
.port-feat-desc { font-size:15px; color:var(--muted); line-height:1.7; margin-bottom:24px; }

.port-feat-quote { background:rgba(255,255,255,.03); border-left:3px solid var(--blue2); border-radius:0 12px 12px 0; padding:16px 20px; margin-bottom:24px; font-size:15px; font-style:italic; color:var(--white); line-height:1.6; }
.pq-mark { font-size:32px; color:var(--blue2); font-family:var(--fs); line-height:1; display:block; margin-bottom:-8px; }
.port-feat-quote cite { display:block; margin-top:8px; font-size:13px; color:var(--muted); font-style:normal; }

.port-feat-metrics { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px; }
.pfm { text-align:center; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); border-radius:12px; padding:16px 8px; }
.pfm-v { font-size:22px; font-family:var(--fs); font-weight:700; color:var(--blue2); letter-spacing:-.01em; }
.pfm-l { font-size:11px; color:var(--muted); margin-top:4px; text-transform:uppercase; letter-spacing:.5px; }

.port-cta { display:inline-flex; margin-top:8px; align-self:flex-start; }
.port-feat-tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px; }

/* Tags */
.port-tag { padding:5px 14px; border-radius:20px; border:1px solid rgba(255,255,255,.08); font-size:12px; color:var(--muted); background:rgba(255,255,255,.02); transition:all .3s; }
.port-tag:hover { border-color:rgba(30,144,255,.3); color:var(--blue2); }

/* 3-col grid */
.port-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.port-card { background:rgba(255,255,255,.02); border:1px solid var(--border); border-radius:20px; overflow:hidden; display:flex; flex-direction:column; transition:transform .4s var(--ease), box-shadow .4s, border-color .4s; }
.port-card:hover { transform:translateY(-8px); border-color:rgba(30,144,255,.25); box-shadow:0 16px 48px rgba(0,0,0,.5); }
.port-card-img { height:220px; position:relative; display:flex; align-items:flex-end; padding:16px; flex-shrink:0; }
.port-card-overlay { position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,8,16,0) 20%,rgba(5,8,16,.6) 100%); }
.port-card-tag { position:relative;z-index:2;padding:6px 14px;border-radius:16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px; }
.port-card-emoji { position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:64px;opacity:.18;pointer-events:none; }
.port-card-body { padding:28px; flex:1; display:flex; flex-direction:column; }
.port-card-cat { font-size:12px; text-transform:uppercase; letter-spacing:1px; margin-bottom:12px; font-weight:700; }
.port-card-body h3 { font-size:19px; font-family:var(--fs); color:var(--white); margin-bottom:12px; line-height:1.2; letter-spacing:-.01em; }
.port-card-body p { font-size:14px; color:var(--muted); line-height:1.7; margin-bottom:20px; }
.port-card-metrics { display:flex; gap:12px; margin-bottom:16px; }
.pcm { flex:1; text-align:center; background:rgba(255,255,255,.03); border-radius:10px; padding:12px 6px; border:1px solid rgba(255,255,255,.05); }
.pcm-v { font-size:17px; font-family:var(--fs); font-weight:700; color:var(--white); letter-spacing:-.01em; }
.pcm-l { font-size:11px; color:var(--muted); margin-top:2px; line-height:1.3; }
.port-card-tags { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:20px; }
.port-card-link { font-size:14px; color:var(--blue2); text-decoration:none; display:inline-flex; align-items:center; gap:6px; margin-top:auto; font-weight:600; transition:gap .3s; }
.port-card-link:hover { gap:10px; }

/* CTA card */
.port-cta-card { border:1px dashed rgba(30,144,255,.25) !important; background:radial-gradient(circle at 50% 100%,rgba(30,144,255,.06) 0%,transparent 70%) !important; }
.port-cta-card-inner { padding:40px 28px; display:flex; flex-direction:column; align-items:center; text-align:center; justify-content:center; height:100%; }
.port-cta-icon { font-size:48px; margin-bottom:20px; }
.port-cta-card h3 { font-size:22px; font-family:var(--fs); color:var(--white); margin-bottom:12px; }
.port-cta-card p { font-size:14px; color:var(--muted); line-height:1.6; margin-bottom:20px; }
.port-cta-note { font-size:12px; color:var(--muted); margin-top:12px; }

/* Responsive */
@media(max-width:1200px){
  .port-feat-metrics{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:992px){
  .port-featured{grid-template-columns:1fr;}
  .port-feat-img{min-height:300px;}
  .port-grid{grid-template-columns:repeat(2,1fr);}
  .port-stats{padding:24px 20px;}
  .port-stat{padding:0 16px;}
}
@media(max-width:640px){
  .portfolio-hero{padding:130px 5% 60px;}
  .port-stats{flex-direction:column;gap:24px;}
  .port-stat-divider{width:80px;height:1px;}
  .port-filter-bar{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px;}
  .port-grid{grid-template-columns:1fr;}
  .port-feat-content{padding:28px 20px;}
  .port-feat-metrics{grid-template-columns:repeat(2,1fr);}
}


