/* ============================================================
   Модальное окно «Спасибо за регистрацию»
   ============================================================ */

.modal {
  align-items: center;
  display: flex;
  inset: 0;
  justify-content: center;
  opacity: 0;
  position: fixed;
  transition: visibility var(--transition-base), opacity var(--transition-base);
  visibility: hidden;
  z-index: var(--z-modal);

  &--open {
    opacity: 1;
    visibility: visible;
  }

  &__overlay {
    background-color: var(--clr-overlay);
    inset: 0;
    position: absolute;
  }

  &__content {
    position: relative;
    transform: scale(0.96) translateY(12px);
    transition: transform var(--transition-base);
    width: min(92vw, 720px);
    z-index: 1;

    .modal--open & {
      transform: scale(1) translateY(0);
    }
  }

  &__content--thank-you {
    background-color: var(--clr-white);
    border: none;
    box-shadow: 0 20px 60px rgba(30, 30, 30, 0.12);
    box-sizing: border-box;
    max-height: min(1080px, calc(100dvh - 32px));
    max-width: min(94vw, 960px);
    overflow-x: hidden;
    overflow-y: auto;
    padding: 0;
    transform: none;
    transition: none;
    width: min(94vw, 960px);

    .modal--open & {
      transform: none;
    }

    @media (width <= 860px) {
      box-shadow: 0 12px 40px rgba(30, 30, 30, 0.1);
      max-width: min(100%, 402px);
      width: min(92vw, 402px);
    }

    @media (min-width: $bp-1440) {
      border-radius: 0;
      height: 100vh;
      max-height: 100vh;
      max-width: 100vw;
      width: 100vw;

      .modal__thank-panel {
        min-height: 100vh;
        width: 100%;
      }
    }
  }

  &__close {
    align-items: center;
    background-color: transparent;
    border: none;
    border-radius: var(--radius-md);
    color: var(--clr-primary);
    cursor: pointer;
    display: flex;
    height: 40px;
    justify-content: center;
    position: absolute;
    right: clamp(0.75rem, 2vw, 1.25rem);
    top: clamp(0.75rem, 2vw, 1.25rem);
    transition: background-color var(--transition-base), color var(--transition-base);
    width: 40px;
    z-index: 5;

    &:hover {
      background-color: rgba(2, 168, 168, 0.08);
      color: var(--clr-text-primary);
    }
  }

  &__thank-panel {
    --thank-decor-size-tl: clamp(88px, 22vw, 460.87px);
    --thank-decor-size-br: clamp(88px, 23vw, 460.87px);
    overflow: clip visible;
    padding-bottom: 40px;
    padding-top: 85px;
    position: relative;
    background-image:
      image-set(
        url("/images/fermenkol/thaks-booble-top.avif") type("image/avif"),
        url("/images/fermenkol/thaks-booble-top.webp") type("image/webp"),
        url("/images/fermenkol/thaks-booble-top.png") type("image/png")
      ),
      image-set(
        url("/images/fermenkol/thaks-booble-bottom.avif") type("image/avif"),
        url("/images/fermenkol/thaks-booble-bottom.webp") type("image/webp"),
        url("/images/fermenkol/thaks-booble-bottom.png") type("image/png")
      );
    background-position: left -155px top -235px, right -214px bottom -276px;
    background-repeat: no-repeat;
    background-size: 524px, 574px auto;
  }

  &__content--thank-you &__thank-panel {
    margin-top: 8px;
  }

  &__decor {
    contain: layout paint;
    overflow: visible;
    pointer-events: none;
    position: absolute;
    user-select: none;
    z-index: 0;
  }

  &__decor-img {
    display: block;
    height: auto;
  }

  &__decor--tl {
    left: -106px;
    top: -267px;
    width: clamp(88px, 22vw, 460.87px);
    transform: rotate(371deg) translate(0%, 0%);
  }

  &__decor--tl .modal__decor-img {
    height: 100%;
    left: 0;
    max-width: none;
    object-fit: contain;
    object-position: 0 0;
    top: 0;
    transform: unset;
    width: 100%;
  }

  &__decor--br {
    bottom: -130px;
    right: -140px;
    width: clamp(88px, 23vw, 460.87px);
    transform: rotate(343deg) translate(0%, 0%);
  }

  &__decor--br .modal__decor-img {
    height: 100%;
    left: 0;
    max-width: none;
    object-fit: contain;
    object-position: 0 0;
    top: 0;
    transform: unset;
    width: 100%;
  }

  &__thank-inner {
    --content-width: 850px;
    font-family: var(--font-manrope);
    margin: 0 auto;
    max-width: var(--content-width);
    padding: 0 0 15px;
    position: relative;
    text-align: center;
    z-index: 2;
  }

  &__badge-wrap {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    margin: 0;
    margin-top: 0;
    min-height: 97px;
    padding: 0;
    position: relative;
    width: 100%;
    z-index: 2;
  }

  &__badge-bar {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    margin: 0 auto;
    max-width: 826px;
    min-height: 76px;
    padding: 0;
    width: 826px;
  }

  &__badge-text {
    color: var(--clr-text-inverse);
    display: inline-flex;
    font-size: 59px;
    font-weight: var(--font-weight-semibold);
    justify-content: center;
    letter-spacing: -1.475px;
    line-height: 1;
    margin: 0;
    margin-left: 12px;
    min-height: 76px;
    padding: 0 24px;
    position: relative;
    text-align: center;
    z-index: 1;

    &::before {
      background-color: var(--clr-primary);
      content: "";
      height: 100%;
      left: 0;
      position: absolute;
      top: 0;
      transform: rotate(1.48deg);
      width: 100%;
      z-index: -1;
    }

    @media (min-width: $bp-1440) {
      margin-left: 1px;

      &::before {
        height: 76px;
        transform: translate(-28px, -6px) rotate(1.48deg);
        width: 825px;
      }
    }

    @media (width <= 860px) {
      min-height: clamp(44px, 8vw, 60px);
      margin-left: 0;
      padding: 0 clamp(10px, 2.8vw, 18px);

      &::before {
        height: 100%;
        transform: rotate(1.48deg);
        width: 100%;
      }
    }
  }

  &__headline {
    color: var(--clr-text-primary);
    font-size: 48px;
    font-weight: var(--font-weight-semibold);
    letter-spacing: -1.2px;
    line-height: 1;
    margin: 0 auto 29px;
    max-width: 850px;
    width: 100%;
    white-space: nowrap;
    text-transform: uppercase;

    @media (min-width: $bp-1440) {
      margin-left: -7px;
    }

    @media (width <= 860px) {
      margin-left: 0;
    }
  }

  &__headline-line {
    display: inline-block;
    margin-left: 18px;
  }

  &__lead {
    color: var(--clr-text-primary);
    font-size: 24px;
    font-weight: var(--font-weight-regular);
    line-height: 1;
    margin: 0 auto 16px;
    max-width: 770px;
  }

  &__rule {
    border: 0;
    border-top: 1px solid var(--clr-primary);
    box-sizing: border-box;
    margin: 0;
    max-width: none;
    opacity: 1;
    width: 100%;
  }

  &__gift-block {
    margin: 26px auto 0;
    max-width: 770px;
    padding-left: 11px;
  }

  &__gift-chip-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 14px;
  }

  &__gift-chip {
    box-sizing: border-box;
    color: #fff;
    font-feature-settings: "liga" off, "clig" off;
    font-family: var(--font-manrope);
    font-size: 28px;
    font-style: normal;
    font-weight: 600;
    leading-trim: both;
    line-height: 1;
    margin: 0;
    margin-left: 2px;
    max-width: 100%;
    padding: 0.35em 0.9em 0.4em;
    position: relative;
    text-align: center;
    text-edge: cap;
    text-transform: uppercase;
    width: fit-content;
    z-index: 1;

    &::before {
      background-color: var(--clr-primary);
      content: "";
      height: 33px;
      position: absolute;
      transform: translate(-12px, -2px) rotate(1.3deg);
      width: 232px;
      z-index: -1;
    }

    @media (width <= 860px) {
      &::before {
        width: calc(100% + 12px);
      }
    }
  }

  &__gift-copy {
    color: var(--clr-text-primary);
    font-size: 28px;
    line-height: 28px;
    margin: 0;
    text-align: center;
  }

  &__gift-line {
    display: inline;
  }

  &__gift-line--semi {
    font-weight: var(--font-weight-semibold);
  }

  &__gift-line--reg {
    font-weight: var(--font-weight-regular);
  }

  &__gift-btn {
    -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: 50px;
    box-sizing: border-box;
    color: var(--clr-text-inverse);
    display: inline-flex;
    font-size: 24px;
    font-weight: var(--font-weight-bold);
    justify-content: center;
    letter-spacing: var(--track-btn);
    line-height: 1;
    margin: 37px 0 34px;
    min-width: 332px;
    padding: 27px 21px;
    text-decoration: none;
    text-transform: uppercase;
    transition: opacity var(--transition-base);
    transform: translate(6px, 0);

    &:hover {
      opacity: 0.92;
    }
  }

  &__schedule {
    align-items: baseline;
    color: var(--clr-text-primary);
    display: flex;
    flex-wrap: wrap;
    font-size: 28px;
    font-weight: var(--font-weight-semibold);
    gap: 8px 24px;
    justify-content: space-between;
    line-height: 28px;
    margin: 0 auto 11px;
    max-width: 836px;
    text-align: center;
  }

  &__schedule-note {
    flex: 1 1 auto;
    margin: 0 auto 11px;
    max-width: 839px;
    text-align: left;
  }

  &__schedule-note-strong {
    font-weight: var(--font-weight-semibold);
  }

  &__schedule-note-light {
    font-weight: var(--font-weight-regular);
  }

  &__schedule-time {
    flex: 1 1 auto;
    font-weight: var(--font-weight-semibold);
    margin-right: -9px;
    text-align: right;
  }

  &__schedule-time-main {
    font-size: 28px;
    font-weight: var(--font-weight-semibold);
  }

  &__schedule-time-tz {
    font-size: 20px;
    font-weight: var(--font-weight-semibold);
  }

  &__social-text {
    color: var(--clr-text-primary);
    font-size: 24px;
    font-weight: var(--font-weight-regular);
    line-height: 1;
    margin: 36px auto 18px;
    max-width: 850px;
  }

  &__social-row {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 17px;
    justify-content: center;
    margin-left: 8px;
    margin-bottom: 66px;
  }

  &__social-icon {
    align-items: center;
    color: var(--clr-primary);
    display: inline-flex;
    justify-content: center;
    line-height: 0;
    text-decoration: none;
    transition: opacity var(--transition-base), transform var(--transition-base);

    &:hover {
      opacity: 0.85;
      transform: translateY(-1px);
    }
  }

  &__social-svg {
    display: block;
    height: 42px;
    max-width: 100%;
  }

  &__footer-brand {
    display: block;
    height: auto;
    margin: 0 auto;
    max-width: 131px;
    padding-left: 6px;
  }
}

