/* ============================================
   Pipe de Inovação — Landing Page Styles
   Innovation Pipeline
   ============================================ */

/* ═══════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════ */
.pi-hero{position:relative;min-height:100vh;display:flex;align-items:center;
  padding-top:80px;overflow:hidden}

.pi-hero__bg{position:absolute;inset:0;overflow:hidden}
.pi-hero__canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}

.pi-hero__orb{position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none}
.pi-hero__orb--1{width:700px;height:700px;top:-20%;right:-10%;
  background:radial-gradient(circle,rgba(139,92,246,0.16),transparent 70%);
  animation:pi-drift-1 24s ease-in-out infinite}
.pi-hero__orb--2{width:500px;height:500px;bottom:-15%;left:-8%;
  background:radial-gradient(circle,rgba(99,102,241,0.12),transparent 70%);
  animation:pi-drift-2 28s ease-in-out infinite}
.pi-hero__orb--3{width:450px;height:450px;top:40%;left:35%;
  background:radial-gradient(circle,rgba(6,182,212,0.07),transparent 70%);
  animation:pi-drift-3 22s ease-in-out infinite}

@keyframes pi-drift-1{0%,100%{transform:translate(0,0)}50%{transform:translate(-60px,50px)}}
@keyframes pi-drift-2{0%,100%{transform:translate(0,0)}50%{transform:translate(50px,-40px)}}
@keyframes pi-drift-3{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,-50px)}}

.pi-hero__inner{display:grid;grid-template-columns:1.1fr 0.9fr;gap:4rem;align-items:center}

.pi-hero__super{display:inline-flex;align-items:center;gap:6px;
  font-size:.75rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:var(--wf-violet);background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.2);
  border-radius:var(--wf-r-full);padding:.3rem .9rem;margin-bottom:1.4rem}

.pi-hero__title{font-family:var(--wf-display);font-size:clamp(2.4rem,4.8vw,4rem);
  font-weight:800;letter-spacing:-.05em;line-height:1.06;margin-bottom:1.4rem}

.pi-hero__desc{font-size:clamp(1rem,1.8vw,1.15rem);color:var(--wf-text-2);
  line-height:1.72;max-width:560px;margin-bottom:2.5rem}

.pi-hero__ctas{display:flex;gap:12px;flex-wrap:wrap}

/* KPI strip */
.pi-hero__kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}

.pi-kpi{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-xl);padding:1.5rem;text-align:center;
  transition:all 400ms var(--wf-ease);position:relative;overflow:hidden}
.pi-kpi::before{content:'';position:absolute;inset:0;
  background:var(--wf-grad-glow);opacity:0;transition:opacity 400ms;pointer-events:none}
.pi-kpi:hover{border-color:rgba(139,92,246,.35);transform:translateY(-4px)}
.pi-kpi:hover::before{opacity:1}
.pi-kpi__icon{font-size:1.5rem;color:var(--wf-violet);margin-bottom:.5rem}
.pi-kpi__value{font-family:var(--wf-display);font-size:1.9rem;font-weight:800;
  color:var(--wf-text-1);letter-spacing:-.03em}
.pi-kpi__label{font-size:.72rem;color:var(--wf-text-3);margin-top:4px;line-height:1.4}

/* ═══════════════════════════════════════════
   FLOW RIBBON (End-to-End)
   ═══════════════════════════════════════════ */
.section--flow{padding:5rem 0 3rem}

