/* =========================================================
   CARITECH PROCESS WIDGETS - CSS (from supplied page)
========================================================= */
:root{
  --bg:#ffffff;
  --surface:#f7f8fc;
  --surface-2:#f1f3f8;
  --text:#0f172a;
  --muted:#475569;
  --muted-2:#64748b;
  --border:#e5e7eb;

  --primary:#9973BC;
  --grad:linear-gradient(to right, #D15DA6 0%, #9973BC 50% 50%, #5190DA 100%); 

  --shadow:0 14px 40px rgba(15,23,42,.08);
  --shadow-soft:0 10px 26px rgba(15,23,42,.06);

  --radius:18px;
  --radius-sm:12px;
  --max:1180px;

  --h1:clamp(2.5rem,3.2vw,3.6rem);
  --h2:clamp(1.6rem,2.2vw,2.3rem);
  --h3:1.1rem;
  --p:1.02rem;
  --lh:1.65;
}

.cpw-wrap *{box-sizing:border-box}
.cpw-wrap{color:var(--text)}
.cpw-wrap a{text-decoration:none;color:inherit;}
.cpw-container{max-width:var(--max);margin:0 auto;padding:0 22px}
.cpw-section{/*padding:clamp(64px,8vw,104px) 0*/}
.cpw-section--soft{background:var(--surface)}
.cpw-section--tight{/*padding:clamp(48px,6vw,72px) 0*/}

.cpw-wrap h1,.cpw-wrap h2,.cpw-wrap h3{/*letter-spacing:-.02em;margin:0 0 14px*/}
.cpw-wrap p{
	color:rgb(51, 51, 51);
    margin:0 0 14px;
    text-align: left;
    font-size: 1em;
    font-weight: 500;
    text-transform: none;
    font-style: normal;
    text-decoration: none;
    line-height: 1.5em;
    letter-spacing: 0px;
}
.cpw-wrap ul{padding-left:18px;margin:0}
.cpw-wrap li{margin:8px 0;color:var(--muted)}

/* Buttons */
.cpw-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:13px 18px;
  border-radius:14px;
  font-weight:600;
  font-size:.95rem;
  border:1px solid var(--border);
  background:#fff;
  transition:.25s ease;
}
.cpw-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}
.cpw-btn--primary{
  background:var(--primary);
  color:#fff !important;
  border-color:transparent;
}
.cpw-btn.ghost{background:#fff}

/* HERO */
.cpw-hero{
  /*padding:clamp(92px,9vw,120px) 0;
  background:
    radial-gradient(900px 420px at 12% 18%,rgba(153,115,188,.18),transparent 60%),
    linear-gradient(180deg,#fff,#f9fbff);
  border-bottom:1px solid var(--border);*/
}
.cpw-hero-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:60px;
  align-items:center;
}
.cpw-eyebrow{
    color: #D15DA6;
    font-size: 1em;
    font-weight: 600;
    text-transform: uppercase;
    font-style: normal;
    text-decoration: none;
    word-spacing: 0em;
}
.cpw-eyebrow .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--primary);
}
.cpw-hero h2{font-size: 3em;
    font-weight: 700;
    text-transform: capitalize;
    font-style: normal;
    text-decoration: none;
    line-height: 1em;
    letter-spacing: 0px;}
.cpw-hero h2 span{
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.cpw-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.cpw-hero-tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.cpw-hero-tags span{
  font-size:.85rem;
  padding:6px 12px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface);
  color:var(--muted);
}

/* HERO image stack */
.cpw-hero-image-stack{position:relative;width:100%;max-width:520px;margin-left:auto}
.cpw-hero-image-stack img{width:100%;height:460px;display:block;border-radius:24px;object-fit:cover}
.cpw-image-large{/*border-radius:28px;overflow:hidden;box-shadow:0 30px 70px rgba(15,23,42,.18)*/}
.cpw-image-small{
  position:absolute;bottom:-60px;right:-40px;width:58%;
  border-radius:22px;overflow:hidden;box-shadow:0 24px 60px rgba(15,23,42,.22);
  background:#fff;padding:6px;
}

/* WHY IT MATTERS */
.cpw-grid-2{/*display:grid;*/grid-template-columns:1fr 1fr;gap:32px}
.cpw-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow-soft);margin-top: 40px;
}

