/* ============================================================
   page-zoho-sub.css
   Shared styles for all Zoho sub-service pages:
   Zoho CRM · Creator · Analytics · One · Desk ·
   Campaigns · Books · Marketing Automation
   Enqueue via: wp_enqueue_style() with is_page() checks
   ============================================================ */

/* ── Variables inherited from global page-zoho-services.css ── */
/* Do NOT redefine :root here — it overrides the global theme and breaks the header */

/* ── Reset / base ── */
.zp-page *,
.zp-page *::before,
.zp-page *::after { box-sizing:border-box; }
.zp-page { overflow-x:hidden; }

/* ── Animations ── */
@keyframes zp-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.7)} }
@keyframes zp-up    { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ── Scroll reveal ── */
.zp-page .rv { opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.zp-page .rv.v { opacity:1; transform:translateY(0); }
.zp-page .d1{transition-delay:.12s} .zp-page .d2{transition-delay:.22s}
.zp-page .d3{transition-delay:.32s} .zp-page .d4{transition-delay:.42s}

/* ── Utility ── */
.zp-hl { background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }

/* ── Section header ── */
.zp-sh { text-align:center; max-width:640px; margin:0 auto 52px; }
.zp-sh-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.76rem; font-weight:700; color:var(--teal-dark);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:14px;
}
.zp-sh-tag::before,.zp-sh-tag::after {
  content:''; width:20px; height:1.5px; background:var(--teal); opacity:.35;
}
.zp-sh h2 { font-size:clamp(1.9rem,3.8vw,2.55rem); font-weight:800; color:var(--navy); margin-bottom:12px; }
.zp-sh p  { font-size:1rem; color:var(--tx2); line-height:1.75; }
/* dark variant */
.zp-sh-d .zp-sh-tag  { color:var(--teal-light); }
.zp-sh-d .zp-sh-tag::before,
.zp-sh-d .zp-sh-tag::after { background:var(--teal); }
.zp-sh-d h2 { color:#fff; }
.zp-sh-d p  { color:var(--g300); }
/* left-aligned variant */
.zp-sh-l { text-align:left; margin-left:0; }
.zp-sh-l .zp-sh-tag { justify-content:flex-start; }

/* ── Buttons ── */
.zp-btn-p {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 34px; background:var(--grad); color:#fff;
  font-weight:700; font-size:.95rem; border-radius:60px;
  transition:all .4s var(--ease);
  box-shadow:0 4px 20px rgba(46,196,182,0.28);
  position:relative; overflow:hidden; font-family:'Mulish',sans-serif;
}
.zp-btn-p::before {
  content:''; position:absolute; inset:0;
  background:var(--grad-h); opacity:0; transition:opacity .4s; border-radius:inherit;
}
.zp-btn-p:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(46,196,182,0.38); }
.zp-btn-p:hover::before { opacity:1; }
.zp-btn-p span,.zp-btn-p svg { position:relative; z-index:1; }


/* ── Container — fallback so .c works even if global CSS loads late ── */
.zp-page .c {
  max-width:1180px;
  margin:0 auto;
  padding:0 24px;
}

/* ══════════════════════════════════════════
   HERO — 2-col split (dark navy + form card)
══════════════════════════════════════════ */
.zp-hero {
  position:relative; padding:130px 0 0;
  background:linear-gradient(160deg,#0A1628 0%,#0E1A30 55%,#0B1F2E 100%);
  overflow:hidden;
}
.zp-hero::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(46,196,182,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(46,196,182,.04) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 28% 50%,black 25%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 28% 50%,black 25%,transparent 70%);
}
.zp-hero-orb1 {
  position:absolute; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(46,196,182,.1) 0%,transparent 65%);
  top:-200px; left:-100px; pointer-events:none;
}
.zp-hero-orb2 {
  position:absolute; width:400px; height:400px; border-radius:50%;
  background:radial-gradient(circle,rgba(77,163,232,.09) 0%,transparent 65%);
  bottom:-120px; right:-60px; pointer-events:none;
}
.zp-hero-grid {
  display:grid; grid-template-columns:1fr 400px; gap:52px;
  align-items:start; position:relative; z-index:3; padding-bottom:80px;
}
/* breadcrumb */
.zp-breadcrumb {
  display:flex; align-items:center; gap:8px; font-size:.8rem;
  color:rgba(255,255,255,.35); margin-bottom:22px;
}
.zp-breadcrumb a { color:var(--teal); font-weight:600; transition:color .2s; }
.zp-breadcrumb a:hover { color:#fff; }
.zp-breadcrumb svg { width:12px; height:12px; opacity:.4; }
/* eyebrow badge */
.zp-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 18px; background:var(--teal-muted);
  border:1px solid rgba(46,196,182,.2); border-radius:50px;
  font-size:.73rem; font-weight:700; color:var(--teal-light);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:22px;
}
.zp-eyebrow-dot { width:6px; height:6px; border-radius:50%; background:var(--teal); animation:zp-pulse 2s infinite; }
/* product logo — on white pill background so dark SVG logos are visible */
/* logo wrap removed — using text-only eyebrow badge */
/* headline */
.zp-hero h1 { font-size:clamp(2.2rem,4.5vw,3.4rem); font-weight:900; color:#fff; line-height:1.08; margin-bottom:20px; }
.zp-hero-sub { font-size:1rem; color:rgba(255,255,255,.55); line-height:1.85; margin-bottom:28px; max-width:500px; }
/* trust pills */
.zp-pills { display:flex; flex-wrap:wrap; gap:9px; margin-bottom:32px; }
.zp-pill {
  display:flex; align-items:center; gap:6px;
  padding:7px 15px; background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08); border-radius:50px;
  font-size:.78rem; color:rgba(255,255,255,.5); font-weight:600;
}
.zp-pill svg { width:12px; height:12px; color:var(--teal); flex-shrink:0; }
/* connects row */
.zp-connects { display:flex; gap:8px; flex-wrap:wrap; }
.zp-connects-label {
  font-size:.76rem; font-weight:600; color:rgba(255,255,255,.25);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:10px;
}
.zp-app {
  display:flex; align-items:center; gap:7px;
  padding:7px 14px; background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07); border-radius:10px;
  font-size:.76rem; font-weight:600; color:rgba(255,255,255,.4);
  transition:all .3s;
}
.zp-app:hover { background:rgba(46,196,182,.08); border-color:rgba(46,196,182,.18); color:rgba(255,255,255,.7); }
.zp-app-dot { width:8px; height:8px; border-radius:50%; }
/* product icon in hero */
.zp-product-icon {
  width:64px; height:64px; margin-bottom:20px;
}

