/* Дополнения к референсным стилям: публичный сайт kumari-phases (без лоадера) */

.logo--text {
  text-decoration: none;
  display: inline-flex;
  align-items: baseline;
  gap: 0.15em;
  font-family: "Zen Maru Gothic", "Open Sans", sans-serif;
  font-size: 1.75rem;
  max-height: none;
  line-height: 1.1;
}

.logo__brand {
  color: #303a4d;
  font-weight: 700;
}

.logo__accent {
  color: #4f5987;
  font-weight: 700;
}

/* Как в референсе: img в шапке/подвале; в style.css у всех img pointer-events: none */
.header__logo img,
.footer__logo img {
  pointer-events: auto;
}

/* Размер как в Reference/website/css/style.css → .logo img { max-height: 96px; … } */
.header__logo img {
  display: block;
  height: auto;
  width: auto;
  max-height: 96px;
  object-fit: contain;
}

.footer__logo img {
  display: block;
  height: auto;
  width: auto;
  max-height: 120px;
  object-fit: contain;
}

/**
 * В style.css при min-width: 1100px меню центрируется через position:absolute + left:50%,
 * из-за этого блок наезжает на логотип. Восстанавливаем поток: лого слева, меню по центру
 * свободного места, «Войти» справа.
 */
@media (min-width: 1100px) {
  .header__container {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1.25rem;
  }

  .header__logo {
    flex: 0 0 auto;
    margin-inline-end: 0.75rem;
  }

  .header__navigation {
    position: static !important;
    left: auto !important;
    transform: none !important;
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    min-width: 0;
    justify-content: flex-end;
  }

  .header__navigation > .header__menu.menu,
  .header__navigation > .menu {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    justify-content: center;
  }

  .header__navigation > .header__menu.menu .menu__body,
  .header__navigation > .menu .menu__body {
    width: 100%;
    justify-content: space-evenly;
  }

  .header__navigation > .actions-header {
    flex: 0 0 auto;
  }

  /* Пункты меню равномерно занимают всё место между лого и кнопкой Войти */
  .menu__list {
    width: 100%;
    gap: 0;
    justify-content: space-evenly;
  }

  .menu__link {
    padding: 0 0.4rem;
  }
}

/* Полноэкранное меню <1100px: компактнее пункты (десктоп не трогаем) */
@media (max-width: 1099px) {
  .menu__body {
    row-gap: 2rem;
  }

  .menu__item:not(:last-child) {
    margin-bottom: 0.75rem;
  }

  .menu__link {
    font-size: 1.35rem;
  }
}

.header__login {
  font-family: "Zen Maru Gothic", "Open Sans", sans-serif;
  font-weight: 600;
  font-size: 1.1rem;
  color: #303a4d;
  text-decoration: none;
  padding: 0.5rem 1rem;
  border-radius: 30px;
  border: 2px solid #303a4d;
  transition: box-shadow 0.3s ease, color 0.2s ease;
  white-space: nowrap;
}

.header__login:hover,
.header__login.active {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  color: #A62A21;
  border-color: #A62A21;
}

/* Кнопка «Выйти» в шапке публичного сайта (та же разметка, что в ЛК) */
.lk-logout-form {
  display: inline;
  margin: 0;
  padding: 0;
}

.lk-logout-form .header__login {
  font: inherit;
  cursor: pointer;
  background: transparent;
}

.menu__link.active {
  color: #303a4d;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

/*
 * Полоса Moon под шапкой (layout-start / lk-layout-start).
 * Без width:100% на img — на десктопе высота росла как 0.8×ширины (5:4) и занимала экран.
 * max-height + object-fit:contain — компактная полоса (~в 3 раза ниже), картинка целиком, без обрезки.
 */
.public-hero-moon-band {
  width: 100%;
  margin-top: 5.75rem;
  margin-bottom: 2rem;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}

.public-hero-moon-band__img {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: clamp(110px, 17.5vw, 190px);
  object-fit: contain;
}

/* Три верхних проекта («Все проекты»): под лунной полосой */
.kp-home-upcoming {
  width: 100%;
  background-color: #fff;
}

.kp-home-upcoming__inner {
  padding-bottom: 0;
}

/* Шапка: заголовок слева, «все проекты» справа (шрифты как раньше на сайте) */
.kp-home-upcoming-heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1.5rem;
  margin-bottom: clamp(1.75rem, 4vw, 2.75rem);
}