/* ─── Entry channels ─── */
.pj-entry{text-align:center;margin-bottom:0}
.pj-entry__label{font-size:.72rem;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--wf-text-3);margin-bottom:1rem}
.pj-entry__row{display:flex;justify-content:center;gap:.65rem;flex-wrap:wrap;margin-bottom:.6rem}
.pj-entry__ch{display:flex;align-items:center;gap:.45rem;padding:.4rem .9rem;border-radius:100px;border:1px solid var(--wf-border);background:var(--wf-bg-card);font-size:.8rem;font-weight:600;color:var(--wf-text-secondary)}
.pj-entry__ch i{font-size:.95rem}
.pj-entry__ch--web i{color:var(--wf-emerald)}
.pj-entry__ch--mob i{color:var(--wf-cyan)}
.pj-entry__ch--int i{color:var(--wf-amber)}
.pj-entry__ch--par i{color:var(--wf-violet)}
.pj-entry__ch--sta i{color:var(--wf-primary)}
.pj-entry__funnel{display:flex;flex-direction:column;align-items:center;gap:.4rem}
.pj-entry__svg{display:block;width:100%;max-width:460px;height:44px}
.pj-entry__gate{display:inline-flex;align-items:center;gap:.55rem;padding:.45rem 1.1rem;border-radius:100px;background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.28);color:var(--wf-violet);font-size:.82rem}
.pj-entry__gate strong{font-weight:700;margin-right:.15rem}
.pj-entry__gate span{color:var(--wf-text-3)}
.pj-entry__arrow-down{font-size:1.1rem;color:rgba(139,92,246,.5);margin-top:.1rem}

/* ─── Scroll wrapper ─── */
.pj-scroll{overflow-x:auto;padding:1.5rem 0 1rem;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,.3) transparent}
.pj-scroll::-webkit-scrollbar{height:4px}
.pj-scroll::-webkit-scrollbar-thumb{background:rgba(139,92,246,.3);border-radius:4px}

/* ─── Pipeline container ─── */
.pj-pipeline{position:relative;min-width:1020px}

/* ══════════════════════════════════════
   TRACK ROW — dots + line + ball
   The line lives ONLY in this row.
   It can never visually bleed into cards.
   ══════════════════════════════════════ */
.pj-track{
  position:relative;
  height:48px;           /* exactly the dot height — line is clipped here */
  margin-bottom:.75rem;
}

/* Line — behind dots */
.pj-line{
  position:absolute;
  top:50%;left:5%;right:5%;
  height:2px;
  transform:translateY(-50%);
  background:rgba(255,255,255,.07);
  border-radius:2px;
  z-index:0;
}
.pj-line__fill{
  height:100%;width:0;
  background:linear-gradient(to right,var(--wf-emerald),var(--wf-cyan),var(--wf-amber),var(--wf-violet),var(--wf-rose));
  border-radius:2px;
  transition:width .35s ease;
}

/* Ball — travels along line */
.pj-ball{
  position:absolute;
  top:50%;
  left:calc((var(--pj-i,0) + .5) / 10 * 100% - 16px);
  transform:translateY(-50%);
  width:32px;height:32px;border-radius:50%;
  background:rgba(139,92,246,.18);border:2px solid var(--wf-violet);
  display:flex;align-items:center;justify-content:center;
  transition:left .3s cubic-bezier(.4,0,.2,1);
  z-index:3;
  box-shadow:0 0 14px rgba(139,92,246,.55),0 0 4px rgba(139,92,246,.9);
}
.pj-ball i{font-size:.9rem;color:var(--wf-violet)}

/* Dots row — grid aligned with cards below */
.pj-dotrow{
  display:grid;
  grid-template-columns:repeat(10,1fr);
  height:100%;
  position:relative;
  z-index:2;
}
.pj-dot{
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:2;
}

/* Dot circle */
.pj-dot::after{
  content:'';
  position:absolute;
  inset:4px;
  border-radius:50%;
  border:2px solid var(--wf-border);
  background:var(--wf-bg-elevated); /* solid fill — covers the line behind */
  transition:border-color .25s,background .25s,box-shadow .25s;
  z-index:0;
}
/* Spinning ring (pseudobefore) shown while processing */
.pj-dot::before{
  content:'';
  position:absolute;
  inset:2px;
  border-radius:50%;
  border:2px solid transparent;
  border-top-color:var(--pj-color,var(--wf-violet));
  opacity:0;
  transition:opacity .2s;
  z-index:1;
  pointer-events:none;
}
.pj-dot.is-processing::before{opacity:1;animation:pjDotSpin .55s linear infinite}
@keyframes pjDotSpin{to{transform:rotate(360deg)}}

