/* ============================================================
   Plans — colorful list cards + dense detail pages
   Each card/detail sets --cat (category accent color) inline.
   ============================================================ */

/* ---- plans hero band ---- */
.plans-hero{position:relative;padding:120px 0 56px;overflow:hidden;
  background:linear-gradient(180deg,#faf9ff,#fff)}
.plans-hero::after{content:"";position:absolute;right:-8%;top:-30%;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,55,153,.10),transparent 68%);pointer-events:none}
.plans-hero h1{font-size:clamp(30px,4.4vw,52px);line-height:1.32;margin:14px 0 20px}

/* ---- category chips (colorful) ---- */
.cat-chip{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;
  padding:5px 12px 5px 10px;border-radius:999px;line-height:1;white-space:nowrap;
  color:var(--cat,#3E1487);background:color-mix(in srgb,var(--cat,#3E1487) 12%,#fff);
  border:1px solid color-mix(in srgb,var(--cat,#3E1487) 22%,#fff)}
.cat-chip .ic{width:13px;height:13px}
.dom-label{display:inline-block;font-size:11.5px;font-weight:500;color:var(--mut);
  background:var(--soft);border:1px solid var(--line-soft);padding:4px 10px;border-radius:6px}

/* ---- list group ---- */
.plan-group-head{display:flex;align-items:baseline;gap:14px;margin:50px 0 24px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.plan-group-head h2{font-size:23px}
.plan-group-head .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--pp)}
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ---- colorful plan card ---- */
.pcard{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;
  transition:transform .3s,box-shadow .3s,border-color .3s}
.pcard:hover{transform:translateY(-4px);box-shadow:0 22px 50px color-mix(in srgb,var(--cat,#3E1487) 16%,transparent);
  border-color:color-mix(in srgb,var(--cat,#3E1487) 35%,#fff)}
.pcard-top{position:relative;height:122px;display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:linear-gradient(135deg,color-mix(in srgb,var(--cat,#3E1487) 84%,transparent) 0%,color-mix(in srgb,var(--cat,#3E1487) 75%,transparent) 100%),var(--img,none) center/cover no-repeat,var(--cat,#3E1487)}
.pcard-top::before{content:"";position:absolute;inset:0;opacity:.18;
  background-image:radial-gradient(circle at 20% 30%,#fff 1px,transparent 1.4px),radial-gradient(circle at 70% 60%,#fff 1px,transparent 1.4px),radial-gradient(circle at 45% 80%,#fff 1px,transparent 1.4px);
  background-size:46px 46px}
.pcard-top .picon{width:38px;height:38px;color:#fff;position:relative;z-index:1;opacity:.96}
.pcard-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.pcard .cat-chip{align-self:flex-start;margin-bottom:12px}
.pcard h3{font-size:17px;line-height:1.5;margin-bottom:10px}
.pcard p{font-size:13px;color:var(--mut);line-height:1.85;margin:0 0 16px}
.pcard-doms{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.pcard-foot{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;
  padding-top:14px;border-top:1px solid var(--line-soft)}
.pcard-kpi{font-family:var(--serif);font-size:17px;color:var(--cat,#3E1487);font-weight:600;
  display:flex;flex-direction:column;line-height:1.2;min-width:0}
.pcard-kpi small{font-size:.6em;color:var(--mut);font-weight:400;font-family:var(--sans);margin-top:4px;line-height:1.4}
.pcard-go{font-size:12.5px;font-weight:600;color:var(--cat,#3E1487);display:inline-flex;align-items:center;gap:5px;
  white-space:nowrap;flex-shrink:0;padding-bottom:2px}
.pcard:hover .pcard-go .ar{transform:translateX(4px)}
.pcard-go .ar{transition:transform .25s}
.coming{border-style:dashed;background:var(--soft);align-items:center;justify-content:center;text-align:center;min-height:300px}
.coming .ic{font-size:24px;color:var(--pp2);margin-bottom:8px}
.coming p{font-size:13px;color:var(--mut)}

.plans-cta{margin-top:64px;background:var(--tint);border-radius:22px;padding:50px;text-align:center}
.plans-cta h2{font-size:26px;margin-bottom:14px}
.plans-cta p{color:var(--mut);max-width:30em;margin:0 auto 26px}

/* ============== DETAIL PAGE ============== */
.detail-hero{position:relative;padding:112px 0 50px;overflow:hidden;
  background:linear-gradient(160deg,color-mix(in srgb,var(--cat) 8%,#fff),#fff 70%);border-bottom:1px solid var(--line-soft)}
.detail-hero .crumb a{color:var(--cat)}
.detail-hero .cat-chip{margin:16px 0 18px}
.detail-hero h1{font-size:clamp(27px,3.8vw,44px);line-height:1.4;margin-bottom:20px;max-width:20em}
.detail-hero .lead{font-size:16px;max-width:40em;color:#48434f}
.detail-doms{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.detail-meta{display:flex;flex-wrap:wrap;gap:26px;margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.detail-meta .m{font-size:12.5px;color:var(--mut)}
.detail-meta .m b{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--cat);margin-bottom:5px}

.dsection{padding:60px 0;border-bottom:1px solid var(--line-soft)}
.dsection .eyebrow{color:var(--cat)}
.dsection .eyebrow::before{background:var(--cat)}
.dsection h2{font-size:clamp(22px,2.8vw,30px);margin-bottom:24px}
.challenge-body p{font-size:15.5px;line-height:2.05;color:#454049;margin:0 0 16px;max-width:46em}
.challenge-body p .hl{color:var(--cat);font-weight:700}

/* approach steps */
.approach{display:grid;grid-template-columns:auto 1fr;gap:26px;padding:26px 0;border-top:1px solid var(--line)}
.approach:first-of-type{border-top:none}
.approach-n{font-family:var(--mono);font-size:14px;font-weight:500;color:#fff;width:52px;height:52px;border-radius:13px;
  display:flex;align-items:center;justify-content:center;background:var(--cat)}
.approach-c h3{font-size:19px;margin-bottom:9px}
.approach-c p{font-size:14.5px;color:var(--mut);line-height:1.95;margin:0;max-width:44em}

/* outcomes */
.outcomes{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px}
.ocard{border:1px solid var(--line);border-radius:16px;padding:24px;background:#fff;
  border-top:3px solid var(--cat)}
.ocard .v{font-family:var(--serif);font-size:32px;color:var(--cat);font-weight:600;line-height:1}
.ocard .v small{font-size:.5em;margin-left:2px}
.ocard .l{font-size:13px;color:var(--ink);margin-top:10px;line-height:1.6}
.outcome-note{font-size:12.5px;color:var(--mut);margin-top:20px}

/* process mini */
.dprocess{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pstep{background:var(--soft);border-radius:14px;padding:22px}
.pstep .ph{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--cat);margin-bottom:8px}
.pstep h4{font-size:15px;margin-bottom:7px}
.pstep p{font-size:12.5px;color:var(--mut);line-height:1.8;margin:0}

/* related */
.related-row{display:flex;flex-wrap:wrap;gap:10px}

.detail-cta{background:linear-gradient(135deg,color-mix(in srgb,var(--cat) 92%,#000),var(--cat));color:#fff;text-align:center;padding:72px 0}
.detail-cta h2{color:#fff;font-size:clamp(24px,3vw,34px);margin-bottom:16px}
.detail-cta p{color:rgba(255,255,255,.85);max-width:30em;margin:0 auto 30px;line-height:1.9}
.detail-cta .btn{background:#fff;color:var(--cat)}
.detail-cta .btn:hover{background:#f3eefb}

/* ---- figures in plan pages ---- */
.sec-fig{margin:30px 0 6px}
.sec-fig svg{width:100%;height:auto;display:block}
.dhero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:44px;align-items:center}
.dhero-text{min-width:0}
.detail-hero-visual{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/3;
  background:color-mix(in srgb,var(--cat) 9%,#fff);border:1px solid color-mix(in srgb,var(--cat) 18%,#fff)}
.detail-hero-visual img{width:100%;height:100%;object-fit:cover;display:block}
.detail-hero-visual .dhv-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.detail-hero-visual:not(.noimg) img+.dhv-fallback{display:none}
.detail-hero-visual .dhv-fallback svg{width:66px;height:66px;color:var(--cat);opacity:.5}

@media(max-width:880px){
  .plan-grid,.dprocess{grid-template-columns:1fr}
  .plans-hero{padding:92px 0 44px}
  .detail-hero{padding:92px 0 40px}
  .approach{grid-template-columns:1fr;gap:14px}
  .plans-cta{padding:34px 22px}
  .dhero-grid{grid-template-columns:1fr;gap:24px}
  .detail-hero-visual{max-width:420px}
  .sec-fig{margin:22px 0 4px}
}