.kp-home-upcoming-heading__title {
  margin: 0;
  font-family: "Zen Maru Gothic", "Open Sans", sans-serif;
  font-size: clamp(1.25rem, 2.8vw, 1.65rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #303a4d;
  line-height: 1.15;
}

.kp-home-upcoming-heading__all {
  font-family: "Zen Maru Gothic", "Open Sans", sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  text-decoration: none;
  color: #4f5987;
  border-bottom: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
  white-space: nowrap;
}

.kp-home-upcoming-heading__all-arrow {
  font-family: inherit;
  font-weight: 600;
}

.kp-home-upcoming-heading__all:hover,
.kp-home-upcoming-heading__all:hover .kp-home-upcoming-heading__all-arrow {
  color: #A62A21;
}

.kp-home-upcoming-heading__all:hover {
  border-bottom-color: rgba(166, 42, 33, 0.35);
}

.kp-home-upcoming__empty,
.kp-muted.kp-home-upcoming__empty {
  text-align: center;
  color: #4f5987;
}

/* Колоночная сетка: промежуток между колонками */
.kp-home-upcoming__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: clamp(1.75rem, 4vw, 2.75rem);
  row-gap: 0;
  margin: 0;
  padding: 0;
  align-items: start;
}

.kp-home-upcoming__grid:has(> .kp-home-upcoming__event-card:only-child) {
  grid-template-columns: 1fr;
  column-gap: 0;
}

.kp-home-upcoming__grid:has(> .kp-home-upcoming__event-card:nth-child(2):last-child) {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.kp-home-upcoming__event-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  box-sizing: border-box;
  min-height: 0;
  margin: 0;
  padding: 0;
  text-decoration: none;
  color: inherit;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.kp-home-upcoming__event-card:hover {
  background: transparent;
  box-shadow: none;
}

.kp-home-upcoming__event-inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  padding: 0 0 1.2rem;
  margin: 0;
  border: none;
}

/* Дата — как раньше */
.kp-home-upcoming__event-meta {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #4f5987;
  line-height: 1.35;
}

/* Заголовок карточки — как раньше */
.kp-home-upcoming__event-title {
  font-family: "Zen Maru Gothic", "Open Sans", sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: #303a4d;
  line-height: 1.3;
}

.kp-home-upcoming__event-arrow {
  margin-top: -0.05rem;
  font-family: "Open Sans", system-ui, sans-serif;
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1;
  color: #4f5987;
  transition: color 0.2s ease;
}

.kp-home-upcoming__event-card:hover .kp-home-upcoming__event-arrow {
  color: #A62A21;
}

.kp-home-upcoming__event-excerpt {
  margin-top: 0.25rem;
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 400;
  line-height: 1.45;
  color: rgb(172, 170, 170);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 900px) {
  .kp-home-upcoming__grid {
    grid-template-columns: 1fr;
    column-gap: 0;
    row-gap: 0;
  }

  .kp-home-upcoming__event-card:not(:first-child) .kp-home-upcoming__event-inner {
    padding-top: 1.5rem;
  }
}

/* Нейтрально, как полоски .icon-menu (style.css → background-color: #000) */
.kp-home-upcoming__divider {
  margin-top: 3rem;
  margin-bottom: 3rem;
  height: 0.1875rem;
  border-radius: 1px;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.14) 18%,
    rgba(0, 0, 0, 0.26) 50%,
    rgba(0, 0, 0, 0.14) 82%,
    rgba(0, 0, 0, 0) 100%
  );
}

/*
 * Баннер «Главная»: рабочая ширина; слева фото Aleona, справа текст из админки.
 */
.kp-home-banner-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
  width: 100%;
  box-sizing: border-box;
}

.kp-home-banner-row__media {
  align-self: start;
  display: flex;
  align-items: flex-start;
}

.kp-home-banner-row__img {
  display: block;
  width: 320px;
  max-width: 100%;
  height: auto;
}

.kp-home-banner-row__text {
  align-self: stretch;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  text-align: left;
  overflow-wrap: break-word;
  word-break: break-word;
  padding-block: clamp(0.75rem, 2vw, 1.25rem);
}

