/**
 * Inner Pages — Shared Styles
 * Used on all service, solution, resource, and company pages
 * Namespace: .pi- (page inner)
 */

/* ── Custom Properties ────────────────────────────────────────────────────── */
:root {
  --pi-primary:    #6C4DF6;
  --pi-primary-h:  #7C5FF7;
  --pi-bg:         #0F172A;
  --pi-bg-2:       #151F30;
  --pi-bg-3:       #1E293B;
  --pi-border:     rgba(255,255,255,.08);
  --pi-text:       #F8FAFC;
  --pi-muted:      #94A3B8;
  --pi-accent:     #06B6D4;
  --pi-green:      #10B981;
  --pi-radius:     12px;
  --pi-radius-lg:  20px;
  --pi-shadow:     0 4px 24px rgba(0,0,0,.4);
  --pi-glow:       0 0 60px rgba(108,77,246,.25);
}

/* ── Breadcrumb ───────────────────────────────────────────────────────────── */
.pi-breadcrumb {
  padding: 16px 0;
  font-size: .8125rem;
  color: var(--pi-muted);
}
.pi-breadcrumb a {
  color: var(--pi-muted);
  text-decoration: none;
}
.pi-breadcrumb a:hover { color: var(--pi-text); }
.pi-breadcrumb__sep { margin: 0 6px; opacity: .5; }
.pi-breadcrumb__current { color: var(--pi-text); }

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.pi-hero {
  position: relative;
  background: var(--pi-bg);
  padding: 80px 0 72px;
  overflow: hidden;
}
.pi-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(108,77,246,.22) 0%, transparent 65%),
    radial-gradient(ellipse 40% 40% at 90% 80%, rgba(6,182,212,.08) 0%, transparent 55%);
  pointer-events: none;
}
.pi-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.pi-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  background: rgba(108,77,246,.15);
  border: 1px solid rgba(108,77,246,.35);
  border-radius: 100px;
  font-size: .75rem;
  font-weight: 600;
  color: #A78BFA;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.pi-hero__h1 {
  font-family: 'Sora', sans-serif;
  font-size: clamp(2rem, 4vw, 3.125rem);
  font-weight: 800;
  line-height: 1.1;
  color: var(--pi-text);
  margin: 0 0 20px;
}
.pi-hero__h1 span {
  background: linear-gradient(135deg, #A78BFA 0%, #6C4DF6 50%, #06B6D4 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pi-hero__sub {
  font-size: 1.125rem;
  color: var(--pi-muted);
  line-height: 1.7;
  margin: 0 0 32px;
  max-width: 520px;
}
.pi-hero__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}
.pi-hero__trust {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}
.pi-hero__trust-item {
  font-size: .8125rem;
  color: var(--pi-muted);
  display: flex;
  align-items: center;
  gap: 6px;
}
.pi-hero__trust-item svg { color: var(--pi-green); flex-shrink: 0; }
.pi-hero__visual {
  position: relative;
  border-radius: var(--pi-radius-lg);
  overflow: hidden;
}
.pi-hero__img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  border-radius: var(--pi-radius-lg);
  display: block;
}
.pi-hero__img-badge {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: rgba(15,23,42,.85);
  backdrop-filter: blur(12px);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.pi-hero__img-badge-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--pi-primary), var(--pi-accent));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
}
.pi-hero__img-badge-title {
  font-size: .8125rem;
  font-weight: 700;
  color: var(--pi-text);
}
.pi-hero__img-badge-sub {
  font-size: .6875rem;
  color: var(--pi-muted);
}

/* ── Stats Row ────────────────────────────────────────────────────────────── */
.pi-stats {
  background: var(--pi-bg-2);
  border-top: 1px solid var(--pi-border);
  border-bottom: 1px solid var(--pi-border);
  padding: 40px 0;
}
.pi-stats__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.pi-stats__item {
  text-align: center;
  padding: 16px;
}
.pi-stats__num {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 800;
  color: var(--pi-text);
  display: block;
}
.pi-stats__label {
  font-size: .8125rem;
  color: var(--pi-muted);
  margin-top: 4px;
}

