/* ════════════════════════════
   HERO
════════════════════════════ */
#hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

#hero-grain {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
  opacity: 0.08;
}

.hero > *:not(#hero-bg):not(#hero-grain) {
  position: relative;
  z-index: 1;
}

.hero {
  padding-top: 10rem;
  padding-bottom: 4rem;
  padding-left: var(--page-margin);
  padding-right: var(--page-margin);
  position: relative;
}

/* ── Two-column grid: text left, portrait right, both constrained to content body ── */
.hero__content-row {
  display: grid;
  grid-template-columns: clamp(32rem, 47.5vw, 43rem) clamp(9rem, 18vw, 16.25rem);
  justify-content: start;
  align-items: center;
  gap: 4rem;
  max-width: var(--content-body);
  margin: 0 auto;
  padding-bottom: 3rem;
}

.hero__text {
  padding-left: clamp(0rem, 7.75vw, 7rem);
}

.hero__headline {
  font-size: var(--text-hero-lg);
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--black);
}

.hero__headline-line {
  display: block;
}

.hero__headline-line--comm {
  font-family: var(--font-body);
  font-weight: 500;
}

.hero__headline-line--coco {
  font-family: var(--font-display);
  font-weight: 600;
  margin-bottom: -0.55rem;
}

.hero__word-swap {
  display: inline-block;
}

.hero__word-swap.word-exit {
  animation: word-exit 0.3s ease forwards;
}

.hero__word-swap.word-enter {
  animation: word-enter 0.5s ease forwards;
}

.hero__portrait-outer {
  position: relative;
  justify-self: center;
  width: fit-content;
  overflow: visible;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

/* static 1px sand ring, 20px from portrait edge */
.hero__portrait-outer::before {
  content: '';
  position: absolute;
  inset: -0.6rem;
  border-radius: 50%;
  border: 1px solid var(--sand);
  pointer-events: none;
  z-index: 1;
  opacity: 1;
  transition: opacity 0.3s ease;
}

.hero__portrait-outer:hover {
  transform: translateY(-10px);
}

.hero__portrait-outer:hover::before {
  opacity: 0;
}

/* canvas sized to match the static ring radius — inset matches ::before inset */
#portrait-ring {
  position: absolute;
  inset: -20px;
  width: calc(100% + 40px);
  height: calc(100% + 40px);
  pointer-events: none;
  z-index: 3;
  opacity: 0;
  transition: opacity 0.4s ease;
}

#portrait-ring.visible {
  opacity: 1;
}

.hero__portrait {
  width: clamp(9rem, 18vw, 16.25rem);
  height: clamp(9rem, 18vw, 16.25rem);
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  will-change: transform;
}

.hero__portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.hero__subtitle {
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--mid);
  max-width: 34rem;
  margin: 2.2rem 0 0;
  line-height: 1.5;
}

/* ── Stats row ── */
.hero__divider {
  width: 100%;
  height: 1px;
  background: var(--black);
  margin: 3.5rem 0 0;
  max-width: var(--content-body);
}

.hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  width: 100%;
  max-width: var(--content-body);
  margin-top: 2.5rem;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
}

.stat-block {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-right: 1rem;
}

.stat-block__number {
  font-family: var(--font-body);
  font-size: var(--text-stat);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--black);
  padding-top: 0.75rem;
}

.stat-block__label {
  font-family: var(--font-display);
  font-size: var(--text-body);
  color: var(--mid);
}

.stat-block__desc {
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--mid);
}

.stat-block__link {
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--mid);
  text-decoration: underline;
  cursor: pointer;
}

/* ════════════════════════════
   SELECTED WORKS
════════════════════════════ */
.works {
  padding: 0 var(--page-margin);
}

.works__inner {
  max-width: var(--content-body);
  margin: 0 auto;
}

/* 1-col featured card */
.cs-card--featured {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.cs-card--featured .cs-card__img {
  height: 28.75rem;
  border-radius: var(--radius-md);
}

/* 2-col cards */
.cs-card--2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: center;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.cs-card--2col.cs-card--img-right {
  /* image right: text left */
}

.cs-card--2col.cs-card--img-left {
  /* image left: text right */
}

.cs-card--2col .cs-card__img {
  height: 27.8125rem;
  border-radius: var(--radius-md);
}

.cs-card__text {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 0 1rem;
}

.cs-card__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-label);
  letter-spacing: 0.02em;
  color: var(--black);
}

.cs-card__title {
  font-family: var(--font-display);
  font-size: var(--text-card);
  line-height: 1.2;
  color: var(--black);
  margin-top: 0.25rem;
}

.cs-card__company {
  font-family: var(--font-mono);
  font-size: var(--text-label);
  letter-spacing: 0.02em;
  color: var(--black);
}

.cs-card__desc {
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--mid);
  padding-top: 0.5rem;
}

.works__list {
  display: flex;
  flex-direction: column;
  gap: 6.25rem;
  padding-bottom: var(--section-gap);
}

/* ════════════════════════════
   HOW I LEAD
════════════════════════════ */
.how-i-lead {
  padding: 0 var(--page-margin);
}

.how-i-lead__inner {
  max-width: var(--content-body);
  margin: 0 auto;
}

.how-i-lead__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-top: var(--section-gap);
  padding-bottom: 2.5rem;
  border-top: 1px solid var(--sand);
}

