/* グリッド */
.burger {
  --side:20px;
  @media (width >= 1024px) {
    --side: calc( (100vw - 960px) / 2 );
  }
  display: grid;
  grid-template: auto 180px auto / 1fr auto;
  @media (width >= 768px) {
    grid-template: auto 180px / 100px 1fr auto;
  }


  gap: 30px 15px;
  margin-inline: var(--side);
  margin-block-end: 30px;
  font-family: "Noto Sans JP", sans-serif;

  /* テキストの継続部分をぼかす為に */
  @media (width < 768px) {
    &::after {
      grid-area: 2 / 1;
      justify-self: start;
      z-index: 1;
      width: 30px;
      content: "";
      background: linear-gradient(to right, #fff 0%, transparent 100%);
    }
  }
}

/* 大きい画像 */
.photo {
  grid-area: 1 / 1 / 1 / -1;
  margin-inline: calc(-1 * var(--side));

  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    max-height: 600px;
  }
}

/* タイトル */
.title {
  grid-area: 1 / 2 / 3 / 2;
  font-size: 35px;
  @media (width >= 768px) {
    grid-area: 1 / 3 / -1 / 3;
    font-size: 56px;
  }
  align-self: end;
  z-index: 1;
  padding-inline: 120px 40px;
  font-weight: 900;
  line-height: 1.3;
  writing-mode: vertical-rl;
}

/* 文章 */
.text {
  grid-area: 2 / 1;
  @media (width >= 768px) {
    grid-area: 2 / 2;
  }
  overflow-x: auto;
  min-width: 1px;

  justify-self: stretch;
  padding-inline-start: 30px;
  font-size: 12px;

  @media (width >= 768px) {
    /* 可変行高さ 22px - 30px */
    line-height: clamp(22px, 22px + 8 * (100vw - 768px) / 256, 30px);
    padding-inline-start: unset;
  }
  @media (width >= 1024px) {
    line-height: 2.5;
  }

  font-weight: 300;
  line-height: 1.85;
  writing-mode: vertical-rl;
  text-align: justify;
}

/* サブ情報 */
.sub {
  grid-area: 3 / 1 / 3 / -1;
  @media (width >= 768px) {
    grid-area: 2 / 1;
  }

  display: grid;
  grid-auto-flow: column;
  @media (width >= 768px) {
    grid-auto-flow: row;
  }
  column-gap: 10px;
  max-width: 280px;

  img {
    max-height: 100px;
  }

  p {
    margin: 0;
    @media (width >= 768px) {
      margin-block-start: 10px;
    }
    font-size: 10px;
    font-weight: 500;
    line-height: 1.5;
    text-align: justify;
  }
}
