/* ============================================================
   VALUNXT — site-wide design system (Finovate-style translation)
   Cream canvas · deep navy panels · blue/purple brand accents
   ============================================================ */
:root{
  --cream:   #F6F4EF;
  --card:    #FBFAF7;
  --white:   #FFFFFF;
  --navy:    #0053B7;
  --navy-2:  #0E355F;
  --ink:     #16233B;
  --text:    #35415A;
  --muted:   #6A7590;
  --blue:    #0053B7;
  --blue-d:  #00408C;
  --violet:  #9C00DD;
  --sky:     #8FB7FF;
  --grad:    linear-gradient(115deg,#0053B7 0%,#9C00DD 100%);
  --grad-s:  linear-gradient(115deg,#2E7FE0 0%,#B24DE8 100%);
  --line:    rgba(11,44,86,.12);
  --line-inv:rgba(255,255,255,.16);
  --head: "Poppins", -apple-system, sans-serif;
  --body: "Inter", -apple-system, sans-serif;
  --r-lg: 26px;
  --r-md: 20px;
  --pad: clamp(20px,4vw,48px);
  --gap: clamp(16px,1.8vw,26px);
  --ease: cubic-bezier(.25,.75,.25,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);color:var(--text);background:var(--cream);
  font-size:16.5px;line-height:1.7;-webkit-font-smoothing:antialiased;
}
::selection{background:var(--blue);color:#fff}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--head);font-weight:500;color:var(--navy);line-height:1.22;letter-spacing:-.01em}
.h1{font-size:clamp(40px,5.4vw,68px);font-weight:500;line-height:1.12}
.h2{font-size:clamp(30px,3.6vw,48px)}
.h3{font-size:clamp(20px,1.9vw,25px)}
section{scroll-margin-top:100px}
.wrap{max-width:1320px;margin-inline:auto;padding-inline:var(--pad)}
.sub{color:var(--muted);font-size:clamp(16px,1.4vw,18px);max-width:56ch}

/* chips */
.chip{
  display:inline-flex;align-items:center;
  font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--navy);border:1px solid var(--line);border-radius:100px;
  padding:8px 16px;background:rgba(255,255,255,.55);
}
.chip.inv{color:#fff;border-color:var(--line-inv);background:rgba(255,255,255,.08)}

/* accent underline stroke */
.stroke{position:relative;display:inline-block}
.stroke::after{
  content:"";position:absolute;left:calc(100% + 18px);top:.62em;width:clamp(70px,9vw,150px);height:2px;
  background:var(--grad-s);border-radius:2px;
}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--head);font-size:15px;font-weight:500;
  padding:15px 28px;border-radius:100px;border:0;cursor:pointer;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s;
}
.btn:hover{transform:translateY(-2px)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-d);box-shadow:0 14px 30px -12px rgba(0,83,183,.5)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{box-shadow:0 14px 30px -14px rgba(0,0,0,.45)}
.btn-ghost{border:1.5px solid var(--line);color:var(--navy);background:transparent}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.circ{
  flex:none;width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  background:#fff;color:var(--navy);border:0;cursor:pointer;
  transition:transform .4s var(--ease),background .3s,color .3s;
}
.circ svg{width:17px;height:17px;transition:transform .4s var(--ease)}
.circ.grad{background:var(--grad);color:#fff}
.circ.soft{background:rgba(11,44,86,.06)}
a:hover > .circ, .circ:hover{transform:translateY(-2px)}
a:hover > .circ svg, .circ:hover svg{transform:translate(2px,-2px)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:6px}
.skip{position:absolute;left:-9999px;top:0;background:#fff;color:var(--navy);padding:12px 20px;z-index:300;border-radius:0 0 10px 0}
.skip:focus{left:0}

/* reveal */
.rv{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.08s}.rv-d2{transition-delay:.16s}.rv-d3{transition-delay:.24s}
.fu{opacity:0;transform:translateY(22px);animation:fadeup .9s var(--ease) forwards}
.fu-1{animation-delay:.1s}.fu-2{animation-delay:.28s}.fu-3{animation-delay:.46s}
@keyframes fadeup{to{opacity:1;transform:none}}

/* section rhythm */
.sec{padding-block:clamp(70px,8vw,120px)}
.sec-head-c{text-align:center;margin-bottom:clamp(40px,5vw,64px)}
.sec-head-c .chip{margin-bottom:22px}
.sec-head-c .h2{max-width:24ch;margin-inline:auto}
.sec-head-c .sub{margin:18px auto 0}

/* ============================================================ NAV */
.nav{
  position:sticky;top:0;z-index:100;background:rgba(246,244,239,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  transition:box-shadow .3s;
}
.nav.scrolled{box-shadow:0 10px 30px -18px rgba(11,44,86,.25)}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:24px;height:84px}
@media (min-width:921px){
  .nav-in{
    max-width:2400px;margin-inline:auto;padding-inline:clamp(22px,2.4vw,40px);
    transition:max-width .6s var(--ease),padding-inline .6s var(--ease);
  }
  .nav.scrolled .nav-in{max-width:1320px;padding-inline:var(--pad)}
}
.nav-logo img{height:34px;width:auto;filter:drop-shadow(0 4px 14px rgba(4,12,26,.28))}
.nav.over:not(.scrolled) .nav-logo img{filter:drop-shadow(0 4px 16px rgba(4,12,26,.55))}
.nav-links{display:flex;align-items:center;gap:clamp(18px,2.4vw,36px)}
.nav-links > li{position:relative}
.nav-links a.top{
  font-family:var(--head);font-size:15px;font-weight:500;color:var(--navy);
  padding:8px 0;position:relative;transition:color .3s;display:inline-flex;align-items:center;gap:6px;
}
.nav-links a.top::after{
  content:"";position:absolute;left:0;bottom:2px;width:100%;height:2px;border-radius:2px;
  background:var(--grad-s);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);
}
.nav-links a.top:hover{color:var(--blue)}
.nav-links a.top:hover::after{transform:scaleX(1)}
.nav-links a.top .car{width:10px;height:10px;transition:transform .3s}
.nav-links li:hover a.top .car,.nav-links li:focus-within a.top .car{transform:rotate(180deg)}
.dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,8px);
  min-width:280px;background:#fff;border-radius:18px;padding:12px;
  box-shadow:0 30px 60px -24px rgba(11,44,86,.35);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
  z-index:110;
}
.nav-links li:hover .dropdown,.nav-links li:focus-within .dropdown{opacity:1;visibility:visible;transform:translate(-50%,0)}
.dropdown a{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-family:var(--head);font-size:14.5px;font-weight:500;color:var(--navy);
  padding:11px 16px;border-radius:12px;transition:background .25s,color .25s;
}
.dropdown a:hover{background:var(--cream);color:var(--blue)}
.dropdown a span{font-size:11px;color:var(--muted);font-family:var(--body);font-weight:500}
.dropdown a svg{width:13px;height:13px;flex:none}
.dropdown .all{border-top:1px solid var(--line);margin-top:8px;padding-top:14px;color:var(--blue)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-tel{
  display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--navy);
  transition:color .3s;
}
.nav-tel:hover{color:var(--blue)}
.nav-tel svg{width:15px;height:15px}
.nav-burger{display:none;background:none;border:0;cursor:pointer;padding:10px;margin-right:-6px}
.nav-burger span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;border-radius:2px;transition:transform .4s var(--ease),opacity .3s}
.menu-open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-open .nav-burger span:nth-child(2){opacity:0}
.menu-open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{
  position:fixed;inset:0;z-index:90;background:var(--cream);
  display:flex;flex-direction:column;justify-content:center;padding:var(--pad);
  opacity:0;visibility:hidden;transition:opacity .45s var(--ease),visibility .45s;
  overflow-y:auto;
}
.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu a{
  font-family:var(--head);font-size:clamp(24px,6vw,36px);font-weight:500;color:var(--navy);
  padding:12px 0;border-bottom:1px solid var(--line);
  opacity:0;transform:translateY(18px);transition:opacity .45s var(--ease),transform .45s var(--ease);
}
.menu-open .mobile-menu a{opacity:1;transform:none}
.menu-open .mobile-menu a:nth-child(1){transition-delay:.06s}
.menu-open .mobile-menu a:nth-child(2){transition-delay:.12s}
.menu-open .mobile-menu a:nth-child(3){transition-delay:.18s}
.menu-open .mobile-menu a:nth-child(4){transition-delay:.24s}
.menu-open .mobile-menu a:nth-child(5){transition-delay:.3s}
.menu-open .mobile-menu a:nth-child(6){transition-delay:.36s}
.menu-open .mobile-menu a:nth-child(7){transition-delay:.42s}
.mobile-menu .mm-tel{font-family:var(--body);font-size:15px;color:var(--muted);border:0;margin-top:24px}

