/* ============================================================
   PNB Private Limited — Liquid Glass Design System
   Shared across all pages
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --navy-900:#060c18;
  --navy-800:#081120;
  --navy-700:#0a1830;
  --blue:#0066ff;
  --blue-bright:#2b8bff;
  --cyan:#00e5ff;
  --gold:#f5b800;

  --text:#eaf1ff;
  --text-dim:#9fb0cc;
  --text-faint:#6c7e9c;

  /* glass */
  --glass-fill: linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.025));
  --glass-fill-strong: linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.04));
  --glass-border: rgba(255,255,255,.14);
  --glass-radius:24px;
  --glass-blur:22px;

  --shadow-float: 0 20px 60px -20px rgba(0,0,0,.65);
  --shadow-glass:
     0 8px 32px rgba(0,0,0,.40),
     inset 0 1px 0 rgba(255,255,255,.40),
     inset 0 -1px 1px rgba(0,0,0,.25),
     inset 0 0 0 1px rgba(255,255,255,.04);

  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --font-display:"Space Grotesk", system-ui, sans-serif;
  --font-sub:"Sora", system-ui, sans-serif;
  --font-body:"Inter", system-ui, sans-serif;
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--text);
  background:var(--navy-900);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
::selection{background:var(--cyan);color:var(--navy-900)}

/* ---------- Ambient background ---------- */
.bg-stage{position:fixed;inset:0;z-index:-3;overflow:hidden;
  background:
    radial-gradient(1200px 800px at 80% -10%, rgba(0,102,255,.22), transparent 60%),
    radial-gradient(1000px 700px at 0% 100%, rgba(0,229,255,.14), transparent 55%),
    linear-gradient(180deg, var(--navy-900), var(--navy-800) 40%, var(--navy-900));
}
.bg-grid{position:fixed;inset:0;z-index:-2;pointer-events:none;
  background-image:
    linear-gradient(rgba(140,180,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(140,180,255,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
}
.aurora{position:fixed;border-radius:50%;filter:blur(80px);opacity:.55;z-index:-2;
  animation:drift 22s var(--ease) infinite alternate;will-change:transform}
.aurora.a{width:520px;height:520px;top:-120px;left:-80px;
  background:radial-gradient(circle,var(--blue),transparent 70%)}
.aurora.b{width:460px;height:460px;top:30%;right:-120px;
  background:radial-gradient(circle,var(--cyan),transparent 70%);animation-delay:-6s}
.aurora.c{width:420px;height:420px;bottom:-120px;left:30%;
  background:radial-gradient(circle,rgba(245,184,0,.5),transparent 70%);animation-delay:-12s}
@keyframes drift{
  from{transform:translate(0,0) scale(1)}
  to{transform:translate(60px,40px) scale(1.15)}
}
/* cursor light that reveals the world behind the glass */
.cursor-glow{position:fixed;width:560px;height:560px;border-radius:50%;
  left:0;top:0;transform:translate(-50%,-50%);pointer-events:none;z-index:-1;
  background:radial-gradient(circle, rgba(0,229,255,.16), rgba(0,102,255,.08) 40%, transparent 70%);
  transition:opacity .4s}

/* ---------- Liquid glass primitive ---------- */
.glass{
  position:relative;
  background:var(--glass-fill);
  backdrop-filter:blur(var(--glass-blur)) saturate(170%);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(170%);
  border:1px solid var(--glass-border);
  border-radius:var(--glass-radius);
  box-shadow:var(--shadow-glass);
  overflow:hidden;
}
/* specular sheen — a soft moving highlight in the top-left */
.glass::before{
  content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  background:radial-gradient(120% 80% at 18% 0%, rgba(255,255,255,.22), transparent 45%);
  mix-blend-mode:screen;opacity:.9;
}
/* refraction rim — bright thin top edge */
.glass::after{
  content:"";position:absolute;left:8%;right:8%;top:0;height:1px;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);
}
.glass-strong{background:var(--glass-fill-strong)}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:96px 0;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-sub);font-size:.78rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--cyan);
  padding:8px 16px;border-radius:999px;
  background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.25)}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 10px var(--cyan)}
.section-head{max-width:680px;margin-bottom:56px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.08;letter-spacing:-.02em}
h2.title{font-size:clamp(2rem,4vw,3.1rem);margin:18px 0 14px}
.lead{color:var(--text-dim);font-size:1.08rem;max-width:60ch}
.grad-text{background:linear-gradient(100deg,var(--cyan),var(--blue-bright) 50%,var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-sub);font-weight:600;font-size:.96rem;
  padding:14px 26px;border-radius:999px;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  white-space:nowrap}
.btn:focus-visible{outline:2px solid var(--cyan);outline-offset:3px}
.btn-primary{
  color:#ffffff;
  background:linear-gradient(100deg,var(--cyan),var(--blue-bright));
  box-shadow:0 10px 30px -8px rgba(0,229,255,.55), inset 0 1px 0 rgba(255,255,255,.55)}
.btn-primary:hover{transform:translateY(-3px);
  box-shadow:0 18px 40px -10px rgba(0,229,255,.7), inset 0 1px 0 rgba(255,255,255,.6)}
.btn-gold{color:#241700;background:linear-gradient(100deg,#ffd34d,var(--gold));
  box-shadow:0 10px 30px -8px rgba(245,184,0,.5), inset 0 1px 0 rgba(255,255,255,.55)}
.btn-gold:hover{transform:translateY(-3px)}
.btn-ghost{
  color:var(--text);
  background:var(--glass-fill);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--glass-border);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25)}
.btn-ghost:hover{transform:translateY(-3px);background:var(--glass-fill-strong)}
.btn-wa{
  color:#fff;
  background:linear-gradient(135deg,#25D366,#128C7E);
  border:1px solid rgba(37,211,102,.6);
  box-shadow:0 8px 24px -8px rgba(37,211,102,.45),inset 0 1px 0 rgba(255,255,255,.25)}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 14px 32px -8px rgba(37,211,102,.55),inset 0 1px 0 rgba(255,255,255,.3);background:linear-gradient(135deg,#22c25b,#0f7a6e)}
.btn-wa .ic{color:#fff}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Header / Nav ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;
  background:linear-gradient(90deg,var(--cyan),var(--blue),var(--gold))}
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;
  transition:background .35s,box-shadow .35s,padding .35s;padding:18px 0}
.site-header.scrolled{
  background:linear-gradient(180deg, rgba(8,17,32,.72), rgba(8,17,32,.5));
  backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);
  box-shadow:0 1px 0 rgba(255,255,255,.06), 0 10px 30px -15px rgba(0,0,0,.6);
  padding:12px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:14px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);
  font-weight:700;font-size:1.12rem;letter-spacing:-.01em;white-space:nowrap;line-height:1.12}
.brand .mark{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;
  font-size:1rem;color:#041020;font-weight:700;
  background:linear-gradient(135deg,var(--cyan),var(--blue));
  box-shadow:0 6px 18px -6px rgba(0,229,255,.7), inset 0 1px 0 rgba(255,255,255,.6)}
.brand small{display:block;font-family:var(--font-sub);font-weight:500;
  font-size:.62rem;letter-spacing:.22em;color:var(--text-faint);text-transform:uppercase}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links a{font-family:var(--font-sub);font-weight:500;font-size:.9rem;color:var(--text-dim);
  padding:8px 11px;border-radius:999px;transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:rgba(255,255,255,.07)}
.nav-right{display:flex;align-items:center;gap:12px}
.site-header .nav-right .btn-primary{padding:12px 20px;font-size:.9rem}
.hamburger{display:none;width:44px;height:44px;border-radius:12px;
  background:var(--glass-fill);border:1px solid var(--glass-border);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  align-items:center;justify-content:center;color:var(--text);transition:transform .3s,background .2s,border-color .2s;cursor:pointer;padding:0}
.hamburger svg{width:26px;height:26px;transition:transform .3s var(--ease)}
.hamburger:hover{background:rgba(0,131,163,.10);border-color:rgba(0,131,163,.35);color:var(--cyan)}
.hamburger.open svg{transform:rotate(90deg)}
.hamburger.open{background:linear-gradient(135deg,var(--cyan),var(--blue));color:#fff;border-color:transparent}

/* ---------- Hero ---------- */
.hero{min-height:100vh;display:flex;align-items:center;padding:130px 0 80px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(2.4rem,5.2vw,4.3rem);margin:22px 0 20px}
.hero .lead{font-size:1.15rem;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px;}
.trust-row{display:flex;flex-wrap:wrap;gap:10px}
.trust-pill{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-dim);
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.trust-pill b{color:var(--text);font-family:var(--font-sub);font-weight:600}

/* ---------- Hero reviews (4.5★ pills above CTA) ---------- */
.hero-reviews{display:flex;gap:14px;flex-wrap:wrap;margin:18px 0 6px}
.review-pill{display:inline-flex;align-items:center;gap:12px;padding:10px 16px 10px 12px;
  border-radius:14px;background:rgba(255,255,255,.62);border:1px solid var(--glass-border);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);text-decoration:none;color:inherit;
  box-shadow:0 6px 18px -10px rgba(0,30,100,.18);transition:transform .25s,box-shadow .25s,border-color .25s}
.review-pill:hover{transform:translateY(-2px);border-color:rgba(0,131,163,.35);box-shadow:0 12px 26px -12px rgba(0,30,100,.22)}
.review-pill .g-mark{width:28px;height:28px;flex-shrink:0}
.review-pill .c-mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#ffd23a,#f1a000);color:#3b2400;font-weight:800;font-size:1.05rem;display:grid;place-items:center;flex-shrink:0;box-shadow:0 4px 10px -3px rgba(245,184,0,.55)}
.review-pill .rt-top{font-family:var(--font-sub);font-size:.86rem;color:var(--text);display:flex;align-items:center;gap:7px;line-height:1}
.review-pill .rt-top strong{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--text)}
.review-pill .rt-sub{font-family:var(--font-sub);font-size:.72rem;color:var(--text-dim);margin-top:3px;letter-spacing:.02em}
.review-pill .stars{display:inline-flex;gap:1px}
.review-pill .stars svg{width:13px;height:13px;fill:#f5b800}
.review-pill .stars svg.half{fill:url(#halfStar)}
.review-pill .stars svg.half polygon{fill:#f5b800;clip-path:polygon(0 0,50% 0,50% 100%,0 100%)}

/* ---------- Hero 3D growth chart visual ---------- */
/* hero visual */
.hero-visual{position:relative;aspect-ratio:1;display:grid;place-items:center}
.growth-stage{position:relative;width:100%;aspect-ratio:1;display:grid;place-items:center;
  perspective:1200px}
.growth-svg{width:100%;height:100%;overflow:visible;
  filter:drop-shadow(0 30px 60px rgba(0,40,120,.18)) drop-shadow(0 12px 24px rgba(0,82,204,.12))}
.growth-svg .gh-grid{transform-origin:170px 330px;animation:gh-grid-fade 1.2s ease-out both .2s}
.growth-svg .gh-bar{transform-origin:bottom;animation:gh-bar-rise .9s cubic-bezier(.4,1.4,.6,1) backwards;animation-delay:calc(.5s + var(--i,0) * .15s)}
.growth-svg .gh-area{opacity:0;animation:gh-area-fade 1s ease-out forwards 1.6s}
.growth-svg .gh-trend{stroke-dasharray:480;stroke-dashoffset:480;animation:gh-trend-draw 2.6s cubic-bezier(.55,.05,.3,.92) forwards .8s}
.growth-svg .gh-dots circle{opacity:0;transform-origin:center;animation:gh-dot-pop .5s cubic-bezier(.4,1.5,.6,1) forwards}
.growth-svg .gh-dots circle:nth-child(1){animation-delay:1.0s}
.growth-svg .gh-dots circle:nth-child(2){animation-delay:1.35s}
.growth-svg .gh-dots circle:nth-child(3){animation-delay:1.7s}
.growth-svg .gh-dots circle:nth-child(4){animation-delay:2.05s}
.growth-svg .gh-dots circle:nth-child(5){animation-delay:2.4s}
.growth-svg .gh-rocket{transform-box:fill-box;opacity:0;
  animation:gh-rocket-launch 3.2s cubic-bezier(.34,.05,.36,1) forwards .9s,
            gh-rocket-float 3s ease-in-out 4.4s infinite alternate}
.growth-svg .gh-flame{transform-origin:22px 78px;animation:gh-flame .25s ease-in-out infinite alternate 3s}
.growth-svg .gh-callout{opacity:0;animation:gh-callout-in .55s cubic-bezier(.4,1.5,.6,1) forwards 2.9s}
.growth-svg .gh-spark{transform-origin:310px 60px;opacity:.7;animation:gh-spark 2.2s ease-in-out infinite 3s}

@keyframes gh-grid-fade{from{opacity:0}to{opacity:1}}
@keyframes gh-bar-rise{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes gh-area-fade{to{opacity:1}}
@keyframes gh-trend-draw{to{stroke-dashoffset:0}}
@keyframes gh-dot-pop{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
/* Rocket launches from bottom-left of chart and flies up along the trend line.
   SVG group is anchored at transform="translate(310,60)"; every offset is relative. */
@keyframes gh-rocket-launch{
  0%   {opacity:0; transform:translate(310px,60px) translate(-285px,290px) scale(.35)}
  8%   {opacity:1; transform:translate(310px,60px) translate(-260px,250px) scale(.42)}
  22%  {opacity:1; transform:translate(310px,60px) translate(-205px,200px) scale(.55)}
  40%  {opacity:1; transform:translate(310px,60px) translate(-150px,150px) scale(.70)}
  60%  {opacity:1; transform:translate(310px,60px) translate(-100px,100px) scale(.82)}
  80%  {opacity:1; transform:translate(310px,60px) translate(-50px,55px)   scale(.92)}
  100% {opacity:1; transform:translate(310px,60px) translate(0,0)          scale(1)}
}
@keyframes gh-rocket-float{
  from {transform:translate(310px,60px) translate(0,0)      scale(1)}
  to   {transform:translate(310px,60px) translate(-3px,-7px) scale(1)}
}
@keyframes gh-flame{from{transform:scaleY(.85) scaleX(1)}to{transform:scaleY(1.18) scaleX(.9)}}
@keyframes gh-callout-in{from{opacity:0;transform:translate(330px,40px) translateY(8px) scale(.9)}to{opacity:1;transform:translate(330px,40px) translate(0,0) scale(1)}}
@keyframes gh-spark{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.25);opacity:1}}

/* Floating depth cards beside the chart */
.gh-card{position:absolute;display:flex;align-items:center;gap:10px;padding:10px 14px;
  background:rgba(255,255,255,.95);border:1px solid var(--glass-border);
  border-radius:14px;box-shadow:0 16px 36px -14px rgba(0,30,100,.22),0 6px 12px -6px rgba(0,30,100,.10);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  font-family:var(--font-sub);font-size:.78rem;min-width:155px;
  animation:gh-card-float 4s ease-in-out infinite alternate}
.gh-card b{display:block;color:var(--text);font-size:.86rem;font-weight:600;line-height:1.2}
.gh-card span{display:block;color:var(--text-dim);font-size:.72rem;margin-top:2px;line-height:1.3}
.gh-card-ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex-shrink:0;
  background:linear-gradient(135deg,rgba(0,131,163,.14),rgba(0,82,204,.12));color:var(--cyan)}
.gh-card-ic svg{width:18px;height:18px}
.gh-card{opacity:0;transform:translateY(20px) scale(.92);
  animation:gh-card-in .7s cubic-bezier(.34,1.3,.5,1) forwards,gh-card-float 4s ease-in-out 1.5s infinite alternate}
.gh-card-a{top:18%;left:-4%;animation-delay:.6s,2.1s}
.gh-card-b{bottom:18%;right:-6%;animation-delay:1.1s,2.6s}
.gh-card-c{top:6%;right:-4%;animation-delay:.9s,2.4s}
.gh-card-d{bottom:6%;left:-2%;animation-delay:1.4s,2.9s}
.gh-card-b .gh-card-ic{background:linear-gradient(135deg,rgba(245,184,0,.18),rgba(245,184,0,.10));color:var(--gold)}
.gh-card-c .gh-card-ic{background:linear-gradient(135deg,rgba(25,195,125,.18),rgba(25,195,125,.10));color:#19c37d}
.gh-card-d .gh-card-ic{background:linear-gradient(135deg,rgba(0,82,204,.18),rgba(0,131,163,.10));color:var(--blue)}
@keyframes gh-card-in{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes gh-card-float{from{transform:translateY(0)}to{transform:translateY(-10px)}}

/* Dashboard "LIVE" pill — green dot pulses */
.growth-svg .gh-live{opacity:0;animation:gh-live-in .6s ease-out forwards .3s}
.growth-svg .gh-live-dot{transform-origin:12px 11px;transform-box:fill-box;animation:gh-live-pulse 1.6s ease-in-out infinite 1s}
@keyframes gh-live-in{to{opacity:1}}
@keyframes gh-live-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.55}}

/* Outer dashed orbit rings — slow counter-rotation */
.growth-svg .gh-orbit{transform-origin:230px 230px;animation:gh-orbit-spin 38s linear infinite;opacity:0;animation:gh-orbit-in 1s ease-out forwards .2s,gh-orbit-spin 38s linear infinite 1.2s}
.growth-svg .gh-orbit-2{animation:gh-orbit-in 1s ease-out forwards .4s,gh-orbit-spin-rev 52s linear infinite 1.4s}
@keyframes gh-orbit-in{to{opacity:1}}
@keyframes gh-orbit-spin{to{transform:rotate(360deg)}}
@keyframes gh-orbit-spin-rev{to{transform:rotate(-360deg)}}

/* Pulse rings around each data dot — staggered, expand + fade infinitely */
.growth-svg .gh-pulse{transform-origin:center;transform-box:fill-box;opacity:0;
  animation:gh-pulse-ring 2.4s ease-out infinite;
  animation-delay:calc(3s + var(--i,0) * .35s)}
@keyframes gh-pulse-ring{
  0%  {opacity:.6;transform:scale(.5)}
  70% {opacity:0;transform:scale(3)}
  100%{opacity:0;transform:scale(3)}
}

/* Particle trail behind rocket — each particle fades in then floats up + fades */
.growth-svg .gh-particle{opacity:0;transform-box:fill-box;transform-origin:center;
  animation:gh-particle-rise 1.4s ease-out forwards;
  animation-delay:var(--d,1s)}
@keyframes gh-particle-rise{
  0%  {opacity:0;transform:translate(0,0) scale(.5)}
  20% {opacity:.9;transform:translate(-2px,-4px) scale(1)}
  100%{opacity:0;transform:translate(-14px,-26px) scale(.3)}
}

/* Hide extra cards at narrow widths so chart breathes */
@media (max-width: 1100px){
  .gh-card-c,.gh-card-d{display:none}
}
@media (max-width: 900px){
  .gh-card-a,.gh-card-b,.gh-card-c,.gh-card-d{display:none}
  .growth-svg .gh-particle,.growth-svg .gh-pulse,.growth-svg .gh-orbit,.growth-svg .gh-orbit-2{display:none}
}

/* legacy rocket-stage (hidden) — keep for any old refs */
.rocket-stage{display:none !important}
.rocket-stage{position:relative;width:62%;aspect-ratio:1;display:grid;place-items:center;
  animation:rocket-float 5s var(--ease) infinite alternate;
  filter:drop-shadow(0 30px 50px rgba(0,40,120,.35)) drop-shadow(0 10px 24px rgba(0,82,204,.25))}
.rocket-svg{width:100%;height:100%;overflow:visible}
.rocket-svg .rk-flame{transform-origin:150px 220px;animation:rocket-flame .3s ease-in-out infinite alternate}
@keyframes rocket-float{from{transform:translateY(0) rotate(-3deg)}to{transform:translateY(-22px) rotate(3deg)}}
@keyframes rocket-flame{from{transform:scaleY(0.85) scaleX(1)}to{transform:scaleY(1.15) scaleX(0.92)}}
/* Legacy orb styles kept for any leftover references */
.orb{width:78%;aspect-ratio:1;border-radius:50%;position:relative;display:grid;place-items:center;animation:float 7s var(--ease) infinite alternate}
.orb-core{font-family:var(--font-display);font-weight:700;font-size:clamp(1.4rem,3vw,2.4rem);text-align:center;line-height:1.1}
.orb-core span{display:block;font-family:var(--font-sub);font-weight:500;font-size:.7rem;letter-spacing:.2em;color:var(--cyan);text-transform:uppercase;margin-top:6px}
.ring{position:absolute;inset:-6%;border:1px dashed rgba(255,255,255,.18);border-radius:50%;
  animation:spin 30s linear infinite}
.ring.r2{inset:-18%;border-color:rgba(0,229,255,.18);animation-duration:42s;animation-direction:reverse}
.node{position:absolute;display:inline-flex;align-items:center;gap:7px;font-size:.78rem;font-weight:600;
  font-family:var(--font-sub);padding:8px 13px;border-radius:999px;color:var(--text);
  background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.04));
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 8px 24px -8px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.4);
  animation:float 6s var(--ease) infinite alternate}
