// Блок со спикером.
// Узкая мобильная версия использует тот же порог, что и первый экран.

.speaker {
  background: rgba(255, 227, 237, 0.5);
  font-family: var(--font-manrope);
  overflow: hidden;
  position: relative;

  @media (min-width: $bp-1440) {
    height: 1080px;
  }

  &__content {
    box-sizing: border-box;
    max-width: none;
    position: relative;
    width: 100%;

    @media (width > #{$bp-md}) {
      align-items: flex-start;
      column-gap: clamp(24px, 3.33vw, 64px);
      display: flex;
      justify-content: space-between;
      min-height: clamp(860px, 54vw, 1020px);
      padding-block: clamp(72px, 6.09vw, 117px) clamp(88px, 7.4vw, 142px);
      padding-inline: clamp(120px, 13.13vw, 252px) clamp(20px, 1.46vw, 28px);
    }

    @media (max-width: $bp-md) {
      display: flex;
      flex-direction: column;
      min-height: unset;
    }
  }

  &__col--text {
    box-sizing: border-box;
    min-width: 0;

    @media (width > #{$bp-md}) {
      align-items: flex-start;
      display: flex;
      flex: 0 1 57%;
      flex-direction: column;
    }

    @media (min-width: $bp-1440) {
      flex: 0 1 48%;
    }

    @media (max-width: $bp-md) {
      align-items: center;
      display: flex;
      flex-basis: auto;
      flex-direction: column;
      gap: clamp(20px, 1.77vw, 34px);
      order: 2;
      padding: 0 20px 40px;
      text-align: center;
    }

    @media (width <= #{$hero-mq-narrow}) {
      gap: clamp(56px, 1.77vw, 34px);
      padding: 0 20px 76px;
    }
  }

  &__col--photo {
    box-sizing: border-box;
    min-width: 0;

    @media (width > #{$bp-md}) {
      display: flex;
      flex: 0 1 43%;
      justify-content: center;
      padding-top: clamp(24px, 2.5vw, 48px);
    }

    @media (min-width: $bp-1440) {
      flex: 1 1 47%;
      justify-content: flex-start;
      padding-left: 18px;
      padding-top: 77px;
    }

    @media (max-width: $bp-md) {
      align-items: center;
      display: flex;
      flex-basis: auto;
      flex-direction: column;
      order: 1;
      padding: 37px 20px 20px;
    }

    @media (width <= #{$hero-mq-narrow}) {
      padding: 32px 20px 33px;
    }
  }

  /* Плашка визуально выделяет подпись над именем спикера. */
  &__label {
    margin: 0 0 -2px -8px;

    @media (max-width: $bp-md) {
      margin-left: 0;
    }
  }

  &__label-text {
    color: var(--clr-text-inverse);
    display: inline-block;
    font-size: var(--font-size-59);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--track-title-59);
    line-height: var(--leading-none);
    padding: 0.1em 0.2em;
    position: relative;
    z-index: 0;

    &::before {
      background-color: var(--clr-primary);
      content: '';
      height: 56.405px;
      left: 50%;
      position: absolute;
      top: 50%;
      transform: translate(-50%, -50%) rotate(-1.412deg);
      width: 237.647px;
      z-index: -1;
    }

    @media (max-width: $bp-md) {
      font-size: var(--font-size-59);
      letter-spacing: -0.025em;
    }

    @media (width <= #{$hero-mq-narrow}) {
      font-family: var(--font-manrope);
      font-size: 32px;
      font-style: normal;
      font-weight: var(--font-weight-semibold);
      letter-spacing: -0.8px;
      line-height: 100%;

      /* stylelint-disable order/properties-alphabetical-order, property-no-unknown */
      font-feature-settings: 'liga' off, 'clig' off;
      text-edge: cap;
      /* stylelint-enable order/properties-alphabetical-order, property-no-unknown */

      &::before {
        height: 33.405px;
        left: 49%;
        top: 61%;
        transform: translate(-50%, -50%) rotate(1.588deg);
        width: 171.647px;
      }
    }
  }

  &__name {
    color: var(--clr-text);
    font-size: var(--font-size-59);
    font-weight: var(--font-weight-regular);
    letter-spacing: var(--track-title-59);
    line-height: var(--leading-none);
    margin: 0 0 5px 1px;
    white-space: nowrap;

    @media (max-width: $bp-md) {
      font-size: var(--font-size-59);
      letter-spacing: -0.025em;
      margin-left: 0;
      text-align: center;
      white-space: normal;
    }

    @media (width <= #{$hero-mq-narrow}) {
      color: var(--clr-text);
      font-family: var(--font-manrope);
      font-size: 32px;
      font-style: normal;
      font-weight: var(--font-weight-regular);
      letter-spacing: -0.8px;
      line-height: 100%;
      margin: 0 0 8px 1px;
      text-align: center;

      /* stylelint-disable order/properties-alphabetical-order, property-no-unknown */
      font-feature-settings: 'liga' off, 'clig' off;
      leading-trim: both;
      text-edge: cap;
      /* stylelint-enable order/properties-alphabetical-order, property-no-unknown */
    }
  }

  &__meta {
    color: var(--clr-text);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-regular);
    line-height: var(--leading-tight-12);
    margin: 0 0 20px;
    margin-left: 1px;
    max-width: 481px;

    @media (max-width: $bp-md) {
      font-size: var(--font-size-sm);
      margin-left: 0;
      max-width: min(100%, 22rem);
      text-align: center;
    }

    @media (width <= #{$hero-mq-narrow}) {
      color: var(--clr-text);
      font-family: var(--font-manrope);
      font-size: 8px;
      font-style: normal;
      font-weight: var(--font-weight-regular);
      line-height: 120%;
      margin: 0 0 17px;
      text-align: center;

      /* stylelint-disable order/properties-alphabetical-order, property-no-unknown */
      font-feature-settings: 'liga' off, 'clig' off;
      leading-trim: both;
      text-edge: cap;
      /* stylelint-enable order/properties-alphabetical-order, property-no-unknown */
    }
  }

  &__experience {
    color: var(--clr-text);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-regular);
    line-height: var(--leading-tight-12);
    margin: 0 0 clamp(28px, 2.6vw, 50px);

    @media (max-width: $bp-md) {
      font-size: var(--font-size-sm);
      margin-bottom: 24px;
      text-align: center;
    }

    @media (width <= #{$hero-mq-narrow}) {
      color: var(--clr-text);
      font-family: var(--font-manrope);
      font-size: 8px;
      font-style: normal;
      font-weight: var(--font-weight-regular);
      line-height: 120%;
      margin-bottom: 15px;
      text-align: center;

      /* stylelint-disable order/properties-alphabetical-order, property-no-unknown */
      font-feature-settings: 'liga' off, 'clig' off;
      leading-trim: both;
      text-edge: cap;
      /* stylelint-enable order/properties-alphabetical-order, property-no-unknown */

      &-lead {
        font-weight: var(--font-weight-semibold);
      }
    }
  }

  @include section-pipeline-list;

  &__list {
    --speaker-list-gap: clamp(20px, 1.77vw, 34px);

    display: flex;
    flex-direction: column;
    gap: var(--speaker-list-gap);
    margin-bottom: 0;
    max-width: 695px;

    @media (max-width: $bp-md) {
      margin-inline: auto;
      max-width: 22rem;
      text-align: left;
    }

    @media (width <= #{$hero-mq-narrow}) {
      --speaker-list-gap: 19px;

      gap: 19px;
      padding-inline: 9px;
    }
  }

  &__item {
    color: var(--clr-text);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-regular);
    line-height: var(--leading-tight-12);
    padding-bottom: 0;
    padding-inline-start: clamp(36px, 3.7vw, 71px);

    &::before {
      left: calc(var(--pipeline-rail-width) * 0.5);
      top: 0.6em;
      transform: translate(-50%, -50%);
    }

    &:not(:last-child)::after {
      background-color: var(--clr-primary);
      content: '';
      height: calc(100% + var(--speaker-list-gap));
      left: calc(var(--pipeline-rail-width) * 0.5);
      position: absolute;
      top: 0.6em;
      transform: translateX(-50%);
      width: 1px;
      z-index: 0;
    }

    @media (max-width: $bp-md) {
      font-size: var(--font-size-lg);
      padding-inline-start: 1.5rem;
    }

    @media (width <= #{$hero-mq-narrow}) {
      color: var(--clr-text);
      font-family: var(--font-manrope);
      font-size: 16px;
      font-style: normal;
      font-weight: var(--font-weight-regular);
      line-height: 120%;
      margin-left: -2px;
      padding-inline-start: 3.3rem;

      /* stylelint-disable order/properties-alphabetical-order, property-no-unknown */
      font-feature-settings: 'liga' off, 'clig' off;
      leading-trim: both;
      text-edge: cap;
      /* stylelint-enable order/properties-alphabetical-order, property-no-unknown */

      &::before {
        height: 7px;
        left: calc(18px * 0.5);
        top: 0.6em;
        width: 7px;
      }

      &:not(:last-child)::after {
        left: calc(18px * 0.5);
      }
    }
  }

  &__photo-ring {
    aspect-ratio: 1 / 1;
    border: 1px solid var(--clr-border-light);
    border-radius: 50%;
    height: auto;
    max-width: 100%;
    overflow: hidden;
    width: clamp(320px, 29.01vw, 557px);

    @media (min-width: $bp-1440) {
      height: 557px;
      width: 557px;
    }

    @media (max-width: $bp-md) {
      width: min(100%, 28rem);
    }
  }

  &__photo-img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: 25px -40px;
    transform: scale(1.2);
    width: 100%;

    @media (width <= #{$hero-mq-narrow}) {
      height: 216px;
      object-fit: cover;
      object-position: 8px -14px;
      transform: scale(1.13);
      width: 216px;
    }
  }

  &__media {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 1.77vw, 34px);
    max-width: 100%;
    width: 100%;

    @media (min-width: $bp-1440) {
      gap: 41px;
      width: auto;
    }
  }

  &__cta {
    -webkit-backdrop-filter: blur(var(--blur-backdrop));
    backdrop-filter: blur(var(--blur-backdrop));
    background-color: var(--clr-primary);
    border: 1px solid var(--clr-border-light);
    border-radius: var(--radius-btn);
    color: var(--clr-text-inverse);
    display: inline-flex;
    font-size: var(--font-size-24);
    font-weight: var(--font-weight-bold);
    justify-content: center;
    letter-spacing: var(--track-btn);
    line-height: var(--leading-none);
    padding-block: clamp(18px, 1.56vw, var(--pad-btn-y));
    padding-inline: var(--pad-btn-x);
    text-decoration: none;
    text-transform: uppercase;
    transform: none;
    width: fit-content;

    @media (width > #{$bp-md}) {
      height: 80px;
      margin-top: 0;
    }

    @media (max-width: $bp-md) {
      box-sizing: border-box;
      font-size: var(--font-size-24);
      max-width: 100%;
      padding-inline: clamp(0.75rem, 3vw, 1.5rem);
    }

    @media (width <= #{$hero-mq-narrow}) {
      align-items: center;
      color: var(--clr-text-inverse);
      display: inline-flex;
      font-family: var(--font-manrope);
      font-size: 24px;
      font-style: normal;
      font-weight: var(--font-weight-bold);
      gap: 10px;
      justify-content: center;
      letter-spacing: 0.96px;
      line-height: 100%;
      padding: 25px 31px;
      text-align: center;
      text-transform: uppercase;

      /* stylelint-disable order/properties-alphabetical-order, property-no-unknown */
      font-feature-settings: 'liga' off, 'clig' off;
      leading-trim: both;
      text-edge: cap;
      /* stylelint-enable order/properties-alphabetical-order, property-no-unknown */
    }
  }

  &__brand {
    bottom: 40px;
    display: block;
    height: 17px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 125px;

    @media (max-width: $bp-md) {
      bottom: 24px;
      width: min(125px, 32vw);
    }

    @media (width <= #{$hero-mq-narrow}) {
      bottom: 11px;
      width: min(77px, 32vw);
    }
  }

  @media (width <= #{$hero-mq-narrow}) {
    &__content {
      align-items: center;
      padding-bottom: 84px;
      padding-top: 24px;
    }

    &__col--photo,
    &__col--text,
    &__media {
      display: contents;
    }

    &__label {
      margin: 0 0 4px;
      order: 1;
    }

    &__name {
      margin: 0 0 11px;
      max-width: 320px;
      order: 2;
    }

    &__meta {
      margin: 0 0 14px;
      max-width: 230px;
      order: 3;
    }

    &__experience {
      margin: 0 0 14px;
      order: 4;
    }

    &__photo-ring {
      height: 216px;
      margin: 0 0 36px;
      order: 5;
      width: 216px;
    }

    &__brand {
      bottom: 17px;
    }

    &__list {
      margin: 0 auto;
      max-width: 348px;
      order: 6;
      width: 100%;
    }

    &__cta {
      margin: 57px auto 0;
      order: 7;
      width: min(100%, 312px);
    }
  }

}