.pj-dot__num,.pj-dot__check{
  position:relative;z-index:3;
  font-size:.68rem;font-weight:800;
  line-height:1;
  transition:opacity .18s,transform .25s;
}
.pj-dot__num{color:var(--wf-text-3)}
.pj-dot__check{color:var(--pj-color,var(--wf-violet));opacity:0;transform:scale(0);position:absolute}

/* Processing dot */
.pj-dot.is-processing::after{border-color:var(--pj-color);background:var(--pj-bg)}
.pj-dot.is-processing .pj-dot__num{opacity:.4}

/* Done dot */
.pj-dot.is-done::after{border-color:var(--pj-color);background:var(--pj-bg);box-shadow:0 0 0 3px var(--pj-bg)}
.pj-dot.is-done .pj-dot__num{opacity:0;transform:scale(0)}
.pj-dot.is-done .pj-dot__check{opacity:1;transform:scale(1);animation:pjCheckBounce .35s cubic-bezier(.34,1.56,.64,1) both}
@keyframes pjCheckBounce{0%{transform:scale(0)}100%{transform:scale(1)}}

/* ══════════════════════════════════════
   CARDS — below the track
   ══════════════════════════════════════ */
.pj-cards{
  display:grid;
  grid-template-columns:repeat(10,1fr);
  gap:0 5px;
}
.pj-card{
  background:var(--wf-bg-elevated);
  border:1px solid var(--wf-border);
  border-radius:10px;
  padding:.6rem .45rem .55rem;
  display:flex;flex-direction:column;gap:.4rem;
  opacity:.35;
  transition:opacity .25s,border-color .25s,background .25s,transform .25s;
}

/* Card head: icon + gear side by side */
.pj-card__head{
  display:flex;align-items:center;justify-content:center;
  height:26px;position:relative;margin-bottom:.1rem;
}
.pj-card__icon{
  font-size:1.1rem;color:var(--wf-text-3);
  transition:color .25s,opacity .2s;
}
.pj-card__gear{
  font-size:.95rem;color:var(--pj-color,var(--wf-violet));
  position:absolute;right:2px;top:50%;transform:translateY(-50%);
  opacity:0;transition:opacity .2s;
}

/* Progress bar */
.pj-progress{height:2px;background:rgba(255,255,255,.07);border-radius:2px;overflow:hidden;margin-top:.1rem}
.pj-progress__fill{height:100%;width:0;border-radius:2px;background:var(--pj-color,var(--wf-violet));transition:width .42s linear}

/* Title */
.pj-card__title{font-size:.64rem;font-weight:700;color:var(--wf-text-3);letter-spacing:.25px;text-align:center;transition:color .25s}

/* Check list */
.pj-checks{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}
.pj-checks li{
  font-size:.59rem;color:var(--wf-text-3);line-height:1.3;
  padding-left:.8rem;position:relative;text-align:left;
  opacity:0;transform:translateX(-5px);
}
.pj-checks li::before{content:"✓";position:absolute;left:0;font-size:.56rem;top:1px;color:var(--pj-color,var(--wf-violet))}

/* ─── State: is-processing ─── */
.pj-card.is-processing{
  opacity:1;
  border-color:var(--pj-border);
  background:var(--pj-bg);
  transform:translateY(-2px);
}
.pj-card.is-processing .pj-card__icon{color:var(--pj-color);opacity:.5}
.pj-card.is-processing .pj-card__gear{opacity:1;animation:pjGearSpin .7s linear infinite}
.pj-card.is-processing .pj-progress__fill{width:100%}
.pj-card.is-processing .pj-card__title{color:var(--wf-text-secondary)}
@keyframes pjGearSpin{to{transform:translateY(-50%) rotate(360deg)}}