/* ── Section Base ─────────────────────────────────────────────────────────── */
.pi-section {
  padding: 80px 0;
}
.pi-section--alt {
  background: var(--pi-bg-2);
}
.pi-section--dark {
  background: var(--pi-bg-3);
}
.pi-section__header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
}
.pi-section__header--left {
  text-align: left;
  margin: 0 0 48px;
}
.pi-eyebrow {
  display: inline-block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #A78BFA;
  margin-bottom: 12px;
}
.pi-h2 {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.625rem, 3vw, 2.375rem);
  font-weight: 800;
  color: var(--pi-text);
  line-height: 1.2;
  margin: 0 0 16px;
}
.pi-h2 span {
  background: linear-gradient(135deg, #A78BFA, #06B6D4);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pi-lead {
  font-size: 1.0625rem;
  color: var(--pi-muted);
  line-height: 1.7;
  margin: 0;
}

/* ── Grid Layouts ─────────────────────────────────────────────────────────── */
.pi-grid-2 { display: grid; grid-template-columns: 1fr 1fr;       gap: 24px; }
.pi-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.pi-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.pi-grid-2-1 { display: grid; grid-template-columns: 2fr 1fr;     gap: 48px; align-items: start; }
.pi-grid-1-2 { display: grid; grid-template-columns: 1fr 2fr;     gap: 48px; align-items: start; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.pi-card {
  background: var(--pi-bg-3);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius);
  padding: 28px 24px;
  transition: border-color .25s, transform .25s, box-shadow .25s;
}
.pi-card:hover {
  border-color: rgba(108,77,246,.45);
  transform: translateY(-3px);
  box-shadow: var(--pi-shadow), 0 0 24px rgba(108,77,246,.12);
}
.pi-card__icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(108,77,246,.2), rgba(6,182,212,.1));
  border: 1px solid rgba(108,77,246,.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.375rem;
  margin-bottom: 16px;
}
.pi-card__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--pi-text);
  margin: 0 0 8px;
}
.pi-card__text {
  font-size: .9rem;
  color: var(--pi-muted);
  line-height: 1.65;
  margin: 0;
}
.pi-card--highlight {
  background: linear-gradient(135deg, rgba(108,77,246,.12), rgba(6,182,212,.06));
  border-color: rgba(108,77,246,.3);
}
.pi-card--img img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: 16px;
}

/* ── Feature Split (image + text side-by-side) ────────────────────────────── */
.pi-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.pi-split--reverse { direction: rtl; }
.pi-split--reverse > * { direction: ltr; }
.pi-split__img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  border-radius: var(--pi-radius-lg);
  box-shadow: var(--pi-shadow);
}
.pi-split__list {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pi-split__list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .9375rem;
  color: var(--pi-muted);
  line-height: 1.55;
}
.pi-split__list li::before {
  content: '✓';
  color: var(--pi-green);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Checklist ────────────────────────────────────────────────────────────── */
.pi-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pi-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .9375rem;
  color: var(--pi-muted);
  line-height: 1.55;
}
.pi-checklist li::before {
  content: '✓';
  color: var(--pi-green);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Process Steps ────────────────────────────────────────────────────────── */
.pi-steps {
  counter-reset: pi-step;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pi-step {
  position: relative;
  display: flex;
  gap: 20px;
  padding-bottom: 36px;
}
.pi-step:last-child { padding-bottom: 0; }
.pi-step::before {
  content: '';
  position: absolute;
  left: 19px;
  top: 40px;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, rgba(108,77,246,.5), transparent);
}
.pi-step:last-child::before { display: none; }
.pi-step__num {
  counter-increment: pi-step;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pi-primary), #5038D4);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .875rem;
  font-weight: 800;
  color: #fff;
  z-index: 1;
}
.pi-step__content { padding-top: 8px; }
.pi-step__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--pi-text);
  margin: 0 0 6px;
}
.pi-step__text {
  font-size: .9rem;
  color: var(--pi-muted);
  line-height: 1.65;
  margin: 0;
}

