/* ============================================================
   Dean Blankfield — Coaching overview. Method step cards.
   Depends on tokens from anxious.css.
   ============================================================ */

.msteps { margin-top: clamp(40px,5vw,64px); display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px,1.5vw,22px); }
.mstep {
  position: relative; overflow: hidden;
  background: var(--white); border: 1px solid var(--hair); border-radius: var(--r);
  padding: clamp(30px,3vw,42px) clamp(26px,2.8vw,36px) clamp(30px,3vw,40px);
  display: flex; flex-direction: column;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease);
}
.mstep:hover { transform: translateY(-5px); box-shadow: 0 40px 70px -50px rgba(22,21,15,0.45); }
.mstep__bg {
  position: absolute; right: 16px; top: -18px;
  font-size: clamp(110px,11vw,150px); font-weight: 600; letter-spacing: -0.05em; line-height: 1;
  color: rgba(106,93,82,0.07); pointer-events: none; user-select: none;
}
.mstep__icon { width: 58px; height: 58px; border-radius: 15px; background: var(--paper); border: 1px solid var(--hair); display: grid; place-items: center; color: var(--brown); position: relative; z-index: 1; }
.mstep__icon svg { width: 27px; height: 27px; }
.mstep__k { margin-top: 22px; font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--taupe); position: relative; z-index: 1; }
.mstep__t { font-size: clamp(24px,2.2vw,30px); letter-spacing: -0.03em; color: var(--ink); margin-top: 7px; position: relative; z-index: 1; }
.mstep__d { margin-top: 13px; font-size: clamp(16px,1.3vw,18px); line-height: 1.5; color: var(--muted); max-width: 34ch; position: relative; z-index: 1; }

/* week-by-week / shape of the six weeks */
.weeks { margin-top: clamp(40px,5vw,64px); border-top: 1px solid var(--hair); }
.week { display: grid; grid-template-columns: 120px 1fr; gap: clamp(20px,4vw,56px); padding: clamp(24px,2.8vw,36px) 0; border-bottom: 1px solid var(--hair); align-items: baseline; transition: padding-left .4s var(--ease); }
.week:hover { padding-left: 12px; }
.week__n { font-size: clamp(15px,1.2vw,16px); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--brown); }
.week__b h3 { font-size: clamp(21px,2vw,28px); letter-spacing: -0.03em; color: var(--ink); margin-bottom: 10px; }
.week__b p { font-size: clamp(16px,1.4vw,19px); line-height: 1.5; color: var(--muted); max-width: 60ch; }

/* Therapy vs Coaching — comparison */
.compare { margin-top: clamp(40px,5vw,64px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(14px,1.6vw,22px); }
.compare__col { border: 1px solid var(--hair); border-radius: var(--r); background: var(--white); padding: clamp(28px,3vw,44px); }
.compare__col--me { background: var(--ink); color: #fff; border-color: var(--ink); }
.compare__k { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--taupe); }
.compare__col--me .compare__k { color: var(--greige); }
.compare__t { font-size: clamp(22px,2vw,28px); letter-spacing: -0.03em; color: var(--ink); margin-top: 8px; }
.compare__col--me .compare__t { color: #fff; }
.compare__list { list-style: none; margin: clamp(20px,2vw,28px) 0 0; padding: 0; }
.compare__list li { position: relative; padding: 14px 0 14px 30px; border-top: 1px solid var(--hair); font-size: clamp(16px,1.3vw,18px); color: var(--muted); line-height: 1.45; }
.compare__col--me .compare__list li { border-top-color: rgba(255,255,255,0.16); color: rgba(255,255,255,0.82); }
.compare__list li::before { content:""; position: absolute; left: 0; top: 21px; width: 14px; height: 1.5px; background: var(--brown); }
.compare__col--me .compare__list li::before { background: var(--greige); }
.compare__note { margin-top: clamp(28px,3vw,40px); max-width: 72ch; font-size: clamp(17px,1.4vw,20px); line-height: 1.55; color: var(--muted); }

/* The approach — disciplines */
.disc { margin-top: clamp(40px,5vw,64px); display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px,1.5vw,20px); }
.disc__card { position: relative; background: var(--white); border: 1px solid var(--hair); border-radius: var(--r); padding: clamp(26px,2.6vw,34px); transition: transform .4s var(--ease), box-shadow .4s var(--ease); }
.disc__card:hover { transform: translateY(-4px); box-shadow: 0 40px 70px -50px rgba(22,21,15,0.45); }
.disc__n { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; color: var(--taupe); }
.disc__card h3 { font-size: clamp(20px,1.8vw,24px); letter-spacing: -0.025em; color: var(--ink); margin: 10px 0 9px; }
.disc__card p { font-size: clamp(15px,1.2vw,17px); line-height: 1.5; color: var(--muted); }
.disc__note { margin-top: clamp(28px,3vw,40px); max-width: 62ch; font-size: clamp(18px,1.6vw,22px); line-height: 1.5; font-weight: 500; color: var(--ink); }

/* What we work on — layers */
.layers { margin-top: clamp(40px,5vw,64px); border-top: 1px solid var(--hair); }
.layer { display: grid; grid-template-columns: 220px 1fr; gap: clamp(20px,4vw,56px); padding: clamp(22px,2.6vw,34px) 0; border-bottom: 1px solid var(--hair); align-items: baseline; transition: padding-left .4s var(--ease); }
.layer:hover { padding-left: 12px; }
.layer__n { font-size: clamp(18px,1.7vw,24px); letter-spacing: -0.02em; font-weight: 600; color: var(--brown); }
.layer__b p { font-size: clamp(16px,1.4vw,19px); line-height: 1.5; color: var(--muted); max-width: 60ch; }

@media (max-width: 860px) {
  .msteps { grid-template-columns: 1fr; }
  .compare { grid-template-columns: 1fr; }
  .disc { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .week { grid-template-columns: 1fr; gap: 8px; }
  .disc { grid-template-columns: 1fr; }
  .layer { grid-template-columns: 1fr; gap: 6px; }
}