@media (max-width: 47.999rem) {
  .kp-home-banner-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 1rem;
  }

  .kp-home-banner-row__media {
    justify-content: center;
  }

  .kp-home-banner-row__text {
    padding-block: 0 0.25rem;
  }
}

.kp-home-banner__empty-hint {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.45;
  font-style: italic;
  color: #4f5987;
  text-shadow: none;
  overflow-wrap: anywhere;
}

.kp-prose--home-banner {
  max-width: 100%;
  margin: 0;
  font-size: clamp(1rem, 2.35vw, 1.125rem);
  line-height: 1.52;
  color: #232834;
  text-shadow: none;
  overflow-wrap: anywhere;
}

.kp-prose--home-banner p {
  margin: 0 0 0.6em 0;
}

.kp-prose--home-banner p:last-child {
  margin-bottom: 0;
}

.kp-prose--home-banner a {
  color: #1f4faa;
  text-decoration: underline;
}

.kp-prose--home-banner a:hover {
  color: #163a82;
}

.page__main.main.main_tours.main--kumari-home {
  background-color: #fff;
}

/* Отступ под шапку даёт .public-hero-moon-band — не дублировать в секции */
.main_tours {
  padding-top: 0;
}

@media (max-width: 47.999rem) {
  .main_tours {
    padding-top: 0;
  }
}

/* Раньше заголовок сидел на полноэкранном Moon (белый текст); фон секции теперь белый */
.page__main.main_pages .main__title,
.page__main.main_pages .main__text,
.page__main.main_pages .main__text_pages {
  color: #303a4d;
}

.main_pages .main__container_pages {
  padding-top: 2rem;
}

/* Ref. style.css: .page__main { padding-bottom: 160px } — для компактных списков (проекты, фазы, …) слишком много «воздуха» до блока .guides */
.page__main.main.main_about.main_pages {
  padding-bottom: clamp(1.25rem, 4vw, 2rem);
}

/* Сразу после такого hero — меньше верхний отступ у .guides__container (было 4rem) */
.page__main.main_pages + .page__guides.guides .guides__container {
  padding-top: 1.5rem;
}

/* Раньше min-height под полноэкранный Moon; с полосой hero не нужен */
.page__main.main.main_pages {
  min-height: auto !important;
}

main.page {
  background-color: #fff;
}

audio {
  pointer-events: auto;
  width: 100%;
  max-width: 36rem;
}

/* ---------- Главная: карусель фаз (референс «панель машин»: фото слева, текст справа) ---------- */

/* Полоса карусели на всю ширину блока главной (как рейка в референсе) */
.kp-phases-carousel {
  width: 100%;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
  padding: 0 0 2rem;
  box-sizing: border-box;
}

