/* ===== Additional components for full content build ===== */

/* photo hero band (image showing through dark overlay) */
.phero--img{background-size:cover;background-position:center}
.phero--img::before{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(11,10,18,.78),rgba(11,10,18,.92)),
  linear-gradient(110deg,rgba(228,86,160,.32),rgba(79,137,232,.28));z-index:1}

/* service detail tags */
.srow__chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.srow__chips span{font-size:.78rem;font-weight:600;padding:.45em 1em;border-radius:100px;
  border:1px solid var(--line-light);color:var(--tx-dark-muted);background:#fff}

/* WHY grid */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.why{padding:34px 30px;border-radius:var(--r);background:var(--ink-2);border:1px solid var(--line-dark);
  transition:transform .5s var(--ease),border-color .4s}
.why:hover{transform:translateY(-6px);border-color:rgba(139,92,214,.5)}
.why__ic{width:48px;height:48px;border-radius:14px;background:var(--grad);display:grid;place-items:center;
  color:#fff;font-size:1.2rem;margin-bottom:20px}
.why h3{color:#fff;margin-bottom:10px}
.why p{color:var(--tx-light-muted)}
@media(max-width:900px){.why-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr}}

/* PRICING */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.tier{display:flex;flex-direction:column;padding:38px 32px;border-radius:var(--r-lg);background:var(--paper-2);
  border:1px solid var(--line-light);transition:transform .5s var(--ease),box-shadow .5s}
.tier:hover{transform:translateY(-8px);box-shadow:0 40px 80px -34px rgba(139,92,214,.4)}
.tier--feat{background:var(--ink);color:#fff;border-color:transparent;position:relative;overflow:hidden}
.tier--feat::before{content:"";position:absolute;inset:0;background:var(--grad-soft);z-index:0}
.tier--feat > *{position:relative;z-index:1}
.tier__badge{align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:.4em 1em;border-radius:100px;background:var(--grad);color:#fff;margin-bottom:18px}
.tier h3{font-size:1.6rem;margin-bottom:8px}
.tier__desc{color:var(--tx-dark-muted);margin-bottom:24px;min-height:48px}
.tier--feat .tier__desc{color:var(--tx-light-muted)}
.tier__list{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:30px;flex:1}
.tier__list li{display:flex;gap:11px;align-items:flex-start;font-weight:500}
.tier__list li::before{content:"✓";color:var(--g-purple);font-weight:800;flex-shrink:0}
.tier--feat .tier__list li::before{color:var(--g-pink)}
.tier .btn{width:100%;justify-content:center}
@media(max-width:880px){.pricing{grid-template-columns:1fr;max-width:460px;margin-inline:auto}}

/* numbered principles */
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:24px 40px}
.principle{display:flex;flex-direction:column;gap:10px;padding-top:24px;border-top:2px solid var(--line-light)}
.principle__no{font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--g-purple);letter-spacing:.08em}
.principle h3{font-size:1.3rem}
.principle p{color:var(--tx-dark-muted)}
@media(max-width:860px){.principles{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.principles{grid-template-columns:1fr}}

/* TIMELINE */
.timeline{position:relative;max-width:760px;margin:0 auto;padding-left:34px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--grad)}
.tl{position:relative;padding-bottom:46px}
.tl:last-child{padding-bottom:0}
.tl::before{content:"";position:absolute;left:-34px;top:4px;width:16px;height:16px;border-radius:50%;
  background:var(--ink);border:3px solid var(--g-purple)}
.tl__year{font-family:var(--font-display);font-weight:600;font-size:1.4rem;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:6px}
.tl h3{color:#fff;margin-bottom:8px;font-size:1.3rem}
.tl p{color:var(--tx-light-muted);max-width:60ch}

/* team with photos */
.member__photo{aspect-ratio:1;object-fit:cover;width:100%;display:block}

/* FILTER bar (work) */
.filterbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:44px}
.filterbar button{font-family:var(--font-body);font-weight:600;font-size:.92rem;padding:.6em 1.2em;border-radius:100px;
  border:1.5px solid var(--line-light);color:var(--tx-dark-muted);background:#fff;transition:.3s var(--ease)}
.filterbar button:hover{border-color:var(--g-purple);color:var(--ink)}
.filterbar button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.wi[hidden]{display:none}

/* ARTICLE */
.article-hero{position:relative;overflow:hidden;padding-top:clamp(140px,18vh,200px);padding-bottom:clamp(40px,6vw,70px)}
.article-hero .wrap{position:relative;z-index:2;max-width:820px}
.article-hero__cat{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;
  display:inline-block;padding:.5em 1.1em;border-radius:100px;background:var(--grad);margin-bottom:22px}
.article-hero h1{font-size:clamp(2.1rem,4.6vw,3.6rem);line-height:1.04;letter-spacing:-.025em;margin-bottom:22px;max-width:20ch}
.article-meta{display:flex;gap:16px;align-items:center;color:var(--tx-light-muted);font-size:.92rem;flex-wrap:wrap}
.article-meta .by{display:flex;align-items:center;gap:10px}
.article-meta .by img{width:38px;height:38px;border-radius:50%;object-fit:cover}
.article-body{max-width:760px;margin:0 auto;padding-block:clamp(40px,6vw,72px)}
.article-body > *{margin-bottom:26px}
.article-body p{font-size:1.16rem;line-height:1.72;color:#2a2733}
.article-body h2{font-size:clamp(1.5rem,2.6vw,2rem);margin-top:48px;margin-bottom:18px;letter-spacing:-.02em}
.article-body h3{font-size:1.3rem;margin-top:32px;margin-bottom:12px}
.article-body ul{padding-left:4px;list-style:none;display:flex;flex-direction:column;gap:14px}
.article-body ul li{position:relative;padding-left:26px;font-size:1.12rem;line-height:1.6;color:#2a2733}
.article-body ul li::before{content:"";position:absolute;left:2px;top:.62em;width:9px;height:9px;border-radius:50%;background:var(--grad)}
.article-body blockquote{border-left:3px solid;border-image:var(--grad) 1;padding:6px 0 6px 28px;margin:36px 0;
  font-family:var(--font-display);font-style:italic;font-size:1.5rem;line-height:1.35;letter-spacing:-.01em}
.article-body strong{font-weight:700}
.article-body .lead{font-size:1.3rem;line-height:1.6;color:var(--ink);font-weight:500}
.article-share{display:flex;align-items:center;gap:14px;padding-top:30px;border-top:1px solid var(--line-light);
  margin-top:20px;color:var(--tx-dark-muted);font-weight:600;font-size:.9rem}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:860px){.related{grid-template-columns:1fr}}

.posts.posts--two{grid-template-columns:repeat(2,1fr)}
@media(max-width:640px){.posts.posts--two{grid-template-columns:1fr}}

/* case study detail */
/* iceberg infographic (about page) */
.iceberg{max-width:760px;margin:0 auto;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-dark);box-shadow:0 50px 120px -50px rgba(79,137,232,.5)}
.iceberg img{width:100%;height:auto;display:block}
/* fill-slot: a droppable image-slot that fills a media container (work/blog cards) */
.fill-slot{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:2}
.wi__media .wi__metric,.blog-feat__media >*:not(image-slot),.post__media >*:not(image-slot){z-index:3;pointer-events:none}
.wi__media::after,.post__media::after,.blog-feat__media::after{z-index:1;pointer-events:none}
image-slot.case-shot{display:block;width:100%;height:auto;aspect-ratio:16/9;border-radius:20px;
  background:linear-gradient(135deg,var(--c1,#E456A0),var(--c2,#4F89E8))}
.case-quote{font-family:var(--font-display);font-style:italic;font-size:clamp(1.5rem,3vw,2.3rem);
  line-height:1.3;letter-spacing:-.01em;max-width:20ch;margin:0 auto;text-align:center}