/* ─── State: is-done ─── */
.pj-card.is-done{
  opacity:1;
  border-color:var(--pj-border);
  transform:translateY(0);
}
.pj-card.is-done .pj-card__icon{color:var(--pj-color);opacity:1}
.pj-card.is-done .pj-card__gear{opacity:0}
.pj-card.is-done .pj-progress__fill{width:100%}
.pj-card.is-done .pj-card__title{color:var(--wf-text-primary)}
.pj-card.is-done .pj-checks li:nth-child(1){animation:pjCheckIn .22s .04s ease forwards}
.pj-card.is-done .pj-checks li:nth-child(2){animation:pjCheckIn .22s .2s  ease forwards}
.pj-card.is-done .pj-checks li:nth-child(3){animation:pjCheckIn .22s .36s ease forwards}
@keyframes pjCheckIn{to{opacity:1;transform:translateX(0)}}

/* ─── Per-phase color tokens ─── */
.pj-dot--c1,.pj-card--c1{--pj-color:var(--wf-emerald);--pj-bg:rgba(16,185,129,.1);--pj-border:rgba(16,185,129,.3)}
.pj-dot--c2,.pj-card--c2{--pj-color:var(--wf-cyan);--pj-bg:rgba(6,182,212,.1);--pj-border:rgba(6,182,212,.3)}
.pj-dot--c3,.pj-card--c3{--pj-color:var(--wf-amber);--pj-bg:rgba(245,158,11,.1);--pj-border:rgba(245,158,11,.3)}
.pj-dot--c4,.pj-card--c4{--pj-color:var(--wf-primary);--pj-bg:rgba(99,102,241,.1);--pj-border:rgba(99,102,241,.3)}
.pj-dot--c5,.pj-card--c5{--pj-color:var(--wf-violet);--pj-bg:rgba(139,92,246,.1);--pj-border:rgba(139,92,246,.3)}
.pj-dot--c6,.pj-card--c6{--pj-color:var(--wf-rose);--pj-bg:rgba(244,63,94,.1);--pj-border:rgba(244,63,94,.3)}
.pj-dot--c7,.pj-card--c7{--pj-color:var(--wf-emerald);--pj-bg:rgba(16,185,129,.1);--pj-border:rgba(16,185,129,.3)}
.pj-dot--c8,.pj-card--c8{--pj-color:var(--wf-cyan);--pj-bg:rgba(6,182,212,.1);--pj-border:rgba(6,182,212,.3)}
.pj-dot--c9,.pj-card--c9{--pj-color:var(--wf-amber);--pj-bg:rgba(245,158,11,.1);--pj-border:rgba(245,158,11,.3)}
.pj-dot--c10,.pj-card--c10{--pj-color:var(--wf-primary);--pj-bg:rgba(99,102,241,.1);--pj-border:rgba(99,102,241,.3)}

/* ─── Result banner ─── */
.pj-result{display:flex;align-items:center;gap:1rem;justify-content:center;max-width:440px;margin:2rem auto 0;padding:1rem 1.75rem;background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.22);border-radius:12px;opacity:0;transform:translateY(12px);transition:opacity .5s,transform .5s}
.pj-result.is-visible{opacity:1;transform:translateY(0)}
.pj-result > i{font-size:1.9rem;color:var(--wf-amber);flex-shrink:0}
.pj-result strong{display:block;font-weight:700;color:var(--wf-text-primary);font-size:.92rem}
.pj-result span{font-size:.8rem;color:var(--wf-text-secondary)}

/* ─── Replay button ─── */
.pj-replay-wrap{text-align:center;margin-top:.75rem}
.pj-replay{background:none;border:1px solid var(--wf-border);border-radius:100px;padding:.38rem 1rem;font-size:.76rem;color:var(--wf-text-3);cursor:pointer;transition:all 220ms;font-family:inherit}
.pj-replay:hover{border-color:var(--wf-violet);color:var(--wf-violet)}

