/* =====================================================================
   publications-section — full-bleed, stable grid layout
   Подпись (label), две обложки (стопкой/рядом), текст справа.
===================================================================== */

.publications {
  position: relative;
  width: 100vw;
  margin: 0;
  padding: 0;
  background: #fff;
  overflow: hidden;
}

.publications__grid {
  position: relative;
  width: 100%;
  min-height: calc(100vh - var(--header-h, 100px));
  box-sizing: border-box;
  padding: clamp(40px, 8vh, 96px) clamp(24px, 5.7vw, 82px);

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-areas:
    "label   label"
    "media   copy";
  grid-template-rows: auto 1fr;
  column-gap: clamp(24px, 5vw, 80px);
  row-gap: clamp(24px, 6vh, 60px);
  align-items: center;
}

/* ----- Label (top-left) ----- */
.publications__label {
  grid-area: label;
  align-self: start;
  justify-self: start;

  font-family: Inter, system-ui, sans-serif;
  font-weight: 200;
  font-size: 10px;
  line-height: 1.2;
  letter-spacing: .04em;
  text-transform: capitalize;
  color: #000;
}

/* ----- Media: 2 magazine covers ----- */
.publications__media {
  grid-area: media;
  align-self: center;
  justify-self: end;
  width: 100%;
  max-width: 360px;
}

.publications__stack {
  position: relative;
  width: 100%;
  /* Высота за счёт обложек, без абсолютов */
  display: grid;
  grid-template-columns: 1fr;
}

.publications__cover {
  margin: 0;
  display: block;
  background: #f4f4f4;
}

.publications__img {
  display: block;
  width: 100%;
  height: auto;
}

/* На десктопе кладём обложки слегка внахлёст через grid+overlap */
@media (min-width: 992px) {
  .publications__stack {
    grid-template-columns: 1fr 1fr;
    align-items: end;
  }
  .publications__cover--back {
    grid-column: 2;
    grid-row: 1;
    transform: translate(-18%, -10%);
    width: 110%;
    z-index: 1;
  }
  .publications__cover--front {
    grid-column: 1;
    grid-row: 1;
    transform: translate(18%, 10%);
    width: 110%;
    z-index: 2;
  }
  /* Если только одна обложка — без сдвига */
  .publications__stack > .publications__cover:only-child {
    grid-column: 1 / -1;
    transform: none;
    width: 80%;
    margin: 0 auto;
  }
}

/* ----- Copy block ----- */
.publications__copy {
  grid-area: copy;
  align-self: center;
  justify-self: start;
  max-width: 360px;
  width: 100%;

  font-family: Inter, system-ui, sans-serif;
  font-size: 10px;
  line-height: 1.8;
  color: #595959;
  letter-spacing: 0.15px;
}

.publications__title {
  margin: 0 0 14px;
  font-size: 10px;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: .04em;
}

.publications__text p { margin: 0 0 1em; }
.publications__text p:last-child { margin-bottom: 0; }

.publications__more {
  display: inline-block;
  margin-top: 14px;
  font-size: 8px;
  font-weight: 500;
  letter-spacing: .04em;
  color: #c6c6c6;
  text-decoration: none;
}
.publications__more:hover { text-decoration: underline; }

/* ----- Цвет текста ----- */
.publications.is-text-light .publications__label { color: #ffffff; }
.publications.is-text-light .publications__copy  { color: #b8b8b8; }
.publications.is-text-light .publications__title { color: #ffffff; }
.publications.is-text-light .publications__more  { color: #ffffff; }

.publications.is-text-dark .publications__label  { color: #000000; }
.publications.is-text-dark .publications__copy   { color: #595959; }
.publications.is-text-dark .publications__title  { color: #000000; }

/* ===== MOBILE ===== */
@media (max-width: 991px) {
  .publications__grid {
    min-height: calc(100vh - var(--header-h, 70px));
    padding: clamp(24px, 6vh, 48px) clamp(16px, 5vw, 30px);
    grid-template-columns: 1fr;
    grid-template-areas:
      "label"
      "media"
      "copy";
    grid-template-rows: auto auto auto;
    row-gap: clamp(20px, 4vh, 36px);
  }

  .publications__media {
    justify-self: stretch;
    max-width: 100%;
  }

  .publications__stack {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .publications__cover {
    flex: 0 0 85%;
    max-width: 85%;
    scroll-snap-align: start;
    transform: none;
    width: auto;
  }

  .publications__copy {
    max-width: 100%;
    justify-self: stretch;
  }

  .publications__more--mobile-hidden { display: none; }
}