.node .dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.node.n1{top:4%;left:50%;transform:translateX(-50%)}
.node.n2{top:34%;right:-6%;animation-delay:-1.5s}
.node.n3{bottom:6%;right:8%;animation-delay:-2.5s}
.node.n4{bottom:14%;left:-6%;animation-delay:-3.5s}
.node.n5{top:30%;left:-8%;animation-delay:-1s}
.node.n5 .dot{background:var(--gold);box-shadow:0 0 10px var(--gold)}
.node.n3 .dot{background:var(--gold);box-shadow:0 0 10px var(--gold)}
@keyframes float{from{transform:translateY(0)}to{transform:translateY(-16px)}}
@keyframes float-centered{from{transform:translateX(-50%) translateY(0)}to{transform:translateX(-50%) translateY(-16px)}}
@keyframes spin{to{transform:rotate(360deg)}}
.node.n1{animation-name:float-centered}
.node.n2,.node.n3,.node.n4,.node.n5{transform-origin:center}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;padding:26px 0;
  border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:56px;width:max-content;animation:scroll-x 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--font-display);font-weight:600;font-size:1.15rem;
  color:var(--text-faint);display:flex;align-items:center;gap:12px;white-space:nowrap}
.marquee-item::before{content:"◆";color:var(--cyan);font-size:.7rem}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ---------- Stats ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.stat{padding:30px 22px;text-align:center}
.stat .num{font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.7rem);
  background:linear-gradient(180deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .label{font-size:.82rem;color:var(--text-dim);margin-top:6px;font-family:var(--font-sub)}

/* ---------- Service cards ---------- */
.cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.service-card{padding:30px 26px;transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.service-card:hover{transform:translateY(-8px)}
.service-card:hover::before{opacity:1}
.svc-icon{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:18px}
.service-card h3{font-size:1.18rem;margin-bottom:10px}
.service-card p{color:var(--text-dim);font-size:.92rem}
.service-card .more{display:inline-flex;gap:6px;margin-top:16px;font-size:.85rem;font-weight:600;
  color:var(--cyan);font-family:var(--font-sub)}

/* ---------- Split (why choose) ---------- */
.split{display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:stretch}
.split > *{display:flex;flex-direction:column;justify-content:center}
.benefit-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:10px}
.benefit{display:flex;gap:13px;align-items:flex-start;padding:18px;border-radius:18px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.benefit:hover{transform:translateY(-3px);box-shadow:0 12px 28px -14px rgba(0,30,100,.18)}
.benefit .tick{flex:0 0 auto;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  color:#fff;font-weight:700;background:linear-gradient(135deg,var(--cyan),var(--blue));
  box-shadow:0 6px 16px -6px rgba(0,131,163,.45)}
.benefit .tick svg{width:20px;height:20px}
.benefit:hover .tick{transform:scale(1.05) rotate(-3deg);transition:transform .35s var(--ease)}
/* Unique tick colour per category */
.benefit .tick-target  {background:linear-gradient(135deg,#00b6e6,#0083a3);box-shadow:0 6px 16px -6px rgba(0,182,230,.5)}
.benefit .tick-team    {background:linear-gradient(135deg,#5a8dff,#0052cc);box-shadow:0 6px 16px -6px rgba(0,82,204,.5)}
.benefit .tick-fast    {background:linear-gradient(135deg,#ffd84a,#f1a000);color:#3b2400;box-shadow:0 6px 16px -6px rgba(245,184,0,.5)}
.benefit .tick-quality {background:linear-gradient(135deg,#c47dff,#7a32cc);box-shadow:0 6px 16px -6px rgba(140,82,255,.45)}
.benefit .tick-report  {background:linear-gradient(135deg,#54e5b0,#08a76a);box-shadow:0 6px 16px -6px rgba(8,167,106,.45)}
.benefit .tick-support {background:linear-gradient(135deg,#ff7a8d,#d63555);box-shadow:0 6px 16px -6px rgba(214,53,85,.45)}

/* ---------- Why P&P animated visual ---------- */
.why-visual{aspect-ratio:1;display:grid;place-items:center;position:relative;width:115%;margin-left:-7.5%;min-height:100%}
.why-svg{width:100%;height:auto;overflow:visible;filter:drop-shadow(0 36px 70px rgba(0,40,120,.26)) drop-shadow(0 14px 28px rgba(0,82,204,.18))}
.why-svg .why-rings{transform-origin:180px 180px;animation:why-rings-spin 40s linear infinite}
.why-svg .why-orbit-a,
.why-svg .why-orbit-b,
.why-svg .why-orbit-c{transform-origin:180px 180px}
.why-svg .why-orbit-a{animation:why-orbit 14s linear infinite}
.why-svg .why-orbit-b{animation:why-orbit 10s linear infinite reverse}
.why-svg .why-orbit-c{animation:why-orbit 7s linear infinite}
.why-svg .why-trend{stroke-dasharray:520;stroke-dashoffset:520;animation:why-trend-draw 3.2s cubic-bezier(.6,.05,.28,.91) forwards .25s}
.why-svg .why-area{opacity:0;animation:why-area-fade 1s ease-out forwards 2.4s}
.why-svg .why-dots circle{opacity:0;transform-origin:center;animation:why-dot-pop .55s cubic-bezier(.4,1.5,.6,1) forwards}
.why-svg .why-dots circle:nth-child(1){animation-delay:.6s}
.why-svg .why-dots circle:nth-child(2){animation-delay:.95s}
.why-svg .why-dots circle:nth-child(3){animation-delay:1.3s}
.why-svg .why-dots circle:nth-child(4){animation-delay:1.65s}
.why-svg .why-dots circle:nth-child(5){animation-delay:2s}
.why-svg .why-dots circle:nth-child(6){animation-delay:2.35s}
.why-svg .why-dots circle:nth-child(7){animation-delay:2.7s}
.why-svg .why-spark{transform-origin:300px 90px;animation:why-spark-pulse 2.4s ease-in-out infinite 3s}
@keyframes why-rings-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes why-orbit{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes why-trend-draw{to{stroke-dashoffset:0}}
@keyframes why-area-fade{to{opacity:1}}
@keyframes why-dot-pop{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
@keyframes why-spark-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.55}}
@media(max-width:860px){.why-visual{width:100%;margin-left:0;max-width:460px;margin-right:auto;margin-left:auto}}
.benefit b{font-family:var(--font-sub);font-weight:600;font-size:.98rem}
.benefit p{color:var(--text-dim);font-size:.85rem;margin-top:2px}
.glass-visual{aspect-ratio:1;position:relative;display:grid;place-items:center;padding:30px}
.glass-visual .pulse{position:absolute;width:60%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(0,229,255,.4),transparent 70%);filter:blur(30px);
  animation:float 6s var(--ease) infinite alternate}
.metric-chip{position:relative;z-index:1;text-align:center}
.metric-chip .big{font-family:var(--font-display);font-weight:700;font-size:3.4rem;
  background:linear-gradient(180deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.metric-chip .sm{color:var(--text-dim);font-family:var(--font-sub)}

/* ---------- Portfolio ---------- */
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.port-card{position:relative;min-height:280px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:26px;transition:transform .4s var(--ease);overflow:hidden}
.port-card .cat{position:absolute;top:20px;left:20px;font-size:.72rem;font-weight:600;z-index:2;
  font-family:var(--font-sub);letter-spacing:.1em;text-transform:uppercase;color:var(--navy-900);
  padding:6px 12px;border-radius:999px;background:linear-gradient(100deg,var(--cyan),var(--blue-bright))}
.port-card .bg-art{position:absolute;inset:0;z-index:-1;opacity:.5;
  background:radial-gradient(circle at 70% 20%, rgba(0,229,255,.4),transparent 55%),
             radial-gradient(circle at 20% 90%, rgba(245,184,0,.25),transparent 55%)}
.port-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.7;transition:opacity .4s,transform .6s var(--ease)}
.port-card::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(6,12,24,.92) 40%,rgba(6,12,24,.3) 100%)}
.port-card h3,.port-card .res,.port-card .tech{position:relative;z-index:2}
.port-card:hover{transform:translateY(-8px) scale(1.01)}
.port-card:hover .port-img{opacity:.9;transform:scale(1.05)}
.port-card h3{font-size:1.25rem;margin-bottom:6px}
.port-card .res{color:var(--cyan);font-family:var(--font-sub);font-weight:600;font-size:.9rem}
.port-card .tech{color:var(--text-faint);font-size:.8rem;margin-top:8px}

/* ---------- Process timeline ---------- */
.timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative}
.timeline::before{content:"";position:absolute;top:34px;left:8%;right:8%;height:2px;
  background:linear-gradient(90deg,var(--cyan),var(--blue),var(--gold));opacity:.4}
.step{text-align:center;padding:0 8px}
.step .bubble{width:68px;height:68px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:1.2rem;position:relative;
  background:var(--glass-fill-strong);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:var(--shadow-glass)}
.step h3{font-size:1.05rem;margin-bottom:6px}
.step p{color:var(--text-dim);font-size:.85rem}

/* ---------- Testimonials ---------- */
.tcarousel{position:relative;overflow:hidden}
.ttrack{display:flex;transition:transform .6s var(--ease)}
.tcard{flex:0 0 100%;padding:44px;display:grid;gap:22px}
.tcard p.quote{font-family:var(--font-sub);font-size:1.3rem;line-height:1.5;font-weight:500}
.tclient{display:flex;align-items:center;gap:14px}
.tclient .av{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;font-weight:700;
  font-family:var(--font-display);color:#04111f;
  background:linear-gradient(135deg,var(--cyan),var(--gold))}
.tclient b{font-family:var(--font-sub)}
.tclient span{display:block;color:var(--text-faint);font-size:.85rem}
.tdots{display:flex;gap:9px;justify-content:center;margin-top:26px}
.tdots button{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.25);transition:.3s}
.tdots button.on{width:26px;border-radius:999px;background:var(--cyan)}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.price-card{padding:34px 30px;display:flex;flex-direction:column;transition:transform .35s var(--ease)}
.price-card:hover{transform:translateY(-8px)}
.price-card.featured{background:var(--glass-fill-strong);
  border-color:rgba(0,229,255,.4);transform:scale(1.03)}
.price-card.featured:hover{transform:scale(1.03) translateY(-8px)}
.badge{align-self:flex-start;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#04111f;padding:6px 13px;border-radius:999px;margin-bottom:16px;
  background:linear-gradient(100deg,var(--cyan),var(--gold))}
.price-card h3{font-size:1.4rem}
.price-card .who{color:var(--text-faint);font-size:.86rem;margin-bottom:18px}
.price-card .price{font-family:var(--font-display);font-weight:700;font-size:2.6rem;margin-bottom:4px}
.price-card .price small{font-size:.95rem;color:var(--text-dim);font-weight:400}
.price-card ul{display:grid;gap:11px;margin:22px 0 26px}
.price-card li{display:flex;gap:10px;font-size:.92rem;color:var(--text-dim)}
.price-card li::before{content:"✓";color:var(--cyan);font-weight:700}
.price-card .btn{margin-top:auto;justify-content:center}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post-card{overflow:hidden;display:flex;flex-direction:column;transition:transform .35s var(--ease)}
.post-card:hover{transform:translateY(-8px)}
.post-thumb{aspect-ratio:16/9;position:relative;
  background:linear-gradient(135deg,rgba(0,102,255,.35),rgba(0,229,255,.2));
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:2rem;opacity:.9}
.post-thumb .tag{position:absolute;top:14px;left:14px;font-size:.7rem;font-weight:600;
  padding:5px 11px;border-radius:999px;background:rgba(6,12,24,.6);color:var(--cyan);
  border:1px solid rgba(0,229,255,.3)}
.post-body{padding:24px}
.post-body .meta{font-size:.78rem;color:var(--text-faint);font-family:var(--font-sub)}
.post-body h3{font-size:1.18rem;margin:8px 0 10px;line-height:1.25}
.post-body p{color:var(--text-dim);font-size:.9rem}
.post-body .more{display:inline-flex;gap:6px;margin-top:14px;color:var(--cyan);font-weight:600;
  font-family:var(--font-sub);font-size:.85rem}

/* ---------- Final CTA ---------- */
.cta-band{position:relative;padding:70px 50px;text-align:center;overflow:hidden}
.cta-band h2{font-size:clamp(2rem,4.5vw,3.4rem);margin-bottom:16px}
.cta-band p{color:var(--text-dim);max-width:56ch;margin:0 auto 30px;font-size:1.08rem}
.cta-band .hero-cta{justify-content:center}
.cta-band .glow{position:absolute;width:600px;height:300px;left:50%;top:-40%;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(0,229,255,.35),transparent 70%);filter:blur(40px);z-index:-1}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid rgba(255,255,255,.07);padding:70px 0 30px;margin-top:40px;
  background:linear-gradient(180deg,transparent,rgba(6,12,24,.6))}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;margin-bottom:50px}
.footer-col h4{font-family:var(--font-sub);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-faint);margin-bottom:18px}
.footer-col ul{display:grid;gap:11px}
.footer-col a{color:var(--text-dim);font-size:.92rem;transition:color .2s}
.footer-col a:hover{color:var(--cyan)}
.footer-brand p{color:var(--text-dim);font-size:.92rem;margin:16px 0;max-width:34ch}
.socials{display:flex;gap:10px}
.socials a{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
  background:var(--glass-fill);border:1px solid var(--glass-border);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:transform .25s,background .25s}
.socials a:hover{transform:translateY(-3px);background:var(--glass-fill-strong)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  padding-top:26px;border-top:1px solid rgba(255,255,255,.07);
  color:var(--text-faint);font-size:.85rem}
.footer-bottom .links{display:flex;gap:20px}
.footer-bottom a:hover{color:var(--cyan)}

/* ---------- Contact form ---------- */
.form-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:30px;align-items:start}
.field{margin-bottom:16px}
.field label{display:block;font-size:.82rem;font-family:var(--font-sub);font-weight:500;
  color:var(--text-dim);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:.95rem;color:var(--text);
  padding:13px 16px;border-radius:14px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  transition:border .25s,background .25s;outline:none}
.field input::placeholder,.field textarea::placeholder{color:var(--text-faint)}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--cyan);background:rgba(0,229,255,.06)}
.field select option{background:var(--navy-800)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-info{padding:32px}
.contact-info .row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.07)}
.contact-info .row:last-child{border-bottom:none}
.contact-info .ic{width:42px;height:42px;border-radius:12px;flex:0 0 auto;display:grid;place-items:center;
  font-size:1.1rem;background:linear-gradient(135deg,rgba(0,229,255,.2),rgba(0,102,255,.12));
  border:1px solid rgba(255,255,255,.15)}
.contact-info .row b{font-family:var(--font-sub);font-size:.95rem}
.contact-info .row span{display:grid;color:var(--text-dim);font-size:.88rem}
.map-glass{margin-top:22px;height:200px;border-radius:18px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(0,102,255,.18),rgba(0,229,255,.1));
  color:var(--text-dim);font-family:var(--font-sub);position:relative;overflow:hidden}
.map-glass::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(140,180,255,.12) 1px,transparent 1px),
    linear-gradient(90deg,rgba(140,180,255,.12) 1px,transparent 1px);background-size:28px 28px}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{padding:160px 0 60px;text-align:center}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.6rem);margin:18px auto 16px;max-width:16ch}