/* ─── Light theme overrides ─── */
[data-theme="light"] .pj-line{background:rgba(0,0,0,.07)}
[data-theme="light"] .pj-dot::after{background:var(--wf-bg-elevated)}
[data-theme="light"] .pj-entry__ch{background:var(--wf-bg-card)}
[data-theme="light"] .pj-card{background:var(--wf-bg-elevated)}

/* ═══════════════════════════════════════════
   PHASES (Stage-gate)
   ═══════════════════════════════════════════ */
.pi-phases{display:flex;flex-direction:column;gap:1.5rem}

.pi-phase{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-xl);overflow:hidden;transition:border-color 300ms}
.pi-phase:hover{border-color:var(--wf-border-hover)}
.pi-phase.is-open{border-color:rgba(139,92,246,.3)}

.pi-phase__header{padding:1.6rem 2rem;display:flex;align-items:center;gap:1.2rem;
  cursor:pointer;user-select:none}

.pi-phase__number{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-family:var(--wf-display);font-size:.85rem;font-weight:800;
  flex-shrink:0;letter-spacing:-.02em}

/* per-phase colours */
.pi-phase--1 .pi-phase__number{background:rgba(16,185,129,.12);color:var(--wf-emerald-light);border:1px solid rgba(16,185,129,.25)}
.pi-phase--2 .pi-phase__number{background:rgba(6,182,212,.12);color:var(--wf-cyan-light);border:1px solid rgba(6,182,212,.25)}
.pi-phase--3 .pi-phase__number{background:rgba(245,158,11,.12);color:var(--wf-amber);border:1px solid rgba(245,158,11,.25)}
.pi-phase--4 .pi-phase__number{background:rgba(99,102,241,.12);color:var(--wf-primary-light);border:1px solid rgba(99,102,241,.25)}
.pi-phase--5 .pi-phase__number{background:rgba(139,92,246,.12);color:var(--wf-violet);border:1px solid rgba(139,92,246,.25)}
.pi-phase--6 .pi-phase__number{background:rgba(244,63,94,.12);color:var(--wf-rose);border:1px solid rgba(244,63,94,.25)}
.pi-phase--7 .pi-phase__number{background:rgba(16,185,129,.12);color:var(--wf-emerald-light);border:1px solid rgba(16,185,129,.25)}
.pi-phase--8 .pi-phase__number{background:rgba(6,182,212,.12);color:var(--wf-cyan-light);border:1px solid rgba(6,182,212,.25)}
.pi-phase--9 .pi-phase__number{background:rgba(245,158,11,.12);color:var(--wf-amber);border:1px solid rgba(245,158,11,.25)}
.pi-phase--10 .pi-phase__number{background:rgba(99,102,241,.12);color:var(--wf-primary-light);border:1px solid rgba(99,102,241,.25)}

.pi-phase__meta{flex:1}
.pi-phase__title{font-size:1.05rem;font-weight:700;color:var(--wf-text-1);
  line-height:1.3;margin-bottom:.25rem}
.pi-phase__sub{font-size:.82rem;color:var(--wf-text-3)}

.pi-phase__badge{font-size:.68rem;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;padding:.2rem .7rem;border-radius:var(--wf-r-full);
  background:var(--wf-bg-elevated);border:1px solid var(--wf-border);
  color:var(--wf-text-3);white-space:nowrap;margin-right:.5rem}

.pi-phase__toggle{font-size:1.1rem;color:var(--wf-text-3);transition:transform 300ms var(--wf-ease)}
.pi-phase.is-open .pi-phase__toggle{transform:rotate(180deg);color:var(--wf-violet)}

.pi-phase__body{max-height:0;overflow:hidden;transition:max-height 450ms var(--wf-ease)}
.pi-phase.is-open .pi-phase__body{max-height:1200px}

.pi-phase__content{padding:0 2rem 2rem;border-top:1px solid var(--wf-border)}

.pi-phase__goal{font-size:.93rem;color:var(--wf-text-2);line-height:1.65;
  margin:1.2rem 0 1.4rem;max-width:700px}

.pi-phase__items{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1rem}

