/* =============================================
   MasterAI — Main Stylesheet
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#ffffff;--bg-alt:#F8F9FC;--bg-dark:#060C1A;--bg-dark2:#0C1528;
  --surface:#ffffff;--surface2:#f1f5f9;--border:#e2e8f0;--border2:#cbd5e1;
  --primary:#4F46E5;--primary-dark:#4338CA;--primary-light:#EEF2FF;
  --secondary:#7C3AED;--accent:#0EA5E9;--green:#10B981;--gold:#C9A227;
  --text:#111827;--text2:#374151;--text3:#6B7280;--text4:#9CA3AF;
  --radius:16px;--radius-sm:10px;
  --shadow:0 4px 24px rgba(0,0,0,.08);--shadow-md:0 8px 40px rgba(0,0,0,.12);
  --font:'Plus Jakarta Sans',system-ui,sans-serif;
  --transition:.3s cubic-bezier(.4,0,.2,1);
  --nav-h:72px;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;padding-top:var(--nav-h)}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px}
::selection{background:rgba(79,70,229,.15);color:var(--primary)}
a{text-decoration:none}

/* ── Layout ── */
.container{
  width:100%;
  max-width:1800px;
  margin:0 auto;

  /* balanced spacing */
  padding-left:60px;
  padding-right:60px;
}
.section{
  padding:88px 0;
  width:100%;
}
.bg-alt{background:var(--bg-alt)}

/* ── Typography ── */
h1,h2,h3,h4{color:var(--text);line-height:1.2;font-weight:800}
p{color:var(--text3);line-height:1.7}
.gtext{background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── Tags & Badges ── */
.stag{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);background:var(--primary-light);border:1px solid rgba(79,70,229,.2);padding:5px 14px;border-radius:99px;margin-bottom:12px}
.section-hd{text-align:center;margin-bottom:56px}
.section-hd h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:12px}
.section-hd p{color:var(--text3);font-size:1rem;max-width:500px;margin:0 auto}

/* ── Buttons ── */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;font-family:var(--font);font-size:.9rem;font-weight:600;border:none;border-radius:99px;cursor:pointer;transition:var(--transition);box-shadow:0 4px 16px rgba(79,70,229,.3);position:relative;overflow:hidden;text-decoration:none}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(79,70,229,.45)}
.btn-primary:active{transform:translateY(0)}
.btn-full{width:100%;justify-content:center}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:12px 24px;background:#fff;border:1.5px solid var(--border2);border-radius:99px;color:var(--text2);font-family:var(--font);font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;background:transparent;border:1.5px solid var(--border2);border-radius:99px;color:var(--text2);font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.pring{width:30px;height:30px;border-radius:50%;background:rgba(79,70,229,.1);border:1px solid rgba(79,70,229,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.btn-ghost:hover .pring{background:var(--primary);border-color:var(--primary);color:#fff}

/* CTA strip buttons */
.btn-primary-light{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:#fff;color:var(--primary);font-weight:700;font-size:.9rem;border-radius:99px;text-decoration:none;transition:var(--transition);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.btn-primary-light:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.btn-outline-light{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff;font-weight:600;font-size:.9rem;border-radius:99px;text-decoration:none;transition:var(--transition)}
.btn-outline-light:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}

/* ── Reveal animations ── */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .28s ease,transform .28s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════════════
   HERO (Homepage only)
