@import url(lower.css);

.top {
  padding-inline: 0;
  width: min(90%, 1000px);
  margin-inline: auto;
  h2 {
    margin-bottom: max(3vw, 1em);
    span {
      word-break: keep-all;
    }
  }
  .contents {
    display: flex;
    gap: 5vw;
    align-items: center;
  }
  .body {
    flex: 1;
    line-height: 2;
  }
  .img-box {
    width: 50%;
    border-radius: 1em;
    overflow: hidden;
    img {
      width: 100%;
      aspect-ratio: 7/5;
      object-fit: cover;
    }
  }
  ~ section {
    padding-top: 0;
  }
}

.case,
.first {
  padding-inline: 0;
  width: min(90%, 1000px);
  margin-inline: auto;
  h2 {
    margin-bottom: max(3vw, 1em);
  }
}
.case1 {
  ul {
    --gap-x: 3%;
    margin-inline: auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    row-gap: max(3vw, 1em);
    column-gap: var(--gap-x);
  }
  li {
    display: grid;
    justify-items: center;
    gap: 1em;
    line-height: 1.7;
    font-weight: 500;
    border-radius: 10px;
    background: linear-gradient(135deg, #fff, var(--bg-c));
    text-align: center;
    width: calc((100% - var(--gap-x) * 2) / 3);
    padding: max(2vw, 1em);
    container-type: inline-size;
  }
  img {
    height: 50cqi;
  }
}
.case2,
.case3 {
  .area {
    background-color: var(--bg-c);
    border-radius: 10px;
    padding: max(2vw, 1.4em) max(3vw, 1em);
    width: min(100%, 600px);
    margin-left: auto;
    > p {
      margin-top: 0.5em;
    }
  }
  ul {
    display: flex;
    flex-direction: column;
    gap: 0.6em;
  }
  li {
    position: relative;
    padding-left: 1.6em;
    line-height: 1.6;
    &::before {
      position: absolute;
      inset: 0.3em auto auto 0;
      content: "";
      width: 1em;
      aspect-ratio: 1;
      border-radius: 50%;
      border: 1px solid;
    }
  }
}

.first {
  .body {
    width: min(100%, 600px);
    margin-left: auto;
    p {
      line-height: 1.8;
    }
  }
  ul {
    border: 3px solid var(--bg-c);
    border-radius: 10px;
    padding: max(2.4vw, 1.4em) max(3vw, 1em);
    display: flex;
    flex-direction: column;
    gap: 1em;
    margin-top: 1.6em;
  }
  li {
    display: flex;
    gap: 1em;
    align-items: start;
    line-height: 1.6;
    img {
      width: 1.6em;
    }
  }
}

@media (width < 1024px) {
  .case1 li {
    width: calc((100% - var(--gap-x)) / 2);
  }
}
@media (width < 768px) {
  .top .contents {
    flex-direction: column;
    .img-box {
      width: 100%;
    }
  }
  .case1 {
    ul {
      --gap-x: 3vw;
    }
    li {
      padding-inline: 0;
      font-size: 14px;
    }
  }
}
@media (width < 510px) {
  .case1 li {
    width: min(80%, 340px);
    gap: 10px;
    img {
      height: 26cqi;
    }
  }
}