.pi-item{background:var(--wf-bg-elevated);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-lg);padding:1.1rem 1.3rem;display:flex;gap:.8rem;align-items:flex-start}
.pi-item i{font-size:1.1rem;flex-shrink:0;margin-top:1px}
.pi-item__title{font-size:.88rem;font-weight:600;color:var(--wf-text-1);margin-bottom:.25rem}
.pi-item__desc{font-size:.8rem;color:var(--wf-text-3);line-height:1.5}

/* tags */
.pi-phase__outputs{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.pi-tag{display:inline-flex;align-items:center;gap:5px;font-size:.73rem;font-weight:600;
  padding:.25rem .75rem;border-radius:var(--wf-r-full);
  background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.18);color:var(--wf-text-2)}
.pi-tag i{font-size:.85rem;color:var(--wf-violet)}

/* ═══════════════════════════════════════════
   TIMELINE TABLE
   ═══════════════════════════════════════════ */
.pi-timeline__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:1rem}

.pi-tcard{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-lg);padding:1.2rem 1.4rem;position:relative;overflow:hidden}
.pi-tcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}

.pi-tcard--green::before{background:var(--wf-emerald)}
.pi-tcard--cyan::before{background:var(--wf-cyan)}
.pi-tcard--amber::before{background:var(--wf-amber)}
.pi-tcard--indigo::before{background:var(--wf-primary)}
.pi-tcard--violet::before{background:var(--wf-violet)}
.pi-tcard--rose::before{background:var(--wf-rose)}

.pi-tcard__phase{font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--wf-text-3);margin-bottom:.4rem}
.pi-tcard__duration{font-family:var(--wf-display);font-size:1.05rem;font-weight:800;
  color:var(--wf-text-1);line-height:1.2;margin-bottom:.4rem}
.pi-tcard__note{font-size:.75rem;color:var(--wf-text-3);line-height:1.4}

/* ═══════════════════════════════════════════
   FEATURES GRID
   ═══════════════════════════════════════════ */
.pi-features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:1.5rem}

.pi-feat{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-xl);padding:1.8rem;transition:all 350ms var(--wf-ease);
  position:relative;overflow:hidden}
.pi-feat::after{content:'';position:absolute;inset:0;
  background:var(--wf-grad-glow);opacity:0;transition:opacity 350ms;pointer-events:none}
.pi-feat:hover{border-color:rgba(139,92,246,.3);transform:translateY(-4px)}
.pi-feat:hover::after{opacity:1}

.pi-feat__num{font-family:monospace;font-size:.68rem;font-weight:700;letter-spacing:.8px;
  color:var(--wf-violet);margin-bottom:.8rem;opacity:.7}
.pi-feat__icon{width:46px;height:46px;border-radius:var(--wf-r-md);display:flex;
  align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem}
.pi-feat__icon--violet{background:rgba(139,92,246,.12);color:var(--wf-violet)}
.pi-feat__icon--indigo{background:rgba(99,102,241,.12);color:var(--wf-primary-light)}
.pi-feat__icon--cyan{background:rgba(6,182,212,.12);color:var(--wf-cyan-light)}
.pi-feat__icon--emerald{background:rgba(16,185,129,.12);color:var(--wf-emerald-light)}
.pi-feat__icon--amber{background:rgba(245,158,11,.12);color:var(--wf-amber)}
.pi-feat__icon--rose{background:rgba(244,63,94,.12);color:var(--wf-rose)}

.pi-feat h4{font-size:1rem;font-weight:700;color:var(--wf-text-1);margin-bottom:.5rem}
.pi-feat p{font-size:.86rem;color:var(--wf-text-2);line-height:1.6}

/* ═══════════════════════════════════════════
   ROLES TABLE
   ═══════════════════════════════════════════ */
.pi-roles__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}