.page-hero .lead{margin:0 auto}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:14px;max-width:820px;margin:0 auto}
.faq details{padding:6px 26px;transition:background .3s}
.faq summary{padding:20px 0;font-family:var(--font-sub);font-weight:600;font-size:1.05rem;
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--cyan);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 0 20px;color:var(--text-dim)}

/* values / mission grid */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.trio .glass{padding:30px}
.trio h3{font-size:1.25rem;margin-bottom:10px}
.trio p{color:var(--text-dim);font-size:.94rem}
.value-tags{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.value-tags .glass{padding:14px 24px;font-family:var(--font-sub);font-weight:600}

/* sub-services list (services page) */
.svc-block{padding:32px;margin-bottom:0;display:flex;flex-direction:column;align-items:flex-start;height:100%}
.svc-block .svc-icon{margin-bottom:16px;flex-shrink:0}
.svc-block h3{font-size:1.3rem;margin-bottom:14px;line-height:1.3}
.svc-block ul{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0;padding:0;list-style:none;width:100%}
.svc-block li{display:flex;gap:9px;font-size:.9rem;color:var(--text-dim);align-items:flex-start;line-height:1.45}
.svc-block li::before{content:"▹";color:var(--cyan);flex-shrink:0;line-height:1.45}
.svc-block .more{display:inline-flex;gap:6px;margin-top:18px;font-size:.85rem;font-weight:600;color:var(--cyan);align-items:center}
.svc-block .more::after{content:"→";transition:transform .25s var(--ease)}
.svc-block:hover .more::after{transform:translateX(4px)}
/* Force consistent icon dimensions across all card types */
.svc-block .svc-icon,
.service-card .svc-icon{width:60px;height:60px;border-radius:18px;display:grid;place-items:center;margin-bottom:18px;font-size:1.7rem;line-height:1}
.svc-block .svc-icon{background:linear-gradient(135deg,rgba(0,131,163,.12),rgba(0,82,204,.10));color:var(--cyan)}
.service-card{display:flex;flex-direction:column;align-items:flex-start;height:100%}
.service-card h3{margin-bottom:8px;line-height:1.3}
.service-card p{margin-bottom:auto}
.service-card .more{margin-top:18px;align-self:flex-start}
/* KPI card alignment lock */
.kpi-card{align-items:flex-start;justify-content:flex-start}
.kpi-card .kpi-icon-wrap{flex-shrink:0}
.kpi-card .kpi-num{margin-top:4px}
.kpi-card .kpi-sub{margin-top:0}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none;place-content: center;}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Loader ---------- */
.loader{position:fixed;inset:0;z-index:200;display:grid;place-items:center;
  background:var(--navy-900);transition:opacity .6s,visibility .6s}
.loader.hide{opacity:0;visibility:hidden}
.loader .spin{width:64px;height:64px;border-radius:50%;
  border:3px solid rgba(255,255,255,.12);border-top-color:var(--cyan);
  animation:spin 1s linear infinite}
.loader .lbl{position:absolute;margin-top:110px;font-family:var(--font-display);font-weight:700;
  letter-spacing:.3em;color:var(--text-dim);font-size:.8rem}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .port-grid,.price-grid,.blog-grid,.trio{grid-template-columns:1fr 1fr}
  .timeline{grid-template-columns:1fr 1fr;gap:34px}
  .timeline::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .nav-links{position:fixed;top:74px;left:16px;right:16px;flex-direction:column;align-items:stretch;gap:4px;
    padding:14px;border-radius:22px;z-index:140;
    background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(245,247,255,.92));
    backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);
    border:1px solid rgba(0,30,100,.12);box-shadow:0 24px 60px -16px rgba(0,30,100,.20),0 8px 22px -8px rgba(0,30,100,.10);
    transform:translateY(-14px);opacity:0;pointer-events:none;transition:.3s var(--ease)}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a,.has-dropdown .nav-parent{padding:13px 16px;color:var(--text);background:transparent;border-radius:12px}
  .nav-links a:hover,.nav-links a.active,.has-dropdown .nav-parent:hover,.has-dropdown.active > .nav-parent{color:var(--cyan);background:rgba(0,131,163,.08)}
  .nav-links a .ic,.has-dropdown .nav-parent .ic{color:var(--cyan);opacity:.9}
  /* Mobile: dropdown becomes an inline accordion inside the hamburger menu */
  .has-dropdown{display:block;width:100%}
  .has-dropdown .nav-parent{display:flex;justify-content:space-between;width:100%}
  .dropdown-panel{position:static;display:none;grid-template-columns:1fr;
    background:rgba(0,131,163,.04);border:none;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;
    margin:4px 0 8px;padding:6px;opacity:1;visibility:visible;transform:none}
  .has-dropdown.open .dropdown-panel{display:grid}
  .dd-item{padding:11px 14px;font-size:.88rem}
  .hamburger{display:flex !important;border:1px solid rgba(0,30,100,.10);background:rgba(255,255,255,.6)}
  .hamburger span{background:var(--text)}
  /* HIDE the consultation button on mobile — beat existing higher-specificity rule */
  .site-header .nav-right .btn-primary{display:none !important}
  .hero-grid,.split,.form-grid{grid-template-columns:1fr}
  .hero-visual{max-width:380px;margin:0 auto;order:2}
  .benefit-list{grid-template-columns:1fr}
  /* Hide orbital service-name pills on mobile — they overlap the growth chart */
  .node{display:none !important}
  /* Keep growth chart contained inside its column on mobile */
  .growth-stage{width:100%;max-width:340px;margin:0 auto}
  .hero-visual{overflow:visible}
  .ring,.ring.r2{display:none}
}
@media(max-width:680px){
  .section{padding:68px 0}
  .stats-grid,.cards-grid,.port-grid,.price-grid,.blog-grid,.trio,.svc-block ul,.field-row{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr}
  .price-card.featured{transform:none}
  .price-card.featured:hover{transform:translateY(-8px)}
  .footer-grid,.footer-bottom{grid-template-columns:1fr;text-align:left}
  .cta-band{padding:48px 24px}
  .tcard{padding:30px}
  .tcard p.quote{font-size:1.1rem}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   v2 ADDITIONS — icons, Let's Talk, mobile tab bar
   ============================================================ */

/* ---------- Icon base ---------- */
.ic{width:16px;height:16px;flex:0 0 auto;vertical-align:-2px;display:inline-block}

/* ---------- Header nav with icons ---------- */
.nav-links a{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.nav-links a .ic,.nav-links a > svg{width:15px;height:15px;opacity:.8;transition:opacity .2s;flex-shrink:0}
.nav-links a:hover .ic,.nav-links a.active .ic{opacity:1;color:var(--cyan)}
.nav-links a span{line-height:1}

/* ---------- Services dropdown ---------- */
.has-dropdown{position:relative;display:inline-flex;align-items:center}
.has-dropdown .nav-parent{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-sub);font-weight:500;
  font-size:.9rem;color:var(--text-dim);padding:7px 10px;border-radius:12px;text-decoration:none;
  white-space:nowrap;cursor:pointer;transition:color .2s,background .2s}
.has-dropdown .nav-parent:hover,.has-dropdown.active > .nav-parent{color:var(--text);background:rgba(255,255,255,.07)}
.has-dropdown .nav-parent .ic{width:15px;height:15px;opacity:.8;flex-shrink:0;transition:opacity .2s}
.has-dropdown.active > .nav-parent .ic,.has-dropdown .nav-parent:hover .ic{opacity:1;color:var(--cyan)}
.has-dropdown .dd-caret{width:12px;height:12px;margin-left:2px;opacity:.65;transition:transform .25s,opacity .2s}
.has-dropdown:hover .dd-caret,.has-dropdown.open .dd-caret{transform:rotate(180deg);opacity:1;color:var(--cyan)}

.dropdown-panel{position:absolute;top:calc(100% + 10px);left:0;min-width:280px;
  padding:8px;border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,255,.96));
  border:1px solid rgba(0,30,100,.10);
  box-shadow:0 24px 60px -18px rgba(0,30,100,.22),0 10px 24px -10px rgba(0,30,100,.12),inset 0 1px 0 rgba(255,255,255,.6);
  backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .22s ease,transform .22s ease,visibility .22s ease;
  z-index:140;display:grid;grid-template-columns:1fr 1fr;gap:2px}
.has-dropdown:hover .dropdown-panel,.has-dropdown.open .dropdown-panel{opacity:1;visibility:visible;transform:none}
.dropdown-panel::before{content:"";position:absolute;top:-12px;left:0;right:0;height:14px}
.dd-item{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  color:var(--text);font-family:var(--font-sub);font-weight:500;font-size:.86rem;text-decoration:none;
  transition:background .18s,color .18s}
.dd-item:hover,.dd-item.active{background:rgba(0,131,163,.08);color:var(--cyan)}
.dd-item .ic{width:16px;height:16px;color:var(--cyan);opacity:.85;flex-shrink:0}
.dd-item.active .ic,.dd-item:hover .ic{opacity:1}
.dd-item span{line-height:1.2}
.site-header .nav-right .btn-primary{display:inline-flex;align-items:center;gap:8px}
.site-header .nav-right .btn-primary .ic{width:16px;height:16px}
.brand .mark{font-size:.92rem}

/* tighten desktop nav so 8 icon-links + CTA fit comfortably */
@media (min-width:861px){
  .nav{gap:10px}
  .brand{font-size:1.06rem}
  .nav-links{gap:0}
  .nav-links a,.has-dropdown .nav-parent{padding:7px 8px;font-size:.84rem;gap:6px}
  .nav-links a .ic,.has-dropdown .nav-parent .ic{width:14px;height:14px}
  .has-dropdown .dd-caret{width:11px;height:11px}
  .site-header .nav-right .btn-primary{padding:10px 15px;font-size:.85rem;gap:6px}
  .site-header .nav-right .btn-primary .ic{width:15px;height:15px}
}
/* icon-only nav on narrower laptops to guarantee the CTA always fits */
@media (min-width:861px) and (max-width:1199px){
  .nav-links a span,.has-dropdown .nav-parent span{display:none}
  .nav-links a{padding:9px 11px}
  .nav-links a .ic{width:19px;height:19px}
}

/* ---------- Footer links with icons ---------- */
.footer-col a{display:inline-flex;align-items:center;gap:9px}
.footer-col a .ic{width:16px;height:16px;color:var(--cyan);opacity:.85}
.socials a .ic{width:18px;height:18px}
.footer-bottom .links a[href="admin.html"]{color:var(--text-faint)}
.footer-bottom .links a[href="admin.html"]:hover{color:var(--cyan)}

/* ---------- Floating "Let's Talk" widget ---------- */
.lets-talk{position:fixed;right:22px;bottom:22px;z-index:120;display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.lt-fab{display:inline-flex;align-items:center;gap:9px;padding:13px 20px;border-radius:50px;
  font-family:var(--font-sub);font-weight:600;font-size:.95rem;color:#04223a;
  background:linear-gradient(135deg,var(--cyan),var(--blue-bright));
  box-shadow:0 14px 36px -8px rgba(0,229,255,.55),inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .25s var(--ease),box-shadow .25s}
.lt-fab .ic{width:20px;height:20px}
.lt-fab:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 20px 46px -8px rgba(0,229,255,.7)}
.lt-panel{width:320px;max-width:calc(100vw - 44px);padding:18px;border-radius:22px;
  transform-origin:bottom right;transform:scale(.86) translateY(10px);opacity:0;pointer-events:none;
  transition:transform .3s var(--ease),opacity .3s}
.lets-talk.open .lt-panel{transform:none;opacity:1;pointer-events:auto}
.lets-talk:not(.open) .lt-panel{display:none}
.lt-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.lt-head strong{font-family:var(--font-display);font-size:1.05rem}
.lt-x{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:var(--text-dim);
  background:rgba(255,255,255,.06)}
.lt-x:hover{color:var(--text);background:rgba(255,255,255,.12)}
.lt-x .ic{width:16px;height:16px}
.lt-sub{font-size:.85rem;color:var(--text-dim);margin-bottom:12px}
.lt-form{display:grid;gap:9px}
.lt-form input,.lt-form textarea{width:100%;padding:11px 13px;border-radius:12px;
  background:rgba(255,255,255,.05);border:1px solid var(--glass-border);color:var(--text);
  font-family:var(--font-body);font-size:.9rem;resize:vertical}
.lt-form input:focus,.lt-form textarea:focus{outline:none;border-color:var(--cyan);background:rgba(255,255,255,.08)}
.lt-form .btn-primary{width:100%;justify-content:center;display:inline-flex;align-items:center;gap:8px}
.lt-form .btn-primary .ic{width:17px;height:17px}
.lt-wa{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:12px;
  font-family:var(--font-sub);font-weight:600;font-size:.88rem;color:#25D366;
  border:1px solid rgba(37,211,102,.4);background:rgba(37,211,102,.08)}
.lt-wa:hover{background:rgba(37,211,102,.16)}
.lt-wa .ic{width:18px;height:18px}
.lt-done{display:none;align-items:center;gap:8px;margin-top:10px;font-size:.86rem;color:var(--cyan)}
.lt-done .ic{width:16px;height:16px}

/* ---------- Mobile bottom tab bar (app style, light theme) ---------- */
.mobile-tabs{display:none;position:fixed;left:0;right:0;bottom:0;z-index:115;
  grid-auto-flow:column;grid-auto-columns:1fr;
  padding:8px 10px calc(8px + env(safe-area-inset-bottom,0px));
  background:linear-gradient(180deg,rgba(255,255,255,.85),rgba(245,247,255,.96));
  backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);
  border-top:1px solid rgba(0,30,100,.10);box-shadow:0 -8px 30px -10px rgba(0,30,100,.10)}
.mobile-tabs a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  padding:6px 4px;border-radius:14px;color:var(--text-dim);font-family:var(--font-sub);
  font-size:.66rem;font-weight:600;letter-spacing:.02em;transition:color .2s,background .2s;text-decoration:none}
.mobile-tabs a .ic{width:22px;height:22px;color:var(--text-dim);opacity:.85;transition:color .2s,opacity .2s}
.mobile-tabs a.active{color:var(--cyan)}
.mobile-tabs a.active .ic{color:var(--cyan);opacity:1}
.mobile-tabs a:hover{color:var(--cyan)}
.mobile-tabs a:hover .ic{color:var(--cyan)}
.mobile-tabs a:active{background:rgba(0,131,163,.10)}

/* ---------- Responsive switch ---------- */
@media (max-width:680px){
  .lets-talk{display:none !important;}     /* hide floating button on mobile (replaced by tab bar) */
  .mobile-tabs{display:grid;}
  body{padding-bottom:78px}                /* avoid content under the fixed tab bar */
  body{padding-bottom:70px;}               /* room so tab bar never covers content */
  .site-footer{margin-bottom:0;}
}

/* ============================================================
   NEW HOMEPAGE SECTIONS
   ============================================================ */

/* ---------- Focus headings ---------- */
.focus-heading{font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.15;letter-spacing:-.03em;font-weight:700}

/* ---------- Client logos section ---------- */
.clients-section{padding-top:40px}
.logos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:44px}
.logo-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:22px 18px;border-radius:20px;transition:transform .3s var(--ease),box-shadow .3s;
  text-decoration:none;color:var(--text)}
.logo-item:hover{transform:translateY(-5px);box-shadow:0 20px 48px -14px rgba(0,229,255,.2)}
.logo-item img{width:100%;max-width:130px;height:52px;object-fit:contain;filter:brightness(.8) saturate(.6);
  transition:filter .3s}