/* ── Hero form card ── */
.zp-form-card {
  background:#fff; border-radius:22px; padding:30px 26px;
  box-shadow:0 28px 72px rgba(0,0,0,.28);
}
.zp-form-tag {
  display:inline-flex; align-items:center; gap:7px;
  padding:4px 14px; background:var(--teal-muted);
  border:1px solid rgba(46,196,182,.18); border-radius:50px;
  font-size:.7rem; font-weight:700; color:var(--teal-dark);
  text-transform:uppercase; letter-spacing:.09em; margin-bottom:14px;
}
.zp-form-card h3 { font-size:1.15rem; font-weight:800; color:var(--navy); margin-bottom:3px; }
.zp-form-card>p { font-size:.81rem; color:var(--tx3); margin-bottom:18px; }
.zp-fg { margin-bottom:12px; }
.zp-fg label { display:block; font-size:.78rem; font-weight:700; color:var(--navy); margin-bottom:4px; }
.zp-fg input,.zp-fg select,.zp-fg textarea {
  width:100%; padding:10px 14px; border:1.5px solid var(--g100);
  border-radius:11px; font-family:'Mulish',sans-serif; font-size:.87rem;
  color:var(--navy); background:#fff; outline:none;
  transition:border-color .25s,box-shadow .25s;
}
.zp-fg input:focus,.zp-fg select:focus,.zp-fg textarea:focus {
  border-color:var(--teal); box-shadow:0 0 0 3px rgba(46,196,182,.08);
}
.zp-fg textarea { resize:vertical; min-height:44px; max-height:80px; }
.zp-fg select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg width='11' height='7' viewBox='0 0 11 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5.5 6L10 1' stroke='%237A8BA3' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 13px center; padding-right:34px;
}
.zp-fr { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.zp-f-sub {
  width:100%; padding:13px; background:var(--grad); color:#fff;
  font-weight:700; font-size:.93rem; border-radius:50px; border:none;
  cursor:pointer; transition:all .3s;
  box-shadow:0 4px 18px rgba(46,196,182,.25); margin-top:4px;
  font-family:'Mulish',sans-serif;
}
.zp-f-sub:hover { transform:translateY(-1px); box-shadow:0 8px 26px rgba(46,196,182,.38); }
.zp-f-note { text-align:center; font-size:.71rem; color:var(--g300); margin-top:8px; }
/* hero wave */
.zp-hero-wave { display:block; width:100%; margin-bottom:-2px; position:relative; z-index:3; }

/* ══════════════════════════════════
   STATS BAND
══════════════════════════════════ */
.zp-stats {
  background:var(--white);
  border-top:1px solid var(--g100);   /* closes the gap after hero wave */
  border-bottom:1px solid var(--g100);
  margin-top:0;
}
.zp-stats-row { display:grid; grid-template-columns:repeat(4,1fr); }
.zp-stat {
  padding:30px 24px; text-align:center; border-right:1px solid var(--g100);
  position:relative; overflow:hidden; transition:background .3s, box-shadow .3s;
  /* No extra box-shadow on hover — use background change only so it doesn't float */
}
.zp-stat:last-child { border-right:none; }
.zp-stat:hover { background:var(--g50); }
/* top gradient accent on hover — contained within the row border */
.zp-stat::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--grad); transform:scaleX(0); transition:transform .45s var(--ease); transform-origin:left;
}
.zp-stat:hover::before { transform:scaleX(1); }
.zp-stat-n {
  font-family:'League Spartan',sans-serif; font-size:2rem; font-weight:900;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; line-height:1; margin-bottom:5px;
}
.zp-stat-l { font-size:.78rem; font-weight:600; color:var(--tx3); line-height:1.4; }