.pi-role{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-lg);padding:1.2rem 1.4rem;display:flex;gap:1rem;align-items:flex-start}
.pi-role__icon{width:40px;height:40px;border-radius:var(--wf-r-md);display:flex;
  align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.pi-role__icon--violet{background:rgba(139,92,246,.12);color:var(--wf-violet)}
.pi-role__icon--indigo{background:rgba(99,102,241,.12);color:var(--wf-primary-light)}
.pi-role__icon--cyan{background:rgba(6,182,212,.12);color:var(--wf-cyan-light)}
.pi-role__icon--emerald{background:rgba(16,185,129,.12);color:var(--wf-emerald-light)}
.pi-role__icon--amber{background:rgba(245,158,11,.12);color:var(--wf-amber)}
.pi-role__icon--rose{background:rgba(244,63,94,.12);color:var(--wf-rose)}

.pi-role__name{font-size:.93rem;font-weight:700;color:var(--wf-text-1);margin-bottom:.3rem}
.pi-role__resp{font-size:.8rem;color:var(--wf-text-3);line-height:1.5}

/* ═══════════════════════════════════════════
   KPIs
   ═══════════════════════════════════════════ */
.pi-kpis__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}

.pi-kpicard{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-xl);padding:1.5rem;text-align:center;
  transition:all 350ms var(--wf-ease)}
.pi-kpicard:hover{border-color:rgba(139,92,246,.3);transform:translateY(-3px)}
.pi-kpicard i{font-size:1.6rem;color:var(--wf-violet);margin-bottom:.6rem;display:block}
.pi-kpicard__metric{font-family:var(--wf-display);font-size:1.6rem;font-weight:800;
  color:var(--wf-text-1);letter-spacing:-.03em;margin-bottom:.35rem}
.pi-kpicard__label{font-size:.78rem;color:var(--wf-text-3);line-height:1.4}

/* ═══════════════════════════════════════════
   DIFFERENTIALS
   ═══════════════════════════════════════════ */
.pi-diff__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}

.pi-diff{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-radius:var(--wf-r-lg);padding:1.4rem;display:flex;gap:1rem;align-items:flex-start;
  transition:border-color 300ms}
.pi-diff:hover{border-color:rgba(139,92,246,.3)}
.pi-diff i{font-size:1.3rem;color:var(--wf-violet);flex-shrink:0;margin-top:1px}
.pi-diff strong{display:block;font-size:.93rem;font-weight:700;color:var(--wf-text-1);
  margin-bottom:.3rem}
.pi-diff span{font-size:.82rem;color:var(--wf-text-3);line-height:1.5}

/* ═══════════════════════════════════════════
   RISKS
   ═══════════════════════════════════════════ */
.pi-risks__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}

.pi-risk{background:var(--wf-bg-card);border:1px solid var(--wf-border);
  border-left:3px solid var(--wf-amber);border-radius:var(--wf-r-lg);padding:1.2rem 1.4rem}
.pi-risk__label{font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  color:var(--wf-amber);margin-bottom:.4rem}
.pi-risk__risk{font-size:.9rem;font-weight:600;color:var(--wf-text-1);margin-bottom:.5rem}
.pi-risk__mit{font-size:.8rem;color:var(--wf-text-2);line-height:1.5}
.pi-risk__mit::before{content:'✓ ';color:var(--wf-emerald-light);font-weight:700}

/* ═══════════════════════════════════════════
   CTA SECTION
   ═══════════════════════════════════════════ */
.pi-cta{position:relative;background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(99,102,241,.1),rgba(6,182,212,.06));
  border:1px solid rgba(139,92,246,.2);border-radius:var(--wf-r-xl);
  padding:4rem;overflow:hidden;text-align:center}
.pi-cta::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(139,92,246,.08),transparent);
  pointer-events:none}
.pi-cta__orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.pi-cta__orb--1{width:400px;height:400px;top:-30%;right:-10%;
  background:rgba(99,102,241,.12);animation:pi-drift-1 18s ease-in-out infinite}
.pi-cta__orb--2{width:350px;height:350px;bottom:-30%;left:-10%;
  background:rgba(139,92,246,.10);animation:pi-drift-2 22s ease-in-out infinite}