/* ── Steps Grid (horizontal, for shorter step lists) ─────────────────────── */
.pi-steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.pi-step-card {
  background: var(--pi-bg-3);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius);
  padding: 24px 20px;
  position: relative;
}
.pi-step-card__num {
  font-family: 'Sora', sans-serif;
  font-size: 2rem;
  font-weight: 800;
  color: rgba(108,77,246,.3);
  line-height: 1;
  margin-bottom: 12px;
}
.pi-step-card__title {
  font-size: .9375rem;
  font-weight: 700;
  color: var(--pi-text);
  margin: 0 0 8px;
}
.pi-step-card__text {
  font-size: .85rem;
  color: var(--pi-muted);
  line-height: 1.6;
  margin: 0;
}

/* ── FAQ ──────────────────────────────────────────────────────────────────── */
.pi-faq {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pi-faq--wide { max-width: 100%; }
.pi-faq__item {
  background: var(--pi-bg-3);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius);
  overflow: hidden;
  transition: border-color .2s;
}
.pi-faq__item[open],
.pi-faq__item.is-open {
  border-color: rgba(108,77,246,.35);
}
.pi-faq__q {
  width: 100%;
  background: none;
  border: none;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-size: 1rem;
  font-weight: 600;
  color: var(--pi-text);
  text-align: left;
  cursor: pointer;
  transition: color .2s;
}
.pi-faq__q:hover { color: #A78BFA; }
.pi-faq__icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(108,77,246,.15);
  border: 1px solid rgba(108,77,246,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .3s, background .2s;
}
.pi-faq__q[aria-expanded="true"] .pi-faq__icon { transform: rotate(45deg); background: var(--pi-primary); }
.pi-faq__a {
  padding: 0 24px 20px;
  font-size: .9375rem;
  color: var(--pi-muted);
  line-height: 1.7;
}
.pi-faq__a p { margin: 0 0 8px; }
.pi-faq__a p:last-child { margin-bottom: 0; }

/* ── Comparison Table ─────────────────────────────────────────────────────── */
.pi-table-wrap {
  overflow-x: auto;
  border-radius: var(--pi-radius);
  border: 1px solid var(--pi-border);
}
.pi-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}
.pi-table th, .pi-table td {
  padding: 14px 20px;
  text-align: left;
  border-bottom: 1px solid var(--pi-border);
  color: var(--pi-text);
}
.pi-table th {
  background: var(--pi-bg-3);
  font-weight: 700;
  font-size: .8125rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--pi-muted);
}
.pi-table td:first-child { color: var(--pi-muted); }
.pi-table tbody tr:last-child td { border-bottom: none; }
.pi-table tbody tr:hover td { background: rgba(108,77,246,.04); }
.pi-table__us {
  background: rgba(108,77,246,.06) !important;
  font-weight: 600;
  color: #A78BFA !important;
}
.pi-table__yes { color: var(--pi-green) !important; font-weight: 700; }
.pi-table__no  { color: #F87171 !important; }
.pi-table__partial { color: #FBBF24 !important; }

/* ── Testimonials ─────────────────────────────────────────────────────────── */
.pi-testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.pi-testimonial {
  background: var(--pi-bg-3);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius);
  padding: 28px 24px;
}
.pi-testimonial__stars {
  color: #FBBF24;
  font-size: 1rem;
  margin-bottom: 14px;
  letter-spacing: 2px;
}
.pi-testimonial__quote {
  font-size: .9375rem;
  color: var(--pi-muted);
  line-height: 1.7;
  margin: 0 0 20px;
  font-style: italic;
}
.pi-testimonial__author {
  display: flex;
  align-items: center;
  gap: 12px;
}
.pi-testimonial__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
}
.pi-testimonial__name {
  font-size: .875rem;
  font-weight: 700;
  color: var(--pi-text);
}
.pi-testimonial__role {
  font-size: .8125rem;
  color: var(--pi-muted);
}