.logo-item:hover img{filter:brightness(1) saturate(1)}
.logo-name{font-family:var(--font-sub);font-size:.75rem;font-weight:600;letter-spacing:.05em;
  color:var(--text-faint);text-transform:uppercase;text-align:center}

/* ---------- Results / KPI section ---------- */
.results-section{background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(0,102,255,.06),transparent)}
.results-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:44px}
.kpi-card{padding:32px 26px;border-radius:24px;display:flex;flex-direction:column;align-items:flex-start;gap:12px;
  box-shadow:0 24px 60px -16px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.07),0 8px 32px -8px rgba(0,229,255,.14);
  transition:transform .35s var(--ease),box-shadow .35s}
.kpi-card:hover{transform:translateY(-7px);
  box-shadow:0 32px 72px -16px rgba(0,0,0,.7),0 0 0 1px rgba(0,229,255,.18),0 12px 40px -8px rgba(0,229,255,.22)}
.kpi-icon-wrap{width:46px;height:46px;border-radius:14px;display:grid;place-items:center}
.kpi-icon-wrap svg{width:22px;height:22px}
.kpi-cyan{background:rgba(0,229,255,.12);color:var(--cyan);box-shadow:0 0 24px -6px rgba(0,229,255,.25)}
.kpi-blue{background:rgba(0,102,255,.14);color:#6ba8ff;box-shadow:0 0 24px -6px rgba(0,102,255,.25)}
.kpi-gold{background:rgba(245,184,0,.12);color:var(--gold);box-shadow:0 0 24px -6px rgba(245,184,0,.25)}
.kpi-num{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;
  background:linear-gradient(135deg,#fff 40%,rgba(255,255,255,.55));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.kpi-label{font-family:var(--font-sub);font-weight:600;font-size:1rem;color:var(--text)}
.kpi-sub{font-size:.82rem;color:var(--text-faint);margin-top:-6px}
.results-chart{margin-top:50px;background:rgba(255,255,255,.03);border:1px solid var(--glass-border);
  border-radius:24px;padding:28px 28px 18px;display:flex;flex-direction:column;gap:16px}
.chart-label{font-family:var(--font-sub)}
.chart-label strong{font-size:1rem;font-weight:600}
.growth-chart-img{width:100%;border-radius:12px}

/* ---------- Service detail layout (rich content pages) ---------- */
/* Disable reveal animation on service-page body content — show instantly */
.svc-detail .reveal,
.svc-detail .reveal.d1,
.svc-detail .reveal.d2,
.svc-detail .reveal.d3,
.svc-detail .reveal.d4,
.svc-body .reveal,
.svc-body .cover-block,
.svc-body .num-row,
.svc-body .step-block,
.svc-body .callout,
.svc-aside .aside-card,
.svc-aside .aside-cta{opacity:1 !important;transform:none !important;transition:none !important}
.svc-detail{padding:60px 0 20px}
.svc-detail .container{max-width:1080px}
.svc-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
@media(max-width:1000px){.svc-detail-grid{grid-template-columns:1fr;gap:32px}}
.svc-body h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.65rem,2.6vw,2rem);line-height:1.25;margin:48px 0 14px;color:var(--text)}
.svc-body h2:first-child{margin-top:0}
.svc-body h3{font-family:var(--font-sub);font-weight:600;font-size:1.18rem;margin:26px 0 10px;color:var(--text);line-height:1.3}
.svc-body p{color:var(--text-dim);font-size:1rem;line-height:1.78;margin:0 0 16px}
.svc-body p strong{color:var(--text);font-weight:600}
.svc-body p a, .svc-body li a{color:var(--blue);text-decoration:none;border-bottom:1px solid rgba(0,82,204,.25);transition:border-color .2s,color .2s}
.svc-body p a:hover, .svc-body li a:hover{color:var(--cyan);border-bottom-color:var(--cyan)}
.svc-body > ul{padding-left:0;list-style:none;margin:14px 0 24px}
.svc-body > ul > li{position:relative;padding:8px 0 8px 30px;color:var(--text-dim);font-size:.98rem;line-height:1.7}
.svc-body > ul > li::before{content:"";position:absolute;left:6px;top:18px;width:8px;height:8px;border-radius:2px;background:linear-gradient(135deg,var(--cyan),var(--blue))}
.svc-body > ul > li strong{color:var(--text);font-weight:600}

/* Hero stat strip — small inline tiles below H1 */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:28px 0 8px;max-width:760px}
@media(max-width:640px){.stat-strip{grid-template-columns:repeat(2,1fr)}}
.stat-strip .st{padding:18px 16px;border:1px solid var(--glass-border);border-radius:14px;background:var(--glass-fill);backdrop-filter:blur(10px);text-align:left;position:relative;overflow:hidden}
.stat-strip .st::before{content:"";position:absolute;top:14px;right:14px;width:22px;height:22px;border-radius:7px;background:linear-gradient(135deg,rgba(0,131,163,.14),rgba(0,82,204,.10));opacity:.85}
.stat-strip .st::after{content:"";position:absolute;top:18px;right:18px;width:14px;height:14px;background-repeat:no-repeat;background-position:center;background-size:14px}
.stat-strip .st:nth-child(1)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2l2.4 7.4H22l-6.2 4.5 2.4 7.4L12 17l-6.2 4.3 2.4-7.4L2 9.4h7.6z'/%3E%3C/svg%3E")}
.stat-strip .st:nth-child(2)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='22 12 18 12 15 21 9 3 6 12 2 12'/%3E%3C/svg%3E")}
.stat-strip .st:nth-child(3)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 7v5l3.5 2'/%3E%3C/svg%3E")}
.stat-strip .st:nth-child(4)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7' rx='1.5'/%3E%3Crect x='14' y='3' width='7' height='7' rx='1.5'/%3E%3Crect x='3' y='14' width='7' height='7' rx='1.5'/%3E%3Crect x='14' y='14' width='7' height='7' rx='1.5'/%3E%3C/svg%3E")}
.stat-strip .st .n,.stat-strip .st .l{position:relative;z-index:1}
.stat-strip .st .n{font-family:var(--font-display);font-weight:700;font-size:1.5rem;line-height:1;background:linear-gradient(135deg,var(--cyan),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-strip .st .l{font-family:var(--font-sub);font-weight:500;font-size:.78rem;color:var(--text-dim);margin-top:6px;line-height:1.35}

/* Numbered explainer rows (Why X matters, principles) */
.num-row{display:grid;grid-template-columns:54px 1fr;gap:18px;padding:18px 0;border-bottom:1px solid var(--glass-border)}
.num-row:last-child{border-bottom:none}
.num-row .nm{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--cyan);line-height:1.2;padding-top:2px}
.num-row .nm small{display:block;font-family:var(--font-sub);font-weight:500;font-size:.65rem;letter-spacing:.12em;color:var(--text-faint);text-transform:uppercase;margin-top:2px}
.num-row h3{margin:0 0 6px;font-size:1.12rem;line-height:1.3}
.num-row p{margin:0;font-size:.95rem;line-height:1.7;color:var(--text-dim)}

/* What-we-cover blocks — H3 title + paragraph + checklist */
.cover-block{padding:24px 26px;border-radius:18px;border:1px solid var(--glass-border);background:rgba(255,255,255,.50);backdrop-filter:blur(10px);margin-bottom:18px}
.cover-block h3{display:flex;align-items:center;gap:12px;margin:0 0 10px;font-size:1.12rem;line-height:1.3}
.cover-block h3 .ic{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,rgba(0,131,163,.12),rgba(0,82,204,.10));color:var(--cyan);display:grid;place-items:center;font-size:1.05rem;flex-shrink:0}
.cover-block p{margin:0 0 12px;font-size:.96rem;line-height:1.72;color:var(--text-dim)}
.cover-block ul{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:6px 16px}
@media(max-width:600px){.cover-block ul{grid-template-columns:1fr}}
.cover-block li{position:relative;padding:4px 0 4px 22px;font-size:.9rem;color:var(--text-dim);line-height:1.5}
.cover-block li::before{content:"✓";position:absolute;left:0;top:4px;color:var(--cyan);font-weight:700;font-size:.95rem}

/* Comparison table */
.svc-table{width:100%;border-collapse:collapse;margin:18px 0 28px;font-size:.94rem}
.svc-table th{text-align:left;padding:14px 16px;font-family:var(--font-sub);font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text);background:rgba(0,131,163,.08);border-bottom:2px solid rgba(0,131,163,.20)}
.svc-table td{padding:14px 16px;color:var(--text-dim);line-height:1.6;border-bottom:1px solid var(--glass-border);vertical-align:top}
.svc-table tr:hover td{background:rgba(0,131,163,.03)}
.svc-table td strong{color:var(--text);font-weight:600}

/* Practical steps */
.step-block{display:grid;grid-template-columns:50px 1fr;gap:18px;padding:20px 22px;border-radius:14px;background:rgba(255,255,255,.45);border:1px solid var(--glass-border);margin-bottom:14px;transition:border-color .25s,box-shadow .25s}
.step-block:hover{border-color:rgba(0,131,163,.35);box-shadow:0 8px 24px -12px rgba(0,30,100,.12)}
.step-block .sn{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--blue));color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.05rem;flex-shrink:0}
.step-block h3{margin:0 0 6px;font-size:1.05rem;line-height:1.3}
.step-block p{margin:0;font-size:.94rem;line-height:1.7;color:var(--text-dim)}

/* Sidebar (Quick facts + related services) */
.svc-aside{position:sticky;top:100px;display:flex;flex-direction:column;gap:18px}
@media(max-width:1000px){.svc-aside{position:static}}
.aside-card{padding:22px;border-radius:18px;border:1px solid var(--glass-border);background:rgba(255,255,255,.55);backdrop-filter:blur(12px)}
.aside-card h4{font-family:var(--font-sub);font-weight:600;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);margin:0 0 14px}
.aside-card .facts{margin:0;padding:0;list-style:none}
.aside-card .facts li{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--glass-border);font-size:.88rem;color:var(--text-dim)}
.aside-card .facts li:last-child{border-bottom:none}
.aside-card .facts li b{color:var(--text);font-weight:600;font-family:var(--font-sub)}
.aside-card .alinks{list-style:none;margin:0;padding:0}
.aside-card .alinks li{margin-bottom:8px}
.aside-card .alinks a{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:9px;color:var(--text);text-decoration:none;background:rgba(0,131,163,.04);font-size:.9rem;transition:background .2s,color .2s}
.aside-card .alinks a:hover{background:rgba(0,131,163,.10);color:var(--cyan)}
.aside-card .alinks a::after{content:"→";margin-left:auto;color:var(--text-faint);transition:transform .2s,color .2s}
.aside-card .alinks a:hover::after{transform:translateX(3px);color:var(--cyan)}
.aside-cta{padding:24px;border-radius:18px;background:linear-gradient(135deg,rgba(0,131,163,.10),rgba(0,82,204,.10));border:1px solid rgba(0,131,163,.25);text-align:center}
.aside-cta h4{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--text);margin:0 0 8px;line-height:1.3}
.aside-cta p{font-size:.88rem;color:var(--text-dim);margin:0 0 14px;line-height:1.55}
.aside-cta .btn{padding:11px 16px;font-size:.85rem;width:100%;justify-content:center}

/* Standards / chip strip */
.chip-strip{display:flex;flex-wrap:wrap;gap:8px;margin:20px 0 8px}
.chip-strip .chip{font-family:var(--font-sub);font-weight:600;font-size:.74rem;letter-spacing:.06em;padding:6px 12px;border-radius:999px;background:rgba(0,131,163,.10);color:var(--cyan);border:1px solid rgba(0,131,163,.20)}
.chip-strip .chip.gold{background:rgba(192,136,0,.10);color:var(--gold);border-color:rgba(192,136,0,.22)}
.chip-strip .chip.blue{background:rgba(0,82,204,.08);color:var(--blue);border-color:rgba(0,82,204,.20)}

/* Related-services strip at bottom */
.rel-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:14px}
.rel-strip a{padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.55);border:1px solid var(--glass-border);color:var(--text);text-decoration:none;font-size:.92rem;font-weight:600;display:flex;align-items:center;justify-content:space-between;transition:background .2s,border-color .2s,color .2s}
.rel-strip a:hover{background:rgba(0,131,163,.08);border-color:rgba(0,131,163,.30);color:var(--cyan)}
.rel-strip a::after{content:"→";color:var(--text-faint);transition:transform .2s,color .2s}
.rel-strip a:hover::after{transform:translateX(3px);color:var(--cyan)}

/* Pull-quote / key callout */
.callout{padding:22px 26px;border-left:4px solid var(--cyan);background:rgba(0,131,163,.05);border-radius:0 14px 14px 0;margin:22px 0;font-style:normal}
.callout p{margin:0;color:var(--text);font-size:1rem;line-height:1.7}
.callout p strong{color:var(--cyan)}

/* Icons inside case-study result tiles + featured-case fcase-stat tiles */
.cs-result{position:relative;overflow:hidden}
.cs-result::after{content:"";position:absolute;top:12px;right:12px;width:14px;height:14px;background-repeat:no-repeat;background-position:center;background-size:14px;opacity:.65;
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='22 12 18 12 15 21 9 3 6 12 2 12'/%3E%3C/svg%3E")}
.fcase-stat{position:relative;overflow:hidden}
.fcase-stat::after{content:"";position:absolute;top:12px;right:12px;width:16px;height:16px;background-repeat:no-repeat;background-position:center;background-size:16px;opacity:.7}
.fcase-stat:nth-child(1)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2v20M2 12h20'/%3E%3C/svg%3E")}
.fcase-stat:nth-child(2)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 17 9 11 13 15 21 7'/%3E%3Cpolyline points='14 7 21 7 21 14'/%3E%3C/svg%3E")}
.fcase-stat:nth-child(3)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E")}
.fcase-stat:nth-child(4)::after{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230083a3' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='13 2 3 14 12 14 11 22 21 10 12 10 13 2'/%3E%3C/svg%3E")}

/* ---------- Our Offices (home) ---------- */
.offices-section{padding-top:0}
.offices-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
@media(max-width:980px){.offices-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.offices-grid{grid-template-columns:1fr}}
.office-card{position:relative;padding:26px 24px;border-radius:20px;border:1px solid var(--glass-border);
  background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(248,250,255,.55));
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  display:flex;flex-direction:column;gap:14px;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;overflow:hidden}
.office-card:hover{transform:translateY(-6px);border-color:rgba(0,131,163,.35);box-shadow:0 22px 50px -18px rgba(0,30,100,.22)}
.office-card::before{content:"";position:absolute;inset:0;border-radius:20px;pointer-events:none;
  background:radial-gradient(circle at 80% 0%,rgba(0,131,163,.10),transparent 60%);opacity:0;transition:opacity .35s}
.office-card:hover::before{opacity:1}
.office-flag{width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(0,131,163,.14),rgba(0,82,204,.10));color:var(--cyan);
  display:grid;place-items:center;flex-shrink:0;box-shadow:0 8px 22px -6px rgba(0,131,163,.30)}
.office-flag svg{width:26px;height:26px}
.office-meta{position:relative;z-index:1}
.office-region{display:inline-block;font-family:var(--font-sub);font-size:.7rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);
  background:rgba(0,131,163,.08);padding:4px 10px;border-radius:999px;margin-bottom:10px}
.office-meta h3{font-family:var(--font-display);font-weight:700;font-size:1.35rem;line-height:1.15;margin:0 0 4px;color:var(--text)}
.office-meta p{margin:0;color:var(--text-dim);font-size:.92rem}
.office-hours{font-family:var(--font-sub);font-size:.78rem;color:var(--text-faint);margin-top:12px;
  padding-top:12px;border-top:1px solid var(--glass-border)}
.office-card-hq{background:linear-gradient(180deg,rgba(0,131,163,.10),rgba(0,82,204,.07));border-color:rgba(0,131,163,.25)}
.office-card-hq .office-flag{background:linear-gradient(135deg,var(--cyan),var(--blue));color:#fff}
.office-card-hq .office-region{background:rgba(192,136,0,.14);color:var(--gold)}

/* ---------- Featured case study (home) ---------- */
.featured-case{display:flex;flex-direction:column;gap:18px}
.fcase-head .fcase-tags{display:flex;gap:8px;flex-wrap:wrap}
.fcase-head .fcase-tags .cs-tag{font-family:var(--font-sub);font-weight:600;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:999px;background:rgba(0,131,163,.10);color:var(--cyan)}
.fcase-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:8px 0 4px}
@media(max-width:760px){.fcase-grid{grid-template-columns:repeat(2,1fr)}}
.fcase-stat{padding:18px 16px;border-radius:14px;border:1px solid var(--glass-border);background:rgba(0,131,163,.04)}
.fcase-stat .v{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,2.4vw,1.85rem);line-height:1;background:linear-gradient(135deg,var(--cyan),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.fcase-stat .l{font-family:var(--font-sub);font-size:.78rem;color:var(--text-dim);margin-top:6px;line-height:1.4}
.fcase-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

/* ---------- FAQ Section (AI-Overview ready) ---------- */
.faq-section{padding:60px 0}
.faq-wrap{max-width:880px;margin:0 auto}
.faq-list{display:flex;flex-direction:column;gap:14px;margin-top:36px}
.faq-item{border:1px solid var(--glass-border);border-radius:16px;background:var(--glass-fill);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);overflow:hidden;transition:box-shadow .3s var(--ease),border-color .3s}
.faq-item:hover{border-color:rgba(0,131,163,.30);box-shadow:0 8px 24px -10px rgba(0,30,100,.12)}
.faq-q{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;
  font-family:var(--font-sub);font-weight:600;font-size:1.02rem;color:var(--text);line-height:1.4;margin:0;user-select:none}
