:root {
  --top-height: 80vw;
}

.home {
  position: relative;

  section {
    padding: 2rem 1rem;
  }
}

.home_hero {
  position: relative;
  height: 80vw;
  background: url(/assets/home/bg_sm.webp) no-repeat center / cover;
  border-bottom: 2px solid black;
  img {
    width: 75%;
    position: absolute;
    top: 28vw;
    left: 50%;
    translate: -50%;
    filter: drop-shadow(-1px -1px 0.1rem rgb(255 255 255 / 0.8))
      drop-shadow(0 0.1rem 0.1rem rgb(0 0 0 / 0.8))
      drop-shadow(0.1rem 0.2rem 0.2rem rgb(0 0 0 / 0.8));
  }
}

.home_description {
  position: relative;
  background: url(/assets/home/des_c.webp) no-repeat center / cover;
  overflow: hidden;
  border-bottom: 2px solid var(--black);
  &::before,
  &::after {
    content: "";
    position: absolute;
    height: 50%;
  }
  &::before {
    background: url(/assets/home/des_l.webp) no-repeat top left / contain;
    width: 50%;
    top: -1rem;
    left: 0;
    filter: drop-shadow(0.1rem 0.2rem 0.2rem rgb(0 0 0 / 0.1));
  }
  &::after {
    background: url(/assets/home/des_r.webp) no-repeat bottom right / contain;
    bottom: -3.5rem;
    right: -6.5rem;
    width: 84vw;
    height: 100%;
    pointer-events: none;
    filter: drop-shadow(-0.1rem -0.2rem 0.2rem rgb(0 0 0 / 0.1));
  }

  > div {
    position: relative;
    padding: 1rem;
    background: rgb(255 255 255 / 0.8);
    backdrop-filter: blur(2px);
    border: 1px solid var(--black);
    border-radius: 0.25rem;
    box-shadow: 0 0.1rem 0.2rem -0.1rem rgb(0 0 0 / 0.4);
  }

  h1 {
    z-index: 1;
    font-size: 1rem;
    font-weight: normal;
    strong {
      font-size: 1.25rem;
      font-weight: bold;
      margin-right: 0.125rem;
      color: var(--red);
    }
  }
}

.home_pickup {
  h2 {
    margin-bottom: 1rem;
  }
}

.home_new,
.home_comments {
  &::after {
    content: "";
    display: block;
    clear: both;
  }

  h2 {
    writing-mode: vertical-rl;
    background: url(/assets/home/heading_bg.png) no-repeat top / 100% 100%;
    padding: 3rem 1.125rem 1.5rem 1.125rem;
    margin: 0;
    font-size: 1rem;
    height: 16rem;
    &::before,
    &::after {
      left: 50%;
      translate: -50%;
      height: 2rem;
    }
    &::before {
      background: url(/assets/home/heading_t.png) no-repeat center / contain;
      width: 115%;
      top: -0.75rem;
    }
    &::after {
      background: url(/assets/home/heading_b.png) no-repeat center / contain;
      width: 100%;
      bottom: -1rem;
      top: initial;
    }
  }

  strong,
  em {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

.home_new {
  h2 {
    float: left;
  }

  ul {
    padding-left: 5rem;
  }

  .questions a {
    min-height: 5.5rem;
  }
}

.home_comments {
  h2 {
    float: right;
  }

  ul {
    padding-right: 5rem;
  }

  a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    position: relative;
    padding-block: 0.75rem;
    border-bottom: 1px solid #ccc;
    z-index: 1;
    overflow: hidden;
  }

  dl {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }

  dt,
  dd span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  dt {
    font-weight: bold;
  }

  time {
    display: block;
    font-size: 0.875rem;
    opacity: 0.8;
  }

  span {
    display: block;
    font-size: 0.875rem;
    opacity: 0.8;
    margin-bottom: 0.5rem;
  }

  em {
    position: absolute;
    bottom: -2rem;
    right: -1rem;
    z-index: -1;
    font-size: 5rem;
    opacity: 0.3;
    rotate: 15deg;
    transition: translate 0.2s;
  }

  img {
    width: 1.5rem;
    height: 1.5rem;
    opacity: 0.8;
    filter: invert(1);
    transition: translate 0.2s;
  }

  a:hover {
    img {
      translate: 0.25rem;
    }

    em {
      translate: 0 -0.25rem;
    }
  }
}

@media (min-width: 744px) {
  .home {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-template-rows: 17rem 1fr;
    padding-top: 2.9rem;

    section {
      padding: 2rem;
    }
  }

  .home_hero {
    height: auto;
    background: url(/assets/home/bg_md.webp) no-repeat bottom center / 100%;
    grid-row: 1;
    grid-column: 1 / 8;

    img {
      width: 19.5rem;
      top: 3.5rem;
    }
  }

  .home_description {
    grid-row: 1;
    grid-column: 8 / 13;
    display: grid;
    place-items: center;
    border-top: none;
    border-left: 1px solid var(--black);
    &::after {
      width: 100%;
      bottom: -4rem;
      right: -7.5rem;
    }

    h1 {
      margin-bottom: 1rem;
    }

    > div {
      display: grid;
      place-content: center;
    }
  }

  .home {
    .home_new {
      padding-right: 1rem;
    }
    .home_comments {
      padding-left: 1rem;
    }
  }

  .home_pickup {
    grid-row: 2;
    grid-column: 1 / 13;

    h2 {
      width: calc(100% / 3);
      margin-inline: auto;
    }

    .questions {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0 2rem;

      a {
        height: 100%;
      }
    }
  }

  .home_new {
    grid-row: 3;
    grid-column: 1 / 7;
  }

  .home_comments {
    grid-row: 3;
    grid-column: 7 / 13;

    h2 {
      float: left;
    }

    ul {
      padding-inline: 5rem 0;
    }
  }
}

@media (min-width: 1024px) {
  .home {
    grid-template-rows: 27rem 1fr;
    gap: 2rem 0;
  }

  .home_hero {
    grid-column: 1 / 9;

    img {
      width: 32rem;
      top: 6rem;
    }
  }

  .home_description {
    grid-column: 9 / 13;

    > div {
      padding: 3rem 2rem;
      gap: 2rem;
    }

    h1,
    .button {
      writing-mode: vertical-rl;
    }

    h1 {
      grid-row: 1;
      grid-column: 2;
      margin: 0;
      line-height: 1.8;
      height: 15rem;
    }

    .button {
      grid-row: 1;
      grid-column: 1;
      padding: 2rem 1rem 4rem 1rem;
      background: conic-gradient(
        from -90deg at -5% center,
        #f9cc45,
        rgb(255, 132, 91),
        var(--red),
        #ff9054
      );
      &::after {
        top: initial;
        bottom: 1.5rem;
        right: initial;
        left: 50%;
        translate: -50%;
      }
    }
  }

  .home .home_pickup {
    padding-bottom: 0;

    .questions {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
}