/* ══════════════════════════════════
   INTRO — 2-col: text + visual
══════════════════════════════════ */
.zp-intro { padding:100px 0; background:var(--white); position:relative; overflow:hidden; }
.zp-intro::after {
  content:''; position:absolute; right:-100px; top:50%; transform:translateY(-50%);
  width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle,rgba(46,196,182,.05) 0%,transparent 65%);
  pointer-events:none;
}
.zp-intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.zp-bullets { display:flex; flex-direction:column; gap:14px; }
.zp-bullet {
  display:flex; align-items:flex-start; gap:14px;
  padding:18px 20px; background:var(--g50); border-radius:var(--r);
  border:1px solid var(--g100); transition:all .35s;
}
.zp-bullet:hover {
  background:var(--white); box-shadow:var(--shd-l);
  border-color:rgba(46,196,182,.12); transform:translateX(4px);
}
.zp-bullet:hover .zp-bullet-ic { background:var(--grad); color:#fff; }
.zp-bullet-ic {
  width:40px; height:40px; border-radius:10px; background:var(--teal-muted);
  display:flex; align-items:center; justify-content:center; color:var(--teal);
  flex-shrink:0; transition:all .3s;
}
.zp-bullet h4 { font-size:.95rem; font-weight:700; color:var(--navy); margin-bottom:3px; }
.zp-bullet p  { font-size:.83rem; color:var(--tx2); line-height:1.6; }

/* Visual panel (app mockup) */
.zp-visual { position:relative; padding-top:20px; }
.zp-mockup {
  background:linear-gradient(145deg,#EBF7F6,#E3F0FB);
  border-radius:22px; padding:26px; position:relative; overflow:hidden;
  border:1px solid rgba(46,196,182,.1);
}
.zp-mockup::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(46,196,182,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(46,196,182,.04) 1px,transparent 1px);
  background-size:28px 28px;
}
.zp-mock-hd {
  position:relative; z-index:1; display:flex; align-items:center;
  justify-content:space-between; margin-bottom:16px;
}
.zp-mock-title { font-family:'League Spartan',sans-serif; font-size:.88rem; font-weight:700; color:var(--navy); }
.zp-mock-badge { padding:4px 12px; background:var(--grad); border-radius:50px; font-size:.66rem; font-weight:700; color:#fff; }
.zp-mock-rows { display:flex; flex-direction:column; gap:9px; position:relative; z-index:1; }
.zp-mock-row {
  background:#fff; border-radius:10px; padding:10px 14px;
  border:1px solid rgba(46,196,182,.1); display:flex; align-items:center; gap:10px;
}
.zp-mock-label { font-size:.7rem; font-weight:600; color:var(--tx3); min-width:90px; }
.zp-mock-val  { font-size:.78rem; color:var(--navy); font-weight:600; }
.zp-mock-bar  { flex:1; height:6px; background:var(--g100); border-radius:3px; overflow:hidden; }
.zp-mock-fill { height:100%; border-radius:3px; background:var(--grad); }
.zp-mock-btns { display:flex; gap:8px; margin-top:14px; position:relative; z-index:1; }
.zp-mock-btn  { flex:1; padding:9px; border-radius:8px; border:none; font-size:.74rem; font-weight:700; cursor:pointer; transition:all .25s; font-family:'Mulish',sans-serif; }
.zp-mock-btn.primary   { background:var(--grad); color:#fff; }
.zp-mock-btn.secondary { background:var(--teal-muted); color:var(--teal-dark); border:1px solid rgba(46,196,182,.18); }
/* floating badges */
.zp-float {
  position:absolute; top:-14px; right:20px; background:#fff;
  border-radius:12px; padding:10px 14px; box-shadow:var(--shd-l);
  display:flex; align-items:center; gap:8px; border:1px solid var(--g100);
}
.zp-float-dot { width:8px; height:8px; border-radius:50%; background:#22C55E; }
.zp-float span { font-size:.72rem; font-weight:700; color:var(--navy); }
.zp-float2 {
  position:absolute; bottom:-14px; left:20px; background:var(--grad);
  border-radius:12px; padding:10px 16px;
  box-shadow:0 8px 24px rgba(46,196,182,.28);
  display:flex; align-items:center; gap:8px;
}
.zp-float2 span { font-size:.72rem; font-weight:700; color:#fff; }
.zp-float2 svg  { width:13px; height:13px; }

/* ══════════════════════════════════
   SERVICES GRID
══════════════════════════════════ */
.zp-services { padding:100px 0; background:var(--off-white); }
.zp-svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:52px; }
.zp-svc {
  padding:32px 26px; background:var(--white); border-radius:var(--rl);
  border:1px solid var(--g100); transition:all .4s var(--ease);
  position:relative; overflow:hidden;
}
.zp-svc::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--grad); transform:scaleX(0); transition:transform .4s var(--ease); transform-origin:left;
}
.zp-svc:hover { transform:translateY(-6px); box-shadow:var(--shd-xl); border-color:transparent; }
.zp-svc:hover::before { transform:scaleX(1); }
.zp-svc:hover .zp-svc-ic { background:var(--grad); color:#fff; transform:scale(1.1) rotate(-4deg); }
.zp-svc-ic {
  width:48px; height:48px; border-radius:13px; background:var(--teal-muted);
  display:flex; align-items:center; justify-content:center; color:var(--teal);
  margin-bottom:18px; transition:all .35s var(--ease);
}
.zp-svc h3 { font-size:1.05rem; font-weight:800; color:var(--navy); margin-bottom:8px; }
.zp-svc p  { font-size:.84rem; color:var(--tx2); line-height:1.72; }

/* ── Services CTA band (single CTA) ── */
.zp-cta-band {
  position:relative; overflow:hidden; border-radius:22px; padding:52px 56px;
  background:linear-gradient(165deg,#1B2A4A 0%,#0E1A30 60%,#0B1526 100%);
}
.zp-cta-band::before {
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:52px 52px; pointer-events:none;
  mask-image:linear-gradient(180deg,black,transparent);
  -webkit-mask-image:linear-gradient(180deg,black,transparent);
}
.zp-cta-band::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(46,196,182,.1) 0%,transparent 55%); pointer-events:none;
}
.zp-cta-inner { position:relative; z-index:1; text-align:center; max-width:560px; margin:0 auto; }
.zp-cta-tag {
  display:inline-flex; align-items:center; gap:8px;
  padding:5px 16px; background:rgba(46,196,182,.08);
  border:1px solid rgba(46,196,182,.18); border-radius:50px;
  font-size:.72rem; font-weight:700; color:var(--teal-light);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:18px;
}
.zp-cta-tag svg { width:11px; height:11px; }
.zp-cta-band h3 { font-size:clamp(1.7rem,3.2vw,2.2rem); font-weight:900; color:#fff; margin-bottom:10px; line-height:1.1; }
.zp-cta-band h3 em { font-style:normal; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.zp-cta-band>div>p { font-size:.96rem; color:var(--g300); margin-bottom:28px; line-height:1.75; }
.zp-cta-trust { display:flex; justify-content:center; gap:20px; flex-wrap:wrap; margin-top:22px; }
.zp-cta-trust span {
  font-size:.77rem; color:rgba(255,255,255,.3);
  display:flex; align-items:center; gap:6px; font-weight:600;
}
.zp-cta-trust span svg { width:12px; height:12px; color:var(--teal); flex-shrink:0; }

/* ══════════════════════════════════
   USE CASES
══════════════════════════════════ */
.zp-usecases { padding:100px 0; background:var(--white); }
.zp-uc-grid  { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.zp-uc {
  padding:28px 22px; background:var(--g50); border-radius:var(--r);
  border:1px solid var(--g100); transition:all .35s var(--ease);
  position:relative; overflow:hidden;
}
.zp-uc::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:var(--grad); transform:scaleX(0); transition:transform .4s;
}
.zp-uc:hover { background:var(--white); box-shadow:var(--shd-l); border-color:rgba(46,196,182,.1); transform:translateY(-4px); }
.zp-uc:hover::after { transform:scaleX(1); }
.zp-uc:hover .zp-uc-ic { background:var(--grad); color:#fff; }
.zp-uc-ic {
  width:44px; height:44px; border-radius:11px; background:var(--teal-muted);
  display:flex; align-items:center; justify-content:center; color:var(--teal);
  margin-bottom:14px; transition:all .3s;
}
.zp-uc h4 { font-size:.97rem; font-weight:700; color:var(--navy); margin-bottom:6px; }
.zp-uc p  { font-size:.82rem; color:var(--tx2); line-height:1.65; }

/* ══════════════════════════════════
   PROCESS — BENTO (unique per page)
══════════════════════════════════ */
.zp-process {
  padding:110px 0;
  background:linear-gradient(165deg,#1B2A4A 0%,#0E1A30 60%,#0B1526 100%);
  position:relative; overflow:hidden;
}
.zp-process::after {
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:52px 52px; pointer-events:none;
  mask-image:linear-gradient(180deg,transparent,black 15%,black 85%,transparent);
  -webkit-mask-image:linear-gradient(180deg,transparent,black 15%,black 85%,transparent);
}
.zp-proc-orb {
  position:absolute; width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle,rgba(46,196,182,.08) 0%,transparent 65%);
  right:-150px; top:-100px; pointer-events:none;
}
/* Bento cards */
.zp-proc-bento {
  position:relative; z-index:1;
  display:grid; grid-template-columns:5fr 7fr; gap:14px;
}
.zp-pb {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--rl); padding:32px 28px;
  transition:all .45s var(--ease); position:relative; overflow:hidden;
}
.zp-pb::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--grad); transform:scaleX(0); transition:transform .5s var(--ease); transform-origin:left;
}
.zp-pb:hover { background:rgba(255,255,255,.07); border-color:rgba(46,196,182,.2); transform:translateY(-4px); }
.zp-pb:hover::after { transform:scaleX(1); }
.zp-pb-num {
  font-family:'League Spartan',sans-serif; font-size:4rem; font-weight:900;
  line-height:1; background:var(--grad); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  opacity:.2; transition:opacity .4s; margin-bottom:4px;
}
.zp-pb:hover .zp-pb-num { opacity:.45; }
.zp-pb-week {
  display:inline-flex; align-items:center; padding:3px 12px;
  background:rgba(46,196,182,.08); border-radius:50px;
  font-size:.68rem; font-weight:700; color:var(--teal-light);
  text-transform:uppercase; letter-spacing:.09em; margin-bottom:10px;
}
.zp-pb h4 { font-size:1.1rem; font-weight:800; color:#fff; margin-bottom:10px; line-height:1.2; }
.zp-pb p  { font-size:.85rem; color:rgba(255,255,255,.42); line-height:1.75; margin-bottom:14px; }
.zp-pb-chips { display:flex; flex-wrap:wrap; gap:7px; }
.zp-pb-chip {
  padding:4px 12px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
  border-radius:50px; font-size:.71rem; font-weight:600; color:rgba(255,255,255,.38);
}
.zp-pb-1   { grid-column:1; grid-row:1/3; }
.zp-pb-right { grid-column:2; display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.zp-pb-r1  { grid-column:span 2; }
.zp-pb-r2,.zp-pb-r3 { grid-column:span 1; }

/* ══════════════════════════════════
   CAPABILITIES
══════════════════════════════════ */
.zp-capabilities { padding:100px 0; background:var(--cream); }
.zp-cap-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:64px; align-items:center; }
.zp-cap-items { display:flex; flex-direction:column; gap:12px; }
.zp-cap-item {
  display:flex; align-items:center; gap:14px;
  padding:16px 20px; background:var(--white); border-radius:var(--r);
  border:1px solid var(--g100); transition:all .35s;
}
.zp-cap-item:hover { border-color:rgba(46,196,182,.15); box-shadow:var(--shd); transform:translateX(4px); }
.zp-cap-item:hover .zp-cap-ic { background:var(--grad); color:#fff; }
.zp-cap-ic {
  width:38px; height:38px; border-radius:9px; background:var(--teal-muted);
  display:flex; align-items:center; justify-content:center; color:var(--teal);
  flex-shrink:0; transition:all .3s;
}
.zp-cap-ic svg { width:17px; height:17px; }
.zp-cap-item h4 { font-size:.92rem; font-weight:700; color:var(--navy); }
.zp-cap-item p  { font-size:.8rem; color:var(--tx3); margin-top:1px; }
/* bento */
.zp-cap-bento { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.zp-cb {
  padding:22px 20px; background:var(--white); border-radius:var(--rl);
  border:1px solid var(--g100); transition:all .35s; position:relative; overflow:hidden;
}
.zp-cb::after {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--grad); transform:scaleX(0); transition:transform .4s; transform-origin:left;
}
.zp-cb:hover { transform:translateY(-3px); box-shadow:var(--shd-l); border-color:rgba(46,196,182,.1); }
.zp-cb:hover::after { transform:scaleX(1); }
.zp-cb-full { grid-column:span 2; }
.zp-cb-n {
  font-family:'League Spartan',sans-serif; font-size:1.8rem; font-weight:900;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; line-height:1; margin-bottom:4px;
}
.zp-cb-tag {
  display:inline-block; padding:3px 10px; background:var(--teal-muted);
  border-radius:50px; font-size:.68rem; font-weight:700; color:var(--teal-dark); margin-bottom:8px;
}
.zp-cb h4 { font-size:.93rem; font-weight:700; color:var(--navy); margin-bottom:4px; }
.zp-cb p  { font-size:.8rem; color:var(--tx3); line-height:1.6; }

/* ══════════════════════════════════
   WHO IT'S FOR
══════════════════════════════════ */
.zp-who { padding:100px 0; background:var(--white); }
.zp-who-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.zp-who-card {
  padding:32px 26px; background:var(--g50); border-radius:var(--rl);
  border:1px solid var(--g100); transition:all .4s var(--ease);
  position:relative; overflow:hidden;
}
.zp-who-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:var(--grad); transform:scaleX(0); transition:transform .4s var(--ease);
}
.zp-who-card:hover { transform:translateY(-5px); box-shadow:var(--shd-xl); border-color:transparent; }
.zp-who-card:hover::after { transform:scaleX(1); }
.zp-who-ic {
  width:52px; height:52px; border-radius:var(--r); background:var(--teal-muted);
  display:flex; align-items:center; justify-content:center; color:var(--teal);
  margin-bottom:18px; transition:all .35s var(--ease);
}
.zp-who-card:hover .zp-who-ic { background:var(--grad); color:#fff; transform:scale(1.1) rotate(-3deg); }
.zp-who-ic svg { width:22px; height:22px; }
.zp-who-card h4 { font-size:1.05rem; font-weight:800; color:var(--navy); margin-bottom:8px; }
.zp-who-card p  { font-size:.85rem; color:var(--tx2); line-height:1.72; }

/* ══════════════════════════════════
   BLOG
══════════════════════════════════ */
.zp-blog { padding:100px 0; background:var(--off-white); }
.zp-blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.zp-blog-card {
  background:var(--white); border-radius:var(--rl);
  border:1px solid var(--g100); overflow:hidden; transition:all .4s var(--ease);
}
.zp-blog-card:hover { transform:translateY(-6px); box-shadow:var(--shd-xl); border-color:transparent; }
.zp-blog-img { height:180px; position:relative; display:flex; align-items:center; justify-content:center; }
.zp-blog-card:nth-child(1) .zp-blog-img { background:linear-gradient(135deg,#0A1628,#162240); }
.zp-blog-card:nth-child(2) .zp-blog-img { background:linear-gradient(135deg,#0A1F35,#0d2e4a); }
.zp-blog-card:nth-child(3) .zp-blog-img { background:linear-gradient(135deg,#0A1628,#0E2438); }
.zp-blog-icon { width:54px; height:54px; border-radius:16px; background:rgba(255,255,255,.07); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.5); }
.zp-blog-icon svg { width:28px; height:28px; }
.zp-blog-badge { position:absolute; top:14px; left:14px; padding:4px 12px; background:rgba(46,196,182,.18); border-radius:50px; font-size:.67rem; font-weight:700; color:var(--teal-light); text-transform:uppercase; letter-spacing:.07em; }
.zp-blog-read  { position:absolute; top:14px; right:14px; padding:4px 10px; background:rgba(0,0,0,.25); border-radius:50px; font-size:.66rem; color:rgba(255,255,255,.55); font-weight:600; }
.zp-blog-body  { padding:22px 22px 24px; }
.zp-blog-body h3 { font-size:.97rem; font-weight:800; color:var(--navy); margin-bottom:8px; line-height:1.35; }
.zp-blog-body p  { font-size:.82rem; color:var(--tx2); line-height:1.65; margin-bottom:16px; }
.zp-blog-meta  { display:flex; align-items:center; justify-content:space-between; }
.zp-blog-author { display:flex; align-items:center; gap:8px; }
.zp-blog-av { width:26px; height:26px; border-radius:50%; background:var(--grad); display:flex; align-items:center; justify-content:center; font-size:.58rem; font-weight:800; color:#fff; font-family:'League Spartan',sans-serif; }
.zp-blog-name  { font-size:.76rem; font-weight:700; color:var(--navy); }
.zp-blog-date  { font-size:.72rem; color:var(--g300); }
.zp-blog-link  { display:inline-flex; align-items:center; gap:5px; font-size:.8rem; font-weight:700; color:var(--teal-dark); transition:gap .2s; }
.zp-blog-link:hover { gap:9px; }
.zp-blog-link svg { width:12px; height:12px; }

/* ══════════════════════════════════
   FAQ
══════════════════════════════════ */
.zp-faq { padding:100px 0; background:var(--white); }
.zp-faq-list { max-width:720px; margin:0 auto; display:flex; flex-direction:column; gap:10px; }
.zp-faq-item {
  border:1px solid var(--g100); border-radius:var(--r);
  overflow:hidden; transition:all .35s; background:var(--white);
}
.zp-faq-item:hover { border-color:rgba(46,196,182,.12); }
.zp-faq-item.active { border-color:rgba(46,196,182,.18); box-shadow:var(--shd); }
.zp-fq {
  width:100%; display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px; background:transparent; font-family:'League Spartan',sans-serif;
  font-size:1rem; font-weight:700; color:var(--navy); text-align:left;
  cursor:pointer; transition:color .25s; border:none;
}
.zp-fq:hover { color:var(--teal-dark); }
.zp-fc { width:18px; height:18px; color:var(--g300); transition:transform .4s var(--ease),color .25s; flex-shrink:0; }
.zp-faq-item.active .zp-fc { transform:rotate(180deg); color:var(--teal); }
.zp-fa { max-height:0; overflow:hidden; transition:max-height .5s var(--ease),padding .5s var(--ease); padding:0 24px; }
.zp-faq-item.active .zp-fa { max-height:280px; padding:0 24px 20px; }
.zp-fa p { font-size:.88rem; color:var(--tx2); line-height:1.8; }

/* ══════════════════════════════════
   RELATED SERVICES
══════════════════════════════════ */
.zp-related { padding:80px 0; background:var(--cream); }
.zp-rel-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.zp-rel-card {
  display:flex; align-items:center; gap:14px;
  padding:22px 20px; background:var(--white); border-radius:var(--rl);
  border:1px solid var(--g100); transition:all .35s; text-decoration:none;
}
.zp-rel-card:hover { transform:translateX(4px); box-shadow:var(--shd); border-color:rgba(46,196,182,.12); }
.zp-rel-ic {
  width:38px; height:38px; border-radius:10px; background:var(--teal-muted);
  display:flex; align-items:center; justify-content:center; color:var(--teal);
  flex-shrink:0; transition:all .3s;
}
.zp-rel-ic svg { width:17px; height:17px; }
.zp-rel-card:hover .zp-rel-ic { background:var(--grad); color:#fff; }
.zp-rel-card h4 { font-size:.92rem; font-weight:700; color:var(--navy); margin-bottom:2px; }
.zp-rel-card p  { font-size:.76rem; color:var(--tx3); }
/* Zoho product logo in rel card */
.zp-rel-logo { width:32px; height:32px; object-fit:contain; }

/* ══════════════════════════════════
   FINAL CTA
══════════════════════════════════ */
.zp-fcta {
  padding:110px 0; text-align:center; position:relative; overflow:hidden;
  background:linear-gradient(165deg,#1B2A4A 0%,#0E1A30 60%,#0B1526 100%);
}
.zp-fcta::before {
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:52px 52px; pointer-events:none;
  mask-image:radial-gradient(ellipse 55% 55% at 50% 50%,black 20%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 55% 55% at 50% 50%,black 20%,transparent 70%);
}
.zp-fcta::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 40%,rgba(46,196,182,.10) 0%,transparent 55%); pointer-events:none;
}
.zp-fcta-inner { position:relative; z-index:2; max-width:620px; margin:0 auto; }
.zp-fcta-inner h2 { font-size:clamp(2rem,4.2vw,2.8rem); font-weight:900; color:#fff; margin-bottom:16px; line-height:1.1; }
.zp-fcta-inner>p { font-size:1.05rem; color:var(--g300); margin-bottom:32px; line-height:1.7; }
/* FIXED: trust items with explicit svg sizing */
.zp-fcta-trust {
  margin-top:28px; display:flex; align-items:center; justify-content:center;
  gap:12px; flex-wrap:wrap;
}
.zp-fcta-trust span {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.8rem; color:rgba(255,255,255,.4); font-weight:600;
  padding:7px 16px; background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06); border-radius:50px;
}
/* KEY FIX: force svg size inside trust items */
.zp-fcta-trust span svg {
  width:12px !important; height:12px !important;
  min-width:12px; min-height:12px;
  flex-shrink:0; color:var(--teal);
}


/* ── CF7 form control overrides inside hero form ── */
/* CF7 wraps fields in span.wpcf7-form-control-wrap */
.zp-form-card .wpcf7-form-control-wrap { display:block; width:100%; margin:0; }
.zp-form-card .wpcf7-form-control-wrap input,
.zp-form-card .wpcf7-form-control-wrap select,
.zp-form-card .wpcf7-form-control-wrap textarea {
  width:100%; padding:10px 14px;
  border:1.5px solid var(--g100); border-radius:11px;
  font-family:'Mulish',sans-serif; font-size:.87rem;
  color:var(--navy); background:#fff; outline:none;
  transition:border-color .25s,box-shadow .25s;
  -webkit-appearance:none; appearance:none;
}
.zp-form-card .wpcf7-form-control-wrap input:focus,
.zp-form-card .wpcf7-form-control-wrap select:focus,
.zp-form-card .wpcf7-form-control-wrap textarea:focus {
  border-color:var(--teal); box-shadow:0 0 0 3px rgba(46,196,182,.08);
}
.zp-form-card .wpcf7-form-control-wrap select {
  background-image:url("data:image/svg+xml,%3Csvg width='11' height='7' viewBox='0 0 11 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5.5 6L10 1' stroke='%237A8BA3' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 13px center; padding-right:34px;
}
.zp-form-card .wpcf7-form-control-wrap textarea { resize:vertical; min-height:44px; max-height:80px; }
/* Remove CF7 br tags inside the form card */
.zp-form-card .wpcf7-form br { display:none !important; }
.zp-form-card .wpcf7-form p { margin:0; padding:0; display:contents; }
/* Submit button */
.zp-form-card .wpcf7-submit,
.zp-form-card input[type="submit"] {
  width:100%; padding:13px;
  background:linear-gradient(135deg,#2EC4B6,#4DA3E8);
  color:#fff; font-weight:700; font-size:.93rem;
  border-radius:50px; border:none; cursor:pointer;
  transition:all .3s; font-family:'Mulish',sans-serif;
  box-shadow:0 4px 18px rgba(46,196,182,.25); margin-top:4px;
}
.zp-form-card .wpcf7-submit:hover,
.zp-form-card input[type="submit"]:hover {
  transform:translateY(-1px); box-shadow:0 8px 26px rgba(46,196,182,.38);
}
/* Validation errors */
.zp-form-card .wpcf7-not-valid { border-color:#EF4444 !important; }
.zp-form-card .wpcf7-not-valid-tip { font-size:.72rem; color:#EF4444; margin-top:3px; display:block; }
.zp-form-card .wpcf7-response-output { display:none !important; }
.zp-form-card .wpcf7-spinner { display:none; }

/* ══════════════════════════════════
   RESPONSIVE
══════════════════════════════════ */
@media(max-width:1024px){
  .zp-hero-grid { grid-template-columns:1fr; gap:40px; }
  .zp-form-card { max-width:500px; }
  .zp-intro-grid,.zp-cap-grid { grid-template-columns:1fr; gap:48px; }
  .zp-svc-grid { grid-template-columns:1fr 1fr; }
  .zp-uc-grid  { grid-template-columns:1fr 1fr; }
  .zp-who-grid,.zp-blog-grid,.zp-rel-grid { grid-template-columns:1fr 1fr; }
  .zp-stats-row { grid-template-columns:repeat(2,1fr); }
  .zp-stat:nth-child(2) { border-right:none; }
  .zp-stat:nth-child(3) { border-top:1px solid var(--g100); }
  .zp-cta-band { padding:40px 32px; }
  .zp-proc-bento { grid-template-columns:1fr; }
  .zp-pb-1,.zp-pb-right { grid-column:1; }
  .zp-pb-right { grid-template-columns:1fr 1fr; }
  .zp-cap-bento { grid-template-columns:1fr; }
  .zp-cb-full { grid-column:span 1; }
}
@media(max-width:768px){
  .zp-hero { padding:72px 0 0; }
  .zp-svc-grid,.zp-uc-grid,.zp-who-grid,.zp-blog-grid,.zp-rel-grid { grid-template-columns:1fr; }
  .zp-fr { grid-template-columns:1fr; }
  .zp-pb-right { grid-template-columns:1fr; }
  .zp-pb-r2,.zp-pb-r3 { grid-column:span 1; }
  .zp-fcta-trust { flex-direction:column; align-items:center; }
}