══════════════════════════════════════════════ */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--bg-dark);padding-top:0}
#heroCanvas{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:0}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.orb1{width:500px;height:500px;background:radial-gradient(circle,rgba(79,70,229,.18),transparent 70%);top:-80px;left:-100px;animation:orbF 14s ease-in-out infinite}
.orb2{width:400px;height:400px;background:radial-gradient(circle,rgba(124,58,237,.15),transparent 70%);bottom:0;right:200px;animation:orbF 10s ease-in-out infinite reverse}
@keyframes orbF{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-30px)}}
.hero-inner{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  gap:60px;

  /* same spacing as pages */
  padding:120px 60px 80px;

  width:100%;
  max-width:1800px;
  margin:0 auto;
}
.hero-content{flex:1;max-width:580px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;letter-spacing:.08em;color:#a5b4fc;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);padding:6px 14px;border-radius:99px;margin-bottom:24px}
.bdot{width:7px;height:7px;border-radius:50%;background:#10b981;box-shadow:0 0 8px #10b981;animation:bpulse 2s infinite}
@keyframes bpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.3);opacity:.7}}
.hero-title{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:#f8faff;margin-bottom:20px}
.hero-sub{color:#94a3b8;font-size:1.05rem;line-height:1.7;margin-bottom:32px}
.hero-btns{display:flex;align-items:center;gap:14px;margin-bottom:44px;flex-wrap:wrap}
.trust-row{display:flex;align-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:14px 22px;width:fit-content;flex-wrap:wrap;gap:0}
.tbadge{text-align:center;padding:0 18px}
.tnum{display:block;font-size:1.3rem;font-weight:800;color:#f8faff}
.tlabel{font-size:.72rem;color:#64748b;font-weight:500}
.tdiv{width:1px;height:32px;background:rgba(255,255,255,.1)}

/* Hero visual */
.hero-visual{flex:1;display:flex;align-items:center;justify-content:center;position:relative;min-height:460px;z-index:2;overflow:visible}
#globeCanvas{width:380px;height:380px}
.ring{position:absolute;border-radius:50%;border:1px solid;top:50%;left:50%;transform:translate(-50%,-50%)}
.r1{width:380px;height:380px;border-color:rgba(99,102,241,.22);box-shadow:0 0 18px rgba(99,102,241,.1),inset 0 0 18px rgba(99,102,241,.04);animation:ringR 20s linear infinite}
.r2{width:470px;height:470px;border-color:rgba(124,58,237,.15);box-shadow:0 0 14px rgba(124,58,237,.07);animation:ringR 30s linear reverse infinite}
.r3{width:560px;height:560px;border-color:rgba(14,165,233,.1);box-shadow:0 0 10px rgba(14,165,233,.06);animation:ringR 42s linear infinite}
@keyframes ringR{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}
/* ── Feature nodes orbit system ── */
#connectCanvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}
.fnode{position:absolute;pointer-events:none;z-index:3}
.fnode-float{animation:fnFloat 5.5s ease-in-out infinite}
@keyframes fnFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.fnode-card{display:flex;align-items:center;gap:8px;background:rgba(6,10,24,.84);border:1px solid rgba(255,255,255,.1);border-radius:40px;padding:6px 14px 6px 7px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 20px rgba(0,0,0,.4),0 0 0 0 var(--nc,#6366f1);cursor:pointer;pointer-events:auto;transition:box-shadow .22s,border-color .22s,transform .22s;white-space:nowrap}
.fnode-card:hover{border-color:var(--nc,#6366f1);box-shadow:0 6px 28px rgba(0,0,0,.45),0 0 22px color-mix(in srgb,var(--nc,#6366f1) 38%,transparent);transform:scale(1.07)}
.fnode-ico{width:26px;height:26px;border-radius:50%;background:color-mix(in srgb,var(--nc,#6366f1) 18%,transparent);border:1px solid color-mix(in srgb,var(--nc,#6366f1) 32%,transparent);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--nc,#6366f1);transition:background .22s,box-shadow .22s}
.fnode-card:hover .fnode-ico{background:color-mix(in srgb,var(--nc,#6366f1) 30%,transparent);box-shadow:0 0 12px color-mix(in srgb,var(--nc,#6366f1) 55%,transparent)}
.fnode-lbl{font-size:.7rem;font-weight:600;color:#94a3b8;letter-spacing:.04em;transition:color .22s}
.fnode-card:hover .fnode-lbl{color:#f1f5f9}
/* Cursor glow */
#heroCsrGlow{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.07) 0%,transparent 68%);pointer-events:none;z-index:1;transform:translate(-50%,-50%);opacity:0;transition:opacity .35s;will-change:transform}
.hero-visual:hover #heroCsrGlow{opacity:1}

/* ══ TRUSTED BAR ══ */
.trusted-bar{padding:28px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#fafafe;overflow:hidden}
.trusted-label{text-align:center;font-size:.72rem;color:var(--text4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.logo-scroll{overflow:hidden}
.logo-track{display:flex;align-items:center;gap:56px;animation:scrollL 24s linear infinite;width:max-content}
.logo-track span{font-size:.82rem;font-weight:700;color:var(--text4);letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;transition:color .2s;cursor:default}
.logo-track span:hover{color:var(--primary)}
@keyframes scrollL{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ SERVICES GRID ══ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.services-grid.lg{grid-template-columns:repeat(3,1fr)}
.scard{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:28px;text-decoration:none;transition:var(--transition);position:relative;overflow:hidden;display:block}
.scard::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(79,70,229,.04),transparent);opacity:0;transition:opacity var(--transition)}
.scard:hover{border-color:rgba(79,70,229,.3);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.scard:hover::before{opacity:1}
.scard-icon{width:48px;height:48px;border-radius:12px;background:color-mix(in srgb,var(--c) 12%,transparent);border:1px solid color-mix(in srgb,var(--c) 25%,transparent);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:18px;transition:var(--transition)}
.scard:hover .scard-icon{background:color-mix(in srgb,var(--c) 22%,transparent);box-shadow:0 0 16px color-mix(in srgb,var(--c) 30%,transparent)}
.scard h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:8px}
.scard p{color:var(--text3);font-size:.875rem;line-height:1.6;margin-bottom:16px}
.scard-link{color:var(--primary);font-size:.82rem;font-weight:600;transition:color .2s}
.scard:hover .scard-link{color:var(--secondary)}

/* ══ INDUSTRIES GRID (HOME) ══ */
.ind-grid-home{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.ind-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:18px 12px;text-align:center;text-decoration:none;transition:var(--transition);display:flex;flex-direction:column;align-items:center;gap:8px}
.ind-icon{font-size:1.6rem}
.ind-name{font-size:.78rem;font-weight:600;color:var(--text2);line-height:1.3}
.ind-card:hover{border-color:var(--c);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08)}

/* ══ ABOUT ══ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-vis{position:relative;height:400px;display:flex;align-items:center;justify-content:center}
.about-blob{width:300px;height:300px;background:radial-gradient(circle,rgba(79,70,229,.08) 0%,rgba(124,58,237,.05) 50%,transparent 70%);border-radius:50%;animation:blobP 7s ease-in-out infinite}
@keyframes blobP{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.astat-card{position:absolute;bottom:16px;right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px 24px;box-shadow:var(--shadow-md)}
.arow{display:flex;flex-direction:column}
.anum{font-size:1.7rem;font-weight:800;color:var(--text)}
.albl{font-size:.75rem;color:var(--text4)}
.astat-card hr{border:none;border-top:1px solid var(--border);margin:12px 0}
.atech{position:absolute;top:16px;left:0;display:flex;flex-wrap:wrap;gap:6px;max-width:190px}
.atech span{font-size:.72rem;font-weight:600;padding:4px 10px;background:#fff;border:1px solid var(--border);border-radius:99px;color:var(--primary)}
.about-text h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:18px}
.about-text>p{color:var(--text3);margin-bottom:28px;line-height:1.75}
.about-pts{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.apt{display:flex;gap:12px;align-items:flex-start;font-size:.92rem;color:var(--text3);line-height:1.6}
.apt-dot{color:var(--primary);font-size:.7rem;margin-top:4px;flex-shrink:0}
.apt strong{color:var(--text)}

/* ══ PROCESS ══ */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.proc-step{text-align:center;padding:0 8px}
.pnum{display:block;font-size:.72rem;font-weight:700;color:var(--primary);letter-spacing:.1em;margin-bottom:10px}
.pico{width:68px;height:68px;border-radius:50%;background:#fff;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin:0 auto 18px;transition:var(--transition);position:relative;z-index:1}
.proc-step:hover .pico{border-color:var(--primary);box-shadow:0 0 20px rgba(79,70,229,.2);transform:scale(1.05)}
.proc-step h3{font-size:.95rem;font-weight:700;margin-bottom:8px}
.proc-step p{color:var(--text3);font-size:.85rem;line-height:1.6}

/* ══ STATS ══ */
.stats-section{background:linear-gradient(135deg,#4F46E5,#7C3AED);padding:72px 0}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.stat-item{text-align:center}
.snum{font-size:clamp(2.5rem,5vw,3.2rem);font-weight:800;color:#fff;display:inline-block}
.splus{font-size:1.8rem;font-weight:800;color:rgba(255,255,255,.8)}
.stat-item p{color:rgba(255,255,255,.7);font-size:.875rem;margin-top:4px}

/* ══ ABOUT VISUAL — Rich orbital panel ══ */
.av-wrap{
  position:relative; width:100%; height:400px;
  display:flex; align-items:center; justify-content:center;
}
.av-ring{
  position:absolute; border-radius:50%; border:1.5px solid;
  top:50%; left:50%; transform:translate(-50%,-50%);
}
.av-r1{width:280px;height:280px;border-color:rgba(79,70,229,.18);animation:ringR 22s linear infinite}
.av-r2{width:360px;height:360px;border-color:rgba(124,58,237,.1);animation:ringR 30s linear reverse infinite}
.av-r3{width:440px;height:440px;border-color:rgba(14,165,233,.07);animation:ringR 40s linear infinite}
.av-logo{
  width:88px;height:88px;border-radius:24px;
  background:linear-gradient(135deg,#4F46E5,#7C3AED);
  display:flex;align-items:center;justify-content:center;
  font-size:2.2rem;font-weight:800;color:#fff;
  box-shadow:0 16px 56px rgba(79,70,229,.45);
  position:relative;z-index:2;
  animation:av-pulse 3s ease-in-out infinite;
}
@keyframes av-pulse{0%,100%{box-shadow:0 16px 56px rgba(79,70,229,.45)}50%{box-shadow:0 20px 72px rgba(79,70,229,.65),0 0 0 16px rgba(79,70,229,.06)}}
.av-card{
  position:absolute;background:#fff;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:10px 16px;
  box-shadow:0 8px 32px rgba(0,0,0,.1);
  display:flex;flex-direction:column;align-items:center;
  white-space:nowrap;z-index:3;
  animation:av-float 4s ease-in-out infinite;
}
.av-card strong{font-size:1.2rem;font-weight:800;color:var(--primary);line-height:1.1}
.av-card span{font-size:.7rem;color:var(--text3);font-weight:500}
.av-c1{top:8%;left:8%;animation-delay:0s}
.av-c2{top:8%;right:8%;animation-delay:.8s}
.av-c3{bottom:18%;left:4%;animation-delay:1.6s}
.av-c4{bottom:18%;right:4%;animation-delay:2.4s}
@keyframes av-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.av-tech{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;
}
.av-tech span{
  font-size:.72rem;font-weight:600;padding:5px 13px;border-radius:99px;
  background:var(--primary-light);color:var(--primary);
  border:1px solid rgba(79,70,229,.2);
}

/* ══ TESTIMONIALS — Infinite marquee ══ */
.testi-section{overflow:hidden;padding-bottom:88px}
.tmarquee-wrap{overflow:hidden;margin-bottom:20px;mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent)}
.tmarquee-track{
  display:flex;gap:20px;width:max-content;
}
.tmarquee-wrap .tmarquee-track{animation:tscroll-left 48s linear infinite}
@keyframes tscroll-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Card — JS-driven center zoom via rAF */
.tcard{
  min-width:320px;max-width:320px;
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--radius);padding:24px;flex-shrink:0;
  transform:scale(0.94);transform-origin:center;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.tstars{color:#f59e0b;font-size:.88rem;letter-spacing:2px;margin-bottom:10px}
.tcard p{color:var(--text3);font-size:.86rem;line-height:1.7;margin-bottom:16px;font-style:italic}
.tauthor{display:flex;align-items:center;gap:10px}
.tavatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:#fff;flex-shrink:0}
.ta-purple{background:linear-gradient(135deg,#4F46E5,#7C3AED)}
.ta-blue{background:linear-gradient(135deg,#0EA5E9,#4F46E5)}
.ta-green{background:linear-gradient(135deg,#10B981,#0EA5E9)}
.ta-orange{background:linear-gradient(135deg,#F59E0B,#EF4444)}
.ta-teal{background:linear-gradient(135deg,#14B8A6,#10B981)}
.tauthor strong{display:block;font-size:.86rem;font-weight:700;color:var(--text)}
.tauthor small{font-size:.72rem;color:var(--text4)}

/* ══ WHAT WE DO — highlight strip ══ */
.wwd-section{padding-bottom:0}
.wwd-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  width:100%;
}
.wwd-item{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:28px 24px;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.wwd-item:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(79,70,229,.1);border-color:rgba(79,70,229,.25)}
.wwd-ico{font-size:2rem;margin-bottom:14px;line-height:1}
.wwd-item h4{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:8px}
.wwd-item p{font-size:.88rem;color:var(--text3);line-height:1.65}
@media(max-width:900px){.wwd-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.wwd-grid{grid-template-columns:1fr}}

/* ══ CTA STRIP ══ */
.cta-strip{background:linear-gradient(135deg,#4F46E5,#7C3AED);padding:64px 0}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.cta-inner h2{font-size:clamp(1.5rem,3vw,2.2rem);color:#fff;margin-bottom:8px}
.cta-inner p{color:rgba(255,255,255,.75);font-size:.95rem}
.cta-btns{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}
/* Fix: .gtext is invisible on the purple CTA gradient — override with gold */
.cta-strip .gtext{background:linear-gradient(135deg,#fcd34d,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
/* Fix: .btn-outline-light — stronger border so it reads clearly */
.btn-outline-light{border-color:rgba(255,255,255,.65)}

/* ══ PAGE HERO ══ */
.page-hero{padding:72px 0 64px;background:var(--bg-dark);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(79,70,229,.15),transparent 60%)}
.plain-hero{background:linear-gradient(135deg,var(--bg-dark) 0%,var(--bg-dark2) 100%)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2rem,4.5vw,3.2rem);color:#f8faff;margin-bottom:14px}
.ph-sub{color:#94a3b8;font-size:1.05rem;max-width:560px;line-height:1.7;margin-bottom:4px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.8rem;color:#64748b;margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:#64748b;text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:#a5b4fc}
.breadcrumb span{color:#475569}

/* Page hero with stats */
.ph-content{display:flex;align-items:flex-start;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-top:18px}
.ph-icon{width:64px;height:64px;border-radius:16px;border:1px solid;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:18px}
.ph-btns{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.ph-stats{display:inline-flex;gap:0;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:20px 28px;margin-top:28px;flex-wrap:wrap}
.phstat{text-align:center;padding:0 20px}
.phnum{display:block;font-size:1.6rem;font-weight:800;color:#f8faff}
.phlbl{font-size:.72rem;color:#64748b}
.phstat+.phstat{border-left:1px solid rgba(255,255,255,.1)}

/* ══ SERVICE DETAIL PAGE ══ */
.detail-grid{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start}
.detail-main h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:16px}
.detail-main h3{font-size:1.1rem;font-weight:700;margin:36px 0 16px;color:var(--text)}
.detail-desc{color:var(--text3);line-height:1.75;margin-bottom:8px;font-size:1rem}
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.feat-item{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--text2);padding:10px 14px;background:var(--bg-alt);border-radius:var(--radius-sm)}
.fcheck{font-weight:700;font-size:.9rem;flex-shrink:0}
.process-list{display:flex;flex-direction:column;gap:10px}
.proc-item{display:flex;align-items:center;gap:14px;font-size:.92rem;color:var(--text2);padding:12px 16px;background:var(--bg-alt);border-radius:var(--radius-sm)}
.proc-num{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:#fff;flex-shrink:0}
.use-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.use-item{font-size:.875rem;color:var(--text2);display:flex;align-items:center;gap:8px;padding:8px 0}
.ps-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:24px 0}
.ps-card{padding:20px;border-radius:var(--radius-sm);border:1.5px solid var(--border)}
.ps-problem{background:#fff5f5;border-color:#fecaca}
.ps-solution{background:#f0fdf4;border-color:#bbf7d0}
.ps-card h4{font-size:.9rem;font-weight:700;margin-bottom:10px;color:var(--text)}
.ps-card p{font-size:.875rem;color:var(--text3);line-height:1.65}
.results-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}
.result-item{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text2);padding:10px 16px;background:color-mix(in srgb,var(--c) 6%,transparent);border:1px solid color-mix(in srgb,var(--c) 15%,transparent);border-radius:var(--radius-sm)}
.result-item span{color:var(--c);flex-shrink:0}

/* Sidebar */
.detail-sidebar{display:flex;flex-direction:column;gap:20px}
.sidebar-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:24px}
.sidebar-card h4{font-size:.9rem;font-weight:700;margin-bottom:14px;color:var(--text)}
.tech-tags{display:flex;flex-wrap:wrap;gap:8px}
.ttag{font-size:.75rem;font-weight:600;padding:5px 12px;border-radius:99px;background:color-mix(in srgb,var(--c) 10%,transparent);border:1px solid color-mix(in srgb,var(--c) 20%,transparent);color:var(--c)}
.sidebar-cta{background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:var(--radius);padding:24px;color:#fff}
.sidebar-cta h4{color:#fff;font-size:.95rem;margin-bottom:8px}
.sidebar-cta p{color:rgba(255,255,255,.8);font-size:.85rem;margin-bottom:18px}
.sidebar-cta .btn-primary{background:#fff;color:var(--primary);box-shadow:none}
.sidebar-cta .btn-primary:hover{background:#f0f0ff}
.sidebar-cta .btn-outline{border-color:rgba(255,255,255,.4);color:#fff}
.sidebar-cta .btn-outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}
.rel-list{list-style:none;display:flex;flex-direction:column;gap:4px}
.rel-list a{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;color:var(--text2);font-size:.84rem;transition:.2s}
.rel-list a:hover{background:var(--primary-light);color:var(--primary)}

/* ══ CATEGORY PAGE ══ */
.cat-desc{font-size:1.05rem;color:var(--text2);line-height:1.75;margin-bottom:20px;max-width:700px}
.cat-features{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:48px}
.cf-tag{font-size:.8rem;font-weight:600;padding:6px 14px;border-radius:99px;background:color-mix(in srgb,var(--c) 8%,transparent);border:1px solid color-mix(in srgb,var(--c) 20%,transparent);color:color-mix(in srgb,var(--c) 80%,var(--text))}
.sub-h2{font-size:1.8rem;margin-bottom:32px;color:var(--text)}
.cat-section{margin-bottom:64px;padding-bottom:64px;border-bottom:1px solid var(--border)}
.cat-section:last-child{border-bottom:none;margin-bottom:0}
.cat-section-hd{display:flex;align-items:center;gap:20px;margin-bottom:32px}
.cat-icon-lg{width:56px;height:56px;border-radius:14px;background:color-mix(in srgb,var(--c) 12%,transparent);border:1px solid color-mix(in srgb,var(--c) 25%,transparent);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.cat-section-hd h2{font-size:1.5rem;margin-bottom:4px}
.cat-section-hd h2 a{color:var(--text);text-decoration:none}
.cat-section-hd h2 a:hover{color:var(--primary)}
.cat-section-hd p{color:var(--text3);font-size:.9rem}

/* ══ INDUSTRIES PAGE ══ */
.industries-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ind-full-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:28px;text-decoration:none;transition:var(--transition);display:block;position:relative;overflow:hidden}
.ind-full-card::before{content:'';position:absolute;top:-1px;left:0;right:0;height:3px;background:var(--c);opacity:0;transition:opacity var(--transition)}
.ind-full-card:hover{border-color:color-mix(in srgb,var(--c) 30%,transparent);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.ind-full-card:hover::before{opacity:1}
.ifc-icon{font-size:2rem;margin-bottom:14px;display:block}
.ind-full-card h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:8px}
.ind-full-card p{color:var(--text3);font-size:.875rem;line-height:1.6;margin-bottom:12px}
.ifc-stats{margin-bottom:12px}
.ifc-stats span{font-size:.8rem;color:var(--text4)}
.ifc-stats strong{color:var(--c)}
.ifc-link{font-size:.82rem;font-weight:600;color:var(--c)}

/* ══ ABOUT PAGE ══ */
.about-page-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:start}
.value-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.vcard{background:var(--bg-alt);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:20px}
.vico{font-size:1.4rem;margin-bottom:10px}
.vcard h4{font-size:.9rem;font-weight:700;margin-bottom:6px}
.vcard p{font-size:.82rem;color:var(--text3)}
.about-num-stack{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.astat-big{background:linear-gradient(135deg,var(--primary-light),#fff);border:1.5px solid rgba(79,70,229,.15);border-radius:var(--radius);padding:24px;text-align:center}
.asn{display:block;font-size:2.2rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.asl{font-size:.82rem;color:var(--text3);font-weight:500}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.team-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:28px;text-align:center;transition:var(--transition)}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.team-av{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:#fff;margin:0 auto 14px}
.team-card h4{font-size:.95rem;font-weight:700;margin-bottom:4px;color:var(--text)}
.team-card p{font-size:.82rem;color:var(--text3)}
.timeline{display:flex;flex-direction:column;gap:0;max-width:700px;margin:0 auto;position:relative}
.timeline::before{content:'';position:absolute;left:108px;top:0;bottom:0;width:1px;background:var(--border)}
.tl-item{display:flex;align-items:flex-start;gap:24px;padding:24px 0;position:relative}
.tl-yr{font-size:.85rem;font-weight:700;color:var(--primary);min-width:80px;padding-top:4px}
.tl-dot{width:12px;height:12px;border-radius:50%;background:var(--primary);border:2px solid #fff;box-shadow:0 0 0 2px var(--primary);flex-shrink:0;margin-top:6px;position:relative;z-index:1}
.tl-text h4{font-size:.95rem;font-weight:700;margin-bottom:4px}
.tl-text p{font-size:.875rem;color:var(--text3)}

/* ══ CONTACT PAGE ══ */
.contact-pg-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
.contact-pg-grid h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:16px}
.contact-pg-grid>div>p{color:var(--text3);margin-bottom:32px}
.cdetails{display:flex;flex-direction:column;gap:16px}
.cditem{display:flex;align-items:center;gap:14px}
.cdico{font-size:1.1rem}
.cditem>div{display:flex;flex-direction:column}
.cditem strong{font-size:.85rem;font-weight:700;color:var(--text)}
.cditem span{font-size:.85rem;color:var(--text3)}
.social-links{display:flex;gap:8px;flex-wrap:wrap}
.social-link{width:38px;height:38px;border-radius:50%;background:var(--bg-alt);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:.78rem;font-weight:700;text-decoration:none;transition:var(--transition)}
.social-link:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:translateY(-2px)}

/* ══ FORMS ══ */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fgroup{display:flex;flex-direction:column;gap:7px}
.fgroup input::placeholder,.fgroup textarea::placeholder{color:var(--text4)}
.fgroup select{cursor:pointer}

/* ══ ENQUIRY PAGE ══ */
.enquiry-wrap{display:grid;grid-template-columns:1fr 280px;gap:48px;align-items:start}
.eq-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:16px}
.eq-card h4{font-size:.95rem;font-weight:700;margin-bottom:14px}
.eq-steps{padding-left:18px;display:flex;flex-direction:column;gap:8px}
.eq-steps li{font-size:.875rem;color:var(--text3)}
.eq-card p{font-size:.875rem;color:var(--text3);margin-bottom:6px}
.eq-card strong{font-size:1rem;color:var(--primary)}

/* ══ BLOG PAGE ══ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-img{height:180px;display:flex;align-items:center;justify-content:center;position:relative}
.blog-ico{font-size:2.5rem}
.blog-tag{position:absolute;top:12px;left:12px;font-size:.7rem;font-weight:700;color:#fff;padding:4px 10px;border-radius:99px}
.blog-body{padding:20px}
.blog-body h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.4}
.blog-body p{font-size:.84rem;color:var(--text3);line-height:1.6;margin-bottom:12px}
.blog-meta{display:flex;gap:16px;font-size:.75rem;color:var(--text4)}

/* ══ PORTFOLIO PAGE ══ */
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  width:100%;
}
.pcard{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.pcard-img{height:200px;position:relative;display:flex;align-items:flex-start;justify-content:space-between;padding:16px}
.pcard-tag,.pcard-result{font-size:.72rem;font-weight:700;color:#fff;padding:4px 10px;border-radius:99px;backdrop-filter:blur(8px)}
.pcard-tag{background:rgba(0,0,0,.35)}
.pcard-result{background:rgba(16,185,129,.75)}
.pcard-body{padding:20px}
.pcard-body h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:8px}
.pcard-body p{font-size:.84rem;color:var(--text3);margin-bottom:12px}
.ptags{display:flex;gap:6px;flex-wrap:wrap}
.ptags span{font-size:.72rem;font-weight:600;background:var(--primary-light);color:var(--primary);padding:3px 10px;border-radius:99px}

/* ══ 404 PAGE ══ */
.error-page{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 24px}
.error-code{font-size:8rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:16px}
.error-page h1{font-size:2rem;margin-bottom:12px}
.error-page p{color:var(--text3)}


/* ══ SEARCH OVERLAY ══ */
.search-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:2000;backdrop-filter:blur(8px);align-items:flex-start;justify-content:center;padding-top:80px}
.search-overlay.open{display:flex}
.search-container{width:100%;max-width:640px;padding:0 24px;position:relative}
.search-big-input{width:100%;background:#fff;border:2px solid var(--primary);border-radius:var(--radius);padding:16px 52px 16px 20px;font-size:1.1rem;font-family:var(--font);color:var(--text);outline:none}
.search-close{position:absolute;right:32px;top:14px;background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text3)}
.search-results{background:#fff;border-radius:var(--radius);margin-top:8px;overflow:hidden;box-shadow:var(--shadow-md)}
.sr-item{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);text-decoration:none;transition:.15s}
.sr-item:last-child{border-bottom:none}
.sr-item:hover{background:var(--primary-light)}
.sr-item span:first-child{font-size:.9rem;color:var(--text);font-weight:500}
.sr-tag{font-size:.72rem;font-weight:600;padding:2px 8px;background:var(--bg-alt);color:var(--text3);border-radius:99px}

/* ══ RESPONSIVE ══ */
@media(max-width:1024px){
  .services-grid,.services-grid.lg{grid-template-columns:repeat(2,1fr)}
  .ind-grid-home{grid-template-columns:repeat(4,1fr)}
  .about-grid,.about-page-grid,.contact-pg-grid{grid-template-columns:1fr;gap:40px}
  .about-vis{display:none}
  .detail-grid{grid-template-columns:1fr}
  .ph-content{flex-direction:column}
  .ph-stats{display:flex;width:100%}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:32px}
  .tcard{min-width:calc(50% - 10px)}
  .industries-full-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .enquiry-wrap{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
  .about-num-stack{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:640px){

  .section{
    padding:60px 0;
  }

  .services-grid,
  .services-grid.lg{
    grid-template-columns:1fr;
  }

  .ind-grid-home{
    grid-template-columns:repeat(3,1fr);
  }

  .ps-grid,
  .feat-grid,
  .use-grid{
    grid-template-columns:1fr;
  }

  .tcard{
    min-width:100%;
  }

  .stats-row{
    grid-template-columns:1fr 1fr;
  }

  .portfolio-grid,
  .blog-grid,
  .industries-full-grid{
    grid-template-columns:1fr;
  }

  .team-grid{
    grid-template-columns:1fr;
  }

  .frow{
    grid-template-columns:1fr;
  }

  .cta-inner{
    flex-direction:column;
    text-align:center;
  }

  .footer-grid{
    grid-template-columns:1fr;
  }

  .trust-row{
    justify-content:center;
  }

  .tdiv{
    display:none;
  }

  .tbadge{
    padding:0 10px;
  }

  .hero-visual{
    display:none;
  }

  .process-grid{
    grid-template-columns:1fr 1fr;
  }

  /* ===== FIXED PH STATS ===== */

  .ph-stats{
    display:flex !important;
    flex-wrap:nowrap !important;
    justify-content:space-between !important;
    align-items:center !important;
    gap:0 !important;
    width:100% !important;
  }

  .phstat{
    flex:1 1 33.33% !important;
    width:33.33% !important;
    max-width:33.33% !important;
    min-width:0 !important;
    text-align:center !important;
    padding:0 6px !important;
    border-top:none !important;
  }

  .phstat + .phstat{
    border-left:1px solid rgba(255,255,255,.1) !important;
    border-top:none !important;
  }

  .phnum{
    display:block !important;
    font-size:18px !important;
    line-height:1 !important;
    margin-bottom:6px !important;
    white-space:nowrap !important;
  }

  .phlbl{
    display:block !important;
    font-size:9px !important;
    line-height:1.2 !important;
    white-space:normal !important;
  }

}

/* Footer */
.footer{background:var(--bg-dark);padding:64px 0 28px;border-top:1px solid rgba(255,255,255,.05)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .logo{margin-bottom:14px}
.footer-brand .logo-text{color:#fff!important;font-size:1.32rem!important}
.footer-brand p{color:#64748b;font-size:.85rem;line-height:1.7;margin-bottom:20px}
.footer-col h4{font-size:.85rem;font-weight:700;color:#e2e8f0;margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col ul li,.footer-col ul a{font-size:.82rem;color:#64748b;text-decoration:none;transition:color .2s}
.footer-col ul a:hover{color:#a5b4fc}
.footer-badge{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;color:#64748b;margin-top:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:5px 12px;border-radius:99px}
.footer-badge .badge-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;border-top:1px solid rgba(255,255,255,.06);font-size:.78rem;color:#475569;flex-wrap:wrap;gap:8px}

/* ══════════════════════════════════════════════
   COMPANY / ABOUT PAGE — Advanced 3D Design
   ══════════════════════════════════════════════ */

/* ── Hero ── */
.co-hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:var(--bg-dark);padding-top:var(--nav-h)}
#coCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}

/* ── Hero V2 — Robot Centerpiece ── */
.co-hero-v2{padding-top:0;display:block}

/* Spline iframe fills the full section */
.co-robot-hero-wrap{position:absolute;inset:0;z-index:1}
.co-hero-spline-frame{width:100%;height:100%;border:none;display:block}

/* Vignette: dark base at bottom/sides, fades to transparent in centre */
.co-hero-vignette{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(to top,#060C1A 14%,rgba(6,12,26,.72) 38%,transparent 62%),
    linear-gradient(to right,rgba(6,12,26,.78) 0%,transparent 24%),
    linear-gradient(to left,rgba(6,12,26,.78) 0%,transparent 24%),
    linear-gradient(to bottom,rgba(6,12,26,.6) 0%,transparent 18%);
}

/* Hero copy block — centered, pinned to lower third */
.co-hero-content-v2{
  position:absolute;bottom:88px;left:50%;transform:translateX(-50%);
  text-align:center;z-index:3;width:100%;max-width:720px;padding:0 32px;
}
.co-page-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:#a5b4fc;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.22);
  padding:6px 16px;border-radius:99px;margin-bottom:20px;
}
.co-hero-content-v2 h1{
  font-size:clamp(3.2rem,7.5vw,6.4rem);
  font-weight:800;color:#f8faff;
  margin-bottom:18px;letter-spacing:-.03em;line-height:.98;
}
.co-hero-v2-sub{
  color:#94a3b8;font-size:1.05rem;line-height:1.8;
  max-width:520px;margin:0 auto 32px;
}
.co-hero-v2-cta{display:inline-flex;align-items:center;gap:10px}
/* Particles subtler in V2 */
.co-hero-v2 #coCanvas{opacity:.28}

@media(max-width:900px){
  .co-hero-content-v2{bottom:64px;padding:0 24px}
  .co-hero-content-v2 h1{font-size:clamp(2.4rem,9vw,4rem)}
  .co-hero-v2-sub{font-size:.95rem}
}
@media(max-width:540px){
  .co-hero-content-v2{bottom:52px;padding:0 18px}
  .co-hero-content-v2 h1{font-size:clamp(2rem,10vw,3rem)}
  .co-hero-v2-sub{font-size:.88rem;max-width:100%}
}
.co-orb{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.co-orb1{width:600px;height:600px;background:radial-gradient(circle,rgba(79,70,229,.16),transparent 70%);top:-120px;left:-120px;animation:coOrb 16s ease-in-out infinite}
.co-orb2{width:400px;height:400px;background:radial-gradient(circle,rgba(124,58,237,.13),transparent 70%);bottom:-80px;right:100px;animation:coOrb 12s ease-in-out infinite reverse}
.co-orb3{width:300px;height:300px;background:radial-gradient(circle,rgba(14,165,233,.1),transparent 70%);top:30%;left:45%;animation:coOrb 20s ease-in-out infinite 4s}
@keyframes coOrb{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-40px) scale(1.06)}66%{transform:translate(-20px,30px) scale(.94)}}

.co-hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding-top:40px;padding-bottom:60px}
.co-badge{display:inline-flex;align-items:center;gap:8px;font-size:.76rem;font-weight:600;letter-spacing:.08em;color:#a5b4fc;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);padding:6px 14px;border-radius:99px;margin-bottom:22px}
.co-hero-text h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:#f8faff;margin-bottom:18px}
.co-hero-text p{color:#94a3b8;font-size:1.05rem;line-height:1.7;margin-bottom:32px;max-width:500px}
.co-hero-btns{display:flex;gap:14px;flex-wrap:wrap}

/* 3D Hero Card */
.co-hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:360px}
.co-card-3d{width:300px;height:300px;border-radius:24px;background:linear-gradient(140deg,rgba(79,70,229,.25),rgba(124,58,237,.15));border:1px solid rgba(99,102,241,.25);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;position:relative;transition:transform .5s cubic-bezier(.4,0,.2,1);box-shadow:0 32px 64px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.08);cursor:pointer;z-index:2}
.co-card-face{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px;position:relative}
.co-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;margin-bottom:20px}
.ccg-item{text-align:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 10px}
.ccg-num{display:block;font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,#a5b4fc,#67e8f9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ccg-lbl{font-size:.7rem;color:rgba(255,255,255,.55);font-weight:500}
.co-logo-mark{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#4F46E5,#7C3AED);display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;color:#fff;box-shadow:0 8px 24px rgba(79,70,229,.5)}

/* Floating badges */
.co-float-badge{position:absolute;background:rgba(15,22,41,.85);border:1px solid rgba(99,102,241,.2);border-radius:99px;padding:8px 16px;font-size:.78rem;color:#e2e8f0;display:flex;align-items:center;gap:6px;backdrop-filter:blur(12px);white-space:nowrap;animation:coFloat 4s ease-in-out infinite;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.co-float-badge strong{color:#fff}
.f1{top:10%;left:-30px;animation-delay:0s}
.f2{bottom:15%;left:-20px;animation-delay:1.2s}
.f3{top:40%;right:-20px;animation-delay:.7s}
@keyframes coFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* Scroll indicator */
.co-scroll-indicator{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}
.co-scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,transparent,rgba(165,180,252,.5));animation:scrollPulse 2s ease-in-out infinite}
.co-scroll-indicator span{font-size:.68rem;color:#64748b;letter-spacing:.1em;text-transform:uppercase}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}

/* ── Stats Bar ── */
.co-stats-bar{background:var(--bg-dark2);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);padding:0}
.co-stats-robot-wrap{display:grid;grid-template-columns:1fr 360px;align-items:center;min-height:460px}
.co-stats-cols{display:flex;align-items:center;justify-content:space-around;flex-wrap:wrap;gap:20px;padding:48px 40px 48px 0}
/* keep .co-stats-inner for any other pages that reference it */
.co-stats-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;padding:32px 0}
.co-stat{text-align:center;flex:1;min-width:100px}
.co-snum{font-size:2.4rem;font-weight:800;background:linear-gradient(135deg,#a5b4fc,#67e8f9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}
.co-splus{font-size:1.4rem;font-weight:800;color:#a5b4fc}
.co-stat p{font-size:.8rem;color:#64748b;margin-top:4px}
.co-sdiv{width:1px;height:48px;background:rgba(255,255,255,.07);flex-shrink:0}

/* ── Robot ── */
.co-robot-wrap{position:relative;height:460px;display:flex;align-items:center;justify-content:center;border-left:1px solid rgba(255,255,255,.05)}
.robot-ring{position:absolute;border-radius:50%;border:1px solid;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;animation:robotRingPulse 3.5s ease-in-out infinite}
.rr1{width:300px;height:300px;border-color:rgba(99,102,241,.18);animation-delay:0s}
.rr2{width:400px;height:400px;border-color:rgba(124,58,237,.1);animation-delay:1.2s}
@keyframes robotRingPulse{0%,100%{opacity:.4;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.05)}}
.robot-stage{width:280px;height:360px;border-radius:20px;overflow:hidden;position:relative;z-index:2;border:1px solid rgba(99,102,241,.22);background:#06091a;box-shadow:0 0 40px rgba(79,70,229,.22),0 0 80px rgba(79,70,229,.08),inset 0 1px 0 rgba(255,255,255,.05);transition:box-shadow .4s ease,transform .4s cubic-bezier(.4,0,.2,1);cursor:pointer;transform-style:preserve-3d}
.robot-stage:hover{box-shadow:0 0 60px rgba(99,102,241,.38),0 0 120px rgba(79,70,229,.14),inset 0 1px 0 rgba(255,255,255,.08)}
.robot-stage.robot-clicked{animation:robotBounce .55s cubic-bezier(.4,0,.2,1)}
@keyframes robotBounce{0%{transform:scale(1) translateY(0)}28%{transform:scale(1.05) translateY(-8px)}60%{transform:scale(.97) translateY(3px)}100%{transform:scale(1) translateY(0)}}
.spline-robot{width:100%;height:100%;border:none;display:block;pointer-events:all}
.robot-scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(99,102,241,.025) 3px,rgba(99,102,241,.025) 4px);pointer-events:none;z-index:3}
.robot-bubble{position:absolute;top:-10px;right:-10px;background:linear-gradient(135deg,#4F46E5,#7C3AED);color:#fff;font-size:.75rem;font-weight:600;padding:7px 13px;border-radius:99px;white-space:nowrap;z-index:10;opacity:0;transform:translateY(8px) scale(.9);transition:opacity .35s ease,transform .35s cubic-bezier(.4,0,.2,1);pointer-events:none;box-shadow:0 4px 16px rgba(79,70,229,.45);display:flex;align-items:center;gap:6px}
.robot-bubble.visible{opacity:1;transform:translateY(0) scale(1)}
.rb-dot{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 6px #34d399;flex-shrink:0;animation:bpulse 2s infinite}
.robot-label{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:6px;font-size:.68rem;font-weight:600;color:#475569;letter-spacing:.06em;z-index:4;white-space:nowrap}
.robot-led{width:6px;height:6px;border-radius:50%;background:#10b981;box-shadow:0 0 8px #10b981;flex-shrink:0;animation:bpulse 2s infinite}

/* ── Mission/Vision Cards ── */
.co-mv-section{background:#fff}
.co-mv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.co-mv-card{background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:32px;position:relative;overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition);transform-style:preserve-3d}
.co-mv-card:hover{border-color:rgba(79,70,229,.25);box-shadow:0 20px 60px rgba(79,70,229,.1)}
.co-mv-card-inner{position:relative;z-index:1}
.co-mv-icon{font-size:2.4rem;margin-bottom:16px;display:block}
.co-mv-card h3{font-size:1.15rem;font-weight:800;color:var(--text);margin-bottom:12px}
.co-mv-card p{color:var(--text3);font-size:.9rem;line-height:1.7;margin-bottom:18px}
.co-mv-pts{list-style:none;display:flex;flex-direction:column;gap:8px}
.co-mv-pts li{font-size:.85rem;color:var(--text2);display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--bg-alt);border-radius:8px}
.co-mv-pts li::before{content:'✦';color:var(--primary);font-size:.65rem;flex-shrink:0}
.co-mv-glow{position:absolute;bottom:-60px;right:-60px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(79,70,229,.08),transparent 70%);pointer-events:none;transition:opacity var(--transition)}
.co-mv-card:hover .co-mv-glow{opacity:2}

/* ── Why Choose Us ── */
.co-why-section{background:var(--bg-alt)}
.co-why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.co-why-card{background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:28px;position:relative;overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition);transform-style:preserve-3d}
.co-why-card:hover{border-color:color-mix(in srgb,var(--wc) 35%,transparent);box-shadow:0 16px 48px rgba(0,0,0,.09)}
.co-why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--wc);opacity:0;transition:opacity .3s}
.co-why-card:hover::before{opacity:1}
.co-why-ico{font-size:2rem;margin-bottom:14px;display:block}
.co-why-card h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:8px}
.co-why-card p{color:var(--text3);font-size:.875rem;line-height:1.65;margin-bottom:16px}
.co-why-bar{height:2px;border-radius:99px;background:var(--wc);width:0;transition:width .4s ease}
.co-why-card:hover .co-why-bar{width:48px}

/* ── Team ── */
.co-team-section{background:#fff}
.co-team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.co-team-card{background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:28px;text-align:center;transition:border-color var(--transition),box-shadow var(--transition);transform-style:preserve-3d;position:relative;overflow:hidden}
.co-team-card:hover{border-color:rgba(79,70,229,.2);box-shadow:0 20px 50px rgba(0,0,0,.1)}
.co-team-av{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;margin:0 auto 14px;box-shadow:0 8px 24px rgba(0,0,0,.2)}
.co-team-card h4{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:4px}
.co-team-role{font-size:.8rem;color:var(--primary);font-weight:600;margin-bottom:12px}
.co-team-quote{font-size:.8rem;color:var(--text3);line-height:1.6;font-style:italic;margin-bottom:16px;padding:10px 14px;background:var(--bg-alt);border-radius:8px;border-left:3px solid rgba(79,70,229,.3)}
.co-team-socials{display:flex;gap:8px;justify-content:center}
.co-team-socials a{width:32px;height:32px;border-radius:8px;background:var(--bg-alt);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--text3);text-decoration:none;transition:var(--transition)}
.co-team-socials a:hover{background:var(--primary);border-color:var(--primary);color:#fff}

/* ── Timeline ── */
.co-timeline-section{background:var(--bg-alt)}
.co-timeline{position:relative;max-width:800px;margin:0 auto}
.co-tl-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent,var(--border) 10%,var(--border) 90%,transparent);transform:translateX(-50%)}
.co-tl-item{display:flex;align-items:flex-start;gap:24px;padding:0 0 48px;position:relative}
.co-tl-item.tl-left{flex-direction:row-reverse;text-align:right}
.co-tl-item.tl-left .co-tl-content{margin-right:calc(50% + 36px);margin-left:0}
.co-tl-item.tl-right .co-tl-content{margin-left:calc(50% + 36px)}
.co-tl-dot{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;position:absolute;left:50%;transform:translateX(-50%);box-shadow:0 0 0 4px #fff,0 4px 16px rgba(79,70,229,.3);z-index:2;transition:transform .3s,box-shadow .3s}
.co-tl-item.tl-visible .co-tl-dot{transform:translateX(-50%) scale(1.1)}
.co-tl-content{background:#fff;border:1.5px solid var(--border);border-radius:16px;padding:20px 24px;max-width:calc(50% - 60px);transition:border-color .3s,box-shadow .3s}
.co-tl-item.tl-visible .co-tl-content{border-color:rgba(79,70,229,.2);box-shadow:0 8px 32px rgba(79,70,229,.08)}
.co-tl-yr{font-size:.72rem;font-weight:700;color:var(--primary);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;display:block}
.co-tl-content h4{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:6px}
.co-tl-content p{font-size:.84rem;color:var(--text3);line-height:1.6}

/* Slide-in for timeline */
.co-tl-item.tl-left{opacity:0;transform:translateX(40px)}
.co-tl-item.tl-right{opacity:0;transform:translateX(-40px)}
.co-tl-item.tl-left.tl-visible{opacity:1;transform:translateX(0);transition:opacity .25s ease,transform .25s ease}
.co-tl-item.tl-right.tl-visible{opacity:1;transform:translateX(0);transition:opacity .25s ease,transform .25s ease}

/* ── Responsive ── */
@media(max-width:1024px){
  .co-hero-inner{grid-template-columns:1fr;gap:40px;text-align:center}
  .co-hero-text p{margin:0 auto 32px}
  .co-hero-btns{justify-content:center}
  .co-hero-visual{display:none}
  .co-mv-grid,.co-why-grid,.co-team-grid{grid-template-columns:1fr 1fr}
  .co-stats-robot-wrap{grid-template-columns:1fr;min-height:unset}
  .co-stats-cols{padding:32px 0;justify-content:center}
  .co-robot-wrap{height:380px;border-left:none;border-top:1px solid rgba(255,255,255,.05)}
  .co-stats-inner{justify-content:center;gap:16px}
  .co-sdiv{display:none}
}
@media(max-width:640px){
  .co-mv-grid,.co-why-grid,.co-team-grid{grid-template-columns:1fr}
  .co-tl-line{left:24px}
  .co-tl-item,.co-tl-item.tl-left{flex-direction:column;text-align:left}
  .co-tl-item.tl-left .co-tl-content,.co-tl-item.tl-right .co-tl-content{margin:0;max-width:100%;padding-left:64px}
  .co-tl-dot{left:24px}
  .co-stats-inner{display:grid!important;grid-template-columns:1fr 1fr;gap:20px}
  .co-sdiv{display:none}
  .co-stat{min-width:unset;flex:unset}
}

/* ══════════════════════════════════════════════
   ABOUT PAGE — Dark-Glass Theme
   (body.about-page scoped — no other page affected)
   ══════════════════════════════════════════════ */

/* Page background — shows fixed robot through glass layers */
body.about-page{background:var(--bg-dark)!important}

/* ── Fixed robot — full-viewport persistent background ── */
/*
  LAYERING STRATEGY
  ─────────────────
  Robot (z-index:1, pointer-events:auto)
    → receives mouse events wherever content sections have none/glass gaps
  Sections (z-index:2, pointer-events:none on CONTAINER)
    → containers are visually above robot but transparent to mouse
    → children (cards, buttons, links) retain default pointer-events:auto
      so they ARE interactive; empty glass areas pass through to robot
  CTA strip + footer (z-index:2, pointer-events:auto — fully solid)
  Navbar (z-index:1000, unchanged)
*/
.co-fixed-robot{
  position:fixed;top:-4%;left:-4%;width:108%;height:108%;
  z-index:1;pointer-events:auto;will-change:transform;
  transition:transform .08s linear;
}
.co-fixed-robot-frame{width:100%;height:100%;border:none;display:block}

/* ── Stacking: content above robot, pass-through in empty/glass areas ── */

/* Section CONTAINERS: z-index:2 (above robot), pointer-events:none
   → mouse falls to robot in transparent/glass gaps between cards
   → children (cards, buttons, links) keep default pointer-events:auto — still interactive */
body.about-page .co-hero-v2,
body.about-page .co-stats-bar,
body.about-page .co-mv-section,
body.about-page .co-why-section,
body.about-page .co-team-section,
body.about-page .co-timeline-section{
  position:relative;z-index:2;pointer-events:none;
}

/* CTA strip + footer: solid sections, keep fully interactive */
body.about-page .cta-strip,
body.about-page footer{position:relative;z-index:2;pointer-events:auto}

/* Explicitly re-enable on interactive children just to be explicit */
body.about-page .co-mv-card,
body.about-page .co-why-card,
body.about-page .co-team-card,
body.about-page .co-tl-content,
body.about-page .co-hero-content-v2,
body.about-page .co-stats-inner{pointer-events:auto}

/* ── Hero: transparent — robot shows straight through ── */
body.about-page .co-hero-v2{background:transparent}
body.about-page .co-hero-v2 #coCanvas{opacity:.2}

/* ── Stats bar: semi-opaque — faint glass over robot ── */
body.about-page .co-stats-bar{
  background:rgba(6,12,26,.82);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  padding:32px 0;
}
body.about-page .co-stats-inner{padding:0}

/* ── Section heading overrides (dark bg) ── */
body.about-page .section-hd h2{color:#f1f5f9}
body.about-page .section-hd p{color:#94a3b8}
body.about-page .stag{background:rgba(99,102,241,.14);color:#a5b4fc;border-color:rgba(99,102,241,.25)}

/* ── Mission / Vision — opaque glass, robot barely peeks ── */
body.about-page .co-mv-section{
  background:rgba(6,12,26,.86)!important;
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}
body.about-page .co-mv-card{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.1);
  box-shadow:0 4px 24px rgba(0,0,0,.3);
}
body.about-page .co-mv-card:hover{border-color:rgba(99,102,241,.35);box-shadow:0 20px 60px rgba(79,70,229,.18)}
body.about-page .co-mv-card h3{color:#f1f5f9}
body.about-page .co-mv-card p{color:#94a3b8}
body.about-page .co-mv-pts li{background:rgba(255,255,255,.05);color:#cbd5e1;border:none}
body.about-page .co-mv-pts li::before{color:#a5b4fc}

/* ── Why Choose Us — slightly more transparent, robot visible ── */
body.about-page .co-why-section{
  background:rgba(6,12,26,.74)!important;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
body.about-page .co-why-card{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.1);
}
body.about-page .co-why-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.4)}
body.about-page .co-why-card h3{color:#f1f5f9}
body.about-page .co-why-card p{color:#94a3b8}

/* ── Team ── */
body.about-page .co-team-section{
  background:rgba(6,12,26,.86)!important;
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}
body.about-page .co-team-card{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.1);
}
body.about-page .co-team-card:hover{border-color:rgba(99,102,241,.3);box-shadow:0 20px 50px rgba(0,0,0,.4)}
body.about-page .co-team-card h4{color:#f1f5f9}
body.about-page .co-team-role{color:#a5b4fc}
body.about-page .co-team-quote{background:rgba(255,255,255,.05);border-left-color:rgba(99,102,241,.4);color:#94a3b8}
body.about-page .co-team-socials a{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#94a3b8}
body.about-page .co-team-socials a:hover{background:var(--primary);border-color:var(--primary);color:#fff}

/* ── Timeline ── */
body.about-page .co-timeline-section{
  background:rgba(6,12,26,.78)!important;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
body.about-page .co-tl-content{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.1);
}
body.about-page .co-tl-item.tl-visible .co-tl-content{border-color:rgba(99,102,241,.3);box-shadow:0 8px 32px rgba(79,70,229,.15)}
body.about-page .co-tl-content h4{color:#f1f5f9}
body.about-page .co-tl-content p{color:#94a3b8}
body.about-page .co-tl-line{background:linear-gradient(to bottom,transparent,rgba(255,255,255,.1) 10%,rgba(255,255,255,.1) 90%,transparent)}
body.about-page .co-tl-dot{box-shadow:0 0 0 4px rgba(6,12,26,.9),0 4px 16px rgba(79,70,229,.4)}

/* ── CTA strip keeps its purple gradient ── */
/* already styled globally, no override needed */

/* ══════════════════════════════════════════════
   PAGE HERO — Enhanced (blobs + wave divider)
   ══════════════════════════════════════════════ */
.ph-enhanced {
  padding-top: 58px;
  padding-bottom: 100px;
}
/* Floating colored circles — solid like reference */
.ph-blob {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  animation: ph-drift 6s ease-in-out infinite alternate;
}
.ph-blob-1 {
  width: 160px; height: 160px;
  background: rgba(255,107,74,.75);
  top: 20%; right: 14%;
  animation-duration: 7s;
}
.ph-blob-2 {
  width: 110px; height: 110px;
  background: rgba(255,179,71,.7);
  top: 15%; right: 22%;
  animation-duration: 9s;
  animation-direction: alternate-reverse;
}
.ph-blob-3 {
  width: 75px; height: 75px;
  background: rgba(255,200,100,.65);
  top: 38%; right: 10%;
  animation-duration: 5s;
}
@keyframes ph-drift {
  from { transform: translateY(0px); }
  to   { transform: translateY(-18px); }
}
/* Gradient mesh overlay */
.ph-mesh {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 20% 60%, rgba(79,70,229,.12), transparent 55%),
    radial-gradient(ellipse at 80% 20%, rgba(124,58,237,.10), transparent 50%);
  pointer-events: none; z-index: 0;
}
/* Stronger h1 on enhanced hero */
.ph-enhanced h1 {
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  line-height: 1.15;
  letter-spacing: -.02em;
}
/* Ghost button adapts for dark hero */
.ph-ghost {
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.25) !important;
  color: #e2e8f0 !important;
}
.ph-ghost:hover {
  background: rgba(255,255,255,.16) !important;
  border-color: rgba(255,255,255,.45) !important;
  color: #fff !important;
}
/* Wave divider */
.ph-wave {
  position: absolute; bottom: 0; left: 0; right: 0;
  line-height: 0; pointer-events: none; z-index: 1;
}
.ph-wave svg { display: block; width: 100%; height: 64px; }

/* Industry hero image layout */
.ph-content--image { align-items: flex-start; flex-wrap: nowrap; gap: 56px; }
.ph-text-col { flex: 1 1 0; min-width: 0; }
.ph-stats--inline { margin-top: 38px; align-self: flex-start; width: fit-content; padding-left: 12px; }
.ph-hero-img-wrap {
  flex: 0 0 460px;
  position: relative;
  z-index: 1;
  margin-right: 80px;
}
.ph-hero-img-inner {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  border: none;
  box-shadow: 0 8px 40px rgba(0,0,0,.5);
  background: #0d0f1a;
}
.ph-hero-img {
  display: block;
  width: 100%;
  height: 420px;
  object-fit: cover;
  object-position: center top;
}
/* fade all four edges into page bg for seamless blend */
.ph-hero-img-inner::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, rgba(13,13,26,.55) 0%, transparent 18%, transparent 55%, rgba(13,13,26,.95) 100%),
    linear-gradient(to left,   transparent 60%, rgba(13,13,26,.85) 100%),
    linear-gradient(to right,  transparent 80%, rgba(13,13,26,.4) 100%),
    linear-gradient(to top,    transparent 85%, rgba(13,13,26,.5) 100%);
  pointer-events: none;
}
@media(max-width:1024px) {
  .ph-content--image { flex-direction: column; flex-wrap: wrap; gap: 36px; }
  .ph-hero-img-wrap { flex: none; width: 100%; max-width: 520px; }
  .ph-stats--inline { width: 100%; }
}
@media(max-width:640px) {
  .ph-hero-img { height: 280px; object-position: center top; }
}

/* ══════════════════════════════════════════════
   FORMS — Premium upgrade
   ══════════════════════════════════════════════ */
.contact-form,.enquiry-form {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 40px;
  box-shadow: 0 8px 40px rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.fgroup input,.fgroup select,.fgroup textarea {
  background: var(--bg-alt);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 13px 16px;
  color: var(--text);
  font-family: var(--font);
  font-size: .92rem;
  transition: border-color .2s, box-shadow .2s, background .2s;
  outline: none;
  resize: vertical;
}
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus {
  border-color: var(--primary);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(79,70,229,.12);
}
.fgroup input:hover,.fgroup select:hover,.fgroup textarea:hover {
  border-color: var(--border2);
}
/* Validation states */
.fgroup input:valid:not(:placeholder-shown),
.fgroup textarea:valid:not(:placeholder-shown) {
  border-color: var(--green);
}
.fgroup input:invalid:not(:placeholder-shown):not(:focus),
.fgroup textarea:invalid:not(:placeholder-shown):not(:focus) {
  border-color: #f87171;
  box-shadow: 0 0 0 3px rgba(248,113,113,.1);
}
.fgroup label {
  font-size: .8rem;
  font-weight: 700;
  color: var(--text2);
  letter-spacing: .01em;
}
/* Submit button full-width pulse on hover */
.enquiry-form .btn-primary,
.contact-form .btn-primary {
  margin-top: 4px;
  padding: 15px 28px;
  font-size: .95rem;
}
.enquiry-form .btn-primary:hover,
.contact-form .btn-primary:hover {
  box-shadow: 0 12px 40px rgba(79,70,229,.45);
}

/* ══════════════════════════════════════════════
   FEAT GRID — Modern icon cards
   ══════════════════════════════════════════════ */
.feat-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 12px;
}
.feat-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 18px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font-size: .88rem;
  color: var(--text2);
  transition: border-color .2s, box-shadow .2s, transform .2s;
  line-height: 1.5;
}
.feat-item:hover {
  border-color: rgba(79,70,229,.3);
  box-shadow: 0 6px 24px rgba(79,70,229,.1);
  transform: translateY(-2px);
}
.fcheck {
  font-weight: 700;
  font-size: 1rem;
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--primary-light);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}

/* ══════════════════════════════════════════════
   PROCESS STEPS — Premium card upgrade
   ══════════════════════════════════════════════ */
.proc-step {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 32px 28px;
  text-align: center;
  position: relative;
  transition: border-color .25s, box-shadow .25s, transform .25s;
  overflow: hidden;
}
.proc-step::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(79,70,229,.04), transparent);
  opacity: 0;
  transition: opacity .25s;
}
.proc-step:hover {
  border-color: rgba(79,70,229,.3);
  box-shadow: 0 12px 48px rgba(79,70,229,.12);
  transform: translateY(-4px);
}
.proc-step:hover::before { opacity: 1; }
.pnum {
  position: absolute;
  top: 16px;
  right: 18px;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--primary);
  opacity: .4;
}
.pico {
  width: 68px;
  height: 68px;
  border-radius: 18px;
  background: var(--primary-light);
  border: 1.5px solid rgba(79,70,229,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.7rem;
  margin: 0 auto 18px;
  transition: transform .25s, box-shadow .25s;
}
.proc-step:hover .pico {
  transform: scale(1.08) rotate(-4deg);
  box-shadow: 0 8px 24px rgba(79,70,229,.2);
}

/* ══════════════════════════════════════════════
   GLOBAL SCROLL + HOVER ANIMATIONS
   ══════════════════════════════════════════════ */
/* Staggered reveal delays */
.reveal[data-delay="100"] { transition-delay: .1s; }
.reveal[data-delay="200"] { transition-delay: .2s; }
.reveal[data-delay="300"] { transition-delay: .3s; }
.reveal[data-delay="400"] { transition-delay: .4s; }

/* Slide-in from sides */
.reveal-left  { opacity:0; transform:translateX(-32px); transition:opacity .65s ease,transform .65s ease; }
.reveal-right { opacity:0; transform:translateX(32px);  transition:opacity .65s ease,transform .65s ease; }
.reveal-left.visible,.reveal-right.visible { opacity:1; transform:translateX(0); }

/* Card hover lift — applied globally */
.services-grid .scard:hover,
.industries-full-grid .ind-full-card:hover,
.blog-card:hover,
.pcard:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0,0,0,.12);
}

/* Button ripple micro-interaction */
.btn-primary::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: rgba(255,255,255,.15);
  opacity: 0;
  transition: opacity .3s;
}
.btn-primary:active::after { opacity: 1; }

/* Nav mega menu fade-slide already in navbar.css — no changes needed */

/* ══════════════════════════════════════════════
   FEATURES SECTION (home) — 3-col layout
   ══════════════════════════════════════════════ */
.features-layout {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 48px;
  align-items: center;
}
.features-col {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.feat-box {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 24px 20px;
  transition: border-color .25s, box-shadow .25s, transform .25s;
}
.feat-box:hover {
  border-color: rgba(79,70,229,.3);
  box-shadow: 0 8px 32px rgba(79,70,229,.1);
  transform: translateY(-3px);
}
.feat-box-ico {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--bg-dark);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}
.feat-box h4 { font-size: .95rem; font-weight: 700; margin-bottom: 6px; color: var(--text); }
.feat-box p { font-size: .85rem; color: var(--text3); line-height: 1.6; }

/* Center visual */
.features-center { display: flex; align-items: center; justify-content: center; }
.features-vis {
  width: 220px; height: 220px;
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.fv-ring {
  position: absolute; border-radius: 50%;
  border: 1.5px solid rgba(79,70,229,.2);
  animation: fv-spin 12s linear infinite;
}
.fv-ring-1 { width: 100%; height: 100%; animation-duration: 12s; }
.fv-ring-2 { width: 74%; height: 74%; border-color: rgba(79,70,229,.35); animation-duration: 8s; animation-direction: reverse; }
@keyframes fv-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.fv-icon-wrap {
  width: 90px; height: 90px; border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  display: flex; align-items: center; justify-content: center;
  font-size: 2.2rem;
  box-shadow: 0 12px 40px rgba(79,70,229,.4);
  position: relative; z-index: 1;
}
.fv-dot {
  position: absolute; width: 10px; height: 10px;
  border-radius: 50%; background: var(--primary);
}
.fv-d1 { top: 12%; left: 50%; transform: translateX(-50%); }
.fv-d2 { bottom: 12%; left: 50%; transform: translateX(-50%); background: var(--secondary); }
.fv-d3 { left: 12%; top: 50%; transform: translateY(-50%); background: var(--accent); }
.fv-d4 { right: 12%; top: 50%; transform: translateY(-50%); background: var(--green); }

@media (max-width: 900px) {
  .features-layout { grid-template-columns: 1fr; gap: 32px; }
  .features-center { display: none; }
}

/* ══════════════════════════════════════════════
   DETAIL PAGE — Intro two-column section
   ══════════════════════════════════════════════ */
.detail-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  padding-bottom: 64px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 64px;
}
.detail-intro-vis {
  display: flex; align-items: center; justify-content: center;
  min-height: 320px;
}
.div-vis-inner {
  position: relative; width: 280px; height: 280px;
  display: flex; align-items: center; justify-content: center;
}
.div-vis-icon {
  width: 120px; height: 120px; border-radius: 28px;
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem;
  position: relative; z-index: 2;
  box-shadow: 0 20px 60px rgba(0,0,0,.12);
  border: 1.5px solid rgba(255,255,255,.6);
}
.div-vis-ring {
  position: absolute; border-radius: 50%;
  border: 1.5px dashed rgba(79,70,229,.2);
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  animation: fv-spin 14s linear infinite;
}
.div-vis-ring-1 { width: 220px; height: 220px; }
.div-vis-ring-2 { width: 270px; height: 270px; border-color: rgba(79,70,229,.1); animation-direction: reverse; animation-duration: 20s; }
.div-vis-dots {
  position: absolute; inset: 0; border-radius: 50%;
}
.div-vis-dots span {
  position: absolute; width: 8px; height: 8px; border-radius: 50%;
  background: var(--primary); opacity: .6;
}
.div-vis-dots span:nth-child(1) { top:8%; left:50%; }
.div-vis-dots span:nth-child(2) { top:25%; right:5%; background:var(--secondary); }
.div-vis-dots span:nth-child(3) { bottom:10%; right:20%; background:var(--accent); }
.div-vis-dots span:nth-child(4) { bottom:8%; left:50%; background:var(--green); }
.div-vis-dots span:nth-child(5) { bottom:25%; left:5%; background:var(--gold); }
.div-vis-dots span:nth-child(6) { top:25%; left:5%; background:var(--secondary); opacity:.4; }
.detail-intro-text h2 { font-size: clamp(1.8rem,3.5vw,2.6rem); margin-bottom: 16px; line-height:1.2; }
.detail-intro-text .detail-desc { font-size: 1rem; line-height: 1.8; margin-bottom: 28px; }
.detail-intro-text .stag { margin-bottom: 14px; }

@media (max-width: 768px) {
  .detail-intro-grid { grid-template-columns: 1fr; gap: 32px; }
  .detail-intro-vis { min-height: 200px; }
  .div-vis-inner { width: 200px; height: 200px; }
  .div-vis-ring-1 { width: 160px; height: 160px; }
  .div-vis-ring-2 { width: 196px; height: 196px; }
}

/* ══ Remove orphaned chat-panel mobile override ══ */

/* ══════════════════════════════════════════════
   DOMAIN GALLERY — 3-card visual showcase
   ══════════════════════════════════════════════ */
.dg-section {
  padding: 0 0 0;
  background: var(--bg-alt);
}
.dg-gallery {
  display: grid;
  grid-template-columns: 1.7fr 1.15fr 1fr;
  gap: 20px;
  padding: 48px 0 64px;
}

/* ── Card base ── */
.dg-card {
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  min-height: 320px;
  display: flex;
  flex-direction: column;
  transition: transform .28s ease, box-shadow .28s ease;
}
.dg-card:hover { transform: translateY(-5px); box-shadow: 0 24px 60px rgba(0,0,0,.14); }

/* ── Card 1: Hero panel (dark gradient) ── */
.dg-card-main {
  background: linear-gradient(145deg, #0d1326, #0c1420);
  padding: 36px 32px;
  justify-content: flex-end;
}
.dg-card-main::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 80% 20%, color-mix(in srgb, var(--dc) 28%, transparent), transparent 55%),
    radial-gradient(ellipse at 20% 80%, color-mix(in srgb, var(--dc) 14%, transparent), transparent 50%);
  pointer-events: none;
}
.dg-dots-bg {
  position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 28px 28px;
}
.dg-circle {
  position: absolute; border-radius: 50%; pointer-events: none;
  background: color-mix(in srgb, var(--dc) 18%, transparent);
}
.dg-circle-1 { width: 200px; height: 200px; top: -60px; right: -60px; }
.dg-circle-2 { width: 120px; height: 120px; bottom: -30px; right: 60px; background: color-mix(in srgb, var(--dc) 10%, transparent); }

.dg-main-content { position: relative; z-index: 1; }
.dg-main-icon {
  font-size: 3.2rem;
  display: block;
  margin-bottom: 14px;
  filter: drop-shadow(0 4px 16px rgba(0,0,0,.4));
}
.dg-card-main h3 { font-size: 1.4rem; font-weight: 800; color: #f8faff; margin-bottom: 8px; line-height: 1.2; }
.dg-card-main p { font-size: .88rem; color: rgba(255,255,255,.65); margin-bottom: 20px; line-height: 1.6; }
.dg-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.dg-chips span {
  font-size: .72rem; font-weight: 600; padding: 5px 12px; border-radius: 99px;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); color: rgba(255,255,255,.85);
}

/* ── Card 2: Challenge + process panel ── */
.dg-card-challenge {
  background: #fff;
  border: 1.5px solid var(--border);
  padding: 28px 24px;
}
.dg-card-label {
  font-size: .68rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase;
  color: var(--text3); margin-bottom: 10px;
}
.dg-label-green { color: var(--green); }
.dg-challenge-text { font-size: .85rem; color: var(--text2); line-height: 1.7; margin-bottom: 16px; }
.dg-solution-text { font-size: .85rem; color: var(--text2); line-height: 1.7; }
.dg-divider { height: 1px; background: var(--border); margin: 16px 0; }
.dg-process-mini {
  display: flex; align-items: center; gap: 10px;
  font-size: .82rem; color: var(--text2); margin-bottom: 8px;
}
.dg-process-mini span {
  width: 22px; height: 22px; border-radius: 6px; flex-shrink: 0;
  background: var(--dc); color: #fff; font-size: .7rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

/* ── Card 3: Stats panel ── */
.dg-card-stats {
  background: linear-gradient(145deg, color-mix(in srgb, var(--dc) 8%, #fff), #fff);
  border: 1.5px solid color-mix(in srgb, var(--dc) 20%, transparent);
  padding: 28px 24px;
}
.dg-stat-big { margin: 10px 0 18px; }
.dg-stat-num {
  display: block; font-size: 3rem; font-weight: 800; line-height: 1;
  color: var(--dc);
}
.dg-stat-lbl { font-size: .8rem; color: var(--text3); font-weight: 600; }
.dg-stat-row {
  display: flex; gap: 16px; padding: 12px 0;
  border-top: 1px solid color-mix(in srgb, var(--dc) 15%, transparent);
  margin-bottom: 4px;
}
.dg-stat-row div { display: flex; flex-direction: column; }
.dg-stat-row strong { font-size: 1.15rem; font-weight: 800; color: var(--text); }
.dg-stat-row span { font-size: .72rem; color: var(--text3); }
.dg-results-mini { display: flex; flex-direction: column; gap: 8px; }
.dg-result-row {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: .8rem; color: var(--text2); line-height: 1.5;
}
.dg-result-row span { color: var(--dc); flex-shrink: 0; font-size: .75rem; margin-top: 2px; }

/* ══════════════════════════════════════════════
   DOMAIN INFO SECTION — 2-col about + panel
   ══════════════════════════════════════════════ */
.dg-info-section { padding-top: 72px; }
.dg-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.dg-info-about h2 { font-size: clamp(1.9rem,3.5vw,2.6rem); margin-bottom: 16px; line-height: 1.2; }
.dg-info-about .detail-desc { margin-bottom: 24px; line-height: 1.8; }
.dg-benefit-list {
  list-style: none; display: flex; flex-direction: column; gap: 10px;
}
.dg-benefit-list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .9rem; color: var(--text2); line-height: 1.55;
}
.dg-benefit-list li span {
  width: 22px; height: 22px; border-radius: 6px; flex-shrink: 0;
  background: color-mix(in srgb, var(--dc) 12%, transparent);
  color: var(--dc); font-weight: 700; font-size: .82rem;
  display: flex; align-items: center; justify-content: center; margin-top: 1px;
}

/* Info panel (right card) */
.dg-info-panel {
  background: #fff;
  border: 1.5px solid color-mix(in srgb, var(--dc) 20%, var(--border));
  border-radius: 20px;
  padding: 32px;
  box-shadow: 0 8px 40px rgba(0,0,0,.07);
}
.dg-panel-header {
  display: flex; align-items: center; gap: 14px; margin-bottom: 24px;
  padding-bottom: 20px; border-bottom: 1px solid var(--border);
}
.dg-panel-icon {
  width: 52px; height: 52px; border-radius: 14px; flex-shrink: 0;
  background: color-mix(in srgb, var(--dc) 12%, transparent);
  border: 1.5px solid color-mix(in srgb, var(--dc) 25%, transparent);
  display: flex; align-items: center; justify-content: center; font-size: 1.5rem;
}
.dg-panel-header h4 { font-size: .95rem; font-weight: 700; color: var(--text); margin-bottom: 3px; }
.dg-panel-header p { font-size: .78rem; color: var(--text3); }
.dg-usecase-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: 20px;
}
.dg-usecase-item {
  display: flex; align-items: flex-start; gap: 6px;
  font-size: .82rem; color: var(--text2); line-height: 1.45; padding: 6px 8px;
  background: var(--bg-alt); border-radius: 8px;
}
.dg-usecase-item span { color: var(--dc); font-size: .75rem; flex-shrink: 0; margin-top: 2px; }
.dg-tech-row { border-top: 1px solid var(--border); padding-top: 18px; }
.dg-tech-row p { font-size: .75rem; font-weight: 700; color: var(--text3); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px; }
.dg-tech-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.dg-tech-chips span {
  font-size: .75rem; font-weight: 600; padding: 4px 12px; border-radius: 99px;
  background: color-mix(in srgb, var(--dc) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--dc) 22%, transparent);
  color: color-mix(in srgb, var(--dc) 75%, var(--text));
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .dg-gallery { grid-template-columns: 1fr 1fr; }
  .dg-card-stats { display: none; }
}
@media (max-width: 768px) {
  .dg-gallery { grid-template-columns: 1fr; }
  .dg-card-challenge { display: none; }
  .dg-info-grid { grid-template-columns: 1fr; gap: 36px; }
}

/* ══════════════════════════════════════════════
   PERFORMANCE — GPU layer promotion + blur reduction
   ══════════════════════════════════════════════ */

/* Promote continuously-rotating rings to compositor layers */
.r1,.r2,.r3,.av-r1,.av-r2,.av-r3,
.div-vis-ring,.div-vis-ring-1,.div-vis-ring-2 { will-change: transform; }

/* Promote marquee tracks */
.logo-track, .tmarquee-wrap .tmarquee-track { will-change: transform; }

/* Promote floating / pulsing decorative elements */
.fnode-float, .co-float-badge, .about-blob,
.olabel, .bdot { will-change: transform; }

/* Reduce blur radius on animated orbs — the biggest perf win.
   Blur cost scales as O(r²); halving radius cuts work by 4x.  */
.orb1,.orb2 { filter: blur(40px) !important; }
.co-orb1    { filter: blur(50px) !important; }
.co-orb2    { filter: blur(40px) !important; }
.co-orb3    { filter: blur(35px) !important; }

/* Promote orbs themselves so blur composites on GPU */
.orb1,.orb2,.co-orb,.hero-orb { will-change: transform; }

/* Contain layout/paint inside animation-heavy sections */
.co-hero,
.co-mv-section,
.co-why-section,
.co-team-section,
.co-timeline-section { contain: layout style; }

/* Stop all decorative animations for users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
  .orb1,.orb2,.co-orb1,.co-orb2,.co-orb3,
  .r1,.r2,.r3,.av-r1,.av-r2,.av-r3,
  .div-vis-ring,.div-vis-ring-1,.div-vis-ring-2,
  .logo-track,.tmarquee-wrap .tmarquee-track,
  .fnode-float,.about-blob,.co-float-badge,
  .olabel,.bdot,.av-float-card { animation: none !important; transition: none !important; }
}
.footer-bottom-links button{
  appearance:none !important;
  -webkit-appearance:none !important;
  background:transparent !important;
  border:none !important;
  outline:none !important;
  box-shadow:none !important;
  color:#8a98aa !important;
  cursor:pointer !important;
  font-size:.85rem !important;
  font-family:inherit !important;
  padding:0 !important;
}

.footer-bottom-links button:hover{
  color:#ffffff !important;
}
/* Hide About Us robot only on mobile */
@media (max-width: 768px) {
  body.about-page .co-fixed-robot {
    display: none !important;
  }

  body.about-page .co-hero-v2,
  body.about-page .co-stats-bar,
  body.about-page .co-mv-section,
  body.about-page .co-why-section,
  body.about-page .co-team-section,
  body.about-page .co-timeline-section {
    pointer-events: auto;
  }
}
@media(max-width:1024px){
  .container{
    padding-left:40px;
    padding-right:40px;
  }
}

@media(max-width:640px){
  .container{
    padding-left:18px;
    padding-right:18px;
  }
}

/* ✅ SERVICES + INDUSTRIES HERO RESPONSIVE FIX */
/* Paste at bottom of public/css/main.css */

/* ---------- TABLET FIX ---------- */
@media (min-width: 641px) and (max-width: 1024px) {

  .page-hero.ph-enhanced {
    padding-top: 88px !important;
    padding-bottom: 88px !important;
    overflow: hidden !important;
  }

  .page-hero.ph-enhanced .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 28px !important;
    padding-right: 28px !important;
    box-sizing: border-box !important;
  }

  .ph-content,
  .ph-content--image {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 30px !important;
    flex-wrap: nowrap !important;
    margin-top: 14px !important;
  }

  .ph-content > div:last-child {
    transform: none !important;
  }

  .ph-text-col,
  .ph-content > div:first-child {
    width: 100% !important;
    max-width: 760px !important;
  }

  .page-hero.ph-enhanced h1 {
    font-size: clamp(2.35rem, 6vw, 3.6rem) !important;
    line-height: 1.08 !important;
    max-width: 760px !important;
  }

  .ph-sub {
    max-width: 680px !important;
    font-size: 1rem !important;
    line-height: 1.65 !important;
  }

  .ph-stats,
  .ph-stats--inline {
    width: 100% !important;
    max-width: 680px !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    margin-top: 30px !important;
    padding: 18px 14px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  .phstat {
    flex: 1 1 33.33% !important;
    width: 33.33% !important;
    max-width: 33.33% !important;
    min-width: 0 !important;
    padding: 0 12px !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }

  .phnum {
    font-size: 1.45rem !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
  }

  .phlbl {
    font-size: 0.7rem !important;
    line-height: 1.25 !important;
  }

  .ph-hero-img-wrap {
    width: 100% !important;
    max-width: 620px !important;
    flex: none !important;
    margin-right: 0 !important;
  }

  .ph-hero-img {
    width: 100% !important;
    height: 340px !important;
    object-fit: cover !important;
    object-position: center !important;
  }
}


/* ---------- MOBILE FIX ---------- */
@media (max-width: 640px) {

  .page-hero.ph-enhanced {
    padding-top: 82px !important;
    padding-bottom: 68px !important;
    overflow: hidden !important;
  }

  .page-hero.ph-enhanced .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
  }

  .breadcrumb {
    font-size: 0.72rem !important;
    gap: 6px !important;
    margin-bottom: 14px !important;
  }

  .ph-content,
  .ph-content--image {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 26px !important;
    flex-wrap: nowrap !important;
    margin-top: 8px !important;
  }

  .ph-content > div:last-child {
    transform: none !important;
  }

  .ph-text-col,
  .ph-content > div:first-child {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .page-hero.ph-enhanced h1 {
    font-size: clamp(2rem, 10vw, 2.65rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.03em !important;
    margin-bottom: 16px !important;
    max-width: 100% !important;
    word-break: normal !important;
  }

  .ph-sub {
    max-width: 100% !important;
    font-size: 0.95rem !important;
    line-height: 1.55 !important;
    margin-bottom: 0 !important;
  }

  .ph-btns {
    margin-top: 26px !important;
    width: 100% !important;
    display: flex !important;
    justify-content: flex-start !important;
  }

  .ph-btns .btn-primary,
  .ph-btns .btn-outline {
    min-height: 54px !important;
    padding: 14px 24px !important;
    font-size: 0.95rem !important;
    border-radius: 999px !important;
  }

  .ph-stats,
  .ph-stats--inline {
    width: 100% !important;
    max-width: 100% !important;
    margin-top: 32px !important;
    padding: 16px 8px !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    border-radius: 16px !important;
  }

  .phstat {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
    padding: 0 6px !important;
    text-align: center !important;
    box-sizing: border-box !important;
    border-left: none !important;
  }

  .phstat + .phstat {
    border-left: 1px solid rgba(255,255,255,.12) !important;
  }

  .phnum {
    display: block !important;
    font-size: 1.25rem !important;
    line-height: 1.05 !important;
    margin-bottom: 6px !important;
    white-space: nowrap !important;
  }

  .phlbl {
    display: block !important;
    font-size: 0.62rem !important;
    line-height: 1.2 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .ph-hero-img-wrap {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    margin: 12px 0 0 !important;
  }

  .ph-hero-img-inner {
    width: 100% !important;
    border-radius: 18px !important;
  }

  .ph-hero-img {
    width: 100% !important;
    height: 300px !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  .ph-blob {
    display: none !important;
  }

  .ph-wave svg {
    height: 42px !important;
  }
}


/* ---------- VERY SMALL MOBILE FIX ---------- */
@media (max-width: 380px) {

  .page-hero.ph-enhanced .container {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .page-hero.ph-enhanced h1 {
    font-size: clamp(1.8rem, 10vw, 2.25rem) !important;
  }

  .ph-sub {
    font-size: 0.88rem !important;
  }

  .ph-stats,
  .ph-stats--inline {
    padding: 14px 6px !important;
  }

  .phnum {
    font-size: 1.05rem !important;
  }

  .phlbl {
    font-size: 0.56rem !important;
  }

  .ph-hero-img {
    height: 260px !important;
  }
}


/* ---------- MOBILE LANDSCAPE FIX ---------- */
@media (orientation: landscape) and (max-height: 520px) and (max-width: 950px) {

  .page-hero.ph-enhanced {
    padding-top: 74px !important;
    padding-bottom: 56px !important;
  }

  .page-hero.ph-enhanced h1 {
    font-size: clamp(1.8rem, 5vw, 2.4rem) !important;
    line-height: 1.05 !important;
  }

  .ph-sub {
    font-size: 0.86rem !important;
    line-height: 1.45 !important;
    max-width: 620px !important;
  }

  .ph-btns {
    margin-top: 18px !important;
  }

  .ph-stats,
  .ph-stats--inline {
    margin-top: 22px !important;
    max-width: 620px !important;
    padding: 14px 10px !important;
  }

  .ph-hero-img-wrap {
    display: none !important;
  }
}



/* ✅ SERVICES + INDUSTRIES HERO - IPAD PORTRAIT + LANDSCAPE FIX */
/* Paste at very bottom of public/css/main.css */


/* ---------- IPAD PORTRAIT ---------- */
@media (min-width: 641px) and (max-width: 900px) and (orientation: portrait) {

  .page-hero.ph-enhanced {
    padding: 96px 0 86px !important;
    min-height: auto !important;
    overflow: hidden !important;
  }

  .page-hero.ph-enhanced .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 34px !important;
    padding-right: 34px !important;
    box-sizing: border-box !important;
  }

  .breadcrumb {
    justify-content: flex-start !important;
    font-size: 0.78rem !important;
    margin-bottom: 22px !important;
  }

  .ph-content,
  .ph-content--image {
    width: 100% !important;
    max-width: 100% !important;

    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;

    gap: 36px !important;
    flex-wrap: nowrap !important;
    margin-top: 12px !important;
  }

  .ph-text-col,
  .ph-content > div:first-child {
    width: 100% !important;
    max-width: 720px !important;
    min-width: 0 !important;
  }

  .page-hero.ph-enhanced h1 {
    max-width: 720px !important;
    font-size: clamp(3rem, 7vw, 4.4rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.035em !important;
    margin-bottom: 18px !important;
  }

  .ph-sub {
    max-width: 660px !important;
    font-size: 1.08rem !important;
    line-height: 1.65 !important;
    margin-bottom: 0 !important;
  }

  .ph-btns {
    margin-top: 30px !important;
    justify-content: flex-start !important;
  }

  .ph-btns .btn-primary,
  .ph-btns .btn-outline,
  .ph-btns .ph-ghost {
    min-height: 56px !important;
    padding: 15px 28px !important;
    font-size: 1rem !important;
    border-radius: 999px !important;
  }

  .ph-stats,
  .ph-stats--inline {
    width: 100% !important;
    max-width: 680px !important;
    margin-top: 34px !important;
    padding: 20px 12px !important;

    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 0 !important;

    border-radius: 18px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  .phstat {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 0 12px !important;
    text-align: center !important;
    box-sizing: border-box !important;
    border-left: none !important;
  }

  .phstat + .phstat {
    border-left: 1px solid rgba(255,255,255,.12) !important;
  }

  .phnum {
    display: block !important;
    font-size: 1.5rem !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
    margin-bottom: 6px !important;
  }

  .phlbl {
    display: block !important;
    font-size: 0.72rem !important;
    line-height: 1.25 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .ph-hero-img-wrap {
    width: 100% !important;
    max-width: 680px !important;
    flex: none !important;
    margin: 0 !important;
  }

  .ph-hero-img-inner {
    width: 100% !important;
    border-radius: 22px !important;
  }

  .ph-hero-img {
    width: 100% !important;
    height: 380px !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  .ph-wave svg {
    height: 54px !important;
  }
}


/* ---------- IPAD LANDSCAPE ---------- */
@media (min-width: 901px) and (max-width: 1180px) and (orientation: landscape) {

  .page-hero.ph-enhanced {
    padding: 88px 0 78px !important;
    min-height: auto !important;
    overflow: hidden !important;
  }

  .page-hero.ph-enhanced .container {
    width: 100% !important;
    max-width: 1120px !important;
    padding-left: 34px !important;
    padding-right: 34px !important;
    box-sizing: border-box !important;
  }

  .breadcrumb {
    font-size: 0.76rem !important;
    margin-bottom: 18px !important;
  }

  .ph-content {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 24px !important;
    flex-wrap: nowrap !important;
    margin-top: 10px !important;
  }

  .ph-content--image {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 420px !important;
    align-items: center !important;
    gap: 34px !important;
    flex-wrap: nowrap !important;
    margin-top: 10px !important;
  }

  .ph-text-col,
  .ph-content > div:first-child {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .page-hero.ph-enhanced h1 {
    max-width: 620px !important;
    font-size: clamp(2.45rem, 4.4vw, 3.55rem) !important;
    line-height: 1.07 !important;
    letter-spacing: -0.035em !important;
    margin-bottom: 16px !important;
  }

  .ph-sub {
    max-width: 560px !important;
    font-size: 0.98rem !important;
    line-height: 1.6 !important;
    margin-bottom: 0 !important;
  }

  .ph-btns {
    margin-top: 26px !important;
  }

  .ph-btns .btn-primary,
  .ph-btns .btn-outline,
  .ph-btns .ph-ghost {
    min-height: 52px !important;
    padding: 13px 24px !important;
    font-size: 0.94rem !important;
    border-radius: 999px !important;
  }

  .ph-stats,
  .ph-stats--inline {
    width: 100% !important;
    max-width: 620px !important;
    margin-top: 30px !important;
    padding: 18px 10px !important;

    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 0 !important;

    border-radius: 18px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  .phstat {
    width: 100% !important;
    min-width: 0 !important;
    padding: 0 10px !important;
    text-align: center !important;
    border-left: none !important;
    box-sizing: border-box !important;
  }

  .phstat + .phstat {
    border-left: 1px solid rgba(255,255,255,.12) !important;
  }

  .phnum {
    font-size: 1.35rem !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
    margin-bottom: 5px !important;
  }

  .phlbl {
    font-size: 0.66rem !important;
    line-height: 1.25 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .ph-hero-img-wrap {
    width: 100% !important;
    max-width: 420px !important;
    flex: none !important;
    margin: 0 !important;
  }

  .ph-hero-img-inner {
    width: 100% !important;
    border-radius: 20px !important;
  }

  .ph-hero-img {
    width: 100% !important;
    height: 360px !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  .ph-wave svg {
    height: 50px !important;
  }
}


/* ---------- IPAD LANDSCAPE WITHOUT IMAGE HERO ---------- */
/* For service pages where there is no right-side image */
@media (min-width: 901px) and (max-width: 1180px) and (orientation: landscape) {

  .ph-content:not(.ph-content--image) {
    max-width: 760px !important;
  }

  .ph-content:not(.ph-content--image) .ph-stats {
    max-width: 680px !important;
  }
}


/* ✅ HOMEPAGE HERO GLOBE / RINGS / LABELS ALIGNMENT FIX FOR IPAD */
/* Paste at very bottom of public/css/sections/hero.css */


/* =========================
   IPAD PORTRAIT
========================= */
@media (min-width: 641px) and (max-width: 900px) and (orientation: portrait) {

  .hero-visual {
    position: relative !important;
    width: 100% !important;
    max-width: 700px !important;
    height: 500px !important;
    margin: 0 auto !important;
    overflow: visible !important;
  }

  /* Ring SVG and labels must use SAME canvas */
  #orbit-svg,
  .orbit-labels {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    width: 640px !important;
    height: 480px !important;
    transform: translate(-50%, -50%) !important;
    transform-origin: center center !important;
  }

  /* Globe must sit exactly at center of orbit */
  #globe-container {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    width: 320px !important;
    height: 320px !important;
    transform: translate(-50%, -50%) !important;
    right: auto !important;
    margin: 0 !important;
  }

  .olabel {
    position: absolute !important;
    white-space: nowrap !important;
    font-size: 0.76rem !important;
    padding: 7px 12px !important;
    transform: translate(-50%, -50%) !important;
  }

  /* Labels aligned around the orbit using same canvas */
  .ol-1 { left: 50% !important; top: 6% !important; }
  .ol-2 { left: 82% !important; top: 24% !important; }
  .ol-3 { left: 82% !important; top: 76% !important; }
  .ol-4 { left: 50% !important; top: 94% !important; }
  .ol-5 { left: 18% !important; top: 76% !important; }
  .ol-6 { left: 18% !important; top: 24% !important; }
}


/* =========================
   IPAD LANDSCAPE
========================= */
@media (min-width: 901px) and (max-width: 1180px) and (orientation: landscape) {

  .hero-visual {
    position: relative !important;
    flex: 0 0 52% !important;
    max-width: 52% !important;
    height: 460px !important;
    overflow: visible !important;
  }

  /* Ring SVG and labels same size and same center */
  #orbit-svg,
  .orbit-labels {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    width: 560px !important;
    height: 420px !important;
    transform: translate(-50%, -50%) !important;
    transform-origin: center center !important;
  }

  /* Globe centered perfectly in rings */
  #globe-container {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    width: 290px !important;
    height: 290px !important;
    transform: translate(-50%, -50%) !important;
    right: auto !important;
    margin: 0 !important;
  }

  .olabel {
    position: absolute !important;
    white-space: nowrap !important;
    font-size: 0.72rem !important;
    padding: 7px 11px !important;
    transform: translate(-50%, -50%) !important;
  }

  /* Better balanced label placement for landscape */
  .ol-1 { left: 50% !important; top: 7% !important; }
  .ol-2 { left: 81% !important; top: 24% !important; }
  .ol-3 { left: 81% !important; top: 76% !important; }
  .ol-4 { left: 50% !important; top: 93% !important; }
  .ol-5 { left: 19% !important; top: 76% !important; }
  .ol-6 { left: 19% !important; top: 24% !important; }
}

/* ✅ SERVICES + INDUSTRIES HERO STATS FIX — MOBILE LANDSCAPE */
/* Fixes broken stat labels like Tran/sact/ions in landscape mobile */

@media (orientation: landscape) and (max-height: 520px) and (max-width: 950px) {

  .page-hero.ph-enhanced {
    padding-top: 72px !important;
    padding-bottom: 42px !important;
    overflow: hidden !important;
  }

  .page-hero.ph-enhanced .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
  }

  .ph-content,
  .ph-content--image {
    display: grid !important;
    grid-template-columns: 1fr 0.85fr !important;
    align-items: center !important;
    gap: 26px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .ph-text-col,
  .ph-content > div:first-child {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .page-hero.ph-enhanced h1 {
    font-size: clamp(2rem, 5vw, 2.65rem) !important;
    line-height: 1.05 !important;
    margin-bottom: 12px !important;
  }

  .ph-sub {
    font-size: 0.88rem !important;
    line-height: 1.45 !important;
    max-width: 480px !important;
    margin-bottom: 0 !important;
  }

  .ph-btns {
    margin-top: 18px !important;
  }

  .ph-btns .btn-primary,
  .ph-btns .btn-outline,
  .ph-btns .ph-ghost {
    min-height: 46px !important;
    padding: 11px 20px !important;
    font-size: 0.86rem !important;
  }

  /* ✅ Main stats fix */
  .ph-stats,
  .ph-stats--inline {
    width: 100% !important;
    max-width: 520px !important;
    margin-top: 22px !important;
    padding: 14px 10px !important;

    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0 !important;

    border-radius: 16px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  .phstat {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 0 10px !important;
    text-align: center !important;
    box-sizing: border-box !important;
    border-left: none !important;
  }

  .phstat + .phstat {
    border-left: 1px solid rgba(255,255,255,0.12) !important;
  }

  .phnum {
    display: block !important;
    font-size: 1.22rem !important;
    line-height: 1.05 !important;
    margin-bottom: 6px !important;
    white-space: nowrap !important;
  }

  .phlbl {
    display: block !important;
    font-size: 0.62rem !important;
    line-height: 1.25 !important;

    /* ✅ Stops letter-by-letter breaking */
    word-break: normal !important;
    overflow-wrap: normal !important;
    white-space: normal !important;
    hyphens: none !important;
  }

  .ph-hero-img-wrap {
    width: 100% !important;
    max-width: 390px !important;
    margin: 0 !important;
  }

  .ph-hero-img {
    width: 100% !important;
    height: 300px !important;
    object-fit: cover !important;
    object-position: center !important;
  }
}