.pi-cta__title{font-family:var(--wf-display);font-size:clamp(1.8rem,3.5vw,2.6rem);
  font-weight:800;color:var(--wf-text-1);letter-spacing:-.04em;margin-bottom:1rem;
  position:relative}
.pi-cta__desc{font-size:1rem;color:var(--wf-text-2);max-width:600px;
  margin:0 auto 2.2rem;line-height:1.7;position:relative}
.pi-cta__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}
.pi-cta__note{font-size:.8rem;color:var(--wf-text-3);margin-top:1.4rem;position:relative}

/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
@media(max-width:900px){
  .pi-hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .pi-hero__kpis{grid-template-columns:repeat(2,1fr)}
  .pi-phase__header{padding:1.2rem 1.4rem}
  .pi-phase__content{padding:0 1.4rem 1.4rem}
  .pi-cta{padding:2.5rem 1.5rem}
}
@media(max-width:600px){
  .pi-hero__kpis{grid-template-columns:1fr 1fr}
  .pi-phase__items{grid-template-columns:1fr}
  .pi-feat{padding:1.4rem}
}

/* ═══════════════════════════════════════════
   LIGHT THEME OVERRIDES
   ═══════════════════════════════════════════ */
[data-theme="light"] .pi-phase{background:var(--wf-bg-card)}
[data-theme="light"] .pi-feat{background:var(--wf-bg-card)}
[data-theme="light"] .pi-item{background:var(--wf-bg-elevated)}
[data-theme="light"] .pi-kpicard{background:var(--wf-bg-card)}
[data-theme="light"] .pi-role{background:var(--wf-bg-card)}
[data-theme="light"] .pi-diff{background:var(--wf-bg-card)}
[data-theme="light"] .pi-risk{background:var(--wf-bg-card)}
[data-theme="light"] .pi-tcard{background:var(--wf-bg-card)}

/* ═══════════════════════════════════════════
   CASE INTRO BLOCK
   ═══════════════════════════════════════════ */
.pi-caseblock{
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:3rem 4rem;
  align-items:start;
  background:var(--wf-bg-card);
  border:1px solid rgba(139,92,246,.18);
  border-left:4px solid var(--wf-violet);
  border-radius:16px;
  padding:2.5rem 2.75rem;
}
.pi-caseblock__badge{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--wf-violet);
  background:rgba(139,92,246,.1);
  border:1px solid rgba(139,92,246,.22);
  border-radius:100px;
  padding:.35rem .85rem;
  margin-bottom:1.25rem;
}
.pi-caseblock__title{
  font-size:1.65rem;
  font-weight:700;
  line-height:1.25;
  color:var(--wf-text-primary);
  margin:0;
}
.pi-caseblock__right p{
  color:var(--wf-text-secondary);
  line-height:1.75;
  margin:0 0 1rem;
}
.pi-caseblock__right p:last-of-type{margin-bottom:1.25rem}
.pi-caseblock__highlight{
  display:flex;
  gap:.85rem;
  align-items:flex-start;
  background:rgba(139,92,246,.07);
  border:1px solid rgba(139,92,246,.2);
  border-radius:10px;
  padding:1rem 1.1rem;
  margin-top:.25rem;
}
.pi-caseblock__highlight i{
  font-size:1.3rem;
  color:var(--wf-violet);
  flex-shrink:0;
  margin-top:.15rem;
}
.pi-caseblock__highlight span{
  font-size:.92rem;
  line-height:1.65;
  color:var(--wf-text-secondary);
}
@media(max-width:900px){
  .pi-caseblock{grid-template-columns:1fr;gap:1.5rem;padding:2rem 1.5rem}
}
[data-theme="light"] .pi-caseblock{background:var(--wf-bg-card)}
[data-theme="light"] .pi-caseblock__highlight{background:rgba(139,92,246,.05)}

/* ═══════════════════════════════════════════
   COUNTER ANIMATION
   ═══════════════════════════════════════════ */
.pi-hero__canvas{opacity:.5}