/* ============================================================ HOME HERO */
.hero-frame{padding:10px 10px 0}
.hero{
  position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:min(86vh,820px);
  display:flex;flex-direction:column;justify-content:flex-end;
  background:var(--navy);
}
.hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 68%}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(6,16,38,.30) 0%,rgba(6,16,38,.12) 42%,rgba(6,16,38,.62) 100%);
}
.hero-in{position:relative;z-index:2;padding:clamp(28px,4vw,64px)}
.hero h1{color:#fff;max-width:15ch;margin-bottom:30px}
.hero h1 .stroke::after{top:.58em}
.hero-ctas{display:flex;align-items:center;gap:12px;margin-bottom:clamp(36px,5vw,64px)}
.hero-chips{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}

/* ============================================================ PAGE HERO (inner pages) */
.phero-frame{padding:10px 10px 0}
.phero{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(150deg,#0053B7 0%,#123A72 55%,#28246B 100%);
  color:#fff;padding:clamp(48px,7vw,104px) clamp(26px,4.5vw,72px);
}
.phero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 420px at 88% -10%,rgba(156,0,221,.28),transparent 60%),
             radial-gradient(600px 400px at 5% 110%,rgba(0,83,183,.45),transparent 60%);
}
.phero > *{position:relative}
.crumbs{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:26px}
.crumbs a{color:rgba(255,255,255,.75);transition:color .3s}
.crumbs a:hover{color:#fff}
.crumbs .sep{opacity:.4}
.phero h1{color:#fff;font-size:clamp(34px,4.6vw,58px);max-width:20ch;margin-bottom:20px}
.phero .lede{font-size:clamp(16.5px,1.5vw,19px);color:rgba(255,255,255,.78);max-width:58ch;line-height:1.7}
.phero .chip{margin-bottom:24px}
.phero-ctas{display:flex;align-items:center;gap:12px;margin-top:34px;flex-wrap:wrap}

/* ============================================================ CARD PRIMITIVES */
.icard{
  border-radius:var(--r-lg);padding:clamp(26px,2.6vw,38px);
  background:var(--card);display:flex;flex-direction:column;gap:22px;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.icard:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(11,44,86,.35)}
.icard-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.icard h3{max-width:20ch}
.icard .photo{border-radius:var(--r-md);overflow:hidden;margin-top:auto;aspect-ratio:16/10}
.icard .photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.icard:hover .photo img{transform:scale(1.05)}
.icard.brand{background:var(--grad);color:#fff}
.icard.brand h3{color:#fff}
.icard.brand .chip{color:#fff;border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.12)}
.icard.brand p{color:rgba(255,255,255,.85)}
.xmask{
  margin:auto 0;aspect-ratio:1/1;max-height:230px;width:100%;
  -webkit-mask-image:url('/images/logos/favicon.svg');mask-image:url('/images/logos/favicon.svg');
  -webkit-mask-size:contain;mask-size:contain;
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  -webkit-mask-position:center;mask-position:center;
}
.xmask img{width:100%;height:100%;object-fit:cover}
.intro-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--gap)}
.intro{padding:var(--gap) 10px 0}

/* service photo cards (home) */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.svc-card{
  background:var(--white);border-radius:var(--r-lg);padding:14px 14px 22px;
  display:flex;flex-direction:column;position:relative;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(11,44,86,.35)}
.svc-card .photo{border-radius:var(--r-md);overflow:hidden;aspect-ratio:16/10;position:relative}
.svc-card .photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svc-card:hover .photo img{transform:scale(1.06)}
.svc-badge{
  position:absolute;top:20px;left:20px;z-index:2;
  width:52px;height:52px;border-radius:17px;background:var(--grad);
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 10px 24px -8px rgba(11,44,86,.45);
}
.svc-badge svg{width:23px;height:23px}
.svc-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:20px 12px 0}
.svc-foot h3{font-size:clamp(18px,1.6vw,21px)}
.svc-foot p{font-size:13.5px;color:var(--muted);margin-top:4px}
.svc-cta{text-align:center;margin-top:clamp(36px,4vw,52px)}

/* ============================================================ NAVY PANEL (philosophy / process) */
.philo-wrap{padding-inline:10px}
.philo{
  position:relative;background:var(--navy);border-radius:var(--r-lg);
  padding:clamp(44px,5.5vw,84px) clamp(26px,4.5vw,72px);
  color:#fff;
}
.philo.tail::after{
  content:"";position:absolute;left:clamp(40px,6vw,86px);bottom:-30px;
  width:70px;height:31px;background:var(--navy);
  clip-path:polygon(0 0,100% 0,0 100%);
}
.philo .chip{margin-bottom:26px}
.philo .h2{color:#fff;max-width:26ch;margin-bottom:clamp(36px,4.5vw,60px)}
.philo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.pcard{
  background:rgba(255,255,255,.06);border:1px solid var(--line-inv);border-radius:var(--r-md);
  padding:28px 26px 34px;backdrop-filter:blur(4px);
  transition:background .4s,transform .5s var(--ease);
}
.pcard:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.pcard .ico{
  width:40px;height:40px;border-radius:12px;background:var(--grad-s);
  display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:22px;
  font-family:var(--head);font-weight:600;font-size:15px;
}
.pcard .ico svg{width:20px;height:20px}
.pcard h4{color:#fff;font-size:19px;margin-bottom:12px}
.pcard p{font-size:14.5px;color:rgba(255,255,255,.72);line-height:1.65}

/* ============================================================ STATS */
.stats{padding-block:clamp(56px,6vw,84px)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:10px 30px;border-left:1px solid var(--line)}
.stat:first-child{border-left:0;padding-left:0}
.stat b{
  display:inline-block;font-family:var(--head);font-weight:600;font-size:clamp(34px,3.4vw,46px);
  color:var(--navy);background:var(--card);border-radius:14px;padding:4px 18px;margin-bottom:12px;
  font-variant-numeric:tabular-nums;
}
.stat b .acc{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat > span{display:block;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ============================================================ PHOTO BAND */
.band-wrap{padding-inline:10px}
.band{
  position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:420px;
  display:flex;align-items:flex-end;background:var(--navy);
}
.band img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.band::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,16,38,.08) 30%,rgba(6,16,38,.66) 100%)}
.band-in{
  position:relative;z-index:2;width:100%;
  display:flex;justify-content:space-between;align-items:flex-end;gap:28px;
  padding:clamp(28px,4vw,56px);
}
.band h2{color:#fff;font-size:clamp(26px,3vw,40px);max-width:22ch}
.band-cta{display:flex;align-items:center;gap:12px;flex:none}

/* ============================================================ OFFERINGS (pillar pages) */
.off-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.off-card{
  background:#fff;border-radius:var(--r-md);padding:28px 26px;
  display:flex;flex-direction:column;gap:14px;min-height:190px;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.off-card:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(11,44,86,.35)}
.off-card .num{
  font-family:var(--head);font-weight:600;font-size:13px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.off-card h3{font-size:17.5px;line-height:1.35}
.off-card p{font-size:14px;color:var(--muted);line-height:1.6}
.off-card .go{margin-top:auto;display:flex;justify-content:flex-end}
.off-card .go .circ{width:40px;height:40px}
.off-card .go .circ svg{width:15px;height:15px}

/* offerings list (services hub columns) */
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.hub-col{
  background:#fff;border-radius:var(--r-lg);padding:clamp(26px,2.6vw,36px);
  display:flex;flex-direction:column;
}
.hub-col .ico{
  width:52px;height:52px;border-radius:17px;background:var(--grad);
  display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:20px;
}
.hub-col .ico svg{width:24px;height:24px}
.hub-col h3{font-size:21px;margin-bottom:6px}
.hub-col .cnt{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.hub-list{border-top:1px solid var(--line);margin-bottom:20px}
.hub-list a{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  font-size:14.5px;font-weight:500;color:var(--text);
  padding:11px 2px;border-bottom:1px solid var(--line);
  transition:color .25s,padding-left .3s var(--ease);
}
.hub-list a:hover{color:var(--blue);padding-left:8px}
.hub-list a svg{width:13px;height:13px;flex:none;opacity:.5}
.hub-col .btn{margin-top:auto;align-self:flex-start}

/* ============================================================ TWO-COL DETAIL (sub-service pages) */
.detail-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(32px,4vw,64px);align-items:start}
.prose h2{font-size:clamp(24px,2.4vw,32px);margin:38px 0 16px}
.prose h2:first-child{margin-top:0}
.prose p{margin-bottom:18px}
.prose ul{margin:0 0 18px 2px}
.prose ul li{position:relative;padding-left:26px;margin-bottom:10px}
.prose ul li::before{
  content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:var(--grad);
}
.aside-card{
  position:sticky;top:110px;background:#fff;border-radius:var(--r-lg);
  padding:clamp(26px,2.6vw,36px);
}
.aside-card h3{font-size:19px;margin-bottom:20px}
.check-list li{
  display:flex;gap:12px;align-items:flex-start;
  font-size:14.5px;font-weight:500;color:var(--text);
  padding:11px 0;border-bottom:1px solid var(--line);
}
.check-list li:last-child{border-bottom:0}
.check-list .tick{
  flex:none;width:22px;height:22px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-top:2px;
}
.check-list .tick svg{width:11px;height:11px}
.aside-card .btn{margin-top:22px;width:100%}
.aside-note{font-size:13px;color:var(--muted);margin-top:16px;text-align:center}
.aside-note a{color:var(--blue);font-weight:600}

/* process steps */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.proc{
  background:#fff;border-radius:var(--r-md);padding:26px 24px 30px;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.proc:hover{transform:translateY(-4px);box-shadow:0 22px 44px -28px rgba(11,44,86,.35)}
.proc .n{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:12px;background:var(--grad);color:#fff;
  font-family:var(--head);font-weight:600;font-size:15px;margin-bottom:18px;
}
.proc h4{font-size:17.5px;margin-bottom:8px}
.proc p{font-size:14px;color:var(--muted);line-height:1.6}

/* related chips */
.rel-chips{display:flex;flex-wrap:wrap;gap:10px}
.rel-chips a{
  font-size:13px;font-weight:500;color:var(--navy);
  border:1px solid var(--line);border-radius:100px;padding:9px 18px;background:#fff;
  transition:border-color .3s,color .3s,transform .3s var(--ease);
}
.rel-chips a:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}

/* FAQ */
.faq-list{max-width:860px;margin-inline:auto}
details{background:#fff;border-radius:var(--r-md);margin-bottom:14px;overflow:hidden}
summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:22px 26px;font-family:var(--head);font-size:16.5px;font-weight:500;color:var(--navy);transition:color .3s;
}
summary::-webkit-details-marker{display:none}
summary:hover{color:var(--blue)}
summary .pm{
  flex:none;width:32px;height:32px;border:1px solid var(--line);border-radius:50%;position:relative;
  transition:background .35s,border-color .35s,transform .45s var(--ease);
}
summary .pm::before,summary .pm::after{
  content:"";position:absolute;inset:0;margin:auto;background:currentColor;transition:transform .35s var(--ease);
}
summary .pm::before{width:11px;height:1.5px}
summary .pm::after{width:1.5px;height:11px}
details[open] summary .pm{background:var(--blue);border-color:var(--blue);color:#fff;transform:rotate(180deg)}
details[open] summary .pm::after{transform:scaleY(0)}
.faq-a{padding:0 26px 24px;font-size:15px;color:var(--muted);max-width:70ch}

/* ============================================================ STORY / QUOTE */
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);padding-inline:10px}
.story-photo{
  position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:560px;
  display:flex;align-items:flex-end;padding:clamp(20px,2.6vw,38px);
  background:var(--navy);
}
.story-photo img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.quote-card{
  position:relative;z-index:2;background:rgba(250,249,245,.9);backdrop-filter:blur(10px);
  border-radius:var(--r-md);padding:clamp(24px,2.4vw,36px);
}
.quote-card .qmark{font-family:var(--head);font-size:54px;font-weight:600;line-height:.6;color:var(--blue);margin-bottom:18px}
.quote-card p{font-size:16.5px;color:var(--ink);margin-bottom:22px;max-width:46ch}
.quote-card .who{display:flex;align-items:center;gap:14px}
.quote-card .who .badge{
  width:44px;height:44px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:600;font-size:15px;
}
.quote-card .who b{display:block;font-family:var(--head);font-weight:600;font-size:14.5px;color:var(--navy)}
.quote-card .who span{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.story-panel{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(150deg,#0053B7 0%,#3D2B9E 55%,#9C00DD 130%);
  color:#fff;padding:clamp(30px,3.4vw,52px);
  display:flex;flex-direction:column;
}
.story-panel::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px 400px at 88% -10%,rgba(255,255,255,.16),transparent 60%);
}
.story-panel > *{position:relative}
.story-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:26px}
.story-panel .h2{color:#fff;font-size:clamp(26px,2.7vw,38px);max-width:18ch}
.story-stat{margin-top:auto;padding-top:48px;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.story-stat .num{font-family:var(--head);font-weight:600;font-size:clamp(38px,4vw,54px);line-height:1}
.story-stat .cap{font-size:14.5px;color:rgba(255,255,255,.78);max-width:30ch;margin-top:10px}

/* ============================================================ INSIGHTS */
.insights-bg{background:linear-gradient(180deg,#EFF3EE00,#EDEFF6 40%,#EFF3EE00)}
.ins-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
.ins-card{
  background:#fff;border-radius:var(--r-lg);padding:20px;
  display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);gap:clamp(18px,2vw,30px);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.ins-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(11,44,86,.3)}
.ins-card .photo{border-radius:var(--r-md);overflow:hidden;aspect-ratio:1/1}
.ins-card .photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.ins-card:hover .photo img{transform:scale(1.05)}
.ins-body{display:flex;flex-direction:column;padding:10px 6px 6px 0}
.ins-body .cat{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.ins-body h3{font-size:clamp(18px,1.7vw,23px);max-width:22ch}
.ins-body .meta{font-size:12.5px;color:var(--muted);margin-top:12px}
.ins-body .circ{margin-top:auto;align-self:flex-end}
.ins-cta{text-align:center;margin-top:clamp(34px,4vw,48px)}

/* article */
.article{max-width:800px;margin-inline:auto}
.article .meta{font-size:13px;color:var(--muted);margin-bottom:34px;display:flex;gap:16px;flex-wrap:wrap}
.article h2{font-size:clamp(22px,2.2vw,30px);margin:36px 0 14px}
.article p{margin-bottom:18px;font-size:16.5px}
.article ul{margin:0 0 18px 2px}
.article ul li{position:relative;padding-left:26px;margin-bottom:10px}
.article ul li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:var(--grad)}

/* ============================================================ CLIENTS */
.clients{padding-block:clamp(56px,6vw,88px)}
.clients-head{display:flex;align-items:center;gap:22px;margin-bottom:clamp(36px,4vw,54px)}
.clients-head::before,.clients-head::after{content:"";flex:1;height:1px;background:var(--line)}
.client-row{
  display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(28px,4.5vw,70px);
  font-family:var(--head);font-weight:600;font-size:clamp(17px,1.7vw,22px);color:#8E9AB3;
}
.client-row span{transition:color .3s;cursor:default}
.client-row span:hover{color:var(--navy)}

/* ============================================================ CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);padding-inline:10px}
.form-card{background:var(--card);border-radius:var(--r-lg);padding:clamp(28px,3.4vw,52px)}
.form-card .chip{margin-bottom:24px}
.form-card .h2{margin-bottom:14px}
.form-card .sub{margin-bottom:34px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-size:14px;font-weight:500;color:var(--navy)}
.field input,.field textarea,.field select{
  font-family:var(--body);font-size:15px;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px;
  transition:border-color .3s,box-shadow .3s;resize:vertical;
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,83,183,.12);outline:0}
.field ::placeholder{color:#A9B1C4}
.form-card .btn{margin-top:26px}
.contact-photo{
  position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:560px;
  display:flex;align-items:flex-end;justify-content:center;padding:clamp(20px,2.4vw,34px);
  background:var(--navy);
}
.contact-photo img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.call-pill{
  position:relative;z-index:2;display:flex;align-items:center;gap:16px;
  background:rgba(250,249,245,.92);backdrop-filter:blur(10px);
  border-radius:100px;padding:16px 26px 16px 16px;font-size:14.5px;color:var(--ink);max-width:520px;
}
.call-pill .ico{
  flex:none;width:44px;height:44px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
}
.call-pill .ico svg{width:18px;height:18px}
.call-pill a{font-weight:600;color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.office-card{
  background:#fff;border-radius:var(--r-md);padding:26px;
}
.office-card b{display:block;font-family:var(--head);font-weight:600;font-size:16px;color:var(--navy);margin-bottom:8px}
.office-card p{font-size:14.5px;color:var(--muted);line-height:1.7}
.office-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-top:var(--gap)}

/* CTA panel (inner pages) */
.cta-panel-wrap{padding-inline:10px;padding-block:clamp(40px,5vw,70px)}
.cta-panel{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(150deg,#0053B7 0%,#3D2B9E 55%,#9C00DD 130%);
  color:#fff;padding:clamp(40px,5vw,72px);
  display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;
}
.cta-panel::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 400px at 88% -10%,rgba(255,255,255,.16),transparent 60%)}
.cta-panel > *{position:relative}
.cta-panel h2{color:#fff;font-size:clamp(26px,3vw,40px);max-width:22ch}
.cta-panel p{color:rgba(255,255,255,.8);margin-top:10px;max-width:46ch}
.cta-panel .actions{display:flex;align-items:center;gap:12px;flex:none}

/* ============================================================ NEWSLETTER + FOOTER */
.foot-shell{padding:10px}
.foot-panel{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:linear-gradient(165deg,#0064DB 0%,#0053B7 45%,#003D8C 100%);
}
.foot-panel::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(680px 440px at 100% 0%,rgba(255,255,255,.16),transparent 60%),
    radial-gradient(620px 480px at 0% 116%,rgba(0,20,60,.35),transparent 62%);
}
.foot-panel > *{position:relative;z-index:1}
.news{
  display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;
  padding:clamp(36px,4.5vw,64px) clamp(26px,4vw,64px);
  border-bottom:1px solid var(--line-inv);
}
.news p{font-family:var(--head);font-size:clamp(19px,1.9vw,24px);font-weight:500;color:#fff;max-width:34ch}
.news-form{display:flex;align-items:center;gap:12px;flex:none}
.news-form input{
  font-family:var(--body);font-size:15px;color:var(--ink);
  background:#fff;border:0;border-radius:100px;padding:16px 24px;width:min(320px,62vw);
}
.footer{color:rgba(255,255,255,.68)}
.footer-grid{
  display:grid;grid-template-columns:minmax(0,1.7fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);
  gap:clamp(28px,3.5vw,48px);padding:clamp(48px,5.5vw,76px) clamp(26px,4vw,64px) clamp(36px,4vw,52px);
}
.footer-brand{max-width:300px}
.footer-brand img{height:30px;margin-bottom:26px}
.footer-brand address{font-style:normal;font-size:14.5px;line-height:1.85;color:rgba(255,255,255,.6);margin-bottom:20px}
.footer-brand .fc{display:flex;align-items:center;gap:8px;font-size:14.5px;color:rgba(255,255,255,.82);margin-bottom:8px;transition:color .3s,gap .3s}
.footer-brand .fc:hover{color:#fff;gap:12px}
.footer-brand .btn{margin-top:22px}
.footer-col{border-left:1px solid var(--line-inv);padding-left:clamp(20px,2.2vw,32px)}
.footer h5{
  position:relative;display:inline-flex;align-items:center;gap:8px;
  font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.92);margin-bottom:22px;font-family:var(--body);
}
.footer h5::before{content:"";width:12px;height:2px;border-radius:2px;background:var(--grad)}
.footer-col li{margin-bottom:13px}
.footer-col a{
  position:relative;display:inline-block;font-size:14.5px;color:rgba(255,255,255,.62);
  transition:color .3s,transform .3s var(--ease);
}
.footer-col a:hover{color:#fff;transform:translateX(4px)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  border-top:1px solid var(--line-inv);
  padding:22px clamp(26px,4vw,64px);font-size:12.5px;color:rgba(255,255,255,.4);
}
.footer-bottom nav{display:flex;gap:24px}
.footer-bottom a{transition:color .3s}
.footer-bottom a:hover{color:#fff}
.socials{display:flex;gap:10px}
.socials a{
  width:38px;height:38px;border:1px solid var(--line-inv);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.04);
  transition:background .35s,border-color .35s,color .3s,transform .35s var(--ease),box-shadow .35s var(--ease);
}
.socials a:hover{background:var(--grad);border-color:transparent;color:#fff;transform:translateY(-3px);box-shadow:0 12px 26px -10px rgba(0,83,183,.6)}
.socials svg{width:15px;height:15px}

/* legal / plain page */
.plain{max-width:840px;margin-inline:auto}
.plain h2{font-size:clamp(20px,2vw,26px);margin:34px 0 12px}
.plain p,.plain li{font-size:15.5px;color:var(--text);margin-bottom:14px}
.plain ul{margin-left:22px;list-style:disc}

/* 404 */
.nf{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--pad)}
.nf .big{font-family:var(--head);font-weight:600;font-size:clamp(90px,16vw,180px);line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ============================================================ RESPONSIVE */
@media (max-width:1080px){
  .intro-grid{grid-template-columns:1fr 1fr}
  .icard.brand{order:-1;grid-column:1/-1}
  .svc-grid{grid-template-columns:1fr 1fr}
  .philo-grid{grid-template-columns:1fr 1fr}
  .off-grid{grid-template-columns:1fr 1fr}
  .hub-grid{grid-template-columns:1fr 1fr}
  .proc-grid{grid-template-columns:1fr 1fr}
  .detail-grid{grid-template-columns:1fr}
  .aside-card{position:static}
  .story-grid,.contact-grid{grid-template-columns:1fr}
  .ins-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr;row-gap:34px}
  .stat:nth-child(odd){border-left:0;padding-left:0}
  .office-grid{grid-template-columns:1fr}
  .nav-tel{display:none}
}
@media (max-width:920px){
  .nav-links{display:none}
  .nav-burger{display:block}
}
@media (max-width:720px){
  .nav-links,.nav-tel{display:none}
  .nav-burger{display:block}
  .hero{min-height:78vh}
  .hero-chips{grid-template-columns:1fr}
  .hero-chip{padding:15px 20px}
  .intro-grid{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .philo-grid{grid-template-columns:1fr}
  .off-grid{grid-template-columns:1fr}
  .hub-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .band-in{flex-direction:column;align-items:flex-start}
  .ins-card{grid-template-columns:1fr}
  .ins-card .photo{aspect-ratio:16/10}
  .fgrid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-brand{max-width:none}
  .footer-col{border-left:0;padding-left:0;border-top:1px solid var(--line-inv);padding-top:24px}
  .news{flex-direction:column;align-items:flex-start}
  .news-form{width:100%}
  .news-form input{flex:1;width:auto}
  .cta-panel{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-delay:0s !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .rv,.fu{opacity:1;transform:none}
}

/* ============================================================
   v2 UPGRADE — Finovate deep-study components
   ============================================================ */

/* two-tone heading word */
.gw{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.phero .gw,.philo .gw,.on-dark .gw{background:linear-gradient(115deg,#5EA2F0 0%,#C77DF5 100%);-webkit-background-clip:text;background-clip:text}

/* ---------- MEGA MENU ---------- */
.nav-links li.has-mega{position:static}
.mega{
  position:absolute;left:50%;top:calc(100% + 12px);transform:translate(-50%,8px);
  width:min(1160px,calc(100vw - 40px));
  background:#fff;border-radius:22px;padding:20px;
  box-shadow:0 40px 80px -30px rgba(11,44,86,.4);
  display:grid;grid-template-columns:260px 1fr;gap:26px;
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
  z-index:110;
}
.nav-links li:hover .mega,.nav-links li:focus-within .mega{opacity:1;visibility:visible;transform:translate(-50%,0)}
.mega-promo{
  position:relative;border-radius:16px;overflow:hidden;background:var(--navy);color:#fff;
  padding:24px;display:flex;flex-direction:column;min-height:280px;
}
.mega-promo::after{
  content:"";position:absolute;right:-40px;bottom:-40px;width:190px;height:190px;border-radius:42px;
  background:var(--grad);transform:rotate(24deg);opacity:.85;
}
.mega-promo h4{position:relative;color:#fff;font-size:19px;line-height:1.35;max-width:14ch;z-index:2}
.mega-promo .btn{position:relative;margin-top:auto;align-self:flex-start;padding:11px 20px;font-size:13.5px;z-index:2}
.mega-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:8px 26px;padding:10px 6px 10px 0;align-content:start}
.mega-group{padding-bottom:8px}
.mega-group h6{
  font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  margin-bottom:8px;font-family:var(--body);
}
.mega-group a{
  display:block;font-family:var(--head);font-size:14px;font-weight:500;color:var(--navy);
  padding:6px 8px;margin-left:-8px;border-radius:9px;transition:background .25s,color .25s;
}
.mega-group a:hover{background:var(--cream);color:var(--blue)}
.mega-group a.more{color:var(--blue);font-size:13px}

/* ---------- STAT BAR (under page hero) ---------- */
.stat-bar{border-bottom:1px solid var(--line)}
.stat-bar .stats-grid{padding-block:clamp(30px,4vw,48px)}
.stat-bar .stat b{background:#fff}

/* ---------- SPLIT HEAD (left h2 / right icon+para) ---------- */
.split-head{display:grid;grid-template-columns:minmax(0,6fr) minmax(0,5fr);gap:clamp(32px,5vw,90px);align-items:start}
.split-head .chip{margin-bottom:24px}
.split-head h2{max-width:18ch}
.split-head .side .ico{
  width:56px;height:56px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-bottom:24px;
}
.split-head .side .ico svg{width:24px;height:24px}
.split-head .side p{color:var(--muted);margin-bottom:14px}
.split-head .side{padding-top:54px}

/* ---------- CHECK PILLS ---------- */
.pill-checks{display:flex;flex-wrap:wrap;gap:14px;margin-top:clamp(30px,4vw,46px)}
.pill-checks li{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;border-radius:100px;padding:14px 24px 14px 14px;
  font-family:var(--head);font-size:15px;font-weight:500;color:var(--navy);
  box-shadow:0 10px 26px -18px rgba(11,44,86,.35);
}
.pill-checks .tick{
  width:26px;height:26px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;flex:none;
}
.pill-checks .tick svg{width:12px;height:12px}
.on-dark .pill-checks li{background:rgba(255,255,255,.08);color:#fff;box-shadow:none;border:1px solid var(--line-inv)}

/* ---------- SEGMENT / VALUE CARDS (outline, circle icon) ---------- */
.seg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.seg-card{
  border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 18px 18px;
  min-height:420px;display:flex;flex-direction:column;background:#fff;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .3s;
}
.seg-card:hover{transform:translateY(-5px);box-shadow:0 26px 50px -32px rgba(11,44,86,.3);border-color:transparent}
.seg-card .ico{
  flex:none;width:54px;height:54px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;margin:6px 0 0 8px;
}
.seg-card .ico svg{width:23px;height:23px}
.seg-card .inner{margin-top:auto;background:var(--cream);border-radius:var(--r-md);padding:26px 22px 30px;transition:background .35s}
.seg-card:hover .inner{background:var(--card)}
.seg-card h4{font-size:19px;margin-bottom:14px}
.seg-card p{font-size:14px;color:var(--muted);line-height:1.75}

/* ---------- ACCORDION SPLIT ---------- */
.acc-split{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);gap:clamp(32px,5vw,90px);align-items:start}
.acc-split .chip{margin-bottom:24px}
.acc-split h2{margin-bottom:22px;max-width:16ch}
.acc-split .lede-txt{color:var(--muted);margin-bottom:30px}
.acc-list details{background:transparent;border-radius:0;border-bottom:1px solid var(--line);margin:0}
.acc-list summary{padding:24px 4px;font-size:18px}
.acc-list .faq-a{padding:0 4px 22px}

/* ---------- DUO (photo + gradient panel pair) ---------- */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
.duo .photo{border-radius:var(--r-lg);overflow:hidden;min-height:420px}
.duo .photo img{width:100%;height:100%;object-fit:cover}
.duo .panel{
  position:relative;border-radius:var(--r-lg);overflow:hidden;color:#fff;
  background:linear-gradient(150deg,#0053B7 0%,#3D2B9E 55%,#9C00DD 130%);
  padding:clamp(28px,3vw,46px);display:flex;flex-direction:column;
}
.duo .panel::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 340px at 88% -10%,rgba(255,255,255,.16),transparent 60%)}
.duo .panel > *{position:relative}
.duo .panel .chip{align-self:flex-start;margin-bottom:24px;color:#fff;border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.12)}
.duo .panel h3{color:#fff;font-size:clamp(23px,2.3vw,32px);max-width:18ch;margin-bottom:16px}
.duo .panel p{color:rgba(255,255,255,.82);font-size:15px;max-width:44ch}
.duo .panel .btn{margin-top:auto;align-self:flex-start}

/* ---------- TESTIMONIAL CARDS ---------- */
.t-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
.t-card{
  background:var(--card);border-radius:var(--r-lg);padding:clamp(28px,3vw,44px);
  display:flex;flex-direction:column;gap:24px;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.t-card:hover{transform:translateY(-5px);box-shadow:0 30px 60px -36px rgba(11,44,86,.3)}
.t-card .qmark{font-family:var(--head);font-size:56px;font-weight:600;line-height:.5;color:var(--blue)}
.t-card blockquote{font-size:16.5px;color:var(--ink);line-height:1.75;max-width:52ch}
.t-card .who{display:flex;align-items:center;gap:14px;margin-top:auto}
.t-card .who .badge{
  width:46px;height:46px;border-radius:50%;background:var(--grad);color:#fff;flex:none;
  display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:600;font-size:15px;
}
.t-card .who b{display:block;font-family:var(--head);font-weight:600;font-size:15px;color:var(--navy)}
.t-card .who span{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ---------- OVERVIEW NAVY PANEL (industry pages) ---------- */
.ov-panel{
  position:relative;background:var(--navy);border-radius:var(--r-lg);color:#fff;
  padding:clamp(44px,5.5vw,84px) clamp(26px,4.5vw,72px);overflow:hidden;
}
.ov-panel::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(700px 460px at 90% -20%,rgba(156,0,221,.22),transparent 60%),
             radial-gradient(560px 420px at 0% 120%,rgba(0,83,183,.35),transparent 60%);
}
.ov-panel > *{position:relative}
.ov-grid{display:grid;grid-template-columns:minmax(0,6fr) minmax(0,5fr);gap:clamp(32px,5vw,80px);align-items:start}
.ov-grid h2{color:#fff;max-width:16ch}
.ov-grid .chip{margin-bottom:24px}
.ov-grid .side p{color:rgba(255,255,255,.78);margin-bottom:16px;font-size:15.5px;line-height:1.75}
.ov-grid .side{padding-top:8px}
.ov-panel .btn{margin-top:28px}

/* ---------- OFFICE LOCATION CARDS v2 ---------- */
.loc-card{
  border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,2.4vw,34px);
  background:#fff;display:flex;flex-direction:column;min-height:330px;
}
.loc-card .chip{align-self:flex-start;margin-bottom:26px}
.loc-card h3{font-size:23px;margin-bottom:14px}
.loc-card p{font-size:14.5px;color:var(--muted);line-height:1.75}
.loc-card .dir{
  margin-top:auto;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--head);font-weight:500;font-size:14.5px;color:var(--navy);padding-top:22px;
}
.loc-card .dir .circ{width:34px;height:34px;background:var(--grad);color:#fff}
.loc-card .dir .circ svg{width:13px;height:13px}
.loc-card.hq{
  position:relative;background:var(--navy);border-color:transparent;color:#fff;overflow:hidden;
}
.loc-card.hq::after{
  content:"";position:absolute;right:-46px;bottom:-46px;width:200px;height:200px;border-radius:46px;
  background:var(--grad);transform:rotate(24deg);opacity:.9;
}
.loc-card.hq > *{position:relative;z-index:2}
.loc-card.hq .chip{color:#fff;border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.12)}
.loc-card.hq h3{color:#fff}
.loc-card.hq p{color:rgba(255,255,255,.78)}
.loc-card.hq p a{color:#fff !important}
.loc-card.hq .dir{color:#fff}

/* ---------- INSIGHTS 3-COL ---------- */
.ins3-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.ins3{
  background:#fff;border-radius:var(--r-lg);padding:14px 14px 22px;display:flex;flex-direction:column;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.ins3:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(11,44,86,.3)}
.ins3 .photo{border-radius:var(--r-md);overflow:hidden;aspect-ratio:16/10}
.ins3 .photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.ins3:hover .photo img{transform:scale(1.05)}
.ins3 .body{padding:20px 10px 4px;display:flex;flex-direction:column;flex:1}
.ins3 .cat{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.ins3 h3{font-size:19px;line-height:1.35}
.ins3 .meta{font-size:12.5px;color:var(--muted);margin-top:12px}
.ins3 .circ{margin-top:18px;align-self:flex-end}

/* ---------- THANK YOU ---------- */
.ty-tick{
  width:88px;height:88px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-bottom:30px;
}
.ty-tick svg{width:38px;height:38px}

/* ---------- FAQ HUB GROUPS ---------- */
.faq-group{margin-bottom:clamp(40px,5vw,64px)}
.faq-group .gh{display:flex;align-items:center;gap:16px;margin-bottom:22px}
.faq-group .gh .ico{
  width:44px;height:44px;border-radius:14px;background:var(--grad);color:#fff;flex:none;
  display:flex;align-items:center;justify-content:center;
}
.faq-group .gh .ico svg{width:20px;height:20px}
.faq-group .gh h2{font-size:clamp(21px,2vw,27px)}

/* responsive for new components */
@media (max-width:1080px){
  .mega{grid-template-columns:1fr;width:min(680px,calc(100vw - 40px))}
  .mega-promo{display:none}
  .mega-cols{grid-template-columns:1fr 1fr}
  .split-head,.acc-split,.ov-grid{grid-template-columns:1fr}
  .split-head .side{padding-top:0}
  .seg-grid{grid-template-columns:1fr 1fr}
  .seg-card{min-height:360px}
  .t-grid{grid-template-columns:1fr}
  .ins3-grid{grid-template-columns:1fr 1fr}
  .duo{grid-template-columns:1fr}
}
@media (max-width:720px){
  .seg-grid{grid-template-columns:1fr}
  .seg-card{min-height:0;gap:0}
  .seg-card .inner{margin-top:34px}
  .ins3-grid{grid-template-columns:1fr}
  .pill-checks li{font-size:13.5px;padding:11px 18px 11px 11px}
}

/* ---------- INDUSTRY LIST ROWS + PHOTO ---------- */
.ind-grid{display:grid;grid-template-columns:minmax(0,6fr) minmax(0,6fr);gap:clamp(40px,5vw,90px);align-items:stretch}
.ind-left{display:flex;flex-direction:column}
.ind-left .chip{margin-bottom:24px}
.ind-left .h2{max-width:18ch;margin-bottom:34px}
.ind-photo{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  flex:1;min-height:340px;max-height:520px;max-width:480px;margin-top:10px;
  box-shadow:0 34px 64px -34px rgba(11,44,86,.4);
}
.ind-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.ind-photo:hover img{transform:scale(1.06)}
.ind-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,18,38,0) 42%,rgba(6,18,38,.8) 100%)}
.ind-photo .tx{position:absolute;left:26px;right:26px;bottom:24px;z-index:1;color:#fff}
.ind-photo .k{
  display:inline-flex;align-items:center;font-family:var(--head);font-weight:600;
  font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;
}
.ind-photo p{font-size:14px;line-height:1.65;color:rgba(255,255,255,.88);max-width:32ch}
.ind-list{border-top:1px solid var(--line)}
.ind-row{
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:20px 6px;border-bottom:1px solid var(--line);
  font-family:var(--head);font-size:clamp(18px,1.7vw,23px);font-weight:500;color:var(--navy);
  transition:padding .35s var(--ease),color .3s;
}
.ind-row:hover{color:var(--blue);padding-left:14px}
.ind-more{margin-top:32px}
@media (max-width:1080px){
  .ind-grid{grid-template-columns:1fr}
  .ind-photo{flex:none;aspect-ratio:16/10;max-height:none;min-height:0}
}

/* ============================================================
   v3 UPGRADE — Finovate home sections + hi-fi service pages + motion
   ============================================================ */

/* ---------- word-by-word heading reveal ---------- */
.wr .w{display:inline-block;opacity:0;transform:translateY(.6em) rotate(2deg);
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
.wr.in .w{opacity:1;transform:none}

/* ---------- highlight swipe ---------- */
.hl{position:relative;display:inline-block;padding:0 .18em;color:#fff;z-index:1;white-space:nowrap}
.hl::before{content:"";position:absolute;inset:.04em -.02em;background:var(--grad);border-radius:.18em;z-index:-1;
  transform:scaleX(0);transform-origin:left;transition:transform .9s var(--ease) .35s}
.in .hl::before,.hl.in::before{transform:scaleX(1)}

/* ---------- ken burns hero ---------- */
.kb img.bg{animation:kb 12s var(--ease) forwards}
@keyframes kb{from{transform:scale(1.09)}to{transform:scale(1)}}

/* ---------- hero stat cards ---------- */
.hstats{padding:var(--gap) 10px 0}
.hstats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.hstat{
  background:var(--white);border-radius:var(--r-lg);padding:clamp(20px,2vw,28px);
  display:grid;grid-template-columns:minmax(0,1fr) minmax(72px,110px);gap:8px 18px;align-items:center;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.hstat:hover{transform:translateY(-5px);box-shadow:0 26px 52px -30px rgba(11,44,86,.35)}
.hstat .lab{display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.hstat .lab .ico{flex:none;width:34px;height:34px;border-radius:11px;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center}
.hstat .lab .ico svg{width:16px;height:16px}
.hstat b{font-family:var(--head);font-weight:600;font-size:clamp(30px,2.8vw,42px);color:var(--navy);font-variant-numeric:tabular-nums;line-height:1.05}
.hstat b .acc{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hstat .pic{grid-row:1/3;grid-column:2;border-radius:var(--r-md);overflow:hidden;aspect-ratio:1/1}
.hstat .pic img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.hstat:hover .pic img{transform:scale(1.08)}

/* ---------- who-we-are numbered tabs ---------- */
.who-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(36px,5vw,90px);align-items:start}
.who-grid .h2{max-width:19ch;margin:22px 0 34px}
.who-ctas{display:flex;gap:12px;flex-wrap:wrap}
.wtabs{padding-top:clamp(10px,4vw,64px)}
.wtab-btns{display:flex;gap:26px;margin-bottom:26px}
.wtab-btns button{
  background:none;border:0;border-bottom:2px solid var(--line);cursor:pointer;
  font-family:var(--head);font-size:15px;font-weight:500;color:var(--muted);
  padding:6px 10px 12px;transition:color .3s,border-color .3s;
}
.wtab-btns button.on{color:var(--navy);border-image:var(--grad) 1;border-image-slice:0 0 1 0;border-bottom:2px solid var(--blue)}
.wtab-pane{display:none;font-size:clamp(17px,1.6vw,20px);line-height:1.75;color:var(--text);max-width:44ch}
.wtab-pane.on{display:block;animation:fadeup .6s var(--ease)}

/* ---------- navy services panel ---------- */
.svcp-wrap{padding-inline:10px}
.svcp{
  position:relative;border-radius:var(--r-lg);color:#fff;overflow:hidden;
  padding:clamp(44px,5.5vw,84px) clamp(24px,3.5vw,56px);
  background:linear-gradient(175deg,#060F22 0%,#0B1B3D 46%,#1A1140 100%);
}
.svcp::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(760px 460px at 92% -12%,rgba(156,0,221,.20),transparent 60%),
             radial-gradient(600px 420px at 2% 112%,rgba(0,83,183,.32),transparent 60%)}
.svcp > *{position:relative}
.svcp-head{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;margin-bottom:clamp(34px,4vw,54px);flex-wrap:wrap}
.svcp-head .chip{margin-bottom:24px}
.svcp-head h2{color:#fff;max-width:22ch}
.svcp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.svcp-card{
  position:relative;border-radius:var(--r-md);overflow:hidden;
  background:linear-gradient(150deg,#1663C7 0%,#4A2FA8 60%,#8A16CE 130%);
  padding:16px 16px 20px;display:flex;flex-direction:column;color:#fff;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.svcp-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(0,0,0,.5)}
.svcp-card .blob{
  position:relative;aspect-ratio:16/9;border-radius:14px;overflow:hidden;margin-bottom:18px;
  -webkit-mask-image:radial-gradient(140% 120% at 30% 0%,#000 60%,transparent 61%);
  mask-image:radial-gradient(140% 120% at 30% 0%,#000 60%,transparent 61%);
}
.svcp-card .blob img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svcp-card:hover .blob img{transform:scale(1.07)}
.svcp-card .row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:0 6px;margin-top:auto}
.svcp-card h3{color:#fff;font-size:clamp(17.5px,1.6vw,20px);max-width:16ch}
.svcp-card .cnt{display:block;font-size:12px;color:rgba(255,255,255,.7);margin-top:5px}
.svcp-card .circ{background:rgba(255,255,255,.16);color:#fff}
.svcp-card:hover .circ{background:#fff;color:var(--navy)}

/* ---------- why-us band glass card ---------- */
.band.tall{min-height:560px;align-items:center}
.glass{
  position:relative;z-index:2;max-width:600px;border-radius:var(--r-lg);
  background:linear-gradient(135deg,rgba(250,249,245,.82),rgba(250,249,245,.55));
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:clamp(26px,3vw,44px);margin:clamp(20px,3vw,48px);
}
.glass-top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:26px}
.glass-top .spark{width:42px;height:42px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center}
.glass-top .spark svg{width:18px;height:18px}
.glass h2{font-size:clamp(28px,3.2vw,44px);line-height:1.18;margin-bottom:26px;max-width:14ch;color:var(--navy)}
.glass .row{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.glass .row p{font-size:15.5px;color:var(--ink)}

/* ---------- trusted partner split ---------- */
.trust-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:var(--gap);padding-inline:10px}
.trust-photo{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:480px;background:var(--navy)}
.trust-photo img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.badge-card{
  position:absolute;right:clamp(18px,3vw,40px);bottom:clamp(18px,3vw,40px);z-index:2;
  background:rgba(250,249,245,.94);backdrop-filter:blur(8px);border-radius:var(--r-md);
  padding:22px 26px;display:flex;align-items:center;gap:16px;max-width:320px;
}
.badge-card .mono{
  flex:none;width:52px;height:52px;border-radius:16px;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:600;font-size:13px;
}
.badge-card b{display:block;font-family:var(--head);font-weight:600;font-size:15.5px;color:var(--navy)}
.badge-card span{font-size:12.5px;color:var(--muted)}
.trust-panel{
  position:relative;border-radius:var(--r-lg);overflow:hidden;color:#fff;
  background:linear-gradient(150deg,#0053B7 0%,#3D2B9E 55%,#9C00DD 130%);
  padding:clamp(30px,3.4vw,52px);display:flex;flex-direction:column;
}
.trust-panel::before{content:"";position:absolute;inset:0;background:radial-gradient(560px 400px at 88% -10%,rgba(255,255,255,.16),transparent 60%)}
.trust-panel > *{position:relative}
.trust-panel .chip{align-self:flex-start;margin-bottom:28px;color:#fff;border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.12)}
.trust-panel h3{color:#fff;font-size:clamp(26px,2.8vw,40px);max-width:15ch;margin-bottom:20px}
.trust-panel p{color:rgba(255,255,255,.82);font-size:15.5px;max-width:44ch;margin-bottom:14px}
.trust-panel .tp-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.trust-panel .tp-badges span{font-size:11.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.3);border-radius:100px;padding:8px 15px;background:rgba(255,255,255,.08)}
.trust-panel .actions{margin-top:auto;padding-top:34px;display:flex;align-items:center;gap:12px}

/* ---------- testimonial slider ---------- */
.tsl-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:clamp(36px,5vw,80px);align-items:stretch}
.tsl-left{display:flex;flex-direction:column;align-items:flex-start}
.tsl-left .chip{margin-bottom:24px}
.tsl-left .h2{max-width:14ch;margin-bottom:30px}
.tsl-rating{display:flex;align-items:center;gap:16px;margin-top:auto;padding-top:30px}
.tsl-rating .score{font-family:var(--head);font-weight:600;font-size:clamp(34px,3vw,44px);color:var(--navy);line-height:1}
.tsl-rating .stars{color:#F5A623;font-size:17px;letter-spacing:2px}
.tsl-rating .cap{font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.tsl-card{
  position:relative;background:var(--card);border-radius:var(--r-lg);
  padding:clamp(28px,3.2vw,48px);display:flex;flex-direction:column;min-height:380px;overflow:hidden;
}
.tsl-item{display:none;flex-direction:column;flex:1}
.tsl-item.on{display:flex;animation:fadeup .55s var(--ease)}
.tsl-card .qmark{font-family:var(--head);font-size:60px;font-weight:600;line-height:.5;color:var(--blue);margin-bottom:26px}
.tsl-card blockquote{font-size:clamp(17px,1.7vw,21px);color:var(--ink);line-height:1.7;max-width:50ch}
.tsl-foot{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-top:auto;padding-top:34px}
.tsl-foot .who{display:flex;align-items:center;gap:14px}
.tsl-foot .who .badge{width:46px;height:46px;border-radius:50%;background:var(--grad);color:#fff;flex:none;
  display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:600;font-size:15px}
.tsl-foot .who b{display:block;font-family:var(--head);font-weight:600;font-size:15px;color:var(--navy)}
.tsl-foot .who span{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.tsl-nav{position:absolute;right:clamp(24px,3vw,44px);bottom:clamp(24px,3vw,44px);display:flex;gap:10px}
.tsl-nav .circ{background:#fff;border:1px solid var(--line)}
.tsl-nav .circ:hover{background:var(--navy);color:#fff}
.tsl-item .tsl-foot{padding-right:120px}

/* ---------- clients marquee ---------- */
.marquee{overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:clamp(40px,6vw,90px);width:max-content;animation:marq 34s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--head);font-weight:600;font-size:clamp(17px,1.7vw,22px);color:#8E9AB3;white-space:nowrap;transition:color .3s;cursor:default}
.marquee-track span:hover{color:var(--navy)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- sub-service sticky anchor nav ---------- */
.snav-wrap{position:sticky;top:84px;z-index:60;padding-inline:10px;pointer-events:none}
.snav{
  display:flex;justify-content:flex-end;gap:4px;pointer-events:auto;
  background:rgba(255,255,255,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-radius:0 0 18px 18px;padding:8px 12px;width:max-content;margin-left:auto;
  box-shadow:0 18px 40px -26px rgba(11,44,86,.35);
}
.snav a{
  font-family:var(--head);font-size:13.5px;font-weight:500;color:var(--muted);
  padding:8px 14px;border-radius:100px;transition:color .3s,background .3s;position:relative;
}
.snav a:hover{color:var(--navy)}
.snav a.on{color:#fff;background:var(--navy)}

/* ---------- hero stat chip (service pages) ---------- */
.stat-chip{
  position:relative;margin-top:38px;display:inline-grid;gap:4px 22px;grid-template-columns:auto 1fr;align-items:center;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(10px);
  border-radius:var(--r-md);padding:20px 28px;max-width:520px;
}
.stat-chip .k{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6);grid-column:1/-1}
.stat-chip b{font-family:var(--head);font-weight:600;font-size:clamp(28px,3vw,40px);color:#fff;line-height:1;white-space:nowrap}
.stat-chip .cap{font-size:13.5px;color:rgba(255,255,255,.8);line-height:1.5;max-width:26ch}
.stat-chip .meta{grid-column:1/-1;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);
  border-top:1px solid rgba(255,255,255,.14);padding-top:12px;margin-top:8px}

/* ---------- problem / standard split ---------- */
.pb-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(36px,4.5vw,80px);align-items:start}
.pb-grid .prose h2{font-size:clamp(26px,2.8vw,38px)}
.std-card{
  position:sticky;top:150px;background:#fff;border-radius:var(--r-lg);padding:clamp(26px,2.6vw,36px);
  box-shadow:0 30px 60px -40px rgba(11,44,86,.3);
}
.std-card .k{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:6px;display:block}
.std-card li{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line);
  font-family:var(--head);font-size:15px;font-weight:500;color:var(--navy)}
.std-card li:last-child{border-bottom:0}
.std-card .tick{flex:none;width:24px;height:24px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-top:1px}
.std-card .tick svg{width:11px;height:11px}

/* ---------- deliverable phase columns ---------- */
.phase-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,36px)}
.phase .pn{font-family:var(--head);font-weight:600;font-size:13px;color:var(--muted);letter-spacing:.08em}
.phase h4{font-size:clamp(19px,1.8vw,23px);margin:8px 0 10px}
.phase > p{font-size:14px;color:var(--muted);line-height:1.6;min-height:3.2em;border-bottom:2px solid var(--line);padding-bottom:18px;margin-bottom:16px}
.phase li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;font-weight:500;color:var(--text);padding:7px 0}
.phase li svg{flex:none;width:15px;height:15px;margin-top:4px;color:var(--blue)}

/* ---------- vertical numbered timeline ---------- */
.tl{position:relative;max-width:980px;margin-inline:auto}
.tl-row{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);gap:clamp(24px,4vw,70px);padding:clamp(28px,3.5vw,48px) 0;position:relative}
.tl-row + .tl-row{border-top:1px solid var(--line)}
.tl-row .n{font-family:var(--head);font-weight:600;font-size:clamp(20px,2vw,26px);
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:8px}
.tl-row h3{font-size:clamp(21px,2.1vw,28px);max-width:16ch}
.tl-row p{color:var(--muted);font-size:15.5px;line-height:1.75;padding-top:8px}
.tl-row::after{content:"";position:absolute;left:0;bottom:-1px;height:1px;width:0;background:var(--grad);transition:width 1.1s var(--ease) .2s}
.tl-row.in::after{width:100%}

/* ---------- get-started split ---------- */
.gs-wrap{padding-inline:10px}
.gs{
  position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--navy);color:#fff;
  display:grid;grid-template-columns:minmax(0,5fr) minmax(0,6fr);gap:clamp(30px,4vw,70px);
  padding:clamp(36px,4.5vw,72px) clamp(24px,4vw,64px);
}
.gs::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 440px at 92% -12%,rgba(156,0,221,.22),transparent 60%),
             radial-gradient(560px 420px at 0% 115%,rgba(0,83,183,.35),transparent 60%)}
.gs > *{position:relative}
.gs h2{color:#fff;font-size:clamp(27px,3vw,42px);max-width:16ch;margin:22px 0 16px}
.gs .chip{margin:0}
.gs > div > p{color:rgba(255,255,255,.78);font-size:15.5px;max-width:46ch;margin-bottom:26px}
.gs-list{margin-bottom:30px}
.gs-list li{display:flex;gap:13px;align-items:flex-start;padding:9px 0;font-size:15px;font-weight:500;color:rgba(255,255,255,.92)}
.gs-list .tick{flex:none;width:23px;height:23px;border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-top:2px}
.gs-list .tick svg{width:11px;height:11px}
.gs-contact{display:flex;flex-wrap:wrap;gap:14px 34px;border-top:1px solid var(--line-inv);padding-top:26px}
.gs-contact .k{display:block;font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:6px}
.gs-contact a{font-family:var(--head);font-weight:500;font-size:16.5px;color:#fff;transition:color .3s}
.gs-contact a:hover{color:var(--sky)}
.gs-form{background:#fff;border-radius:var(--r-md);padding:clamp(24px,2.6vw,38px);color:var(--text)}
.gs-form h3{font-size:20px;margin-bottom:8px}
.gs-form .note{font-size:13.5px;color:var(--muted);margin-bottom:24px}
.gs-form .fgrid{gap:14px}
.gs-form .btn{margin-top:18px;width:100%}

/* ---------- button shine sweep ---------- */
.btn-blue,.btn-white{position:relative;overflow:hidden}
.btn-blue::after,.btn-white::after{
  content:"";position:absolute;top:0;left:-80%;width:50%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-20deg);transition:left .7s var(--ease);
}
.btn-blue:hover::after,.btn-white:hover::after{left:130%}

/* ---------- responsive v3 ---------- */
@media (max-width:1080px){
  .hstats-grid{grid-template-columns:1fr}
  .hstat{grid-template-columns:minmax(0,1fr) 96px}
  .who-grid,.tsl-grid,.pb-grid,.gs{grid-template-columns:1fr}
  .svcp-grid{grid-template-columns:1fr 1fr}
  .trust-grid{grid-template-columns:1fr}
  .phase-grid{grid-template-columns:1fr 1fr;row-gap:40px}
  .tl-row{grid-template-columns:1fr;gap:10px}
  .std-card{position:static}
  .snav-wrap{display:none}
  .wtabs{padding-top:0}
}
@media (max-width:720px){
  .svcp-grid{grid-template-columns:1fr}
  .phase-grid{grid-template-columns:1fr}
  .glass{margin:14px}
  .band.tall{min-height:0}
  .stat-chip{grid-template-columns:1fr}
  .stat-chip b{font-size:30px}
  .trust-photo{min-height:380px}
  .badge-card{right:14px;bottom:14px;left:14px;max-width:none}
}
@media (max-width:560px){
  .tsl-item .tsl-foot{padding-right:0;padding-bottom:64px}
  .tsl-nav{right:auto;left:clamp(24px,3vw,44px)}
}
@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  .kb img.bg{animation:none}
  .wr .w{opacity:1;transform:none}
  .tl-row::after{transition:none;width:100%}
  .hl::before{transition:none;transform:scaleX(1)}
}

/* ============================================================
   v4 — services hub redesign (practice showcase rows)
   ============================================================ */
.hero-jump{display:flex;flex-wrap:wrap;gap:10px;margin-top:38px}
.hero-jump a{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:13.5px;font-weight:500;color:#fff;
  border:1px solid rgba(255,255,255,.25);border-radius:100px;padding:10px 18px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);
  transition:background .3s,border-color .3s,transform .3s var(--ease);
}
.hero-jump a:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.hero-jump a svg{width:12px;height:12px;opacity:.7}

.prac{padding-block:clamp(56px,7vw,104px)}
.prac + .prac{border-top:1px solid var(--line)}
.prac-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:clamp(32px,5vw,84px);align-items:start}
.prac.flip .prac-grid > .prac-left{order:2}
.prac-left{position:sticky;top:120px}
.prac-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.prac-eyebrow .n{
  font-family:var(--head);font-weight:600;font-size:14px;letter-spacing:.06em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.prac-eyebrow .rule{flex:none;width:44px;height:1.5px;background:var(--grad);border-radius:2px}
.prac-left h2{font-size:clamp(27px,2.9vw,40px);max-width:14ch;margin-bottom:16px}
.prac-left .tag{color:var(--muted);font-size:15.5px;line-height:1.7;max-width:42ch;margin-bottom:26px}
.prac-left .cta-row{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.prac-left .cnt{font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.prac-photo{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9;background:var(--navy)}
.prac-photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.prac-photo:hover img{transform:scale(1.05)}
.prac-photo .ico{
  position:absolute;top:16px;left:16px;z-index:2;width:50px;height:50px;border-radius:16px;
  background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px -8px rgba(11,44,86,.5);
}
.prac-photo .ico svg{width:22px;height:22px}
.pl-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pl{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  background:#fff;border-radius:16px;padding:17px 20px;
  font-family:var(--head);font-size:14.5px;font-weight:500;color:var(--navy);line-height:1.35;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),color .3s;
}
.pl:hover{transform:translateY(-3px);box-shadow:0 20px 40px -26px rgba(11,44,86,.4);color:var(--blue)}
.pl .circ{width:34px;height:34px;background:rgba(11,44,86,.06)}
.pl .circ svg{width:13px;height:13px}
.pl:hover .circ{background:var(--grad);color:#fff}
.pl.all{background:var(--navy);color:#fff}
.pl.all:hover{color:#fff}
.pl.all .circ{background:rgba(255,255,255,.15);color:#fff}
@media (max-width:1080px){
  .prac-grid{grid-template-columns:1fr}
  .prac.flip .prac-grid > .prac-left{order:0}
  .prac-left{position:static}
}
@media (max-width:640px){
  .pl-grid{grid-template-columns:1fr}
  .hero-jump a{font-size:12.5px;padding:9px 14px}
}

/* ============================================================
   v5 — services hub: slim abstract hero + practice explorer
   ============================================================ */
.phero.slim{padding:clamp(40px,5.5vw,72px) clamp(26px,4.5vw,72px)}
.phero.slim h1{font-size:clamp(28px,3.5vw,46px);max-width:24ch;margin-bottom:16px}
.phero.slim .lede{font-size:clamp(15px,1.3vw,16.5px);max-width:52ch}
.phero.slim .chip{margin-bottom:20px}
.phero.slim .phero-ctas{margin-top:26px}

/* abstract hero art */
.phero-art{
  position:absolute;inset:0 0 0 auto;width:min(46%,600px);pointer-events:none;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.phero-art .ghost{
  position:absolute;right:clamp(20px,4vw,70px);top:50%;transform:translateY(-52%);
  font-family:var(--head);font-weight:600;font-size:clamp(140px,20vw,300px);line-height:1;
  background:linear-gradient(135deg,rgba(94,162,240,.34),rgba(199,125,245,.18) 70%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-.04em;user-select:none;
}
.phero-art svg{position:absolute;right:clamp(-40px,-2vw,-10px);top:50%;transform:translateY(-50%);
  width:clamp(300px,34vw,520px);height:auto;opacity:.9}
.phero-art .orbit{animation:spin 46s linear infinite;transform-origin:center}
@keyframes spin{to{transform:rotate(360deg)}}
@media (max-width:900px){.phero-art{display:none}}

/* practice explorer */
.sx{display:grid;grid-template-columns:minmax(0,4.2fr) minmax(0,7.8fr);gap:clamp(18px,2vw,30px);align-items:start}
.sx-tabs{display:flex;flex-direction:column;gap:10px;position:sticky;top:110px}
.sx-tab{
  display:flex;align-items:center;gap:16px;text-align:left;width:100%;
  background:#fff;border:1px solid transparent;border-radius:18px;padding:16px 20px;cursor:pointer;
  font-family:var(--head);transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s;
}
.sx-tab:hover{transform:translateX(4px);box-shadow:0 16px 34px -24px rgba(11,44,86,.4)}
.sx-tab .num{
  font-weight:600;font-size:12.5px;letter-spacing:.06em;flex:none;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.sx-tab .body{flex:1;min-width:0}
.sx-tab .body b{display:block;font-weight:500;font-size:15.5px;color:var(--navy);line-height:1.3}
.sx-tab .body span{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sx-tab svg{width:14px;height:14px;flex:none;color:var(--muted);transition:transform .35s var(--ease),color .3s}
.sx-tab.on{background:var(--navy)}
.sx-tab.on .body b{color:#fff}
.sx-tab.on .body span{color:rgba(255,255,255,.6)}
.sx-tab.on svg{color:#fff;transform:translate(2px,-2px)}
.sx-tab.on .num{background:linear-gradient(115deg,#5EA2F0,#C77DF5);-webkit-background-clip:text;background-clip:text}
.sx-pane{display:none}
.sx-pane.on{display:block;animation:fadeup .5s var(--ease)}
.sx-head{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  background:#fff;border-radius:var(--r-md);padding:20px 24px;margin-bottom:14px;
}
.sx-head .ico{
  flex:none;width:52px;height:52px;border-radius:16px;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
}
.sx-head .ico svg{width:23px;height:23px}
.sx-head .tx{flex:1;min-width:220px}
.sx-head h3{font-size:clamp(19px,1.8vw,23px)}
.sx-head p{font-size:13.5px;color:var(--muted);line-height:1.55;max-width:56ch;margin-top:4px}
.sx-head .btn{flex:none;padding:12px 22px;font-size:14px}
.sx .pl-grid{gap:10px}
.sx .pl{background:var(--card);padding:15px 18px;font-size:14px}
.sx .pl:hover{background:#fff}
.sx .pl.all{background:var(--navy)}
.sx .pl.all:hover{background:var(--navy-2)}
@media (max-width:1080px){
  .sx{grid-template-columns:1fr}
  .sx-tabs{position:static;flex-direction:row;overflow-x:auto;padding-bottom:6px;gap:8px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .sx-tabs::-webkit-scrollbar{display:none}
  .sx-tab{flex:none;width:auto;padding:12px 16px;border-radius:100px}
  .sx-tab:hover{transform:none}
  .sx-tab .body span{display:none}
  .sx-tab svg{display:none}
}

/* ============================================================
   v6 — home services cards: shaped photo masks + echo shapes
   (Finovate reference: photo cut into organic shape, lighter
    echo of the same shape behind, title + arrow at bottom)
   ============================================================ */
.svcp-card{min-height:clamp(360px,34vw,440px);padding:20px 20px 24px}
.svcp-card .art{position:relative;flex:1;min-height:230px;margin-bottom:20px}
.svcp-card .echo{position:absolute;background:rgba(255,255,255,.16);pointer-events:none;
  transition:transform .7s var(--ease)}
.svcp-card:hover .echo{transform:scale(1.04)}
.svcp-card .shape{position:absolute;overflow:hidden}
.svcp-card .shape img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.svcp-card:hover .shape img{transform:scale(1.09)}

/* circle */
.svcp-card.m-c .shape{width:62%;aspect-ratio:1;border-radius:50%;top:9%;left:7%}
.svcp-card.m-c .echo{width:86%;aspect-ratio:1;border-radius:50%;top:-6%;left:-5%}

/* X monogram (Valunxt favicon mask) */
.svcp-card.m-x .shape{inset:6% 12% 4%;
  -webkit-mask:url('/images/logos/favicon.svg') center/contain no-repeat;
  mask:url('/images/logos/favicon.svg') center/contain no-repeat}
.svcp-card.m-x .echo{inset:-4% 4% -6%;
  -webkit-mask:url('/images/logos/favicon.svg') center/contain no-repeat;
  mask:url('/images/logos/favicon.svg') center/contain no-repeat}

/* organic blob */
.svcp-card.m-b .shape{width:66%;aspect-ratio:1;top:8%;right:7%;
  border-radius:56% 44% 58% 42%/46% 58% 42% 54%}
.svcp-card.m-b .echo{width:90%;aspect-ratio:1;top:-7%;right:-5%;
  border-radius:56% 44% 58% 42%/46% 58% 42% 54%}

/* rounded diamond */
.svcp-card.m-d .shape{width:52%;aspect-ratio:1;border-radius:20%;top:13%;left:24%;
  transform:rotate(45deg)}
.svcp-card.m-d .shape img{transform:rotate(-45deg) scale(1.5)}
.svcp-card.m-d:hover .shape img{transform:rotate(-45deg) scale(1.6)}
.svcp-card.m-d .echo{width:72%;aspect-ratio:1;border-radius:20%;top:2%;left:14%;
  transform:rotate(45deg)}
.svcp-card.m-d:hover .echo{transform:rotate(45deg) scale(1.04)}

.svcp-card .row h3{font-size:clamp(19px,1.8vw,23px)}
@media (max-width:720px){
  .svcp-card{min-height:380px}
  .svcp-card .art{min-height:240px}
}

/* ============================================================
   v7 — home services carousel (compact cards + scroller)
   ============================================================ */
.svcp-track{
  display:flex;gap:var(--gap);overflow-x:auto;scroll-snap-type:x mandatory;
  padding:4px 4px 10px;margin:-4px -4px 0;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;cursor:grab;
}
.svcp-track::-webkit-scrollbar{display:none}
.svcp-track.dragging{cursor:grabbing;scroll-snap-type:none}
.svcp-track .svcp-card{
  flex:0 0 clamp(240px,23.5vw,300px);scroll-snap-align:start;
  min-height:340px;padding:16px 16px 18px;
}
.svcp-track .art{min-height:170px;margin-bottom:14px}
.svcp-track .row h3{font-size:16.5px}
.svcp-track .cnt{font-size:11px;margin-top:3px}
.svcp-track .circ{width:40px;height:40px}
.svcp-track .circ svg{width:14px;height:14px}
.svcp-nav{display:flex;gap:10px;align-items:center}
.svcp-nav .circ{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2)}
.svcp-nav .circ:hover{background:#fff;color:var(--navy)}
.svcp-nav .circ[disabled]{opacity:.35;pointer-events:none}
.svcp-bar{flex:1;max-width:220px;height:3px;border-radius:3px;background:rgba(255,255,255,.15);overflow:hidden}
.svcp-bar i{display:block;height:100%;width:20%;border-radius:3px;background:var(--grad-s);transition:width .3s var(--ease),transform .3s var(--ease)}
.svcp-foot{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-top:clamp(24px,3vw,36px)}
@media (max-width:720px){
  .svcp-track .svcp-card{flex-basis:78vw;min-height:330px}
}

/* ============================================================
   v8 — services carousel: big reference-size cards, X mask on
   all, hover = photo fills the whole card
   ============================================================ */
.svcp-track .svcp-card{
  flex:0 0 clamp(280px,29.5vw,400px);min-height:clamp(420px,34vw,480px);
  padding:20px 20px 24px;position:relative;
}
.svcp-track .art{min-height:240px;margin-bottom:18px;
  transition:opacity .5s var(--ease),transform .6s var(--ease)}
.svcp-track .row h3{font-size:clamp(18px,1.6vw,21px)}
.svcp-track .cnt{font-size:11.5px}
.svcp-track .circ{width:46px;height:46px}
.svcp-track .circ svg{width:16px;height:16px}

/* X mask sizing inside big cards */
.svcp-card.m-x .shape{inset:4% 10%}
.svcp-card.m-x .echo{inset:-4% 3% -6%}

/* hover: full-bleed photo fill */
.svcp-card .fill{
  position:absolute;inset:0;z-index:0;opacity:0;overflow:hidden;border-radius:inherit;
  transition:opacity .55s var(--ease);pointer-events:none;
}
.svcp-card .fill img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.1);transition:transform 1.1s var(--ease);
}
.svcp-card .fill .shade{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(9,20,46,.05) 30%,rgba(9,20,46,.82) 100%);
}
.svcp-card .art,.svcp-card .row{position:relative;z-index:2}
.svcp-card:hover .fill{opacity:1}
.svcp-card:hover .fill img{transform:scale(1.02)}
.svcp-card:hover .art{opacity:0;transform:scale(.92)}
.svcp-card:hover .circ{background:#fff;color:var(--navy)}
@media (max-width:720px){
  .svcp-track .svcp-card{flex-basis:82vw;min-height:420px}
  .svcp-track .art{min-height:250px}
}


/* ============================================================
   v9 — services carousel refined: compact cards, numbered
   badges, spotlight edge-dim, live counter, autoplay
   ============================================================ */
.svcp-track .svcp-card{
  flex:0 0 clamp(225px,20.5vw,275px);min-height:clamp(320px,26vw,360px);
  padding:16px 16px 18px;
  transition:opacity .5s var(--ease),transform .6s var(--ease),box-shadow .5s var(--ease);
}
.svcp-track .art{min-height:160px;margin-bottom:14px}
.svcp-track .row h3{font-size:16px;line-height:1.3}
.svcp-track .cnt{font-size:10.5px;margin-top:2px}
.svcp-track .circ{width:38px;height:38px}
.svcp-track .circ svg{width:13px;height:13px}
.svcp-card.m-x .shape{inset:6% 12%}
.svcp-card.m-x .echo{inset:-2% 5% -4%}

/* numbered badge */
.svcp-card .cnum{
  position:absolute;top:12px;left:12px;z-index:3;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--head);font-weight:600;font-size:11px;color:#fff;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}

/* spotlight: partially visible cards dim */
.svcp-track .svcp-card.edge{opacity:.4;transform:scale(.96)}
.svcp-track.dragging .svcp-card.edge{opacity:.65}

/* counter */
.svcp-count{
  font-family:var(--head);font-size:12px;font-weight:500;color:rgba(255,255,255,.55);
  letter-spacing:.1em;white-space:nowrap;
}
.svcp-count b{font-weight:600;font-size:15px;color:#fff}
.svcp-foot{gap:20px}
@media (max-width:720px){
  .svcp-track .svcp-card{flex-basis:70vw;min-height:340px}
  .svcp-track .art{min-height:190px}
}

/* ============================================================
   v10 — Let's Connect (Finovate reference): cream form card
   overlapping photo, call pill, floating over navy band
   ============================================================ */
.lc{position:relative;padding:clamp(30px,4vw,60px) 10px}
.lc-in{
  position:relative;display:grid;grid-template-columns:repeat(12,1fr);
  align-items:stretch;max-width:1400px;margin-inline:auto;
}
.lc-card{
  grid-column:1/7;grid-row:1;z-index:2;
  background:var(--card);border-radius:var(--r-lg);
  padding:clamp(28px,3.2vw,54px);
  margin-block:clamp(18px,2.6vw,40px);
  box-shadow:0 40px 80px -50px rgba(11,44,86,.45);
}
.lc-card .chip{margin-bottom:26px}
.lc-card h2{font-size:clamp(30px,3.4vw,46px);margin-bottom:14px}
.lc-card .sub{margin-bottom:30px;font-size:15.5px}
.lc-card .fgrid{gap:16px 18px}
.lc-card textarea{min-height:96px}
.lc-card .btn{margin-top:22px}
.lc-photo{
  grid-column:6/13;grid-row:1;position:relative;z-index:1;
  border-radius:var(--r-lg);overflow:hidden;background:var(--navy);min-height:520px;
}
.lc-photo img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.lc-photo .call-pill{
  position:absolute;right:clamp(14px,2vw,28px);bottom:clamp(14px,2vw,28px);left:auto;
  max-width:min(480px,calc(100% - 28px));
}
@media (max-width:1080px){
  .lc-in{display:block}
  .lc-card{margin:0 0 var(--gap)}
  .lc-photo{min-height:420px}
}
@media (max-width:720px){
  .lc-photo{min-height:340px}
  .lc-photo .call-pill{left:14px;right:14px;font-size:13px}
}

/* v10.1 — Let's Connect compacted (was oversized) */
.lc-in{max-width:1180px}
.lc-card{padding:clamp(22px,2.4vw,36px);margin-block:clamp(16px,2vw,30px)}
.lc-card .chip{margin-bottom:16px;padding:6px 13px;font-size:10px}
.lc-card h2{font-size:clamp(22px,2.3vw,30px);margin-bottom:8px}
.lc-card .sub{margin-bottom:20px;font-size:13.5px;line-height:1.55}
.lc-card .fgrid{gap:11px 14px}
.lc-card .field{gap:5px}
.lc-card .field label{font-size:12.5px}
.lc-card .field input,.lc-card .field textarea,.lc-card .field select{
  font-size:13.5px;padding:10px 13px;border-radius:10px}
.lc-card textarea{min-height:60px}
.lc-card .btn{margin-top:10px;padding:12px 22px;font-size:14px}
.lc-photo{min-height:0}
.lc-photo .call-pill{
  font-size:12.5px;padding:10px 18px 10px 10px;max-width:min(400px,calc(100% - 24px))}
.lc-photo .call-pill .ico{width:34px;height:34px}
.lc-photo .call-pill .ico svg{width:14px;height:14px}
@media (max-width:1080px){.lc-photo{min-height:360px}}
@media (max-width:720px){.lc-photo{min-height:300px}}

/* ---------- SERVICES HUB v22 — AiFusionX structure ---------- */
.svh{padding:clamp(44px,6vw,92px) 0 clamp(30px,4vw,54px)}
.svh h1{
  font-family:var(--head);font-weight:600;color:var(--navy);
  font-size:clamp(46px,6.5vw,86px);line-height:1.02;letter-spacing:-.02em;
  margin:20px 0 18px;
}
.lede-txt{color:var(--muted);font-size:clamp(15.5px,1.3vw,18px);line-height:1.7;max-width:600px}
.svh .ctas{display:flex;gap:14px;align-items:center;margin-top:28px}
.svh-band{padding:0 10px}
.svh-band .frame{
  border-radius:var(--r-lg);overflow:hidden;position:relative;
  height:clamp(220px,36vw,430px);
}
.svh-band .frame img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.04)}

.dlv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(26px,3.5vw,60px);margin-top:clamp(28px,3.2vw,46px)}
.dlv h3{font-family:var(--head);font-weight:600;color:var(--navy);font-size:20px;padding-bottom:14px;border-bottom:1.5px solid var(--navy)}
.dlv ul{list-style:none;margin-top:20px;display:grid;gap:15px}
.dlv li{display:flex;gap:11px;align-items:flex-start;font-size:15px;color:var(--text);line-height:1.55}
.dlv li svg{width:15px;height:15px;flex:none;margin-top:5px;color:var(--blue)}

.core-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.core-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:12px 12px 20px;display:flex;flex-direction:column;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.core-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -36px rgba(11,44,86,.35)}
.core-card .pane{
  height:clamp(160px,15vw,205px);border-radius:var(--r-md);position:relative;overflow:hidden;
  background:
    radial-gradient(130% 130% at 50% -10%, rgba(0,83,183,.20), rgba(156,0,221,.08) 55%, rgba(255,255,255,0) 100%),
    linear-gradient(180deg,#EEF3FC,#FBFAF7);
  display:flex;align-items:center;justify-content:center;color:var(--navy);
}
.core-card .pane svg{width:52px;height:52px;transition:transform .5s var(--ease)}
.core-card:hover .pane svg{transform:scale(1.14)}
.core-card .tx{padding:20px 14px 8px}
.core-card h3{font-size:19px;margin-bottom:8px}
.core-card p{font-size:14px;color:var(--muted);line-height:1.65}
.core-card .foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding:14px 14px 2px}
.core-card .cnt{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.core-card .circ{transition:background .3s,color .3s,transform .45s var(--ease)}
.core-card:hover .circ{background:var(--grad);color:#fff;border-color:transparent;transform:rotate(45deg)}

.sb2{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:var(--gap);align-items:stretch}
.sb2-dark{
  background:var(--navy);border-radius:var(--r-lg);padding:clamp(28px,3.4vw,52px);
  color:#fff;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start;
}
.sb2-dark::after{
  content:"";position:absolute;right:-90px;bottom:-120px;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(94,162,240,.5), rgba(156,0,221,.28) 60%, transparent 75%);
  filter:blur(6px);pointer-events:none;
}
.sb2-dark .chip-inv{color:#fff;border-color:var(--line-inv);background:rgba(255,255,255,.08)}
.sb2-dark h3{font-size:clamp(24px,2.4vw,34px);line-height:1.18;color:#fff;margin:22px 0 0}
.sb2-dark p{color:rgba(255,255,255,.72);margin:16px 0 34px;font-size:15px;line-height:1.7;position:relative;z-index:1}
.sb2-dark .btn{margin-top:auto;position:relative;z-index:1}
.sb2-light{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(28px,3.4vw,52px)}
.sb2-light h3{font-size:clamp(22px,2.2vw,30px);color:var(--navy)}
.sb2-light>p{color:var(--muted);font-size:15px;margin:12px 0 26px}
.sb2-chips{display:grid;grid-template-columns:1fr 1fr;gap:12px;list-style:none}
.sb2-chips li{display:flex;gap:11px;align-items:flex-start;background:var(--cream);border-radius:14px;padding:15px 17px;font-size:14px;line-height:1.5;color:var(--text)}
.sb2-chips li svg{width:14px;height:14px;flex:none;margin-top:4px;color:var(--blue)}

.steps4{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  margin-top:clamp(28px,3.2vw,46px);
}
.step4{padding:clamp(24px,2.6vw,36px);border-left:1px solid var(--line);display:flex;flex-direction:column;min-height:290px}
.step4:first-child{border-left:0}
.step4 .eyebrow{
  font-size:11.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
  padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:24px;
}
.step4 h4{font-size:19px;line-height:1.32;color:var(--navy)}
.step4 p{font-size:14px;color:var(--muted);line-height:1.7;margin-top:auto;padding-top:30px}

@media (max-width:1080px){
  .core-grid{grid-template-columns:1fr 1fr}
  .dlv-grid{grid-template-columns:1fr;gap:30px}
  .sb2{grid-template-columns:1fr}
  .steps4{grid-template-columns:1fr 1fr}
  .step4{min-height:0}
  .step4:nth-child(odd){border-left:0}
  .step4:nth-child(n+3){border-top:1px solid var(--line)}
  .step4 p{padding-top:20px}
}
@media (max-width:720px){
  .core-grid{grid-template-columns:1fr}
  .sb2-chips{grid-template-columns:1fr}
  .steps4{grid-template-columns:1fr}
  .step4{border-left:0;border-top:1px solid var(--line)}
  .step4:first-child{border-top:0}
  .svh .ctas{flex-wrap:wrap}
}

/* ---------- INDUSTRIES HUB v23 — AiFusionX photo-card band ---------- */
.indb{padding:0 10px}
.indb-in{background:var(--navy);border-radius:var(--r-lg);padding:clamp(26px,4vw,64px) clamp(16px,3.2vw,60px)}
.indb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.indp{position:relative;display:block;border-radius:var(--r-md);overflow:hidden;aspect-ratio:3/4.1;isolation:isolate}
.indp>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.indp:hover>img{transform:scale(1.08)}
.indp .shade{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,14,30,.66),rgba(4,14,30,.06) 46%,rgba(4,14,30,.30) 100%);
  transition:background .4s;
}
.indp h3{position:absolute;top:18px;left:20px;right:20px;color:#fff;font-size:18.5px;line-height:1.32;z-index:1;font-weight:600}
.indp>.circ{
  position:absolute;right:16px;bottom:16px;z-index:1;
  background:rgba(255,255,255,.16);backdrop-filter:blur(6px);color:#fff;border-color:transparent;
  opacity:0;transform:translateY(10px);
  transition:opacity .35s,transform .5s var(--ease);
}
.indp:hover>.circ{opacity:1;transform:none}
.indp.cta{
  background:var(--grad);padding:clamp(20px,1.8vw,26px);
  display:flex;flex-direction:column;color:#fff;
}
.indp.cta h3{position:static;margin:4px 0 14px;font-size:21px}
.indp.cta p{font-size:13.5px;line-height:1.65;color:rgba(255,255,255,.82)}
.indp.cta .go{
  margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-size:14px;font-weight:600;
}
.indp.cta .go .circ{background:rgba(255,255,255,.18);color:#fff;border-color:transparent;transition:transform .5s var(--ease)}
.indp.cta:hover .go .circ{transform:rotate(45deg)}
@media (max-width:1080px){
  .indb-grid{grid-template-columns:1fr 1fr}
  .indp{aspect-ratio:3/3.4}
}
@media (max-width:560px){
  .indb-grid{grid-template-columns:1fr}
  .indp{aspect-ratio:16/12}
}

/* ---------- CONSULT AN ADVISOR v24 — AiFusionX booking composition ---------- */
.bk{padding:0 10px}
.bk-in{position:relative;display:grid;grid-template-columns:repeat(12,1fr);max-width:1280px;margin-inline:auto}
.bk-media{
  grid-column:1/8;grid-row:1;position:relative;z-index:1;
  border-radius:var(--r-lg);overflow:hidden;background:var(--navy);min-height:660px;
}
.bk-media img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bk-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,18,38,.10),rgba(6,18,38,.52))}
.bk-ask{
  position:absolute;left:clamp(16px,2.5vw,36px);bottom:clamp(16px,2.5vw,36px);z-index:2;
  background:var(--card);border-radius:var(--r-md);padding:clamp(20px,2vw,30px);
  max-width:min(400px,calc(100% - 32px));box-shadow:0 30px 60px -40px rgba(4,14,30,.6);
}
.bk-ask h3{font-size:21px;line-height:1.3;color:var(--navy)}
.bk-ask p{font-size:14px;color:var(--muted);line-height:1.65;margin:12px 0 18px}
.bk-mail{
  display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:11px 13px;transition:border-color .3s,box-shadow .3s;
}
.bk-mail:hover{border-color:transparent;box-shadow:0 16px 34px -22px rgba(11,44,86,.4)}
.bk-mail .ico{flex:none;width:40px;height:40px;border-radius:10px;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center}
.bk-mail .ico svg{width:18px;height:18px}
.bk-mail .tx{display:flex;flex-direction:column;line-height:1.4;min-width:0}
.bk-mail .tx b{font-size:13.5px;color:var(--navy)}
.bk-mail .tx span{font-size:12.5px;color:var(--muted)}
.bk-mail .circ{margin-left:auto;flex:none}
.bk-card{
  grid-column:7/13;grid-row:1;z-index:2;margin-block:clamp(18px,2.6vw,44px);
  border-radius:var(--r-lg);overflow:hidden;background:#fff;display:flex;flex-direction:column;
  box-shadow:0 44px 90px -48px rgba(11,44,86,.5);
}
.bk-head{background:var(--navy);display:flex;align-items:center;gap:16px;padding:17px clamp(20px,2.4vw,34px)}
.bk-head img{height:24px;width:auto;display:block}
.bk-head .dv{width:1px;height:22px;background:rgba(255,255,255,.25)}
.bk-head span:last-child{color:#fff;font-size:14.5px;font-weight:500}
.bk-body{padding:clamp(20px,2.6vw,34px);display:flex;flex-direction:column;flex:1}
.bk-body .intro{font-size:14.5px;color:var(--muted);line-height:1.65;margin-bottom:20px;max-width:540px}
.bk-body .fgrid{gap:14px 16px}
.bk-body .field label{font-size:13px}
.bk-body textarea{min-height:104px}
.bk-body .note{font-size:12.5px;color:var(--muted);margin-bottom:14px}

.next3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3.5vw,56px);margin-top:clamp(26px,3vw,42px)}
.next3 .num{display:block;font-family:var(--head);font-size:13px;font-weight:600;letter-spacing:.12em;color:var(--muted);margin-bottom:12px}
.next3 h4{font-size:20px;color:var(--navy);margin-bottom:10px}
.next3 p{font-size:14.5px;color:var(--muted);line-height:1.7;max-width:340px}

@media (max-width:1080px){
  .bk-in{grid-template-columns:1fr}
  .bk-card{grid-column:1;grid-row:1;margin-block:0}
  .bk-media{grid-column:1;grid-row:2;margin-top:var(--gap);min-height:540px}
  .next3{grid-template-columns:1fr;gap:30px}
}

/* ---------- SERVICE DETAIL v25 — light hero + art band + stat float + examples ---------- */
.svh.sub{padding:clamp(40px,5vw,76px) 0 clamp(28px,3.6vw,50px)}
.svh.sub h1{font-size:clamp(34px,4.6vw,64px);max-width:1000px}
.svh a.chip{transition:border-color .3s,color .3s}
.svh a.chip:hover{border-color:var(--blue);color:var(--blue)}
.sdband{padding:0 10px}
.sdband .frame{position:relative;border-radius:var(--r-lg);overflow:hidden;height:clamp(300px,38vw,470px)}
.sdband .frame>img{width:100%;height:100%;object-fit:cover;display:block}
.sdband .frame::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(6,18,38,.45),rgba(6,18,38,.06) 55%),linear-gradient(0deg,rgba(6,18,38,.28),transparent 45%);
}
.stat-float{
  position:absolute;left:clamp(16px,3vw,44px);bottom:clamp(16px,3vw,44px);z-index:2;
  background:var(--card);border-radius:var(--r-md);padding:20px 24px 18px;
  box-shadow:0 34px 70px -40px rgba(4,14,30,.65);max-width:min(360px,calc(100% - 32px));
}
.stat-float .k{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.stat-float .row{display:flex;align-items:center;gap:14px;margin:10px 0 12px}
.stat-float b{
  font-family:var(--head);font-weight:600;font-size:clamp(28px,2.6vw,38px);line-height:1;flex:none;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat-float .cap{font-size:13px;color:var(--text);line-height:1.45;font-weight:500}
.stat-float .meta{display:block;font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding-top:10px;border-top:1px solid var(--line)}

.exb{padding:clamp(24px,3vw,44px) 10px}
.exb-in{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  padding:clamp(30px,4vw,60px) clamp(18px,3.5vw,60px);
  background:linear-gradient(160deg,#ECEBFA,#F7F1F3 55%,#EEeDF8);
}
.exb-in::before{
  content:"";position:absolute;width:400px;height:400px;left:-130px;top:-150px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,83,183,.22),transparent 68%);filter:blur(8px);
}
.exb-in::after{
  content:"";position:absolute;width:440px;height:440px;right:-150px;bottom:-190px;border-radius:50%;
  background:radial-gradient(circle,rgba(156,0,221,.16),transparent 68%);filter:blur(8px);
}
.ex-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-top:clamp(26px,3vw,42px);position:relative;z-index:1}
.exc{
  background:rgba(255,255,255,.68);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.85);border-radius:var(--r-md);padding:24px 24px 26px;
  box-shadow:0 24px 50px -34px rgba(11,44,86,.35);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.exc:hover{transform:translateY(-5px);box-shadow:0 32px 60px -34px rgba(11,44,86,.42)}
.exc .tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.exc .tags span{font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;background:#fff;border:1px solid var(--line);border-radius:100px;padding:6px 12px;color:var(--navy)}
.exc h3{font-size:19px;color:var(--navy);padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:16px}
.exc dl{display:grid;gap:12px;margin:0}
.exc dl>div{display:grid;grid-template-columns:88px 1fr;gap:12px;align-items:baseline}
.exc dt{font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.exc dd{font-size:14px;color:var(--text);line-height:1.55;margin:0}
.exc dd.res{font-weight:600;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

@media (max-width:1080px){
  .ex-grid{grid-template-columns:1fr}
  .sdband .frame{height:clamp(340px,52vw,470px)}
}
/* v25.1 — svg glyphs in example cards (font subsets lack → and ✦) */
.exc .ar{width:13px;height:13px;display:inline-block;vertical-align:-2px;margin:0 5px;color:var(--blue)}
.exc dd.res{display:flex;align-items:center;gap:7px}
.exc .sp{width:13px;height:13px;flex:none;color:var(--violet)}

/* ---------- v27 — imagery + advanced touches on service detail ---------- */
.ov-side{position:sticky;top:140px;display:grid;gap:var(--gap)}
.ov-side .std-card{position:static}
.ov-photo{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/10;box-shadow:0 24px 50px -34px rgba(11,44,86,.35)}
.ov-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .9s var(--ease)}
.ov-side:hover .ov-photo img{transform:scale(1.06)}
@media (max-width:1080px){.ov-side{position:static}}

@media (prefers-reduced-motion:no-preference){
  .sdband .frame>img{animation:sdkb 14s var(--ease) both}
  @keyframes sdkb{from{transform:scale(1.09)}to{transform:scale(1.005)}}
}

.exb-in{background:#ECEBFA}
.exb-in .bgp{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:blur(5px) saturate(1.08);transform:scale(1.06)}
.exb-in .veil{position:absolute;inset:0;z-index:0;background:linear-gradient(160deg,rgba(238,236,251,.93),rgba(248,242,244,.86) 55%,rgba(238,237,249,.93))}
.exb-in::before,.exb-in::after{z-index:0}
.exb-in>div{position:relative;z-index:1}
.ex-grid{counter-reset:exn}
.exc{position:relative;overflow:hidden;counter-increment:exn}
.exc::before{
  content:"0" counter(exn);position:absolute;top:8px;right:16px;pointer-events:none;
  font-family:var(--head);font-weight:600;font-size:58px;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;opacity:.13;
}

.gs > *{z-index:2}
.gs::before{z-index:1}
.gs-media{position:absolute;inset:0;z-index:0}
.gs-media img{width:100%;height:100%;object-fit:cover}
.gs-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(9,34,66,.97) 28%,rgba(9,34,66,.88) 55%,rgba(13,48,88,.82));
}

/* ---------- v28 — promise band, offerings promo, premium phase cards ---------- */
.band.svcb{min-height:440px;margin-block:clamp(20px,2.6vw,40px)}
.band.svcb h2{max-width:26ch}

.off-promo{
  position:relative;border-radius:var(--r-md);overflow:hidden;min-height:190px;
  background:var(--navy);isolation:isolate;
}
.off-promo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.off-promo:hover img{transform:scale(1.06)}
.off-promo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,18,38,.18),rgba(6,18,38,.72))}
.off-promo .tx{position:absolute;left:22px;right:22px;bottom:20px;z-index:1;color:#fff}
.off-promo .k{
  display:inline-block;font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  background:rgba(255,255,255,.16);backdrop-filter:blur(6px);border-radius:100px;padding:6px 13px;margin-bottom:10px;
}
.off-promo h3{color:#fff;font-size:21px;line-height:1.25}

.phase{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  padding:24px 22px 20px;position:relative;overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
}
.phase:hover{transform:translateY(-4px);box-shadow:0 24px 48px -32px rgba(11,44,86,.32)}
.phase::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad)}
.phase .pn{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;background:var(--grad);
  -webkit-background-clip:border-box;background-clip:border-box;-webkit-text-fill-color:#fff;color:#fff;
  font-size:12.5px;margin-bottom:6px;
}

/* ---------- v29 — cookie consent banner ---------- */
.ck{
  position:fixed;left:16px;bottom:16px;z-index:200;max-width:380px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  padding:18px 18px 16px;box-shadow:0 30px 60px -30px rgba(11,44,86,.45);
  opacity:0;transform:translateY(14px);transition:opacity .35s,transform .45s var(--ease);
}
.ck.up{opacity:1;transform:none}
.ck p{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:14px}
.ck p a{color:var(--blue);text-decoration:underline}
.ck .row{display:flex;gap:10px}
.ck .btn{padding:9px 18px;font-size:12.5px}
@media (max-width:480px){.ck{left:10px;right:10px;max-width:none}}

/* ---------- v29.1 — responsive 3-col utility (replaces inline grid styles) ---------- */
.g3{grid-template-columns:repeat(3,1fr)}
@media (max-width:1080px){.g3{grid-template-columns:1fr 1fr}}
@media (max-width:720px){.g3{grid-template-columns:1fr}}

/* ---------- v30 — mobile polish: nav CTA, touch, iOS, a11y ---------- */
.nav-right .btn{white-space:nowrap}
a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:4px}
@media (max-width:720px){
  .nav-right .btn{padding:10px 15px !important;font-size:12.5px}
  .nav-tel{display:none}
  .field input,.field textarea,.field select{font-size:16px}  /* prevent iOS zoom-on-focus */
  .lc-card .field input,.lc-card .field textarea,.lc-card .field select{font-size:16px}
  .svh h1{overflow-wrap:break-word}
  .ck{padding-bottom:calc(16px + env(safe-area-inset-bottom))}
  .mobile-menu{padding-bottom:calc(var(--pad) + env(safe-area-inset-bottom))}
}
@media (max-width:360px){
  .nav-right .btn{display:none}
}

/* ---------- v32 — searchable FAQ ---------- */
.fq-search{
  display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);
  border-radius:100px;padding:8px 12px 8px 20px;margin-bottom:clamp(30px,4vw,46px);
  transition:border-color .3s,box-shadow .3s;
}
.fq-search:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,83,183,.12)}
.fq-search svg{width:19px;height:19px;color:var(--muted);flex:none}
.fq-search input{
  flex:1;border:0;outline:0;background:transparent;font-family:var(--body);
  font-size:15.5px;color:var(--ink);padding:9px 0;min-width:0;
}
.fq-search input::placeholder{color:#A9B1C4}
.fq-count{flex:none;font-size:12px;font-weight:600;color:var(--muted);background:var(--cream);border-radius:100px;padding:7px 14px}
.fq-none{text-align:center;color:var(--muted);padding:26px 0}

/* ---------- v35 — hero service banners + interactive chips ---------- */
.hero-banners{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-banners img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transform:scale(1.1) translateX(1.6%);
  transition:opacity .65s var(--ease);
}
@media (prefers-reduced-motion:no-preference){
  .hero-banners img{transition:opacity .65s var(--ease),transform 7s linear}
}
.hero-banners img.on{opacity:1;transform:scale(1.03) translateX(0)}
.hero-banners::after{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .65s var(--ease);
  background:linear-gradient(180deg,rgba(6,16,38,.5),rgba(6,16,38,.26) 45%,rgba(6,16,38,.72));
}
.hero-banners.live::after{opacity:1}

/* v37 — frosted-glass service tabs */
.hero-chip{
  position:relative;display:flex;align-items:center;gap:13px;overflow:hidden;text-align:left;
  font-size:12px;letter-spacing:0;text-transform:none;cursor:pointer;
  padding:14px 44px 14px 14px;border-radius:18px;
  background:linear-gradient(135deg,rgba(255,255,255,.17) 0%,rgba(255,255,255,.06) 100%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 20px 44px -28px rgba(3,10,24,.6);
  transition:transform .5s var(--ease),background .45s,border-color .45s,box-shadow .5s var(--ease);
}
.hero-chip .ic{
  flex:none;width:42px;height:42px;border-radius:13px;color:#fff;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22);
  transition:background .45s,border-color .45s,transform .5s var(--ease);
}
.hero-chip .ic svg{width:19px;height:19px}
.hero-chip .tx{display:block;min-width:0}
.hero-chip b{
  display:block;font-family:var(--head);font-weight:600;font-size:14.5px;
  color:#fff;line-height:1.3;text-shadow:0 1px 12px rgba(3,10,24,.35);
}
.hero-chip .tag{
  display:block;font-size:11.5px;font-weight:500;color:rgba(255,255,255,.78);
  margin-top:3px;line-height:1.45;text-shadow:0 1px 10px rgba(3,10,24,.35);
}
.hero-chip .go{
  position:absolute;right:12px;top:50%;width:28px;height:28px;margin-top:-14px;
  border-radius:50%;background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateX(10px) rotate(-45deg);
  transition:opacity .4s,transform .55s var(--ease);
}
.hero-chip .go svg{width:12px;height:12px}
.hero-chip::after{
  content:"";position:absolute;top:-20%;bottom:-20%;left:-55%;width:38%;pointer-events:none;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.22) 50%,transparent);
  transform:skewX(-18deg);opacity:0;
}
.hero-chip:hover,.hero-chip:focus-visible{
  transform:translateY(-7px);
  background:linear-gradient(135deg,rgba(255,255,255,.30) 0%,rgba(255,255,255,.12) 100%);
  border-color:rgba(255,255,255,.45);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 30px 56px -26px rgba(3,10,24,.75);
}
.hero-chip:hover::after,.hero-chip:focus-visible::after{
  opacity:1;transition:left .8s var(--ease),opacity .2s;left:125%;
}
.hero-chip:hover .ic,.hero-chip:focus-visible .ic{
  background:var(--grad);border-color:transparent;transform:scale(1.06);
}
.hero-chip:hover .go,.hero-chip:focus-visible .go{opacity:1;transform:translateX(0) rotate(0deg)}
@media (max-width:1080px){
  .hero-chips{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .hero-chips{grid-template-columns:1fr 1fr;gap:10px}
  .hero-chip{padding:12px 38px 12px 12px;gap:11px;border-radius:15px}
  .hero-chip .ic{width:36px;height:36px;border-radius:11px}
  .hero-chip .ic svg{width:17px;height:17px}
  .hero-chip b{font-size:13px}
  .hero-chip .tag{font-size:10.5px}
}
@media (max-width:460px){
  .hero-chips{grid-template-columns:1fr}
}

/* ---------- v40 — logo scroll-in from heading position ---------- */
.nav.over .nav-logo{will-change:transform}

/* ---------- v38 — home full-bleed hero slider + overlay nav ---------- */
.nav .lg-w{display:none}
.nav.over{position:fixed;left:0;right:0;top:0;transition:background .35s,box-shadow .3s}
.nav.over:not(.scrolled){background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}
body:not(.menu-open) .nav.over:not(.scrolled) .lg-c{display:none}
body:not(.menu-open) .nav.over:not(.scrolled) .lg-w{display:block}
body:not(.menu-open) .nav.over:not(.scrolled) .nav-links a.top{color:#fff}
body:not(.menu-open) .nav.over:not(.scrolled) .nav-tel{color:#fff}
body:not(.menu-open) .nav.over:not(.scrolled) .nav-burger span{background:#fff}

.hero.full{border-radius:0;min-height:100svh;justify-content:flex-end}
.hero.full::before{display:none}
.hero.full .hero-banners::after{
  opacity:1;
  background:
    linear-gradient(180deg,rgba(4,12,26,.34) 0%,rgba(4,12,26,0) 22%),
    linear-gradient(76deg,rgba(4,12,26,.50) 0%,rgba(4,12,26,.20) 44%,rgba(4,12,26,.04) 100%),
    linear-gradient(0deg,rgba(4,12,26,.42) 0%,rgba(4,12,26,0) 28%);
}
.hero.full .hero-in{
  flex:1;display:flex;flex-direction:column;justify-content:center;
  padding-top:calc(84px + 3vh);
}
.hero-hh{display:grid;margin-bottom:34px}
.hero-hh .hh{
  grid-area:1/1;color:#fff;margin:0;max-width:20ch;
  font-size:clamp(36px,4.4vw,62px);line-height:1.12;
  opacity:0;transform:translateY(28px);pointer-events:none;
  transition:opacity .6s var(--ease),transform .8s var(--ease);
}
.hero-hh .hh.on{opacity:1;transform:none;transition-delay:.25s}
.hero.full .hero-ctas{margin-bottom:0}

.hero-tabs{
  position:relative;z-index:2;
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
  padding:26px clamp(16px,2.6vw,42px) clamp(16px,2vw,28px);
}
.hero-tab{
  display:flex;align-items:center;min-height:60px;padding:16px 24px;border-radius:8px;
  font-family:var(--head);font-size:12.5px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;
  color:#fff;background:rgba(255,255,255,.13);
  -webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);
  border:1px solid rgba(255,255,255,.15);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16);
  transition:background .4s,color .4s,border-color .4s,transform .45s var(--ease),box-shadow .45s var(--ease);
}
.hero-tab:hover{background:rgba(255,255,255,.26);transform:translateY(-3px)}
.hero-tab.on{
  background:#fff;color:var(--blue);border-color:#fff;
  box-shadow:0 20px 42px -20px rgba(3,10,24,.65);
}
@media (max-width:900px){
  .hero-tabs{grid-template-columns:1fr 1fr;gap:8px}
  .hero-tab{min-height:50px;padding:13px 18px;font-size:11px}
}
@media (max-width:460px){
  .hero-tab{min-height:44px;padding:11px 14px;font-size:10px;letter-spacing:.06em}
  .hero-hh .hh{font-size:clamp(31px,8.6vw,38px)}
}

/* ---------- v46 — newsletter band: photo bg + true-glass card ---------- */
.news{position:relative;overflow:hidden;display:block}
.news .news-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 8s var(--ease)}
.news:hover .news-bg{transform:scale(1.05)}
.news::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(6,16,38,.5) 0%,rgba(6,16,38,.16) 55%,rgba(6,16,38,.34) 100%);
}
.news-glass{
  position:relative;z-index:1;
  display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;
  padding:clamp(24px,3vw,42px);border-radius:20px;overflow:hidden;
  background:linear-gradient(135deg,rgba(255,255,255,.16) 0%,rgba(255,255,255,.05) 100%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);
  border:1px solid rgba(255,255,255,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 26px 52px -30px rgba(3,10,24,.75);
  transition:transform .5s var(--ease),background .45s,border-color .45s,box-shadow .5s var(--ease);
}
.news-glass::after{
  content:"";position:absolute;top:-20%;bottom:-20%;left:-45%;width:30%;pointer-events:none;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.2) 50%,transparent);
  transform:skewX(-18deg);opacity:0;
}
.news-glass:hover{
  transform:translateY(-4px);
  background:linear-gradient(135deg,rgba(255,255,255,.26) 0%,rgba(255,255,255,.1) 100%);
  border-color:rgba(255,255,255,.44);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.42),0 34px 62px -30px rgba(3,10,24,.85);
}
.news-glass:hover::after{opacity:1;transition:left .9s var(--ease),opacity .2s;left:130%}
@media (max-width:720px){
  .news-glass{flex-direction:column;align-items:flex-start}
  .news-form{width:100%}
  .news-form input{flex:1;width:auto;min-width:0}
  .news-form .circ{flex:none}
}

/* ============================================================
   v56 — HIGH-END ABSTRACT GLASS SYSTEM
   Fixed ambient color-field + frosted glass card surfaces.
   Replaces solid white/cream boxes site-wide with layered glass;
   navy anchor panels (.philo/.ov-panel/.cta-panel/.gs/.sb2-dark)
   stay solid on purpose so the glass has something to contrast.
   ============================================================ */

/* — ambient abstract backdrop: soft brand color orbs, fixed so
     every glass surface picks up gentle tint as the page scrolls — */
html{background:var(--cream)}
body{background:transparent}
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(1100px 720px at 88% -8%, rgba(0,83,183,.11), transparent 62%),
    radial-gradient(820px 640px at -12% 34%, rgba(156,0,221,.08), transparent 62%),
    radial-gradient(900px 700px at 78% 96%, rgba(0,83,183,.08), transparent 62%),
    radial-gradient(620px 480px at 30% 78%, rgba(143,183,255,.10), transparent 64%);
}

/* — light glass surface (was: solid #fff / var(--card)) — */
.icard:not(.brand),.svc-card,.off-card,.aside-card,.ins-card,.form-card,.office-card,
.seg-card,.t-card,.loc-card:not(.hq),.std-card,.core-card,.sx-tab:not(.on),
.quote-card,.sb2-light,.steps4,details,.phase{
  background:linear-gradient(152deg,rgba(255,255,255,.66),rgba(255,255,255,.38));
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  backdrop-filter:blur(16px) saturate(150%);
  border:1px solid rgba(255,255,255,.75);
  box-shadow:0 24px 50px -38px rgba(11,44,86,.28), inset 0 1px 0 rgba(255,255,255,.85);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),
             background .45s,border-color .45s;
}
.icard:not(.brand):hover,.svc-card:hover,.off-card:hover,.ins-card:hover,
.seg-card:hover,.t-card:hover,.loc-card:not(.hq):hover,.core-card:hover,
.sx-tab:not(.on):hover,.phase:hover,details[open]{
  background:linear-gradient(152deg,rgba(255,255,255,.84),rgba(255,255,255,.56));
  border-color:rgba(255,255,255,.95);
}
/* keep the FAQ hub answer text readable while open */
details[open]{box-shadow:0 30px 60px -40px rgba(11,44,86,.35), inset 0 1px 0 rgba(255,255,255,.9)}

/* inner inset boxes ride the glass instead of sitting solid on it */
.seg-card .inner{background:rgba(246,244,239,.62)}
.seg-card:hover .inner{background:rgba(255,255,255,.78)}
.sb2-chips li{
  background:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.8);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}

/* — navy-panel glass (philosophy principle cards) — */
.pcard{
  background:linear-gradient(150deg,rgba(255,255,255,.13),rgba(255,255,255,.05));
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  backdrop-filter:blur(14px) saturate(140%);
  border-color:rgba(255,255,255,.2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16);
}
.pcard:hover{
  background:linear-gradient(150deg,rgba(255,255,255,.2),rgba(255,255,255,.09));
  border-color:rgba(255,255,255,.34);transform:translateY(-4px);
}

/* — consult form card: high-alpha glass (form legibility first) — */
.bk-card{
  background:linear-gradient(150deg,rgba(255,255,255,.88),rgba(255,255,255,.72));
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  backdrop-filter:blur(18px) saturate(150%);
  border:1px solid rgba(255,255,255,.9);
}

/* — no-backdrop-filter fallback: solid near-white so text never
     sits on raw low-alpha glass — */
@supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){
  .icard:not(.brand),.svc-card,.off-card,.aside-card,.ins-card,.form-card,.office-card,
  .seg-card,.t-card,.loc-card:not(.hq),.std-card,.core-card,.sx-tab:not(.on),
  .quote-card,.sb2-light,.steps4,details,.phase,.bk-card{background:rgba(255,255,255,.94)}
  .pcard{background:rgba(255,255,255,.1)}
}

/* — mobile: lighter blur, cheaper compositing — */
@media (max-width:720px){
  .icard:not(.brand),.svc-card,.off-card,.aside-card,.ins-card,.form-card,.office-card,
  .seg-card,.t-card,.loc-card:not(.hq),.std-card,.core-card,.sx-tab:not(.on),
  .quote-card,.sb2-light,.steps4,details,.phase{
    -webkit-backdrop-filter:blur(10px) saturate(140%);
    backdrop-filter:blur(10px) saturate(140%);
  }
}