.how-i-lead__title {
  font-family: var(--font-display);
  font-size: var(--text-section);
  color: var(--black);
}

.how-i-lead__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem 8.125rem;
  max-width: 46.6875rem;
  margin-left: auto;
  padding-bottom: var(--section-gap);
}

.lead-block {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.lead-block__icon {
  font-family: var(--font-icon);
  font-size: 3.4375rem;
  line-height: 1.3;
  color: var(--black);
  /* Fallback emoji when Whirlybats is not loaded */
}

.lead-block__icon.no-whirlybats::before {
  font-family: inherit;
}

.lead-block__title {
  font-family: var(--font-display);
  font-size: var(--text-card);
  line-height: 1.2;
  color: var(--black);
}

.lead-block__desc {
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--mid);
}

/* ════════════════════════════
   TESTIMONIALS PHOTOS
════════════════════════════ */
.testimonial-photos {
  height: 31.25rem;
  position: relative;
  overflow: hidden;
  background: #f0ede7;
}

.testimonial-photos__img {
  position: absolute;
  width: 50rem;
  height: 50rem;
  object-fit: cover;
}

.testimonial-photos__img--1 {
  top: -3rem;
  left: 1.875rem;
}

.testimonial-photos__img--2 {
  top: 1rem;
  right: 1.875rem;
}

/* ════════════════════════════
   WHAT PEOPLE SAY
════════════════════════════ */
.testimonials {
  padding: 0 var(--page-margin);
}

.testimonials__inner {
  max-width: var(--content-body);
  margin: 0 auto;
}

.testimonials__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--section-gap);
  padding-bottom: 2.5rem;
  border-top: 1px solid var(--sand);
}

.testimonials__title {
  font-family: var(--font-display);
  font-size: var(--text-section);
  color: var(--black);
}

.testimonials__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  padding-bottom: var(--section-gap);
}

.testimony-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 2rem 3rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.testimony-card__quote {
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--mid);
  line-height: 1.6;
  flex: 1;
  hanging-punctuation: first;
}

.testimony-card__person {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.testimony-card__avatar {
  width: 3.125rem;
  height: 3.125rem;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.testimony-card__name {
  font-family: var(--font-display);
  font-size: var(--text-body);
  line-height: 1.5;
  color: var(--black);
}

.testimony-card__role {
  font-family: var(--font-display);
  font-size: var(--text-body);
  color: var(--mid);
}

/* ════════════════════════════
   CTA / CONTACT
════════════════════════════ */
.cta {
  padding: 0 var(--page-margin);
  border-top: 1px solid var(--sand);
}

.cta__inner {
  max-width: var(--content-body);
  margin: 0 auto;
  padding: var(--section-gap) 0;
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.cta__headline {
  font-family: var(--font-display);
  font-size: var(--text-hero);
  line-height: 1.1;
  letter-spacing: -0.02em;
  max-width: 55rem;
  color: var(--black);
}

.cta__availability {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-mono);
  font-size: var(--text-label);
  letter-spacing: 0.02em;
  color: var(--black);
}

.cta__dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: #22c55e;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.25);
  animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.25); }
  50%       { box-shadow: 0 0 0 6px rgba(34, 197, 94, 0.1); }
}

.cta__buttons {
  display: flex;
  gap: 1.1875rem;
  flex-wrap: wrap;
}

/* ════════════════════════════
   RESPONSIVE — HOME
════════════════════════════ */
@media (max-width: 1024px) {
  .how-i-lead__grid {
    gap: 3rem 4rem;
    max-width: 100%;
  }

  .cs-card--2col .cs-card__img {
    height: 22rem;
  }

  /* Tighten hero grid on mid-size screens */
  .hero__content-row {
    gap: 2.5rem;
  }

  .hero__text {
    padding-left: clamp(0rem, 5vw, 4rem);
  }
}

@media (max-width: 767px) {
  .hero {
    padding-top: 7rem;
  }

  /* Stack text + portrait vertically on mobile */
  .hero__content-row {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding-bottom: 0;
  }

  .hero__text {
    padding-left: 0;
    text-align: left;
  }

  .hero__subtitle {
    padding-left: 0;
    text-align: left;
  }

  .hero__portrait-outer {
    justify-self: center;
  }

  .hero__portrait {
    width: 9rem;
    height: 9rem;
  }

  .hero__subtitle {
    margin-top: 1.5rem;
  }

  .hero__stats {
    grid-template-columns: 1fr 1fr;
    gap: 2rem 1rem;
  }

  .works__list {
    gap: 4.25rem;
  }

  .cs-card--2col {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .cs-card--2col.cs-card--img-right .cs-card__img,
  .cs-card--2col.cs-card--img-left .cs-card__img {
    order: -1;
  }

  .cs-card--2col .cs-card__img {
    height: 18rem;
  }

  .cs-card--featured .cs-card__img {
    height: 18rem;
  }

  .how-i-lead__grid {
    grid-template-columns: 1fr;
    gap: 3rem;
    margin-left: 0;
  }

  .testimonials__grid {
    grid-template-columns: 1fr;
  }

  .cta__headline {
    font-size: clamp(1.8rem, 7vw, 2.4rem);
  }

  .cta__availability {
    font-size: 0.75rem;
  }
}