.faq-q::after{content:"+";font-family:var(--font-display);font-weight:600;font-size:1.6rem;color:var(--cyan);
  flex-shrink:0;transition:transform .3s var(--ease);line-height:1}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;padding:0 24px;color:var(--text-dim);font-size:.96rem;line-height:1.7;
  transition:max-height .35s var(--ease),padding .35s var(--ease)}
.faq-item.open .faq-a{max-height:600px;padding:0 24px 22px}
.faq-eyebrow{display:inline-block;font-size:.75rem;letter-spacing:.18em;font-weight:600;text-transform:uppercase;
  color:var(--cyan);font-family:var(--font-sub);margin-bottom:12px}
.faq-section h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,3.5vw,2.4rem);
  line-height:1.2;margin-bottom:10px}
.faq-intro{color:var(--text-dim);font-size:1.02rem;line-height:1.6;max-width:600px}

/* ---------- Animated service icons ---------- */
.svc-icon{width:60px;height:60px;border-radius:18px;display:grid;place-items:center;margin-bottom:20px}
.svc-svg{width:38px;height:38px;overflow:visible}

/* colour themes per service */
.svc-seo{background:rgba(0,229,255,.1);color:var(--cyan);box-shadow:0 0 28px -8px rgba(0,229,255,.28)}
.svc-web{background:rgba(43,139,255,.12);color:#6ba8ff;box-shadow:0 0 28px -8px rgba(43,139,255,.28)}
.svc-app{background:rgba(0,102,255,.12);color:#80b8ff;box-shadow:0 0 28px -8px rgba(0,102,255,.28)}
.svc-uiux{background:rgba(101,90,255,.12);color:#a89cff;box-shadow:0 0 28px -8px rgba(101,90,255,.28)}
.svc-ads{background:rgba(245,184,0,.1);color:var(--gold);box-shadow:0 0 28px -8px rgba(245,184,0,.28)}
.svc-consulting{background:rgba(0,229,255,.08);color:var(--cyan);box-shadow:0 0 28px -8px rgba(0,229,255,.2)}
.svc-video{background:rgba(255,80,120,.1);color:#ff6e8a;box-shadow:0 0 28px -8px rgba(255,80,120,.28)}
.svc-branding{background:rgba(245,184,0,.1);color:var(--gold);box-shadow:0 0 28px -8px rgba(245,184,0,.25)}
.svc-instagram{background:linear-gradient(135deg,rgba(255,80,120,.12),rgba(140,82,255,.12));color:#d44a99;box-shadow:0 0 28px -8px rgba(214,53,153,.28)}
.svc-cpi{background:rgba(0,82,204,.12);color:#5a8dff;box-shadow:0 0 28px -8px rgba(90,141,255,.28)}
.svc-audit{background:rgba(0,229,255,.10);color:var(--cyan);box-shadow:0 0 28px -8px rgba(0,229,255,.25)}
/* Hover-animation hooks for new icons */
.service-card:hover .svc-instagram .svc-pulse{animation:pulse-blink 1.2s ease-in-out infinite}
.service-card:hover .svc-cpi .svc-trend{animation:dash-in .8s ease forwards}
.service-card:hover .svc-cpi .svc-pulse{animation:pulse-blink 1.4s ease-in-out infinite}
.service-card:hover .svc-audit{transform:rotate(-3deg);transition:transform .35s var(--ease)}
.service-card:hover .svc-audit .svc-line{animation:dash-in .6s ease forwards}
@keyframes pulse-blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}

/* --- SEO: draw search circle on hover --- */
.svc-seo .svc-path{transition:stroke-dashoffset .6s ease}
.service-card:hover .svc-seo .svc-trend{animation:dash-in .7s ease forwards}
@keyframes dash-in{from{stroke-dasharray:0 60}to{stroke-dasharray:60 0}}

/* --- Web: code brackets bounce --- */
.service-card:hover .svc-web .svc-code{animation:bounce-code .5s ease infinite alternate}
@keyframes bounce-code{from{transform:scaleX(1)}to{transform:scaleX(1.06)}}

/* --- App: pulse bottom dot --- */
.svc-pulse{animation:pulse-dot 2.4s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{r:2.5;opacity:.7}50%{r:4;opacity:1}}

/* --- UI/UX: layers float up --- */
.svc-uiux .svc-layer1,.svc-uiux .svc-layer2,.svc-uiux .svc-layer3{transition:transform .4s var(--ease)}
.service-card:hover .svc-uiux .svc-layer1{transform:translateY(-5px)}
.service-card:hover .svc-uiux .svc-layer2{transform:translateY(-2px)}

/* --- Ads: rings pulse --- */
.svc-ads .svc-ring3{animation:ring-pulse 2.5s ease-in-out infinite}
.svc-ads .svc-ring2{animation:ring-pulse 2.5s ease-in-out infinite .3s}
@keyframes ring-pulse{0%,100%{opacity:.3}50%{opacity:.65}}

/* --- Consulting: bars grow --- */
.svc-consulting .svc-bar1,.svc-consulting .svc-bar2,.svc-consulting .svc-bar3{transform-origin:bottom;transition:transform .5s var(--ease)}
.service-card:hover .svc-consulting .svc-bar1{transform:scaleY(1.15)}
.service-card:hover .svc-consulting .svc-bar2{transform:scaleY(1.1)}
.service-card:hover .svc-consulting .svc-bar3{transform:scaleY(1.05)}

/* --- Branding: star rotate + sparkles float --- */
.svc-branding .svc-star{transition:transform .5s var(--ease);transform-origin:24px 24px}
.service-card:hover .svc-branding .svc-star{transform:rotate(20deg) scale(1.05)}
.svc-sparkle{animation:sparkle-float 3s ease-in-out infinite}
.svc-sparkle:nth-child(2){animation-delay:.8s}
.svc-sparkle:nth-child(3){animation-delay:1.6s}
@keyframes sparkle-float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.2)}}

/* --- stat icons --- */
.stat-icon{width:28px;height:28px;color:var(--cyan);margin-bottom:8px;opacity:.7}

/* ---------- Responsive ---------- */
@media(max-width:1100px){
  .results-grid{grid-template-columns:repeat(2,1fr)}
  .logos-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:680px){
  .results-grid{grid-template-columns:1fr 1fr}
  .logos-grid{grid-template-columns:repeat(2,1fr)}
  .results-chart{padding:18px 14px}
  .kpi-card{padding:22px 18px}
  .focus-heading{font-size:clamp(1.6rem,6vw,2.2rem)}
}
@media(max-width:430px){
  .results-grid,.logos-grid{grid-template-columns:1fr 1fr}
}

/* ============================================================
   LIGHT THEME — complete override
   ============================================================ */

/* --- Tokens ------------------------------------------------ */
:root {
  --navy-900: #f5f7ff;
  --navy-800: #edf0fc;
  --navy-700: #e2e8ff;
  --blue:        #0052cc;
  --blue-bright: #1a6ee8;
  --cyan:        #0083a3;
  --gold:        #c08800;

  --text:       #0d1a3a;
  --text-dim:   #3d5280;
  --text-faint: #6b7eb0;

  --glass-fill:        linear-gradient(135deg,rgba(255,255,255,.88),rgba(255,255,255,.68));
  --glass-fill-strong: linear-gradient(135deg,rgba(255,255,255,.97),rgba(255,255,255,.85));
  --glass-border:      rgba(0,30,100,.10);
  --glass-blur:        20px;
  --glass-radius:      22px;

  --shadow-glass:
    0 2px 8px  rgba(0,20,70,.05),
    0 8px 32px rgba(0,20,70,.08),
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -1px 1px rgba(0,20,60,.03);
  --shadow-float: 0 20px 60px -20px rgba(0,20,70,.16);
}

/* --- Base -------------------------------------------------- */
body { background: #f5f7ff; }
::selection { background: var(--cyan); color: #fff; }

/* --- Ambient background ------------------------------------ */
.bg-stage {
  background:
    radial-gradient(1200px 800px at 80% -10%, rgba(0,82,204,.06), transparent 60%),
    radial-gradient(1000px 700px at 0%  100%, rgba(0,131,163,.05), transparent 55%),
    linear-gradient(180deg, #f5f7ff, #edf0fc 40%, #f5f7ff);
}
.bg-grid {
  background-image:
    linear-gradient(rgba(0,30,100,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,30,100,.04) 1px, transparent 1px);
}
.aurora { opacity: .25; }
.aurora.a { background: radial-gradient(circle, rgba(0,82,204,.22),  transparent 70%); }
.aurora.b { background: radial-gradient(circle, rgba(0,131,163,.18), transparent 70%); }
.aurora.c { background: radial-gradient(circle, rgba(192,136,0,.18), transparent 70%); }
.cursor-glow { background: radial-gradient(circle, rgba(0,82,204,.07), rgba(0,131,163,.03) 40%, transparent 70%); }

/* --- Glass primitive --------------------------------------- */
.glass {
  background: var(--glass-fill);
  border-color: var(--glass-border);
  box-shadow: var(--shadow-glass);
}
.glass::before {
  background: radial-gradient(120% 80% at 18% 0%, rgba(255,255,255,.70), transparent 50%);
  mix-blend-mode: normal;
}
.glass::after {
  background: linear-gradient(90deg, transparent, rgba(0,30,100,.07), transparent);
}

/* --- Loader ----------------------------------------------- */
.loader { background: #f5f7ff; }
.loader .spin { border-color: rgba(0,30,100,.12); border-top-color: var(--cyan); }
.loader .lbl  { color: var(--text-dim); }

/* --- Header ----------------------------------------------- */
.site-header.scrolled {
  background: linear-gradient(180deg, rgba(245,247,255,.92), rgba(237,240,252,.82));
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow: 0 1px 0 rgba(0,30,100,.08), 0 8px 28px -12px rgba(0,20,70,.12);
}
.nav-links a { color: var(--text-dim); }
.nav-links a:hover, .nav-links a.active { color: var(--text); background: rgba(0,30,100,.06); }
.nav-links a:hover .ic, .nav-links a.active .ic { color: var(--cyan); }
.nav-links.open {
  background: linear-gradient(180deg, rgba(245,247,255,.97), rgba(237,240,252,.96));
  border-color: rgba(0,30,100,.10);
  box-shadow: 0 20px 50px -16px rgba(0,20,70,.18);
}
.hamburger { background: var(--glass-fill); border-color: rgba(0,30,100,.10); }
.hamburger span { background: var(--text); }
.brand .mark { color: #fff; }
.brand small  { color: var(--text-faint); }

/* --- Scroll progress (keep colorful) ---------------------- */

/* --- Marquee ---------------------------------------------- */
.marquee { border-color: rgba(0,30,100,.08); }
.marquee-item { color: var(--text-faint); }

/* --- Trust pills ------------------------------------------ */
.trust-pill { background: rgba(0,30,100,.05); border-color: rgba(0,30,100,.10); color: var(--text-dim); }
.trust-pill b { color: var(--text); }
.trust-pill .ic { color: var(--cyan); }

/* --- Eyebrow pill ----------------------------------------- */
.eyebrow { background: rgba(0,131,163,.08); border-color: rgba(0,131,163,.25); }
.eyebrow::before { box-shadow: 0 0 8px var(--cyan); }

/* --- Stat numbers ----------------------------------------- */
.stat .num {
  background: linear-gradient(180deg, var(--text), var(--cyan));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* --- Hero orb nodes --------------------------------------- */
.node {
  background: linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,255,255,.72));
  border-color: rgba(0,30,100,.12);
  box-shadow: 0 6px 20px -6px rgba(0,20,70,.14), inset 0 1px 0 rgba(255,255,255,.95);
  color: var(--text);
}
/* Orb core sits on a blue gradient — keep text white for contrast */
.orb-core { color: #fff; text-shadow: 0 2px 14px rgba(0,40,140,.55); }
.orb-core span { color: rgba(255,255,255,.80); }

/* --- Stat icon -------------------------------------------- */
.stat-icon { color: var(--cyan); }

/* --- Service card "more" link ----------------------------- */
.service-card .more { color: var(--cyan); }

/* --- Service icon wraps ----------------------------------- */
.svc-seo        { background: rgba(0,131,163,.09); color: var(--cyan);       box-shadow: none; }
.svc-web        { background: rgba(26,110,232,.09); color: var(--blue-bright); box-shadow: none; }
.svc-app        { background: rgba(0,82,204,.09);   color: var(--blue);       box-shadow: none; }
.svc-uiux       { background: rgba(101,90,255,.09); color: #6558d4;           box-shadow: none; }
.svc-ads        { background: rgba(192,136,0,.09);  color: var(--gold);       box-shadow: none; }
.svc-consulting { background: rgba(0,131,163,.08);  color: var(--cyan);       box-shadow: none; }
.svc-video      { background: rgba(200,40,80,.09);  color: #b8214a;           box-shadow: none; }
.svc-branding   { background: rgba(192,136,0,.09);  color: var(--gold);       box-shadow: none; }

/* --- Metric chip (Why choose) ----------------------------- */
.metric-chip .big {
  background: linear-gradient(180deg, var(--text), var(--cyan));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.glass-visual .pulse { background: radial-gradient(circle, rgba(0,131,163,.18), transparent 70%); }

/* --- KPI card (Proven results) ---------------------------- */
.kpi-card {
  box-shadow:
    0 2px 12px rgba(0,20,70,.06),
    0 8px 32px rgba(0,20,70,.08),
    0 0 0 1px rgba(0,30,100,.07);
}
.kpi-card:hover {
  transform: translateY(-7px);
  box-shadow:
    0 12px 40px rgba(0,20,70,.13),
    0 0 0 1px rgba(0,82,204,.15);
}
.kpi-icon-wrap { overflow: hidden; }
.kpi-cyan { background: rgba(0,131,163,.10); color: var(--cyan);   box-shadow: none; }
.kpi-blue { background: rgba(0,82,204,.10);  color: var(--blue);   box-shadow: none; }
.kpi-gold { background: rgba(192,136,0,.10); color: var(--gold);   box-shadow: none; }
.kpi-num {
  background: linear-gradient(135deg, var(--text) 40%, var(--text-dim));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.kpi-label { color: var(--text); }
.kpi-sub   { color: var(--text-faint); }
.results-section { background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(0,82,204,.04), transparent); }
.results-chart {
  background: rgba(0,30,100,.025);
  border-color: rgba(0,30,100,.08);
  max-width: 820px;
  margin-left: auto;
  margin-right: auto;
  padding: 22px 24px 16px;
}
.growth-chart-img { max-height: 240px; object-fit: contain; }

/* --- Portfolio cards — icon-based KPI style (no images) --- */
.port-card.glass {
  background: var(--glass-fill);
  border: 1px solid var(--glass-border);
  box-shadow: 0 10px 30px -12px rgba(0,30,100,.12);
}
.port-card.glass::before { display: none; }
.port-card {
  min-height: 230px;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  align-items: flex-start;
  padding: 28px 26px 26px !important;
  border-radius: var(--glass-radius);
  overflow: visible;
  gap: 0;
}
.port-card::after,
.port-card::before { display: none !important; content: none !important; }
.port-card .bg-art,
.port-img { display: none !important; }
.port-icon {
  position: relative !important;
  z-index: 2;
  margin-bottom: 18px;
  flex-shrink: 0;
}
.port-card .cat {
  position: static !important;
  top: auto !important; left: auto !important;
  display: inline-flex;
  align-items: center;
  margin: 0 0 14px 0 !important;
  align-self: flex-start;
  z-index: 2;
  font-size: .68rem;
  padding: 5px 11px;
  color: #fff;
}
.port-card h3 {
  position: relative;
  z-index: 2;
  color: var(--text);
  margin: 0 0 8px 0;
  font-size: 1.2rem;
  line-height: 1.3;
}
.port-card .res {
  position: relative;
  z-index: 2;
  color: var(--blue);
  font-size: .98rem;
  font-weight: 600;
  margin-top: auto;
  padding-top: 8px;
}
.port-card .tech {
  position: relative;
  z-index: 2;
  color: var(--text-faint);
  font-size: .78rem;
  margin-top: 10px;
  letter-spacing: .01em;
}
.port-card:hover { transform: translateY(-6px); box-shadow: 0 18px 40px -14px rgba(0,30,100,.20); }
.port-grid { margin-top: 48px; }

/* --- Process timeline ------------------------------------- */
.step .bubble {
  background: rgba(255,255,255,.88);
  border-color: rgba(0,30,100,.12);
  box-shadow: 0 4px 20px rgba(0,20,70,.09);
}
.timeline::before { opacity: .25; }
.step p { color: var(--text-dim); }

/* --- Testimonials ----------------------------------------- */
.tcard p.quote { color: var(--text); }
.tdots button { background: rgba(0,30,100,.14); }
.tdots button.on { background: var(--cyan); }
.tclient span { color: var(--text-faint); }

/* --- Footer ----------------------------------------------- */
.site-footer {
  border-color: rgba(0,30,100,.08);
  background: linear-gradient(180deg, transparent, rgba(237,240,252,.55));
}
.footer-col h4 { color: var(--text-faint); }
.footer-col a  { color: var(--text-dim); }
.footer-col a:hover { color: var(--cyan); }
.footer-brand p { color: var(--text-dim); }
.socials a { background: rgba(255,255,255,.7); border-color: rgba(0,30,100,.10); }
.socials a:hover { background: rgba(255,255,255,.95); }
.footer-bottom { border-color: rgba(0,30,100,.08); color: var(--text-faint); }
.footer-bottom a:hover { color: var(--cyan); }
.footer-col a .ic { color: var(--cyan); }

/* --- Contact form ----------------------------------------- */
.field label { color: var(--text-dim); }
.field input, .field select, .field textarea {
  background: rgba(255,255,255,.85);
  border-color: rgba(0,30,100,.14);
  color: var(--text);
}
.field input::placeholder, .field textarea::placeholder { color: var(--text-faint); }
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--cyan);
  background: #fff;
}
.field select option { background: #fff; color: var(--text); }
.contact-info .row  { border-color: rgba(0,30,100,.08); }
.contact-info .ic   { background: linear-gradient(135deg, rgba(0,131,163,.10), rgba(0,82,204,.06)); border-color: rgba(0,30,100,.12); }
.contact-info .row b { color: var(--text); }
.map-glass { background: linear-gradient(135deg, rgba(0,82,204,.07), rgba(0,131,163,.05)); }
.map-glass::after {
  background-image:
    linear-gradient(rgba(0,30,100,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,30,100,.07) 1px, transparent 1px);
}

/* --- FAQ -------------------------------------------------- */
.faq summary::after { color: var(--cyan); }
.faq details p { color: var(--text-dim); }

/* --- Client logos ----------------------------------------- */
.logo-item img { filter: grayscale(.25) opacity(.8); }
.logo-item:hover img { filter: grayscale(0) opacity(1); }
.logo-name { color: var(--text-faint); }

/* --- Benefit ticks ---------------------------------------- */
.benefit b { color: var(--text); }
.benefit p { color: var(--text-dim); }

/* --- Buttons (ghost on light) ----------------------------- */
.btn-ghost {
  color: var(--text);
  border-color: rgba(0,30,100,.15);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.btn-ghost:hover { background: rgba(255,255,255,.95); border-color: rgba(0,30,100,.22); }

/* --- "Let's Talk" widget ---------------------------------- */
.lt-fab { color: #fff; }
.lt-x { background: rgba(0,30,100,.06); color: var(--text-dim); }
.lt-x:hover { background: rgba(0,30,100,.10); color: var(--text); }
.lt-sub { color: var(--text-dim); }
.lt-form input, .lt-form textarea {
  background: rgba(255,255,255,.85);
  border-color: rgba(0,30,100,.13);
  color: var(--text);
}
.lt-form input:focus, .lt-form textarea:focus { background: #fff; border-color: var(--cyan); }

/* --- Mobile bottom tab bar -------------------------------- */
.mobile-tabs {
  background: linear-gradient(180deg, rgba(245,247,255,.90), rgba(237,240,252,.96));
  border-color: rgba(0,30,100,.09);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
}
.mobile-tabs a { color: var(--text-faint); }
.mobile-tabs a.active { color: var(--cyan); }
.mobile-tabs a.active .ic { color: var(--cyan); }
.mobile-tabs a:active { background: rgba(0,30,100,.05); }

/* --- Post card (blog page) -------------------------------- */
.post-thumb { background: linear-gradient(135deg, rgba(0,82,204,.10), rgba(0,131,163,.07)); }
.post-thumb .tag { background: rgba(245,247,255,.92); color: var(--cyan); border-color: rgba(0,131,163,.2); }
.post-body .meta { color: var(--text-faint); }
.post-body p { color: var(--text-dim); }
.post-body .more { color: var(--cyan); }

/* --- Pricing page ----------------------------------------- */
.badge { color: #fff; }
.price-card .who { color: var(--text-faint); }
.price-card .price small { color: var(--text-dim); }
.price-card ul li { color: var(--text-dim); }
.price-card li::before { color: var(--cyan); }

/* --- Grad text — stays vivid on light --------------------- */
.grad-text {
  background: linear-gradient(100deg, var(--cyan), var(--blue-bright) 50%, var(--gold));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* --- Svc-block list bullets ------------------------------- */
.svc-block li::before { color: var(--cyan); }
.svc-block li { color: var(--text-dim); }

/* --- Page hero (inner pages) ------------------------------ */
.page-hero .lead { color: var(--text-dim); }


/* --- Admin panel light overrides -------------------------- */
.aside {
  border-right-color: rgba(0,30,100,.09);
  background: linear-gradient(180deg, rgba(255,255,255,.60), rgba(255,255,255,.40));
}
.anav:hover { background: rgba(0,30,100,.05); color: var(--text); }
.anav.on    { background: var(--glass-fill-strong); box-shadow: inset 0 1px 0 rgba(255,255,255,.8); }
table.inq th, table.inq td { border-color: rgba(0,30,100,.07); }
table.inq tr:hover td { background: rgba(0,30,100,.025); }
.icon-btn  { background: rgba(0,30,100,.05); color: var(--text-dim); }
.icon-btn:hover { background: rgba(0,30,100,.10); color: var(--text); }
.icon-btn.danger:hover { background: rgba(200,20,20,.09); color: #c00; }
.fld input, .fld textarea {
  background: rgba(255,255,255,.85); border-color: rgba(0,30,100,.13); color: var(--text);
}
.fld input:focus, .fld textarea:focus { background: #fff; border-color: var(--cyan); }
.admin-burger { background: rgba(255,255,255,.7); border-color: rgba(0,30,100,.12); color: var(--text); }
.login input {
  background: rgba(255,255,255,.85); border-color: rgba(0,30,100,.13); color: var(--text);
}
.login input:focus { border-color: var(--cyan); background: #fff; }
.modal-bg { background: rgba(13,26,58,.35); }
.badge.new  { background: rgba(0,131,163,.12); color: var(--cyan); }
.badge.read { background: rgba(0,30,100,.07);  color: var(--text-faint); }
.badge.done { background: rgba(20,160,80,.10); color: #0a7a3a; }
.note { background: rgba(192,136,0,.06); border-color: rgba(192,136,0,.2); }


/* ============================================================
   MOBILE DESIGN SYSTEM
   Professional, consistent spacing and layout across all pages.
   Hierarchy: 1024px tablet, 768px small tablet, 640px phone,
              480px small phone, 360px micro. Each cascade is
              minimal and complementary — no conflicts.
   ============================================================ */

/* ---------- 1024px — tablet ---------- */
@media (max-width: 1024px) {
  .container { padding-left: 24px; padding-right: 24px; }
  .hero { padding: 130px 0 70px; min-height: auto; }
  .hero h1 { font-size: clamp(2.1rem, 5vw, 3rem); }
  .hero-grid { grid-template-columns: 1fr; gap: 56px; }
  .hero-visual { max-width: 480px; margin: 0 auto; order: 2; }
  .split { grid-template-columns: 1fr; gap: 48px; align-items: start; }
  .form-grid { grid-template-columns: 1fr; gap: 24px; }
  .svc-detail-grid { grid-template-columns: 1fr; gap: 36px; }
  .svc-aside { position: static; }
  /* Hide overlapping decorative orbital pills + rings */
  .node, .ring, .ring.r2 { display: none !important; }
  /* Hide depth callout cards on tablet */
  .gh-card-a, .gh-card-b { display: none; }
}

/* ---------- 768px — small tablet / large phone ---------- */
@media (max-width: 768px) {
  /* Spacing scale */
  .container { padding-left: 20px; padding-right: 20px; }
  .section { padding: 64px 0; }
  .page-hero { padding: 96px 0 24px; }
  .hero { padding: 110px 0 56px; }

  /* Body typography */
  h1 { font-size: clamp(1.85rem, 6vw, 2.4rem); line-height: 1.18; letter-spacing: -0.01em; }
  h2, .title, .focus-heading { font-size: clamp(1.55rem, 5vw, 1.95rem); line-height: 1.22; }
  h3 { font-size: 1.1rem; line-height: 1.3; }
  p, .lead { font-size: 1rem; line-height: 1.7; }

  /* Header */
  .site-header { padding: 14px 0; }
  .site-header .nav { gap: 12px; }
  .site-header .brand { font-size: 1rem; gap: 10px; }
  .site-header .brand .mark { font-size: .78rem; padding: 6px 9px; }
  .site-header .brand small { display: none; }
  .site-header .nav-right .btn-primary { display: none !important; }
  .hamburger { display: flex !important; width: 42px; height: 42px; border-radius: 12px;
    background: rgba(255,255,255,.85); border: 1px solid rgba(0,30,100,.10); color: var(--text);
    align-items: center; justify-content: center; box-shadow: 0 4px 12px -4px rgba(0,30,100,.10); }
  .hamburger svg { width: 22px; height: 22px; }
  .hamburger:hover, .hamburger.open { background: linear-gradient(135deg, var(--cyan), var(--blue)); color: #fff; border-color: transparent; }

  /* Hero copy + CTAs */
  .hero .lead { margin-bottom: 8px; }
  .hero-reviews { gap: 10px; margin: 14px 0 4px; }
  .review-pill { padding: 9px 14px 9px 11px; flex: 0 1 auto; }
  .review-pill .rt-top strong { font-size: 1.05rem; }
  .review-pill .rt-sub { font-size: .7rem; }
  .review-pill .stars svg { width: 11px; height: 11px; }
  .hero-cta { flex-direction: column; gap: 12px; align-items: stretch; margin-bottom: 24px; }
  .hero-cta .btn { width: 100%; justify-content: center; padding: 14px 20px; }
  .trust-row { gap: 8px; }
  .trust-pill { padding: 7px 12px; font-size: .76rem; }

  /* Hero visual sizing */
  .hero-visual { max-width: 400px; padding: 0 8px; }
  .growth-stage { max-width: 360px; margin: 0 auto; }

  /* Grids — base mobile rules */
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .cards-grid { grid-template-columns: 1fr; gap: 16px; }
  .results-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .trio { grid-template-columns: 1fr; gap: 16px; }
  .timeline { grid-template-columns: 1fr; gap: 20px; }
  .timeline::before { display: none; }
  .benefit-list { grid-template-columns: 1fr; }
  .stat-strip { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .stat-strip .st { padding: 16px 14px; }
  .stat-strip .st .n { font-size: 1.25rem; }
  .stat-strip .st .l { font-size: .72rem; }
  .field-row { grid-template-columns: 1fr; gap: 14px; }

  /* Hero stats / about stats */
  .about-stats { grid-template-columns: repeat(2, 1fr); }
  .about-stat { padding: 18px 16px; }
  .stat { padding: 22px 18px; }
  .stat .num { font-size: 1.6rem; }
  .stat .label { font-size: .8rem; }

  /* Cards — consistent padding, never touching edges */
  .glass, .service-card, .svc-block, .kpi-card, .lead-card, .team-card,
  .office-card, .cs-card, .featured-case, .value-card, .exp-card, .cover-block,
  .num-row, .step-block, .aside-card, .aside-cta { padding-left: 20px; padding-right: 20px; }
  .service-card, .svc-block { padding: 26px 22px; }
  .kpi-card { padding: 24px 22px; }
  .lead-card { padding: 24px 22px; gap: 16px; }
  .lead-avatar { width: 64px; height: 64px; font-size: 1.25rem; }
  .team-grid { grid-template-columns: 1fr; }
  .leadership-grid { grid-template-columns: 1fr; }
  .values-grid, .exp-grid { grid-template-columns: 1fr; }

  /* Service detail sections */
  .num-row { grid-template-columns: 48px 1fr; gap: 16px; padding: 18px 0; }
  .num-row .nm { font-size: 1.3rem; }
  .cover-block { padding: 22px 20px; }
  .cover-block ul { grid-template-columns: 1fr; gap: 6px 0; }
  .cover-block h3 { font-size: 1.02rem; }
  .step-block { grid-template-columns: 42px 1fr; gap: 14px; padding: 18px 20px; }
  .step-block .sn { width: 38px; height: 38px; font-size: 1.02rem; }
  .rel-strip { grid-template-columns: 1fr; gap: 10px; }

  /* Comparison tables → stack as cards on mobile */
  .svc-table thead { display: none; }
  .svc-table, .svc-table tbody, .svc-table tr, .svc-table td { display: block; width: 100%; }
  .svc-table tr { background: rgba(255,255,255,.6); border: 1px solid var(--glass-border);
    border-radius: 14px; margin-bottom: 12px; padding: 14px 16px; }
  .svc-table td { padding: 6px 0; border: none; }
  .svc-table td:first-child { font-weight: 700; color: var(--text); padding-bottom: 8px; margin-bottom: 6px;
    border-bottom: 1px solid var(--glass-border); }

  /* Featured case + offices */
  .featured-case { padding: 26px 22px !important; }
  .fcase-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .fcase-stat { padding: 14px; }
  .fcase-stat .v { font-size: 1.25rem; }
  .fcase-cta { flex-direction: column; gap: 10px; }
  .fcase-cta .btn { width: 100%; justify-content: center; }
  .offices-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .office-card { padding: 22px 20px; }
  .office-flag { width: 48px; height: 48px; }

  /* CTA bands */
  .cta-band { padding: 44px 22px; }
  .cta-band h2 { font-size: clamp(1.55rem, 5.5vw, 1.95rem); }
  .cta-band p { font-size: .98rem; }
  .cta-band .hero-cta { flex-direction: column; align-items: stretch; gap: 10px; }
  .cta-band .hero-cta .btn { width: 100%; justify-content: center; }

  /* FAQ */
  .faq-section { padding: 50px 0; }
  .faq-wrap { padding: 0; }
  .faq-q { padding: 16px 18px; font-size: .96rem; gap: 12px; }
  .faq-item.open .faq-a { padding: 0 18px 18px; font-size: .94rem; line-height: 1.65; }

  /* Case studies */
  .cs-grid { grid-template-columns: 1fr; gap: 16px; }
  .cs-card { padding: 22px 20px; }
  .cs-results { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .cs-result { padding: 12px 14px; }
  .cs-result .v { font-size: 1.2rem; }
  .cs-filters { gap: 6px; }
  .cs-filter { padding: 7px 13px; font-size: .76rem; }
  .cs-nda { padding: 14px 18px; gap: 12px; }
  .cs-nda p { font-size: .85rem; line-height: 1.55; }

  /* Careers */
  .jobs-grid { grid-template-columns: 1fr; gap: 16px; }
  .job-card { padding: 24px 22px; }
  .detail-modal { padding: 24px 16px; }
  .detail-box { padding: 26px 22px; border-radius: 16px; }
  .detail-grid { grid-template-columns: 1fr 1fr; gap: 10px; }

  /* Page hero */
  .page-hero h1 { font-size: clamp(1.75rem, 6vw, 2.4rem); }
  .page-hero .lead { font-size: 1rem; }
  .chip-strip { gap: 6px; }
  .chip-strip .chip { font-size: .7rem; padding: 5px 10px; }

  /* Service body typography */
  .svc-body h2 { font-size: 1.45rem; margin: 36px 0 14px; }
  .svc-body h3 { font-size: 1.05rem; }
  .svc-body p { font-size: .97rem; line-height: 1.72; }
  .svc-detail .container { padding-left: 18px; padding-right: 18px; }

  /* Aside */
  .aside-card, .aside-cta { padding: 20px 22px; }

  /* Forms */
  .field input, .field select, .field textarea { font-size: 16px; padding: 13px 14px; } /* iOS no-zoom */
  .form-grid .glass { padding: 26px 22px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer-col h4 { font-size: 1rem; margin-bottom: 14px; }
  .footer-brand p { font-size: .94rem; }
  .footer-bottom { grid-template-columns: 1fr; text-align: center; gap: 14px; padding-top: 28px; }
  .footer-bottom .links { justify-content: center; flex-wrap: wrap; gap: 16px; }
  .footer-brand .socials { justify-content: flex-start; }
  .site-footer { padding: 64px 0 30px; }

  /* Section heads */
  .section-head { padding: 0; }
  .section-head .eyebrow { font-size: .72rem; }

  /* Mobile bottom tab bar — already styled, ensure spacing */
  body { padding-bottom: 76px; }

  /* Legal pages */
  .legal-wrap { padding: 0; }
  .legal-wrap h2 { font-size: 1.3rem; margin: 32px 0 12px; }
  .legal-wrap h3 { font-size: 1.05rem; margin: 22px 0 8px; }
  .legal-wrap p, .legal-wrap li { font-size: .96rem; line-height: 1.72; }
  .legal-toc { padding: 16px 18px; margin-bottom: 26px; }

  /* Universal: no horizontal scroll, wrap long links */
  html, body { overflow-x: hidden; }
  a, p, td, li { overflow-wrap: anywhere; word-break: normal; }
  img, video, svg.responsive { max-width: 100%; height: auto; }
  .cursor-glow { display: none; }
}

/* ---------- 640px — phone ---------- */
@media (max-width: 640px) {
  .container { padding-left: 18px; padding-right: 18px; }
  .section { padding: 56px 0; }
  .page-hero { padding: 88px 0 20px; }
  .hero { padding: 100px 0 48px; }

  /* Tighter typography */
  h1 { font-size: clamp(1.75rem, 7vw, 2.2rem); }
  h2, .title, .focus-heading { font-size: clamp(1.45rem, 5.5vw, 1.8rem); }

  /* Hero visual smaller */
  .hero-visual { max-width: 340px; }
  .growth-stage { max-width: 320px; }

  /* Stats and results to single column */
  .stats-grid { grid-template-columns: 1fr; }
  .results-grid { grid-template-columns: 1fr; }
  .about-stats { grid-template-columns: 1fr; }

  /* Featured case + offices single col */
  .fcase-grid { grid-template-columns: 1fr; gap: 10px; }
  .offices-grid { grid-template-columns: 1fr; gap: 14px; }

  /* Stat strip stays 2 cols but tighter */
  .stat-strip { gap: 10px; }
  .stat-strip .st .n { font-size: 1.15rem; }

  /* CS results stay 2 cols */
  .cs-results { gap: 8px; }
  .cs-result { padding: 11px 13px; }
  .cs-result .v { font-size: 1.1rem; }

  /* Trust pills smaller */
  .trust-pill { font-size: .72rem; padding: 6px 10px; }
  .trust-pill b { font-size: .8rem; }

  /* Step blocks tighter */
  .step-block { grid-template-columns: 38px 1fr; padding: 16px 18px; gap: 12px; }
  .step-block .sn { width: 34px; height: 34px; font-size: .92rem; }

  /* Career detail modal */
  .detail-grid { grid-template-columns: 1fr; }

  /* CTA tighter */
  .cta-band { padding: 36px 20px; }

  /* FAQ tighter */
  .faq-q { padding: 14px 16px; font-size: .92rem; }
  .faq-q::after { font-size: 1.4rem; }
  .faq-item.open .faq-a { padding: 0 16px 16px; font-size: .9rem; }

  /* Hero reviews — full width pills */
  .hero-reviews { gap: 8px; }
  .review-pill { flex: 1 1 100%; padding: 9px 14px; }

  /* Mobile bottom tab bar — keep labels readable */
  .mobile-tabs a { font-size: .62rem; }
}

/* ---------- 480px — small phone ---------- */
@media (max-width: 480px) {
  .container { padding-left: 16px; padding-right: 16px; }

  /* Even smaller hero */
  .hero h1 { font-size: 1.7rem; }
  .hero .lead { font-size: .94rem; }

  /* Headers tighter */
  h2, .title, .focus-heading { font-size: 1.4rem; }
  .svc-body h2 { font-size: 1.3rem; }

  /* Single column for stat strip on tiny screens */
  .stat-strip { grid-template-columns: 1fr; }

  /* Number rows tighter */
  .num-row { grid-template-columns: 40px 1fr; gap: 12px; }
  .num-row .nm { font-size: 1.15rem; }

  /* Cover blocks tighter */
  .cover-block { padding: 20px 18px; }
  .cover-block h3 { font-size: .98rem; gap: 10px; }
  .cover-block h3 .ic { width: 30px; height: 30px; font-size: .92rem; }

  /* Tighter cards */
  .featured-case, .glass, .service-card, .lead-card, .team-card, .office-card,
  .cs-card, .kpi-card, .value-card, .exp-card, .job-card { padding-left: 18px; padding-right: 18px; }

  /* Buttons */
  .btn { padding: 12px 18px; font-size: .9rem; gap: 8px; }

  /* Mobile tab bar — icons only on tiny screens */
  .mobile-tabs a span { display: none; }
  .mobile-tabs a .ic { width: 24px; height: 24px; }
  body { padding-bottom: 62px; }

  /* Footer bottom links wrap nicely */
  .footer-bottom .links a { font-size: .82rem; }
}

/* ---------- 360px — micro phone ---------- */
@media (max-width: 360px) {
  .hero h1 { font-size: 1.55rem; }
  h2, .title, .focus-heading { font-size: 1.3rem; }
  .stat-strip { grid-template-columns: 1fr; }
  .trust-row { flex-direction: column; align-items: stretch; }
  .trust-pill { justify-content: center; }
  .hero-cta { gap: 10px; }
  .cs-results { grid-template-columns: 1fr; }
  .fcase-grid { grid-template-columns: 1fr; }
}

/* ---------- Mobile dropdown polish ---------- */
@media (max-width: 768px) {
  .nav-links { position: fixed; top: 78px; left: 16px; right: 16px;
    flex-direction: column; align-items: stretch; gap: 4px;
    padding: 16px; border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(245,247,255,.95));
    backdrop-filter: blur(20px) saturate(160%);
    -webkit-backdrop-filter: blur(20px) saturate(160%);
    border: 1px solid rgba(0,30,100,.10);
    box-shadow: 0 26px 64px -16px rgba(0,30,100,.22), 0 10px 24px -8px rgba(0,30,100,.10);
    transform: translateY(-14px); opacity: 0; pointer-events: none;
    transition: transform .3s var(--ease), opacity .3s var(--ease); z-index: 140; }
  .nav-links.open { transform: none; opacity: 1; pointer-events: auto; }
  .nav-links a, .has-dropdown .nav-parent { padding: 13px 16px; color: var(--text);
    background: transparent; border-radius: 12px; font-size: .94rem; }
  .nav-links a:hover, .nav-links a.active,
  .has-dropdown .nav-parent:hover, .has-dropdown.active > .nav-parent {
    color: var(--cyan); background: rgba(0,131,163,.08); }
  .nav-links a .ic, .has-dropdown .nav-parent .ic { color: var(--cyan); opacity: .9; }
  .has-dropdown { display: block; width: 100%; }
  .has-dropdown .nav-parent { display: flex; justify-content: space-between; width: 100%; }
  .dropdown-panel { position: static; display: none; grid-template-columns: 1fr;
    background: rgba(0,131,163,.05); border: none; box-shadow: none;
    backdrop-filter: none; -webkit-backdrop-filter: none;
    margin: 4px 0 8px; padding: 6px; opacity: 1; visibility: visible; transform: none; }
  .has-dropdown.open .dropdown-panel { display: grid; }
  .dd-item { padding: 11px 14px; font-size: .88rem; }
}

/* ---------- Reduce motion respect ---------- */
@media (prefers-reduced-motion: reduce) {
  .gh-bar, .gh-trend, .gh-area, .gh-dots circle, .gh-rocket,
  .gh-flame, .gh-callout, .gh-spark, .why-rings, .why-orbit-a,
  .why-orbit-b, .why-orbit-c, .why-trend, .why-area, .why-dots circle,
  .why-spark, .gh-card { animation: none !important; opacity: 1 !important; transform: none !important; }
}

/* ============================================================
   MOBILE POLISH PASS — addresses specific user feedback
   ============================================================ */

/* 1. Contact info row icons — bigger emoji, perfectly centered */
.contact-info .ic{font-size:1.5rem;line-height:1;width:46px;height:46px;border-radius:13px}

/* 2. Remove Why P&P chart animation visual entirely (desktop + mobile) */
.why-visual{display:none !important}
.split{grid-template-columns:1fr !important;max-width:780px;margin:0 auto}

/* 3. Mobile bottom-tab bar — keep labels visible (don't hide on small) */
@media (max-width: 480px) {
  .mobile-tabs a span{display:inline-block !important;font-size:.62rem;line-height:1.1;margin-top:2px}
  .mobile-tabs a .ic{width:20px;height:20px}
  .mobile-tabs a{padding:8px 2px;gap:2px}
  body{padding-bottom:72px}
}
@media (max-width: 360px) {
  .mobile-tabs a span{font-size:.58rem}
}

/* ============================================================
   MOBILE-ONLY CENTRING (≤768px): reviews, KPIs, stats,
   contact info, headings, descriptions, footer
   ============================================================ */
@media (max-width: 768px) {

  /* Header — center brand, hamburger floats right */
  .site-header .nav{position:relative;justify-content:center}
  .site-header .brand{margin:0 auto}
  .site-header .nav-right{position:absolute;right:0;top:50%;transform:translateY(-50%)}

  /* Review pills — text + content centered */
  .hero-reviews{justify-content:center;flex-direction:column;align-items:center}
  .review-pill{width:100%;max-width:340px;justify-content:center;text-align:center}
  .review-pill .review-text{text-align:center}
  .review-pill .rt-top{justify-content:center}

  /* KPI cards — fully centered */
  .kpi-card{align-items:center !important;text-align:center}
  .kpi-card .kpi-icon-wrap{margin:0 auto}
  .kpi-card .kpi-num{text-align:center;width:100%}
  .kpi-card .kpi-label,.kpi-card .kpi-sub{text-align:center;width:100%}

  /* Stat tiles (home + about + service hero stat-strip) — centered */
  .stat{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}
  .stat .stat-icon{margin:0 auto 8px}
  .stat .num,.stat .label{text-align:center;width:100%}
  .about-stat{text-align:center}
  .about-stat .ic{position:static;display:block;margin:0 auto 10px;opacity:.7}
  .about-stat .n,.about-stat .l{text-align:center}
  .stat-strip .st{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}
  .stat-strip .st::before,.stat-strip .st::after{display:none}
  .stat-strip .st .n,.stat-strip .st .l{text-align:center;width:100%}

  /* Featured case stats centered */
  .fcase-stat{text-align:center}
  .fcase-stat::after{display:none}
  .fcase-stat .v,.fcase-stat .l{text-align:center;width:100%}

  /* Case study results centered */
  .cs-result{text-align:center}
  .cs-result::after{display:none}
  .cs-result .v,.cs-result .lbl{text-align:center;width:100%}
  .cs-card{text-align:center}
  .cs-card .cs-tags{justify-content:center}

  /* Office cards centered */
  .office-card{text-align:center;align-items:center}
  .office-flag{margin:0 auto}
  .office-meta{text-align:center;width:100%}
  .office-meta h3,.office-meta p,.office-region,.office-hours{text-align:center}

  /* Value cards + exp cards on about page */
  .value-card{text-align:center}
  .value-card .ic{margin:0 auto 12px}
  .exp-card h3{justify-content:center;text-align:center}
  .exp-card p{text-align:center}

  /* Leadership / Team cards centered */
  .lead-card{flex-direction:column;align-items:center;text-align:center;gap:14px}
  .lead-meta{text-align:center}
  .team-card{text-align:center;align-items:center}
  .team-avatar{margin:0 auto}
  .team-meta{text-align:center}
  .team-skills{justify-content:center}

  /* Trust pills centered */
  .trust-row{justify-content:center}

  /* Section heads + page hero centered */
  .section-head,.page-hero,.hero-copy{text-align:center}
  .hero-copy .lead,.hero-copy h1{text-align:center}
  .hero-cta{justify-content:center}

  /* Contact info rows — centered emoji + content */
  .contact-info{padding:24px}
  .contact-info .row{flex-direction:column;align-items:center;text-align:center;gap:8px;padding:18px 0}
  .contact-info .ic{width:54px;height:54px;font-size:1.7rem;margin:0 auto}
  .contact-info .row b,.contact-info .row span{text-align:center;width:100%}

  /* Featured case body centered */
  .featured-case h3,.featured-case p,.featured-case .ctx,.featured-case .fcase-tags{text-align:center;justify-content:center}
  .featured-case .fcase-tags{display:flex}
  .featured-case .fcase-head{text-align:center}
  .featured-case .fcase-cta{justify-content:center}

  /* SERVICE-PAGE cover blocks centered on mobile too */
  .cover-block h3{justify-content:center;text-align:center}
  .cover-block p{text-align:center}

  /* Footer — everything centered on mobile */
  .site-footer .footer-grid{text-align:center}
  .footer-brand,.footer-col{text-align:center}
  .footer-brand p{text-align:center;max-width:100%}
  .footer-brand .brand{justify-content:center}
  .footer-brand .socials{justify-content:center}
  .footer-col h4{text-align:center}
  .footer-col ul{text-align:center}
  .footer-col li{text-align:center}
  .footer-col li a{justify-content:center}
  .footer-bottom{text-align:center;justify-items:center}
  .footer-bottom .links{justify-content:center}

  /* Fast Response WhatsApp button — keep inside form box */
  #waLeadBtn,#ltWaBtn,#waApplyBtn{width:100% !important;box-sizing:border-box;margin-top:10px !important;padding:13px 16px !important;
    flex-wrap:wrap;text-align:center;justify-content:center !important;font-size:.9rem;line-height:1.3}
  #waLeadBtn span,#ltWaBtn span,#waApplyBtn span{white-space:normal;text-align:center}
  .form-grid,.form-grid > .glass,#contactGrid > .glass,#contactWrap{box-sizing:border-box;max-width:100%;overflow:hidden}
  #contactWrap{padding-left:0;padding-right:0}
  form#leadForm{max-width:100%;overflow:hidden}
}

/* ============================================================
   HERO 3D FUTURISTIC REDESIGN
   ============================================================ */

/* Hide the old orbit pills — overlap with new metric cards */
.hero-visual .node{display:none !important}

/* Stage gets perspective for true 3D depth */
.hero-visual{perspective:1400px;perspective-origin:50% 45%}
.growth-stage{transform-style:preserve-3d;transform:rotateX(8deg) rotateY(-6deg);transition:transform .8s var(--ease)}
.growth-stage:hover{transform:rotateX(4deg) rotateY(0deg)}

/* Holographic gradient backdrop ring */
.growth-stage::before{
  content:"";position:absolute;inset:-6%;border-radius:50%;pointer-events:none;z-index:0;
  background:
    radial-gradient(circle at 30% 30%, rgba(0,229,255,.22), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(0,82,204,.18), transparent 60%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.4), transparent 70%);
  filter:blur(30px);opacity:.85;
  animation:hero-aurora 14s ease-in-out infinite alternate
}
@keyframes hero-aurora{
  from{transform:scale(1) rotate(0deg);opacity:.7}
  to{transform:scale(1.08) rotate(35deg);opacity:1}
}

/* Subtle floor shadow for "anchored in space" feel */
.growth-stage::after{
  content:"";position:absolute;left:10%;right:10%;bottom:-2%;height:30px;border-radius:50%;
  background:radial-gradient(ellipse at center, rgba(0,30,100,.20), transparent 65%);
  filter:blur(14px);z-index:0;pointer-events:none
}

/* SVG gets glow + chroma */
.growth-svg{position:relative;z-index:1;filter:drop-shadow(0 22px 38px rgba(0,30,100,.18))}

/* 3D bars: chrome highlight on top, deeper saturation */
.growth-svg .gh-bar polygon:nth-child(1){filter:brightness(1.05)}
.growth-svg .gh-bar polygon:nth-child(3){filter:brightness(1.18) saturate(1.2)}
.growth-svg .gh-bar polygon:nth-child(2){filter:saturate(1.15)}

/* Trend line — thicker, glowing */
.growth-svg .gh-trend{stroke-width:5;filter:drop-shadow(0 0 6px rgba(0,131,163,.55))}

/* Data dots — bigger + halo */
.growth-svg .gh-dots circle{filter:drop-shadow(0 0 5px rgba(0,82,204,.55))}

/* Rocket bigger glow halo */
.growth-svg .gh-rocket circle:first-child{r:60;filter:blur(4px)}

/* --- Floating METRIC cards — futuristic glass tile (smaller, spread wider) --- */
.gh-card{
  padding:9px 13px;min-width:148px;gap:9px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.78));
  border:1px solid rgba(255,255,255,.85);
  border-radius:14px;
  box-shadow:
    0 22px 48px -18px rgba(0,30,100,.32),
    0 8px 14px -8px rgba(0,30,100,.16),
    inset 0 1px 0 rgba(255,255,255,1);
  backdrop-filter:blur(20px) saturate(1.2);
  -webkit-backdrop-filter:blur(20px) saturate(1.2);
  z-index:3
}
.gh-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg, rgba(0,229,255,.10), transparent 50%);
  opacity:.6
}
.gh-card-ic{
  width:32px;height:32px;border-radius:10px;
  box-shadow:0 4px 10px -3px rgba(0,131,163,.25), inset 0 1px 0 rgba(255,255,255,.5)
}
.gh-card b{font-size:.84rem;font-weight:700;letter-spacing:-.01em}
.gh-card span{font-size:.7rem;color:var(--text-faint)}

/* Spread cards far from center so the chart breathes */
.gh-card-a{top:14%;left:-12%;animation-delay:.6s,2.1s}
.gh-card-b{bottom:14%;right:-14%;animation-delay:1.1s,2.6s}
.gh-card-c{top:-2%;right:-10%;animation-delay:.9s,2.4s}
.gh-card-d{bottom:-2%;left:-10%;animation-delay:1.4s,2.9s}

/* LIVE pill upgraded — futuristic glass */
.growth-svg .gh-live rect{fill:rgba(255,255,255,.92);stroke:rgba(0,131,163,.4);stroke-width:1.5}

/* Make the orbit rings sharper and more futuristic */
.growth-svg .gh-orbit{stroke:rgba(0,131,163,.28);stroke-width:1.2}
.growth-svg .gh-orbit-2{stroke:rgba(0,82,204,.18);stroke-width:1}

/* +212% Callout — futuristic glass capsule */
.growth-svg .gh-callout rect{
  fill:rgba(255,255,255,.95);
  stroke:rgba(0,131,163,.45);
  stroke-width:1.8;
  filter:drop-shadow(0 8px 18px rgba(0,131,163,.25))
}

/* Responsive — undo tilt below 1100px so cards aren't cramped */
@media (max-width: 1100px){
  .growth-stage{transform:rotateX(4deg) rotateY(0deg)}
  .gh-card-a{top:12%;left:-4%}
  .gh-card-b{bottom:12%;right:-4%}
}
@media (max-width: 900px){
  .growth-stage{transform:none}
  .growth-stage::before{display:none}
  .gh-card-a,.gh-card-b,.gh-card-c,.gh-card-d{display:none}
}

/* ============================================================
   SEARCH-RANK HERO STAGE — premium 3D browser mockup
   ============================================================ */
.rank-stage{
  position:relative;width:100%;aspect-ratio:1;
  display:grid;place-items:center;perspective:1600px;perspective-origin:50% 40%;
  isolation:isolate
}

/* Ambient blurred color blobs */
.rs-blob{position:absolute;border-radius:50%;filter:blur(46px);pointer-events:none;z-index:0}
.rs-blob-1{width:46%;height:46%;top:-8%;left:-6%;
  background:radial-gradient(circle, rgba(0,229,255,.42), transparent 65%);
  animation:rs-float-a 14s ease-in-out infinite alternate}
.rs-blob-2{width:42%;height:42%;bottom:-10%;right:-8%;
  background:radial-gradient(circle, rgba(0,82,204,.36), transparent 65%);
  animation:rs-float-b 17s ease-in-out infinite alternate}
.rs-blob-3{width:34%;height:34%;top:50%;left:55%;transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(245,184,0,.18), transparent 70%);
  animation:rs-float-c 20s ease-in-out infinite alternate}
@keyframes rs-float-a{from{transform:translate(0,0) scale(1)}to{transform:translate(20px,-12px) scale(1.08)}}
@keyframes rs-float-b{from{transform:translate(0,0) scale(1)}to{transform:translate(-18px,10px) scale(1.1)}}
@keyframes rs-float-c{from{transform:translate(-50%,-50%) scale(1)}to{transform:translate(-58%,-44%) scale(1.12)}}

/* ----- Main browser card (3D tilt) ----- */
.browser-card{
  position:relative;z-index:2;width:82%;max-width:430px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.92));
  border:1px solid rgba(255,255,255,.85);
  border-radius:18px;overflow:hidden;
  box-shadow:
    0 32px 60px -20px rgba(0,30,100,.32),
    0 14px 28px -14px rgba(0,30,100,.22),
    inset 0 1px 0 rgba(255,255,255,1);
  backdrop-filter:blur(22px) saturate(1.25);
  -webkit-backdrop-filter:blur(22px) saturate(1.25);
  transform:rotateX(10deg) rotateY(-8deg) rotateZ(-1deg);
  transform-style:preserve-3d;transform-origin:50% 50%;
  transition:transform .9s cubic-bezier(.2,.7,.2,1);
  animation:bc-in 1.1s cubic-bezier(.2,.7,.2,1) both
}
.rank-stage:hover .browser-card{transform:rotateX(4deg) rotateY(-2deg) rotateZ(0deg)}
@keyframes bc-in{
  from{opacity:0;transform:rotateX(20deg) rotateY(-14deg) translateY(40px) scale(.85)}
  to  {opacity:1;transform:rotateX(10deg) rotateY(-8deg) rotateZ(-1deg)}
}

/* Chrome bar */
.bc-chrome{
  display:flex;align-items:center;gap:14px;padding:11px 14px;
  background:linear-gradient(180deg, rgba(248,250,254,.95), rgba(238,242,250,.88));
  border-bottom:1px solid rgba(0,30,100,.08)
}
.bc-dots{display:flex;gap:6px}
.bc-dots i{width:10px;height:10px;border-radius:50%;background:#ff5f56;display:block}
.bc-dots i:nth-child(2){background:#ffbd2e}
.bc-dots i:nth-child(3){background:#27c93f}
.bc-url{
  flex:1;display:flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:8px;
  background:rgba(255,255,255,.85);border:1px solid rgba(0,30,100,.10);
  font-family:var(--font-sub);font-size:.72rem;color:var(--text-faint);
  letter-spacing:.01em
}
.bc-url svg{width:13px;height:13px;color:#19c37d;flex-shrink:0}
.bc-tab{width:24px;height:24px;border-radius:6px;background:rgba(0,131,163,.10);flex-shrink:0;
  background-image:linear-gradient(135deg, rgba(0,131,163,.2), rgba(0,82,204,.15))}

/* Search input (Google-style) */
.bc-search{
  margin:22px 18px 0;padding:11px 16px;border-radius:999px;
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.95);
  border:1px solid rgba(0,30,100,.12);
  box-shadow:0 4px 14px -4px rgba(0,30,100,.10), inset 0 1px 0 rgba(255,255,255,.9)
}
.bc-g{
  width:24px;height:24px;border-radius:50%;flex-shrink:0;
  background:conic-gradient(from 90deg, #4285F4, #34A853, #FBBC04, #EA4335, #4285F4);
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:.78rem;color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.2);
  position:relative
}
.bc-g::after{content:"";position:absolute;inset:3px;border-radius:50%;background:#fff}
.bc-g{color:transparent}
.bc-g::before{
  content:"G";position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:.86rem;
  background:linear-gradient(135deg, #4285F4 25%, #34A853 50%, #FBBC04 75%, #EA4335);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;z-index:2
}
.bc-input{
  flex:1;display:flex;align-items:center;
  font-family:var(--font-sub);font-size:.86rem;color:var(--text);font-weight:500
}
.bc-typed::after{content:""}
.bc-typed{display:inline-block;overflow:hidden;white-space:nowrap;animation:bc-type 3.2s steps(34,end) 1s both}
.bc-typed::before{content:"premium digital growth agency"}
.bc-cursor{display:inline-block;width:2px;height:14px;margin-left:2px;background:var(--blue);
  animation:bc-blink 1s steps(2) infinite}
@keyframes bc-type{from{max-width:0}to{max-width:18em}}
@keyframes bc-blink{50%{opacity:0}}
.bc-mic,.bc-srch{width:18px;height:18px;color:var(--text-faint);flex-shrink:0}

/* Results */
.bc-results{padding:18px 18px 22px;display:flex;flex-direction:column;gap:14px}
.bc-result{
  position:relative;display:flex;gap:12px;align-items:flex-start;
  padding:14px 14px 14px 14px;border-radius:12px;
  opacity:0;transform:translateY(8px);animation:bc-result-in .6s cubic-bezier(.4,1.4,.6,1) forwards
}
.bc-result:nth-child(1){animation-delay:3.4s}
.bc-result:nth-child(2){animation-delay:3.8s}
.bc-result:nth-child(3){animation-delay:4.0s}
@keyframes bc-result-in{to{opacity:1;transform:translateY(0)}}

/* #1 Result — winning glow */
.bc-rank-1{
  background:linear-gradient(135deg, rgba(0,131,163,.10), rgba(0,82,204,.06));
  border:1px solid rgba(0,131,163,.25);
  box-shadow:0 12px 28px -12px rgba(0,131,163,.30), inset 0 1px 0 rgba(255,255,255,.6)
}
.bc-rank-1::before{
  content:"";position:absolute;inset:-1px;border-radius:13px;pointer-events:none;
  background:linear-gradient(135deg, rgba(0,229,255,.35), transparent 40%, rgba(0,82,204,.25) 80%);
  z-index:-1;filter:blur(8px);opacity:.5
}
.bc-rank-pill{
  position:absolute;top:-9px;right:14px;
  font-family:var(--font-sub);font-size:.62rem;font-weight:700;letter-spacing:.10em;text-transform:uppercase;
  padding:3px 9px;border-radius:999px;color:#fff;
  background:linear-gradient(135deg, #19c37d, #0083a3);
  box-shadow:0 4px 10px -3px rgba(0,131,163,.4)
}
.bc-fav{
  width:32px;height:32px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg, var(--cyan), var(--blue));color:#fff;
  display:grid;place-items:center;
  box-shadow:0 6px 14px -4px rgba(0,82,204,.35), inset 0 1px 0 rgba(255,255,255,.3);
  font-family:var(--font-display);font-weight:700;font-size:.7rem
}
.bc-fav svg{width:16px;height:16px}
.bc-meta{flex:1;min-width:0}
.bc-domain{
  font-family:var(--font-sub);font-size:.7rem;color:var(--text-faint);
  display:flex;gap:5px;align-items:center;margin-bottom:4px
}
.bc-domain span{color:rgba(0,30,100,.25)}
.bc-title{
  font-family:var(--font-sub);font-size:.92rem;font-weight:600;line-height:1.3;
  background:linear-gradient(135deg, var(--blue), var(--cyan));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:4px
}
.bc-desc{
  font-family:var(--font-sub);font-size:.74rem;color:var(--text-dim);line-height:1.5
}

/* Faded competitor results */
.bc-faded{opacity:.55}
.bc-faded:hover{opacity:.75}
.bc-fav-skel{width:28px;height:28px;border-radius:8px;background:rgba(0,30,100,.08);flex-shrink:0}
.bc-line{height:8px;border-radius:4px;background:rgba(0,30,100,.10);margin-bottom:6px}
.bc-line.w35{width:35%;height:6px}.bc-line.w40{width:40%;height:6px}
.bc-line.w55{width:55%}.bc-line.w62{width:62%}.bc-line.w70{width:70%}.bc-line.w45{width:45%}

/* =============================================================
   Floating glass outcome cards around the browser
   ============================================================= */
.rs-card{
  position:absolute;z-index:3;
  padding:14px 16px;border-radius:14px;min-width:160px;
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.82));
  border:1px solid rgba(255,255,255,.85);
  box-shadow:
    0 22px 44px -16px rgba(0,30,100,.30),
    0 8px 14px -8px rgba(0,30,100,.15),
    inset 0 1px 0 rgba(255,255,255,1);
  backdrop-filter:blur(20px) saturate(1.2);
  -webkit-backdrop-filter:blur(20px) saturate(1.2);
  opacity:0;transform:translateY(14px) scale(.92);
  animation:rs-card-in .8s cubic-bezier(.34,1.3,.5,1) forwards, rs-card-float 5s ease-in-out infinite alternate
}
@keyframes rs-card-in{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes rs-card-float{from{transform:translateY(0)}to{transform:translateY(-8px)}}

.rs-card-head{display:flex;align-items:center;gap:7px;margin-bottom:8px}
.rs-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;
  box-shadow:0 0 0 3px rgba(255,255,255,.5)}
.rs-dot-green{background:#19c37d;box-shadow:0 0 8px #19c37d, 0 0 0 3px rgba(25,195,125,.18)}
.rs-dot-blue{background:var(--blue);box-shadow:0 0 8px var(--blue), 0 0 0 3px rgba(0,82,204,.18)}
.rs-dot-gold{background:var(--gold);box-shadow:0 0 8px var(--gold), 0 0 0 3px rgba(245,184,0,.18)}
.rs-label{font-family:var(--font-sub);font-size:.7rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.10em;color:var(--text-faint)}
.rs-num{font-family:var(--font-display);font-size:1.6rem;font-weight:700;line-height:1;
  background:linear-gradient(135deg, var(--cyan), var(--blue));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:2px}
.rs-sub{font-family:var(--font-sub);font-size:.7rem;color:var(--text-faint);margin-bottom:6px}

/* Traffic card — top-right */
.rs-card-traffic{top:6%;right:-8%;animation-delay:1.5s, 3s}
.rs-spark{display:block;width:100%;height:30px;margin-top:6px}
.rs-spark-line{stroke-dasharray:240;stroke-dashoffset:240;
  animation:rs-spark-draw 1.6s ease-out forwards 2.6s}
.rs-spark-dot{opacity:0;animation:rs-spark-dot 0.4s ease-out forwards 4.2s, rs-spark-pulse 1.8s ease-in-out infinite 4.6s}
@keyframes rs-spark-draw{to{stroke-dashoffset:0}}
@keyframes rs-spark-dot{to{opacity:1}}
@keyframes rs-spark-pulse{0%,100%{r:3}50%{r:5}}

/* Authority gauge — bottom-right */
.rs-card-authority{bottom:18%;right:-12%;animation-delay:1.9s, 3.4s;min-width:150px}
.rs-gauge{position:relative;height:54px;display:flex;align-items:flex-end;justify-content:center}
.rs-gauge svg{width:100%;height:100%}
.rs-gauge-fill{stroke-dashoffset:100;animation:rs-gauge 1.4s cubic-bezier(.4,1.2,.5,1) forwards 2.4s}
@keyframes rs-gauge{to{stroke-dashoffset:22}}
.rs-gauge-val{position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  font-family:var(--font-display);font-size:1.4rem;font-weight:700;
  background:linear-gradient(135deg, var(--cyan), var(--blue));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.rs-gauge-val small{font-size:.7rem;color:var(--text-faint);-webkit-text-fill-color:var(--text-faint);
  font-weight:600;margin-left:2px}

/* Keywords card — top-left */
.rs-card-keywords{top:4%;left:-10%;animation-delay:2.1s, 3.8s;min-width:170px}
.rs-kw-grid{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.rs-kw{
  font-family:var(--font-sub);font-size:.66rem;font-weight:600;
  padding:4px 9px;border-radius:999px;
  background:linear-gradient(135deg, rgba(0,131,163,.12), rgba(0,82,204,.08));
  color:var(--cyan);border:1px solid rgba(0,131,163,.15);
  opacity:0;animation:rs-kw-in .4s ease-out forwards
}
.rs-kw-1{animation-delay:2.6s}.rs-kw-2{animation-delay:2.75s}.rs-kw-3{animation-delay:2.9s}
.rs-kw-4{animation-delay:3.05s}.rs-kw-5{animation-delay:3.2s}
@keyframes rs-kw-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* Verified badge — bottom-left */
.rs-badge{
  position:absolute;bottom:6%;left:-6%;z-index:3;
  display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:14px;
  background:linear-gradient(135deg, #19c37d, #0083a3);color:#fff;
  box-shadow:0 18px 36px -12px rgba(25,195,125,.45),
             0 8px 14px -8px rgba(0,131,163,.30),
             inset 0 1px 0 rgba(255,255,255,.3);
  opacity:0;transform:translateY(14px) scale(.9);
  animation:rs-card-in .8s cubic-bezier(.34,1.3,.5,1) forwards 2.4s, rs-badge-float 4s ease-in-out infinite alternate 4s
}
@keyframes rs-badge-float{from{transform:translateY(0)}to{transform:translateY(-6px)}}
.rs-badge-ic{
  width:34px;height:34px;border-radius:10px;flex-shrink:0;
  background:rgba(255,255,255,.20);
  display:grid;place-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3)
}
.rs-badge-ic svg{width:18px;height:18px}
.rs-badge b{display:block;font-family:var(--font-sub);font-size:.84rem;font-weight:700;line-height:1.2}
.rs-badge small{display:block;font-family:var(--font-sub);font-size:.66rem;font-weight:500;opacity:.85;margin-top:1px}

/* ----- Responsive ----- */
@media (max-width: 1100px){
  .browser-card{transform:rotateX(5deg) rotateY(-3deg)}
  .rs-card-keywords,.rs-card-authority{display:none}
  .rs-card-traffic{top:0%;right:-2%}
  .rs-badge{bottom:2%;left:-2%}
}
@media (max-width: 900px){
  .rank-stage{perspective:none}
  .browser-card{transform:none;max-width:100%}
  .rs-card,.rs-badge{display:none}
  .rs-blob{opacity:.5}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .browser-card,.rs-card,.rs-badge,.rs-blob-1,.rs-blob-2,.rs-blob-3,
  .bc-typed,.rs-spark-line,.rs-gauge-fill,.rs-kw,.bc-result{
    animation:none !important;opacity:1 !important;transform:none !important;
    stroke-dashoffset:0 !important;max-width:none !important
  }
}


/* ============================================================
   HERO TOP-PADDING + REVIEW PILL ALIGNMENT + MOBILE INFOGRAPH
   ============================================================ */

/* Tighten the homepage hero — header is fixed, no need for 130px top */
.hero{padding:64px 0 60px !important;min-height:auto !important}

/* Reduce main top padding so content sits closer to header on all pages */
main{padding-top:76px !important}
.page-hero{padding:80px 0 48px !important}

/* Review pills — match button row width & alignment */
.hero-reviews{margin:14px 0 18px;gap:12px}
.hero-cta{margin-top:6px}
.review-pill{min-height:54px;box-sizing:border-box}

/* Mobile (≤768px) — tighter still and hide hero infograph entirely */
@media (max-width: 768px){
  main{padding-top:64px !important}
  .hero{padding:32px 0 36px !important;min-height:auto !important}
  .page-hero{padding:48px 0 32px !important}

  /* Hide the 3D browser/search-rank infograph on mobile */
  .hero-visual,.rank-stage,.growth-stage{display:none !important}

  /* Center & equalize review pills on mobile so they line up with buttons */
  .hero-reviews{justify-content:center;flex-direction:column;align-items:stretch;gap:10px;margin:12px 0 16px}
  .review-pill{justify-content:flex-start;padding:10px 14px;width:100%;max-width:380px;margin:0 auto}
  .hero-cta{justify-content:center;margin-top:8px;gap:10px}
  .hero-cta .btn{width:100%;max-width:380px;justify-content:center}
}

@media (max-width: 480px){
  main{padding-top:60px !important}
  .hero{padding:24px 0 28px !important}
}