.kp-phases-carousel__viewport {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.kp-phases-carousel__track {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 0.75rem;
  position: relative;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .kp-phases-carousel__track {
    transition-duration: 0.001ms !important;
  }
}

.kp-phase-card {
  flex: 0 0 auto;
  flex-shrink: 0;
  /* Не даём строке карусели «втиснуть» карты в один ряд без переполнения — иначе maxScroll=0 и пропадает прокрутка. */
  min-width: auto;
  display: flex;
  flex-direction: column;
  background: linear-gradient(
    138deg,
    rgba(239, 242, 248, 0.95) 0%,
    rgba(229, 234, 244, 0.98) 45%,
    rgba(247, 248, 251, 1) 100%
  );
  border: 1px solid rgba(79, 89, 135, 0.18);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 14px rgba(48, 58, 77, 0.08);
}

@media (min-width: 700px) {
  /* Горизонтальная лента карточек: gap + шаг по одной; справа «нависает» следующая карточка (реф. Toyota). */
  .kp-phases-carousel__track {
    gap: calc(0.75rem * 1.5 * 0.85);
  }

  /*
   Карточка −15%; колонка текста шире на 20% к прежнему 3fr (4fr : 3.6fr ≈ как 10fr : 9fr).
   Равная высота блоков фото и текста как раньше.
  */
  .kp-phase-card {
    display: grid;
    grid-template-columns: 4fr 3.6fr;
    grid-template-rows: minmax(0, 1fr);
    align-items: stretch;
    column-gap: 0;
    width: min(
      calc((39.75rem * 7 / 6) * 0.85),
      94vw
    );
    height: clamp(18.80625rem, 31.875vw, 21.675rem);
    border-radius: calc(15px * 0.85);
    box-sizing: border-box;
    box-shadow: 0 calc(3px * 0.85) calc(21px * 0.85) rgba(48, 58, 77, 0.08);
  }

  .kp-phase-card__media {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    min-height: 0;
    align-self: stretch;
    overflow: hidden;
    position: relative;
    background-color: #f0f2f5;
  }

  .kp-phase-card__body {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    min-height: 0;
    height: auto;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: calc(1.5rem * 0.85) calc(1.5rem * 0.85) calc(1.35rem * 0.85)
      calc(1.5rem * 0.85);
    background: linear-gradient(
      180deg,
      rgba(232, 234, 226, 0.92) 0%,
      rgba(240, 242, 236, 0.98) 100%
    );
  }

  .kp-phase-card__title {
    flex-shrink: 0;
  }

  .kp-phase-card__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    display: block;
    object-fit: cover;
    object-position: center;
  }

  .kp-phase-card__img--placeholder {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    border-radius: 0;
    background: linear-gradient(145deg, #dfe4ef 0%, #f4f6fa 100%);
  }
}

.kp-phase-card__media {
  min-width: 0;
  display: block;
  overflow: hidden;
  position: relative;
}

@media (max-width: 699.98px) {
  /*
   Картинка целиком, без crop (desktop-колонка использует cover в фикс. ячейке — на мобиле ячейка по контенту).
  */
  .kp-phase-card__media {
    flex-basis: auto;
    width: 100%;
    display: block;
    position: relative;
    overflow: hidden;
    background-color: #f0f2f5;
  }

  .kp-phase-card__media img.kp-phase-card__img {
    display: block;
    margin: 0 auto;
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: min(72vh, 520px);
    object-fit: contain;
    object-position: center top;
  }

  .kp-phase-card__media .kp-phase-card__img--placeholder.kp-phase-card__img {
    position: static;
    width: 100%;
    max-width: 100%;
    aspect-ratio: 16 / 10;
    min-height: 9rem;
    margin: 0;
    border-radius: 0;
    background: linear-gradient(145deg, #dfe4ef 0%, #f4f6fa 100%);
  }
}


.kp-phase-card__body {
  box-sizing: border-box;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background: rgba(255, 255, 255, 0.55);
}

@media (max-width: 699.98px) {
  .kp-phase-card__body {
    padding: 1.25rem 1.1rem 1.2rem;
  }
}

.kp-phase-card__title {
  margin: 0 0 0.5rem 0;
  font-family: "Zen Maru Gothic", "Open Sans", sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.25;
  color: #303a4d;
}

@media (min-width: 700px) {
  .kp-phase-card__title {
    font-size: calc(1.53rem * 0.85);
    margin-bottom: calc(0.75rem * 0.85);
  }
}

.kp-phase-card__title a {
  color: inherit;
  text-decoration: none;
}

.kp-phase-card__title a:hover {
  color: #A62A21;
}

.kp-prose--phase-carousel {
  margin: 0 0 0.65rem 0;
  font-size: 0.875rem;
  line-height: 1.48;
  min-height: 0;
}

@media (min-width: 700px) {
  /* Прокрутка анонса внутри правой колонки (не line-clamp). */
  .kp-prose--phase-carousel {
    flex: 1 1 auto;
    min-height: 0;
    margin-bottom: calc(0.45rem * 1.5 * 0.85);
    font-size: calc(0.875rem * 1.5 * 0.85);
    line-height: 1.48;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    display: block;
    max-height: none;
  }

  .kp-phase-card__cta.button {
    flex-shrink: 0;
    padding: calc(0.75rem * 1.5 * 0.85) calc(1.5rem * 1.5 * 0.85);
  }
}

@media (max-width: 699.98px) {
  .kp-prose--phase-carousel {
    flex: 1 1 auto;
    max-height: 9.5rem;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}

.kp-phase-card__cta.button {
  margin-top: auto;
  align-self: flex-start;
  border-radius: 999px;
  padding-left: 1.35rem;
  padding-right: 1.35rem;
}

.kp-phase-card__muted {
  margin: 0 0 1rem;
}

.kp-phase-card:focus-within {
  box-shadow: 0 8px 24px rgba(48, 58, 77, 0.12);
  border-color: rgba(79, 89, 135, 0.28);
}

.kp-phases-carousel__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}

.kp-phases-carousel__counter {
  min-width: 9rem;
  text-align: center;
  font-size: 0.95rem;
  font-weight: 600;
  color: #303a4d;
}

.kp-phases-carousel__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 2rem;
  padding: 0;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
  color: inherit;
}

.kp-phases-carousel__btn span {
  position: relative;
  top: -1px;
}

.kp-phases-carousel__btn:disabled {
  opacity: 0.35;
  cursor: default;
}

.kp-phases-carousel__btn--prev {
  background: #e8eaee;
  color: #303a4d;
}

.kp-phases-carousel__btn--prev:hover:not(:disabled) {
  background: #dfe2e9;
}

.kp-phases-carousel__btn--next {
  background: #303a4d;
  color: #fff;
}

.kp-phases-carousel__btn--next:hover:not(:disabled) {
  background: #252d3c;
}

.kp-prose {
  font-size: 1.05rem;
  line-height: 1.65;
  color: #303a4d;
}

.kp-prose--lectures {
  margin-top: 0.65rem;
}

.kp-prose img {
  max-width: 100%;
  height: auto;
}

/* Размер шрифта из редактора Quill (классы span) */
.kp-prose .ql-size-small {
  font-size: 0.85em;
}
.kp-prose .ql-size-large {
  font-size: 1.35em;
}
.kp-prose .ql-size-huge {
  font-size: 1.85em;
}

.kp-muted {
  color: #808793;
  font-size: 0.95rem;
}

.kp-card-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.kp-card {
  background: #fff;
  border-radius: 4px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  padding: 1.25rem 1.5rem;
  transition: box-shadow 0.3s;
}

.kp-card:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.kp-card__title {
  margin: 0 0 0.5rem 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: #3f4974;
}

.kp-card__title a {
  color: inherit;
  text-decoration: none;
}

.kp-card__title a:hover {
  color: #A62A21;
}

.kp-badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #4f5987;
  margin-bottom: 0.35rem;
}