/* На мобильных экранах расписание складывается в одну колонку. */
.modal--thank-you {
  .modal__decor {
    display: none;
  }

  @media (width <= 1439px) {
    .modal__content--thank-you {
      max-width: min(95vw, 920px);
      width: min(95vw, 920px);
    }

    .modal__thank-inner {
      max-width: 820px;
    }

    .modal__badge-bar {
      max-width: 790px;
      width: 790px;
    }

    .modal__headline {
      font-size: 44px;
    }

    .modal__lead,
    .modal__social-text {
      font-size: 22px;
    }
  }

  @media (width <= 1400px) {
    .modal__content--thank-you {
      max-width: min(95vw, 860px);
      width: min(95vw, 860px);
    }

    .modal__thank-inner {
      max-width: 770px;
    }

    .modal__badge-bar {
      max-width: 740px;
      width: 740px;
    }

    .modal__headline {
      font-size: 40px;
    }

    .modal__lead,
    .modal__social-text {
      font-size: 21px;
    }
  }

  @media (width <= 1200px) {
    .modal__content--thank-you {
      max-width: min(95vw, 800px);
      width: min(95vw, 800px);
    }

    .modal__thank-inner {
      max-width: 720px;
    }

    .modal__badge-bar {
      max-width: 690px;
      width: 690px;
    }

    .modal__headline {
      font-size: 36px;
    }

    .modal__lead,
    .modal__social-text {
      font-size: 20px;
    }
  }

  @media (width <= 992px) {
    .modal__content--thank-you {
      max-width: min(94vw, 740px);
      width: min(94vw, 740px);
    }

    .modal__thank-inner {
      max-width: 660px;
    }

    .modal__badge-bar {
      max-width: 640px;
      width: 640px;
    }

    .modal__headline {
      font-size: 32px;
    }

    .modal__lead,
    .modal__social-text {
      font-size: 18px;
    }
  }

  @media (width <= 860px) {
    .modal__content--thank-you {
      border-radius: 0;
      height: min(100dvh, 1080px);
      max-height: 1080px;
      max-width: 100vw;
      width: 100vw;
    }

    .modal__thank-panel {
      --thank-decor-size-tl: clamp(88px, 22vw, 460.87px);
      --thank-decor-size-br: clamp(88px, 23vw, 460.87px);
      background-image: url("/images/fermenkol/thaks-booble-top.png"), url("/images/fermenkol/thaks-booble-bottom.png");
      background-position: left -155px top -235px, right -214px bottom -276px;
      background-repeat: no-repeat;
      background-size: 524px, 574px auto;
      min-height: 100%;
      overflow: clip visible;
      padding-bottom: 40px;
      padding-top: 85px;
      position: relative;
    }

    .modal__thank-inner {
      max-width: 100%;
      padding: 56px 16px 0;
    }

    .modal__headline {
      font-size: clamp(1.25rem, 4vw, var(--font-size-48));
      letter-spacing: var(--track-title-48);
      margin-bottom: var(--space-lg);
      max-width: 100%;
      white-space: normal;
    }

    .modal__lead,
    .modal__gift-block,
    .modal__schedule,
    .modal__social-text {
      max-width: 100%;
    }

    .modal__badge-bar {
      max-width: 100%;
      min-height: 48px;
      width: 100%;
    }

    .modal__badge-text {
      font-size: clamp(1.25rem, 3.5vw, var(--font-size-6xl));
      letter-spacing: var(--track-title-59);
      min-height: 48px;
    }

    .modal__gift-chip {
      font-size: clamp(1.125rem, 2.8vw, var(--font-size-28));
      letter-spacing: var(--track-28);
    }

    .modal__gift-copy {
      font-size: clamp(1.125rem, 2.8vw, var(--font-size-28));
      line-height: var(--font-size-28);
    }

    .modal__gift-btn {
      font-size: clamp(1rem, 2.5vw, var(--font-size-24));
      margin-bottom: var(--space-2xl);
      min-width: min(100%, 331px);
      padding: var(--pad-btn-y) var(--pad-btn-x);
    }

    .modal__schedule {
      flex-direction: column;
      font-size: clamp(1rem, 2.5vw, var(--font-size-28));
      gap: 14px;
      text-align: center;
    }

    .modal__schedule-note,
    .modal__schedule-time {
      flex: none;
      text-align: center;
    }

    .modal__schedule-time {
      margin-top: 4px;
      margin-right: 0;
      width: 100%;
    }
    
    .modal__social-text {
      font-size: clamp(1rem, 2.5vw, var(--font-size-24));
    }

    .modal__social-row {
      margin-bottom: 8px;
    }

    .modal__footer-brand {
      margin: 0 auto 10px;
      padding-left: 0;
    }
  }

  @media (width <= 850px) {
    .modal__badge-bar,
    .modal__badge-text {
      min-height: 42px;
    }

    .modal__badge-text::before {
      height: 42px;
    }
  }
}

body.modal-open {
  overflow: hidden;
}
