/* ===================================================================
   AppsXpert — Services page (zps-)  •  light, clean, animated
   Same palette as HRMS/home: white, #f8f9fb light grey, navy text,
   gradient icons, brand-blue accent. Accent via --zps-accent.
   =================================================================== */
.zps-main{--zps-accent:#2563eb;--zps-soft:#eaf1fd;font-family:var(--font-primary,'Inter',sans-serif);color:#1d2433;}
.zps-main h1,.zps-main h2,.zps-main h3{font-family:var(--font-primary,'Inter',sans-serif);}

/* ---- HERO (light) ---- */
.zps-hero{background:#f5f7fb;padding:84px 24px 92px;overflow:hidden;}
.zps-hero-inner{max-width:1140px;margin:0 auto;display:flex;align-items:center;gap:56px;flex-wrap:wrap;}
.zps-hero-text{flex:1 1 430px;}
.zps-hero-visual{flex:0 0 340px;}
.zps-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--zps-soft);color:var(--zps-accent);font-weight:700;text-transform:uppercase;letter-spacing:.8px;font-size:12px;padding:8px 15px;border-radius:30px;}
.zps-hero h1{font-size:52px;line-height:1.06;letter-spacing:-1.8px;color:#0B1F4A;font-weight:800;margin:20px 0 0;}
.zps-hero h1 .ac{color:var(--zps-accent);}
.zps-hero p{font-size:17px;line-height:1.7;color:#5b6473;max-width:560px;margin:20px 0 30px;}
.zps-btns{display:flex;gap:14px;flex-wrap:wrap;}
.zps-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:12px;font-weight:700;font-size:15px;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease;}
.zps-btn-p{background:var(--zps-accent);color:#fff;box-shadow:0 10px 24px rgba(37,99,235,.25);}
.zps-btn-p:hover{transform:translateY(-2px);color:#fff;}
.zps-btn-o{background:#fff;color:#0B1F4A;border:1px solid #dde3ec;}
.zps-btn-o:hover{transform:translateY(-2px);color:#0B1F4A;border-color:#c3ccd9;}

/* hero floating tiles */
.zps-float{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.zps-float-card{background:#fff;border:1px solid #eceff3;border-radius:16px;padding:22px;box-shadow:0 14px 34px rgba(11,31,74,.07);animation:zpsFloat 5.5s ease-in-out infinite;}
.zps-float-card:nth-child(2){animation-delay:.7s;}
.zps-float-card:nth-child(3){animation-delay:1.4s;}
.zps-float-card:nth-child(4){animation-delay:2.1s;}
.zps-float-ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:19px;margin-bottom:13px;}
.zps-float-card b{display:block;font-size:15px;color:#0B1F4A;font-weight:700;}
.zps-float-card span{font-size:12.5px;color:#7a8290;}
@keyframes zpsFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}

/* ---- STATS ---- */
.zps-stats{background:#fed600;}
.zps-stats-inner{max-width:1140px;margin:0 auto;display:flex;flex-wrap:wrap;}
.zps-stat{flex:1;min-width:170px;padding:34px 24px;text-align:center;border-right:1px solid rgba(11,31,74,.12);}
.zps-stat:last-child{border-right:none;}
.zps-stat b{display:block;font-size:30px;font-weight:800;color:#0B1F4A;letter-spacing:-1px;}
.zps-stat span{display:block;font-size:14px;font-weight:600;color:#4a4a32;margin-top:5px;}

/* ---- SECTION ---- */
.zps-sec{padding:84px 24px;}
.zps-sec.grey{background:#f8f9fb;}
.zps-sec-head{max-width:740px;margin:0 auto 50px;text-align:center;}
.zps-sec-head .zps-tag{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--zps-accent);}
.zps-sec-head h2{font-size:38px;letter-spacing:-1.2px;color:#0B1F4A;font-weight:800;margin:12px 0 14px;}
.zps-sec-head p{font-size:16px;line-height:1.7;color:#5b6473;margin:0;}

/* ---- SERVICE CARDS ---- */
.zps-cards{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px;}
.zps-card{background:#fff;border:1px solid #eceff3;border-radius:18px;padding:30px 28px;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s ease;}
.zps-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(11,31,74,.10);}
.zps-card-ic{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;margin-bottom:18px;}
.zps-card h3{font-size:19px;color:#0B1F4A;margin:0 0 9px;font-weight:700;}
.zps-card p{font-size:14.5px;color:#5b6473;line-height:1.6;margin:0;}

/* ---- AREAS (chips) ---- */
.zps-mods{max-width:1000px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:center;gap:12px;}
.zps-mod{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid #eceff3;border-radius:30px;padding:11px 18px;font-size:14.5px;font-weight:600;color:#0B1F4A;transition:transform .2s ease,border-color .2s ease;}
.zps-mod:hover{transform:translateY(-3px);border-color:var(--zps-accent);}
.zps-mod i{color:var(--zps-accent);font-size:15px;}

/* ---- WHY (light cards) ---- */
.zps-why-grid{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px;}
.zps-why-card{background:#fff;border:1px solid #eceff3;border-radius:18px;padding:30px 26px;transition:transform .3s ease,box-shadow .3s ease;}
.zps-why-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(11,31,74,.10);}
.zps-why-card i{width:50px;height:50px;border-radius:13px;background:var(--zps-soft);color:var(--zps-accent);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px;}
.zps-why-card h3{font-size:18px;color:#0B1F4A;margin:0 0 8px;font-weight:700;}
.zps-why-card p{font-size:14px;color:#5b6473;line-height:1.6;margin:0;}

/* ---- PROCESS STEPS ---- */
.zps-steps{max-width:1140px;margin:0 auto;display:flex;flex-wrap:wrap;position:relative;}
.zps-step{flex:1;min-width:180px;text-align:center;padding:0 18px;position:relative;}
.zps-step:not(:last-child)::after{content:"";position:absolute;top:27px;left:62%;width:76%;height:2px;background:#dde3ec;}
.zps-step-n{position:relative;z-index:2;width:56px;height:56px;margin:0 auto 16px;border-radius:50%;background:var(--zps-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;box-shadow:0 10px 24px rgba(37,99,235,.25);}
.zps-step h3{font-size:17px;color:#0B1F4A;margin:0 0 7px;font-weight:700;}
.zps-step p{font-size:13.5px;color:#5b6473;line-height:1.55;margin:0;}

/* ---- CTA (light card) ---- */
.zps-cta{background:#f8f9fb;padding:80px 24px;}
.zps-cta-inner{max-width:780px;margin:0 auto;background:#E63946;border-radius:24px;padding:54px 40px;text-align:center;box-shadow:0 24px 54px rgba(230,57,70,.30);}
.zps-cta h2{font-size:34px;letter-spacing:-1px;color:#fff;font-weight:800;margin:0 0 12px;}
.zps-cta p{font-size:17px;color:rgba(255,255,255,.92);margin:0 0 26px;}
.zps-cta .zps-btn-p{background:#fff;color:#E63946;box-shadow:0 10px 24px rgba(0,0,0,.18);}
.zps-cta .zps-btn-p:hover{transform:translateY(-2px);color:#E63946;}

/* ---- FAQ accordion ---- */
.zps-faq{max-width:820px;margin:0 auto;}
.zps-faq-item{background:#fff;border:1px solid #eceff3;border-radius:14px;margin-bottom:14px;overflow:hidden;transition:box-shadow .25s ease;}
.zps-faq-item.open{box-shadow:0 12px 30px rgba(11,31,74,.08);}
.zps-faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;cursor:pointer;font-size:16.5px;font-weight:700;color:#0B1F4A;}
.zps-faq-q i{color:var(--zps-accent);transition:transform .3s ease;flex:0 0 auto;}
.zps-faq-item.open .zps-faq-q i{transform:rotate(180deg);}
.zps-faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.zps-faq-a p{padding:0 24px 22px;font-size:15px;color:#5b6473;line-height:1.7;margin:0;}

/* ---- card extras (tag pill + checklist, for engagement models) ---- */
.zps-card .zps-card-tag{display:inline-block;background:var(--zps-soft);color:var(--zps-accent);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:5px 11px;border-radius:20px;margin-bottom:13px;}
.zps-card-list{list-style:none;margin:14px 0 0;padding:0;}
.zps-card-list li{position:relative;padding:6px 0 6px 23px;font-size:13.8px;color:#5b6473;line-height:1.5;}
.zps-card-list li::before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;left:0;top:6px;color:var(--zps-accent);font-size:12px;}

/* ---- comparison table (EBS vs Fusion) ---- */
.zps-cmp-wrap{max-width:980px;margin:0 auto;overflow-x:auto;}
.zps-cmp{min-width:620px;background:#fff;border:1px solid #eceff3;border-radius:18px;overflow:hidden;box-shadow:0 14px 34px rgba(11,31,74,.06);}
.zps-cmp-row{display:grid;grid-template-columns:1.25fr 1fr 1fr;}
.zps-cmp-row:not(:last-child){border-bottom:1px solid #eef0f4;}
.zps-cmp-row>div{padding:17px 22px;font-size:14.5px;color:#5b6473;line-height:1.5;}
.zps-cmp-row>div+div{border-left:1px solid #eef0f4;}
.zps-cmp-row>div:first-child{font-weight:600;color:#0B1F4A;background:#fcfcfd;}
.zps-cmp-head{background:#f8f9fb;}
.zps-cmp-head>div{font-weight:700;color:#0B1F4A;font-size:15px;}
.zps-cmp-head>div i{color:var(--zps-accent);margin-right:8px;}
.zps-cmp-note{max-width:980px;margin:18px auto 0;text-align:center;font-size:13.5px;color:#7a8290;}

/* ---- deliverables checklist ---- */
.zps-deliver{max-width:920px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.zps-deliver-item{display:flex;align-items:flex-start;gap:13px;background:#fff;border:1px solid #eceff3;border-radius:13px;padding:18px 20px;transition:transform .25s ease,box-shadow .25s ease;}
.zps-deliver-item:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(11,31,74,.08);}
.zps-deliver-item i{color:#2D9F4F;font-size:18px;margin-top:2px;flex:0 0 auto;}
.zps-deliver-item b{display:block;font-size:15px;color:#0B1F4A;font-weight:700;margin-bottom:3px;}
.zps-deliver-item span{font-size:13.5px;color:#5b6473;line-height:1.5;}
@media(max-width:640px){.zps-deliver{grid-template-columns:1fr;}}

/* =====================================================================
   DISTINCT SECTION LAYOUTS — each section gets its own visual treatment
   ===================================================================== */

/* ---- SERVICES — bento grid (one dark feature tile + small tiles) ---- */
.zps-bento{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(150px,auto);gap:20px;}
.zps-bento-tile{position:relative;background:#fff;border:1px solid #eceff3;border-radius:18px;padding:28px;overflow:hidden;transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s ease;}
.zps-bento-tile:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(11,31,74,.10);}
.zps-bento-ic{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:21px;margin-bottom:16px;}
.zps-bento-tile h3{font-size:18px;color:#0B1F4A;margin:0 0 8px;font-weight:700;}
.zps-bento-tile p{font-size:14px;color:#5b6473;line-height:1.6;margin:0;}
.zps-bento-tile.feat{grid-column:span 2;grid-row:span 2;background:#0B1F4A;display:flex;flex-direction:column;justify-content:center;padding:42px;}
.zps-bento-tile.feat h3{color:#fff;font-size:27px;letter-spacing:-.6px;margin-bottom:14px;}
.zps-bento-tile.feat p{color:rgba(255,255,255,.85);font-size:15.5px;max-width:440px;}
.zps-bento-tile.feat .zps-bento-ic{width:62px;height:62px;font-size:27px;background:rgba(255,255,255,.14);}
.zps-bento-wm{position:absolute;right:-22px;bottom:-34px;font-size:175px;color:rgba(255,255,255,.06);pointer-events:none;animation:zpsFloat 6s ease-in-out infinite;}
.zps-bento-pills{list-style:none;margin:20px 0 0;padding:0;display:flex;gap:10px;flex-wrap:wrap;}
.zps-bento-pills li{font-size:12.5px;font-weight:600;color:#fff;background:rgba(255,255,255,.12);padding:7px 13px;border-radius:20px;}
@media(max-width:820px){.zps-bento{grid-template-columns:1fr 1fr;}.zps-bento-tile.feat{grid-column:span 2;grid-row:auto;}}
@media(max-width:560px){.zps-bento{grid-template-columns:1fr;}.zps-bento-tile.feat{grid-column:auto;}}

/* ---- WHEN — split: sticky left intro + signal rows ---- */
.zps-split{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:.82fr 1.18fr;gap:54px;align-items:start;}
.zps-split-left{position:sticky;top:100px;}
.zps-split-left .zps-tag{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--zps-accent);}
.zps-split-left h2{font-size:34px;letter-spacing:-1px;color:#0B1F4A;font-weight:800;margin:12px 0 16px;line-height:1.13;}
.zps-split-left p{font-size:15.5px;color:#5b6473;line-height:1.7;margin:0 0 24px;}
.zps-signals{display:flex;flex-direction:column;}
.zps-signal{display:flex;gap:20px;align-items:flex-start;padding:22px 0;border-bottom:1px solid #e7ebf2;border-radius:12px;transition:transform .25s ease,background .25s ease,padding .25s ease,box-shadow .25s ease;}
.zps-signal:hover{transform:translateX(8px);background:#fff;padding:22px;border-bottom-color:transparent;box-shadow:0 12px 28px rgba(11,31,74,.07);}
.zps-signal-ic{flex:0 0 auto;width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:21px;}
.zps-signal b{display:block;font-size:17px;color:#0B1F4A;font-weight:700;margin-bottom:5px;}
.zps-signal p{font-size:14px;color:#5b6473;line-height:1.6;margin:0;}
@media(max-width:820px){.zps-split{grid-template-columns:1fr;gap:30px;}.zps-split-left{position:static;}}

/* ---- WHY — value strip (circular icons on a connecting line) ---- */
.zps-vals{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:34px;position:relative;}
.zps-vals::before{content:"";position:absolute;top:42px;left:13%;right:13%;height:2px;background:transparent;opacity:.3;}
.zps-val{text-align:center;position:relative;z-index:2;}
.zps-val-ic{width:84px;height:84px;margin:0 auto 18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;box-shadow:0 14px 30px rgba(11,31,74,.16);transition:transform .3s ease;}
.zps-val:hover .zps-val-ic{transform:translateY(-7px) scale(1.06);}
.zps-val h3{font-size:17px;color:#0B1F4A;margin:0 0 8px;font-weight:700;}
.zps-val p{font-size:13.8px;color:#5b6473;line-height:1.6;margin:0;padding:0 6px;}
@media(max-width:780px){.zps-vals{grid-template-columns:1fr 1fr;gap:34px 20px;}.zps-vals::before{display:none;}}
@media(max-width:430px){.zps-vals{grid-template-columns:1fr;}}

/* ---- OUTCOMES — impact tiles (accent bar + watermark icon) ---- */
.zps-impact{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.zps-impact-tile{position:relative;overflow:hidden;background:#fff;border:1px solid #eceff3;border-radius:20px;padding:34px 34px 34px 40px;transition:transform .3s ease,box-shadow .3s ease;}
.zps-impact-tile:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(11,31,74,.10);}
.zps-impact-tile::before{content:"";position:absolute;left:0;top:24px;bottom:24px;width:5px;border-radius:0 4px 4px 0;background:var(--bar,#2563eb);}
.zps-impact-wm{position:absolute;right:-8px;bottom:-24px;font-size:120px;color:#0B1F4A;opacity:.05;pointer-events:none;transition:transform .45s ease;}
.zps-impact-tile:hover .zps-impact-wm{transform:scale(1.08) rotate(-6deg);}
.zps-impact-tile .k{display:inline-block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--bar,#2563eb);margin-bottom:10px;}
.zps-impact-tile h3{font-size:22px;color:#0B1F4A;margin:0 0 9px;font-weight:800;letter-spacing:-.4px;}
.zps-impact-tile p{font-size:14.5px;color:#5b6473;line-height:1.65;margin:0;max-width:90%;position:relative;z-index:2;}
@media(max-width:680px){.zps-impact{grid-template-columns:1fr;}}

/* ---- ENGAGEMENT — pricing tiers (featured tier elevated) ---- */
.zps-tiers{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:stretch;}
.zps-tier{position:relative;background:#fff;border:1px solid #e7ebf2;border-radius:18px;padding:32px 26px;display:flex;flex-direction:column;box-shadow:0 6px 18px rgba(11,31,74,.05);transition:transform .3s ease,box-shadow .3s ease;}
.zps-tier:hover{transform:translateY(-7px);box-shadow:0 22px 46px rgba(11,31,74,.12);}
.zps-tier.pop{border:2px solid var(--zps-accent);box-shadow:0 24px 54px rgba(37,99,235,.16);}
.zps-tier-ribbon{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--zps-accent);color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:6px 15px;border-radius:20px;white-space:nowrap;box-shadow:0 8px 18px rgba(37,99,235,.3);}
.zps-tier-k{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#9aa3b1;margin-bottom:14px;}
.zps-tier-ic{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;margin-bottom:16px;}
.zps-tier h3{font-size:19px;color:#0B1F4A;margin:0 0 9px;font-weight:700;}
.zps-tier .lead{font-size:13.8px;color:#5b6473;line-height:1.6;margin:0 0 16px;}
.zps-tier ul{list-style:none;margin:auto 0 0;padding:16px 0 0;border-top:1px solid #eef0f4;display:flex;flex-direction:column;gap:11px;}
.zps-tier ul li{position:relative;padding-left:24px;font-size:13.6px;color:#42495a;line-height:1.45;}
.zps-tier ul li::before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;left:0;top:1px;color:#2D9F4F;font-size:12px;}
@media(max-width:980px){.zps-tiers{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.zps-tiers{grid-template-columns:1fr;}}

/* ---- reveal (visible by default; JS adds .zps-anim then .zps-visible) ---- */
.zps-anim{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.zps-visible{opacity:1 !important;transform:none !important;}
@media(prefers-reduced-motion:reduce){.zps-float-card{animation:none;}.zps-anim{opacity:1;transform:none;}}

/* ---- responsive ---- */
@media(max-width:860px){
  .zps-hero h1{font-size:40px;}
  .zps-hero-visual{flex-basis:100%;}
  .zps-step:not(:last-child)::after{display:none;}
}
@media(max-width:560px){
  .zps-hero{padding:54px 20px 60px;}
  .zps-hero h1{font-size:31px;}
  .zps-sec-head h2,.zps-cta h2{font-size:27px;}
  .zps-stat{border-right:none;border-bottom:1px solid #eef0f4;}
  .zps-sec{padding:50px 18px;}
  .zps-cta{padding:50px 18px;}
  .zps-cta-inner{padding:38px 24px;}
  .zps-sec-head{margin-bottom:34px;}
  .zps-hero-trust{gap:8px;}
}

/* ---- module hub: category rows + clickable cards ---- */
.zps-cat{max-width:1140px;margin:42px auto 18px;display:flex;align-items:center;gap:13px;}
.zps-cat:first-of-type{margin-top:0;}
.zps-cat::before{content:"";width:26px;height:3px;border-radius:2px;background:var(--zps-accent);flex:0 0 auto;}
.zps-cat h3{font-size:20px;color:#0B1F4A;font-weight:800;margin:0;letter-spacing:-.4px;}
a.zps-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;}
.zps-card-link{margin-top:14px;font-size:13px;font-weight:700;color:var(--zps-accent);display:inline-flex;align-items:center;gap:7px;}
.zps-card-link i{transition:transform .2s ease;}
.zps-card:hover .zps-card-link i{transform:translateX(4px);}

/* ---- hub hero trust badges + clickable bento ---- */
.zps-hero-trust{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;}
.zps-hero-trust span{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:#0B1F4A;background:#fff;border:1px solid #e7ebf2;border-radius:30px;padding:8px 14px;box-shadow:0 4px 12px rgba(11,31,74,.05);}
.zps-hero-trust span i{color:var(--zps-accent);font-size:12px;}
a.zps-bento-tile{text-decoration:none;color:inherit;display:block;}
.zps-bento-tile .more{margin-top:14px;font-size:13px;font-weight:700;color:var(--zps-accent);display:inline-flex;align-items:center;gap:6px;}
.zps-bento-tile .more i{transition:transform .2s ease;}
.zps-bento-tile:hover .more i{transform:translateX(4px);}
a.zps-bento-tile.feat .more{color:#fff;}