/* STACKED PROCESS */
.cpw-process-stack{position:relative;padding-bottom:10px}
.cpw-process-stack::before{
  content:"";position:absolute;left:22px;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom,rgba(153,115,188,.45),rgba(153,115,188,.08));
}
.cpw-process-step{
  position:sticky;top:120px;display:grid;grid-template-columns:60px 1fr;
  gap:32px;margin-bottom:160px;
  transition:transform .5s ease, filter .5s ease;
}
.cpw-step-marker{
  width:44px;height:44px;border-radius:14px;background:#fff;
  border:1px solid rgba(153,115,188,.4);
  display:grid;place-items:center;font-weight:700;color:var(--primary);
  box-shadow:0 12px 34px rgba(15,23,42,.15);z-index:10;
}
.cpw-step-card--premium{
  background:linear-gradient(180deg,#ffffff,#fbf9fd);
  border-radius:28px;padding:32px 36px;border:1px solid rgba(153,115,188,.35);
  box-shadow:0 40px 120px rgba(15,23,42,.16), inset 0 0 0 1px rgba(255,255,255,.6);
  position:relative;
}
.cpw-card-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:10px}
.cpw-card-phase{
  font-size:.75rem;padding:6px 12px;border-radius:999px;
  background:rgba(153,115,188,.14);color:var(--primary);font-weight:600;letter-spacing:.04em;
}
.cpw-card-purpose{font-size:.95rem;color:var(--muted);margin-bottom:24px}
.cpw-card-body{display:grid;grid-template-columns:1.3fr .7fr;gap:28px}
.cpw-card-list{list-style:none;padding:0;margin:0}
.cpw-card-list li{
  position:relative;padding-left:26px;margin:14px 0;color:var(--text);
}
.cpw-card-list li::before{
  content:"";position:absolute;left:0;top:9px;width:10px;height:10px;border-radius:50%;
  background:linear-gradient(180deg,var(--primary),rgba(153,115,188,.5));
}
.cpw-card-outcome{
  background:linear-gradient(180deg,#f6f1fb,#efe7fa);
  border-radius:20px;padding:22px;border:1px solid rgba(153,115,188,.3);
}
.cpw-card-outcome span{
  display:block;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin-bottom:8px
}
.cpw-card-outcome p{margin:0;font-size:.95rem;color:var(--text)}

/* Active/stack states */
.cpw-process-step.is-active{transform:translateY(0) scale(1);filter:none}
.cpw-process-step.is-behind{transform:translateY(40px) scale(.96);filter:blur(0.4px)}
.cpw-process-step.is-ahead{transform:translateY(60px) scale(.97);filter:none}
.cpw-process-step{z-index:1}
.cpw-process-step.is-ahead{z-index:2}
.cpw-process-step.is-active{z-index:3}

/* last / termination */
.cpw-process-step--last{position:relative;top:auto;margin-bottom:0;z-index:10;transform:none!important;filter:none!important}
.cpw-process-stack-end{height:20px}
.cpw-process-stack.has-ended .cpw-process-step{position:relative!important;top:auto!important;transform:none!important;filter:none!important;opacity:1!important}

/* REGULATED */
.cpw-wc-section{background:#fff}
.cpw-wc-container{max-width:1200px;margin:0 auto;padding:0 24px}
.cpw-wc-header{
  display:grid;grid-template-columns:1fr auto;align-items:center;margin-bottom:60px;gap:24px
}
.cpw-wc-title{grid-column:1/-1;font-size:44px;font-weight:700;line-height:1.15;color:#111;margin-bottom:-14px !important;}
.cpw-wc-btn{
  justify-self:end;display:inline-flex;align-items:center;gap:12px;padding:14px 28px;text-decoration:none;font-weight:600;color:#fff !important;margin-top: -70px !important;
}
.cpw-wc-btn i{
  width:34px;height:34px;background:#fff;color:#111;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center
}
.cpw-wc-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:40px}
.cpw-wc-image img{width:100%;height:100%;min-height:520px;object-fit:cover;border-radius:28px}
.cpw-wc-features{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.cpw-wc-card{
  background:#fff;border-radius:20px;padding:32px;box-shadow:0 20px 50px rgba(0,0,0,0.08);
  transition:transform .3s ease
}
.cpw-wc-card:hover{transform:translateY(-6px)}
.cpw-wc-icon{
  width:56px;height:56px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px
}
.cpw-wc-card h4{font-size:20px;margin-bottom:10px;color:#111}
.cpw-wc-card p{font-size:14px;color:#666;line-height:1.6;margin-bottom:18px}
.cpw-wc-card a{font-size:13px;font-weight:600;color:#111;text-decoration:none}

/* SERVICE CARDS */
.cpw-sc-container{max-width:1200px;margin:0 auto;padding:0 24px}
.cpw-sc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.cpw-sc-card{
  background:#fff;border-radius:20px;border:1px solid #dfe7e3;overflow:hidden;
  transition:transform .35s ease, box-shadow .35s ease
}
.cpw-sc-card:hover{transform:translateY(-8px);box-shadow:0 25px 60px rgba(0,0,0,.08)}
.cpw-sc-image img{width:100%;height:220px;object-fit:cover;display:block}
.cpw-sc-content{padding:28px 28px 32px}
.cpw-sc-content h3{font-size:22px;font-weight:700;color:#0b1f1a;margin-bottom:12px}
.cpw-sc-content p{font-size:15px;line-height:1.65;color:#5f6f6a;margin-bottom:22px}
.cpw-sc-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#0b1f1a;text-decoration:none}
.cpw-sc-link span{transition:transform .3s ease}
.cpw-sc-link:hover span{transform:translateX(4px)}

/* FINAL CTA */
.cpw-cta{
  border-radius:26px;
  background:
    radial-gradient(800px 300px at 20% 20%,rgba(153,115,188,.2),transparent 60%),
    linear-gradient(180deg,#fff,#f7faff);
  border:1px solid rgba(153,115,188,.25);
  box-shadow:var(--shadow);
  text-align:center;
  padding:clamp(36px,4vw,56px);
}

/* Responsive */
@media(max-width:980px){
  .cpw-hero-grid,.cpw-grid-2,.cpw-card-body,.cpw-wc-grid,.cpw-wc-features,.cpw-sc-grid{grid-template-columns:1fr}
  .cpw-image-small{position:relative;bottom:auto;right:auto;width:70%;margin:-40px auto 0}
  .cpw-hero-image-stack{max-width:100%;margin-top:48px}
  .cpw-process-step{position:relative;top:auto;margin-bottom:64px;grid-template-columns:1fr;transform:none!important;filter:none!important}
  .cpw-process-stack::before{display:none}
  .cpw-step-marker{margin-bottom:12px}
  .cpw-wc-header{grid-template-columns:1fr}
  .cpw-wc-btn{justify-self:start}
}

/* ===============================
   MOBILE FIX – Our Process Hero
   =============================== */
@media (max-width: 768px) {

  /* 1. Reduce overall hero padding */
  .our-process-hero,
  .process-hero,
  .delivery-methodology-section {
    padding-top: 48px !important;
    padding-bottom: 40px !important;
  }

  /* 2. Headline: tighter + readable */
  .our-process-hero h1,
  .process-hero h1 {
    font-size: 30px !important;
    line-height: 1.15 !important;
    letter-spacing: -0.5px;
  }

  .our-process-hero h1 span,
  .process-hero h1 span {
    display: inline; /* prevent odd breaks */
  }

  /* 3. Description text */
  .our-process-hero p,
  .process-hero p {
    font-size: 15px !important;
    line-height: 1.6 !important;
    margin-top: 12px;
  }

  /* 4. CTA buttons – stack cleanly */
  .our-process-hero .cta-group,
  .process-hero .cta-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 20px;
  }

  .our-process-hero .cta-group a,
  .process-hero .cta-group a {
    width: 100%;
    text-align: center;
    justify-content: center;
  }

  /* 5. Pill badges – wrap nicely */
  .our-process-hero .pill-group,
  .process-hero .pill-group {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 20px;
  }

  .our-process-hero .pill,
  .process-hero .pill {
    font-size: 12px;
    padding: 6px 12px;
    white-space: nowrap;
  }

  /* 6. Image block – pull it closer */
  .our-process-hero .image-wrap,
  .process-hero .image-wrap {
    margin-top: 32px !important;
  }

  .our-process-hero img,
  .process-hero img {
    width: 100%;
    height: auto;
    border-radius: 16px;
  }
}

/* FIX: cpw hero heading on mobile */
@media (max-width: 767px) {
  .cpw-hero h2 {
    font-size: 1.9em !important;
    line-height: 1.2em !important;
    letter-spacing: -0.2px;
  }
}