/* ── CTA Band ─────────────────────────────────────────────────────────────── */
.pi-cta {
  position: relative;
  padding: 80px 0;
  background: var(--pi-bg-2);
  overflow: hidden;
  text-align: center;
}
.pi-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 80% at 50% 50%, rgba(108,77,246,.2) 0%, transparent 70%);
  pointer-events: none;
}
.pi-cta__inner {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin: 0 auto;
}
.pi-cta__badge {
  display: inline-block;
  padding: 4px 14px;
  background: rgba(108,77,246,.15);
  border: 1px solid rgba(108,77,246,.35);
  border-radius: 100px;
  font-size: .75rem;
  font-weight: 700;
  color: #A78BFA;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.pi-cta__h2 {
  font-family: 'Sora', sans-serif;
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 800;
  color: var(--pi-text);
  line-height: 1.15;
  margin: 0 0 16px;
}
.pi-cta__h2 span {
  background: linear-gradient(135deg, #A78BFA, #06B6D4);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pi-cta__text {
  font-size: 1.0625rem;
  color: var(--pi-muted);
  line-height: 1.65;
  margin: 0 0 32px;
}
.pi-cta__actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.pi-cta__micro {
  font-size: .8125rem;
  color: var(--pi-muted);
}
.pi-cta__micro span { margin: 0 8px; opacity: .4; }

/* ── Tech Tags ────────────────────────────────────────────────────────────── */
.pi-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.pi-tag {
  padding: 4px 12px;
  border-radius: 100px;
  background: rgba(108,77,246,.1);
  border: 1px solid rgba(108,77,246,.2);
  font-size: .75rem;
  font-weight: 600;
  color: #A78BFA;
}

/* ── Pricing Cards ────────────────────────────────────────────────────────── */
.pi-pricing {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.pi-price-card {
  background: var(--pi-bg-3);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius-lg);
  padding: 32px 28px;
}
.pi-price-card--featured {
  border-color: var(--pi-primary);
  background: linear-gradient(135deg, rgba(108,77,246,.12), rgba(6,182,212,.06));
  position: relative;
}
.pi-price-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--pi-primary);
  color: #fff;
  font-size: .6875rem;
  font-weight: 700;
  padding: 3px 14px;
  border-radius: 100px;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.pi-price-card__name {
  font-size: .875rem;
  font-weight: 700;
  color: var(--pi-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 12px;
}
.pi-price-card__price {
  font-family: 'Sora', sans-serif;
  font-size: 1.875rem;
  font-weight: 800;
  color: var(--pi-text);
  margin-bottom: 6px;
}
.pi-price-card__period { font-size: .875rem; color: var(--pi-muted); margin-bottom: 24px; }
.pi-price-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pi-price-card__features li {
  font-size: .875rem;
  color: var(--pi-muted);
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.pi-price-card__features li::before {
  content: '✓';
  color: var(--pi-green);
  font-weight: 700;
  flex-shrink: 0;
}

/* ── USP Strip ────────────────────────────────────────────────────────────── */
.pi-usp-strip {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  padding: 36px 0;
  border-top: 1px solid var(--pi-border);
  border-bottom: 1px solid var(--pi-border);
}
.pi-usp-strip__item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .875rem;
  color: var(--pi-muted);
}
.pi-usp-strip__item strong { color: var(--pi-text); }

/* ── Team / Person Cards ──────────────────────────────────────────────────── */
.pi-person-card {
  background: var(--pi-bg-3);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius);
  overflow: hidden;
}
.pi-person-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}
.pi-person-card__body { padding: 20px; }
.pi-person-card__name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--pi-text);
  margin: 0 0 4px;
}
.pi-person-card__role {
  font-size: .8125rem;
  color: var(--pi-muted);
}