/* Страница «Все проекты» */
.kp-project-card-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.kp-project-card {
  display: grid;
  grid-template-columns: minmax(9rem, 32%) minmax(0, 1fr);
  align-items: stretch;
  gap: 0;
  background: #fff;
  border-radius: 10px;
  border: 1px solid rgba(79, 89, 135, 0.15);
  box-shadow: 0 2px 14px rgba(48, 58, 77, 0.08);
  overflow: hidden;
}

.kp-project-card__media {
  display: block;
  position: relative;
  min-height: 10rem;
  background: #e8eaee;
}

.kp-project-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  margin: 0;
}

.kp-project-card__img--placeholder {
  position: absolute;
  inset: 0;
  background: linear-gradient(145deg, #dfe4ef 0%, #f4f6fa 100%);
}

.kp-project-card__body {
  padding: 1.15rem 1.35rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
}

.kp-project-card__meta {
  margin: 0 0 0.35rem 0;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #4f5987;
}

.kp-project-card__title {
  margin: 0 0 0.5rem 0;
  font-family: "Zen Maru Gothic", "Open Sans", sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.28;
}

.kp-project-card__title a {
  color: #303a4d;
  text-decoration: none;
}

.kp-project-card__title a:hover {
  color: #A62A21;
}

.kp-prose--project-card {
  margin: 0 0 0.85rem 0;
  font-size: 0.92rem;
  line-height: 1.52;
  color: #454e5e;
}

.kp-project-card__cta.button {
  margin-top: auto;
}

@media (max-width: 639.98px) {
  .kp-project-card {
    grid-template-columns: 1fr;
  }

  .kp-project-card__media {
    min-height: 11rem;
    max-height: 14rem;
  }
}

.kp-project-detail__schedule {
  margin: -0.25rem 0 0.85rem;
  font-size: 1rem;
  color: #4f5987;
  font-weight: 600;
}

.kp-review__author {
  font-weight: 600;
  color: #2c3544;
  margin-bottom: 0.35rem;
}

@media (max-width: 991px) {
  .header__login {
    font-size: 1rem;
    padding: 0.45rem 0.85rem;
  }
}
