/* hassan.css — feature spread for the barber (chapter V) */

.feature {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}

@media (min-width: 900px) {
  .feature {
    grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.1fr);
    gap: clamp(3rem, 6vw, 5rem);
  }
}

.feature__portrait {
  position: relative;
  margin: 0;
  border-radius: var(--r-sm);
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--ink-3);
}

.feature__portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.05) saturate(0.95);
}

.feature__portrait::before {
  content: '';
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(237, 230, 214, 0.18);
  pointer-events: none;
  z-index: 1;
}

.feature__cap {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  padding: 0.4rem 0.7rem;
  background: rgba(10, 9, 8, 0.78);
  color: var(--bone-soft);
  letter-spacing: 0.08em;
  border-left: 2px solid var(--gold);
  z-index: 2;
}

.feature__body {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.feature__name {
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
  color: var(--bone);
  margin-bottom: 0.5rem;
}

.feature__body p {
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--bone-soft);
  max-width: 56ch;
}

.feature__quote {
  margin: 1.5rem 0;
  padding: 1.5rem 0 1.5rem 1.5rem;
  border-left: 2px solid var(--gold);
}

.feature__quote .t-pullquote {
  font-size: clamp(1.25rem, 2.2vw, 1.75rem);
  color: var(--bone);
}

.feature__bench {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin: 1.5rem 0 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
}

.feature__bench dt {
  color: var(--gold);
  letter-spacing: 0.18em;
}

.feature__bench dd {
  margin: 0;
}

.feature__tools {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.5rem 1.5rem;
}

.feature__tools li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--rule);
}

.feature__tools li .t-display-sm { font-size: 1rem; }
.feature__tools li .t-meta { color: var(--bone-mute); }