/* ── Two-col content + sticky sidebar ────────────────────────────────────── */
.pi-content-sidebar {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 56px;
  align-items: start;
}
.pi-sidebar-sticky {
  position: sticky;
  top: 100px;
}
.pi-sidebar-card {
  background: var(--pi-bg-3);
  border: 1px solid var(--pi-border);
  border-radius: var(--pi-radius);
  padding: 28px 24px;
}
.pi-sidebar-card + .pi-sidebar-card { margin-top: 20px; }
.pi-sidebar-card__title {
  font-size: .875rem;
  font-weight: 700;
  color: var(--pi-text);
  margin: 0 0 14px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

/* ── Inline CTA box ───────────────────────────────────────────────────────── */
.pi-inline-cta {
  background: linear-gradient(135deg, rgba(108,77,246,.15), rgba(6,182,212,.08));
  border: 1px solid rgba(108,77,246,.3);
  border-radius: var(--pi-radius);
  padding: 32px 28px;
  text-align: center;
  margin: 48px 0;
}
.pi-inline-cta__title {
  font-family: 'Sora', sans-serif;
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--pi-text);
  margin: 0 0 8px;
}
.pi-inline-cta__text {
  font-size: .9375rem;
  color: var(--pi-muted);
  margin: 0 0 20px;
}

/* ── Template Class Aliases ───────────────────────────────────────────────── */
/* Maps class names used in page templates to existing CSS definitions        */

