/*! Writen  by SCSS */
.mainvisual {
  position: relative; }
  .mainvisual .main_image {
    position: relative; }
    .mainvisual .main_image .w_img {
      width: 100%; }
  .mainvisual .main_ttl_wrap {
    position: absolute;
    inset: 0;
    display: flex;
    justify-content: center;
    align-items: center; }
    .mainvisual .main_ttl_wrap .main_ttl {
      font-size: clamp(30px, 3.334vw, 40px);
      color: #FFF;
      line-height: 1; }

.banner_list {
  font-size: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 7px; }
  @media screen and (max-width: 768px) {
    .banner_list {
      flex-wrap: wrap;
      gap: 7px 2%; } }
  @media screen and (max-width: 480px) {
    .banner_list {
      justify-content: space-between;
      gap: 5px; } }
  .banner_list li {
    box-sizing: border-box;
    display: inline-block; }
    @media screen and (max-width: 768px) {
      .banner_list li {
        width: 32%; } }
    @media screen and (max-width: 480px) {
      .banner_list li {
        width: 48%; } }

.obi {
  background: #5aa572;
  padding: 15px; }

.merit {
  padding: 100px 20px; }
  @media screen and (max-width: 768px) {
    .merit {
      padding: 20px 30px 50px; } }

/*# sourceMappingURL=top.css.map */