.pi-hero__title        { font-family: 'Sora', sans-serif; font-size: clamp(2rem, 4vw, 3.125rem); font-weight: 800; line-height: 1.1; color: var(--pi-text); margin: 0 0 20px; }
.pi-hero__title span   { background: linear-gradient(135deg, #A78BFA 0%, #6C4DF6 50%, #06B6D4 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.pi-hero__subtitle     { font-size: 1.125rem; color: var(--pi-muted); line-height: 1.7; margin: 0 0 32px; }
.pi-hero__inner        { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.pi-hero__content      { position: relative; z-index: 1; }
.pi-hero__media        { position: relative; border-radius: var(--pi-radius-lg); overflow: hidden; }
.pi-hero__media img    { width: 100%; height: 420px; object-fit: cover; border-radius: var(--pi-radius-lg); display: block; }
.pi-hero__media .pi-hero__img-badge strong { font-size: .8125rem; font-weight: 700; color: var(--pi-text); display: block; }
.pi-hero__media .pi-hero__img-badge small  { font-size: .6875rem; color: var(--pi-muted); }

.pi-stats__grid        { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.pi-stats__number      { font-family: 'Sora', sans-serif; font-size: clamp(1.75rem, 3vw, 2.5rem); font-weight: 800; color: var(--pi-text); display: block; }

.pi-section__title     { font-family: 'Sora', sans-serif; font-size: clamp(1.625rem, 3vw, 2.375rem); font-weight: 800; color: var(--pi-text); line-height: 1.2; margin: 0 0 16px; text-align: center; }
.pi-section__title span { background: linear-gradient(135deg, #A78BFA, #06B6D4); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.pi-section__subtitle  { font-size: 1.0625rem; color: var(--pi-muted); line-height: 1.7; margin: 0 auto 48px; max-width: 720px; text-align: center; }

.pi-features-grid      { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.pi-card__body         { font-size: .9rem; color: var(--pi-muted); line-height: 1.65; margin: 0; }

.pi-split__media       { position: relative; }
.pi-split__media img   { width: 100%; height: 380px; object-fit: cover; border-radius: var(--pi-radius-lg); box-shadow: var(--pi-shadow); }
.pi-split__content     { position: relative; }
.pi-split__title       { font-family: 'Sora', sans-serif; font-size: clamp(1.375rem, 2.5vw, 1.875rem); font-weight: 800; color: var(--pi-text); line-height: 1.2; margin: 0 0 20px; }

.pi-process-grid       { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 24px; }
.pi-process__step      { background: var(--pi-bg-3); border: 1px solid var(--pi-border); border-radius: var(--pi-radius); padding: 24px 20px; position: relative; }
.pi-process__number    { font-family: 'Sora', sans-serif; font-size: 2rem; font-weight: 800; color: rgba(108,77,246,.3); line-height: 1; margin-bottom: 12px; display: block; }
.pi-process__title     { font-size: .9375rem; font-weight: 700; color: var(--pi-text); margin: 0 0 8px; }
.pi-process__body      { font-size: .85rem; color: var(--pi-muted); line-height: 1.6; margin: 0; }

.pi-faq__chevron       { flex-shrink: 0; width: 20px; height: 20px; border-radius: 50%; background: rgba(108,77,246,.15); border: 1px solid rgba(108,77,246,.3); display: flex; align-items: center; justify-content: center; transition: transform .3s, background .2s; }
.pi-faq__chevron::after { content: '+'; font-size: .875rem; font-weight: 700; color: #A78BFA; }
.pi-faq__q[aria-expanded="true"] .pi-faq__chevron { transform: rotate(45deg); background: var(--pi-primary); }
.pi-faq__q[aria-expanded="true"] .pi-faq__chevron::after { color: #fff; }

.pi-cta__title         { font-family: 'Sora', sans-serif; font-size: clamp(1.75rem, 3.5vw, 2.5rem); font-weight: 800; color: var(--pi-text); line-height: 1.15; margin: 0 0 16px; }
.pi-cta__title span    { background: linear-gradient(135deg, #A78BFA, #06B6D4); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.pi-cta__subtitle      { font-size: 1.0625rem; color: var(--pi-muted); line-height: 1.65; margin: 0 0 32px; }

.pi-content-block      { max-width: 800px; margin: 0 auto; }
.pi-content-block p    { font-size: 1rem; color: var(--pi-muted); line-height: 1.8; margin: 0 0 20px; }
.pi-content-block p:last-child { margin-bottom: 0; }
.pi-content-block strong { color: var(--pi-text); }

/* ── Responsive overrides for template aliases ───────────────────────────── */
@media (max-width: 1024px) {
  .pi-hero__inner      { grid-template-columns: 1fr; }
  .pi-hero__media      { display: none; }
  .pi-hero__subtitle   { max-width: 100%; }
  .pi-stats__grid      { grid-template-columns: repeat(2, 1fr); }
  .pi-features-grid    { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .pi-features-grid    { grid-template-columns: 1fr; }
  .pi-process-grid     { grid-template-columns: 1fr; }
  .pi-stats__grid      { grid-template-columns: repeat(2, 1fr); }
  .pi-section__title   { text-align: left; }
  .pi-section__subtitle { text-align: left; margin-left: 0; }
}
@media (max-width: 480px) {
  .pi-stats__grid      { grid-template-columns: 1fr 1fr; }
}

/* ── Reveal animation ─────────────────────────────────────────────────────── */
.pi-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .5s ease, transform .5s ease;
}
.pi-reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 1200px) {
  .pi-grid-4    { grid-template-columns: repeat(2, 1fr); }
  .pi-steps-grid { grid-template-columns: repeat(2, 1fr); }
  .pi-content-sidebar { grid-template-columns: 1fr; }
  .pi-sidebar-sticky { position: static; }
}
@media (max-width: 1024px) {
  .pi-hero__grid { grid-template-columns: 1fr; }
  .pi-hero__visual { display: none; }
  .pi-hero { padding: 60px 0 56px; }
  .pi-hero__sub { max-width: 100%; }
  .pi-stats__row { grid-template-columns: repeat(2, 1fr); }
  .pi-split { grid-template-columns: 1fr; }
  .pi-split__img { height: 260px; }
  .pi-split--reverse { direction: ltr; }
  .pi-grid-2-1, .pi-grid-1-2 { grid-template-columns: 1fr; }
  .pi-testimonials { grid-template-columns: 1fr 1fr; }
  .pi-pricing { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .pi-section { padding: 56px 0; }
  .pi-grid-2  { grid-template-columns: 1fr; }
  .pi-grid-3  { grid-template-columns: 1fr; }
  .pi-grid-4  { grid-template-columns: 1fr; }
  .pi-steps-grid { grid-template-columns: 1fr 1fr; }
  .pi-testimonials { grid-template-columns: 1fr; }
  .pi-usp-strip { flex-direction: column; gap: 16px; }
  .pi-stats__row { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .pi-hero__actions { flex-direction: column; }
  .pi-cta__actions  { flex-direction: column; align-items: center; }
  .pi-steps-grid { grid-template-columns: 1fr; }
  .pi-stats__row { grid-template-columns: 1fr 1fr; }
}
