/********************
law
********************/
/*
hero
*/
.bsp.law #hero {
  font-size: min(1.25vw, 18px);
}
.bsp.law #hero .hero_wrap {
  position: relative;
  margin-top: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bsp.law #hero .hero_wrap .bg_img {
  width: 100%;
}
.bsp.law #hero .hero_wrap .hero_txt {
  position: absolute;
  text-align: center;
}
.bsp.law #hero .hero_wrap .hero_txt h1 {
  font-size: min(2.78vw, 40px);
  line-height: 2.125;
  color: #fff;
}

@media screen and (max-width: 1023px) {
  .bsp.law #hero .hero_wrap {
    margin-top: 85px;
  }
}
@media screen and (max-width: 767px) {
  .bsp.law #hero .hero_wrap {
    margin-top: calc(60px + 6.67vw);
  }
  .bsp.law #hero .hero_wrap .hero_txt h1 {
    font-size: 5.33vw;
  }
}
/*
contents
*/
.bsp.law .sec_cont {
  font-size: min(1.25vw, 18px);
}
.bsp.law .sec_cont .content_wrap {
  margin-top: 5.56em;
}
.bsp.law .sec_cont .content_wrap h2 {
  font-size: min(1.39vw, 20px);
  background: #E8E5DC;
  padding: 0.2em 1em;
}
.bsp.law .sec_cont .content_wrap dl {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 1.94em;
}
.bsp.law .sec_cont .content_wrap dl .dl_inner {
  display: flex;
  align-items: center;
  border-bottom: 1px solid #CBC3AC;
  width: 100%;
}
.bsp.law .sec_cont .content_wrap dl dt, .bsp.law .sec_cont .content_wrap dl dd {
  padding: 1.88em 0;
}
.bsp.law .sec_cont .content_wrap dl dt a, .bsp.law .sec_cont .content_wrap dl dd a {
  color: #0089FF;
  text-decoration: underline;
}
.bsp.law .sec_cont .content_wrap dl dt {
  font-size: min(1.11vw, 16px);
  line-height: 1.81;
  width: 22.58%;
}
.bsp.law .sec_cont .content_wrap dl dd {
  font-size: min(0.97vw, 14px);
  line-height: 1.86;
}
.bsp.law .sec_cont .content_wrap dl dd p {
  font-size: min(0.97vw, 14px);
  line-height: 1.86;
}
.bsp.law .sec_cont .content_wrap dl dd p + p {
  margin-top: 1em;
}

@media screen and (max-width: 767px) {
  .bsp.law .sec_cont {
    margin-top: 16vw;
  }
  .bsp.law .sec_cont .content_wrap {
    margin-top: 16vw;
  }
  .bsp.law .sec_cont .content_wrap h2 {
    font-size: 3.73vw;
    margin-top: 5.33vw;
  }
  .bsp.law .sec_cont .content_wrap dl dt, .bsp.law .sec_cont .content_wrap dl dd {
    font-size: 3.2vw;
    line-height: 1.79;
    padding: 5.33vw 0;
    letter-spacing: 0.05em;
  }
  .bsp.law .sec_cont .content_wrap dl dt {
    width: 32vw;
  }
  .bsp.law .sec_cont .content_wrap dl dd {
    font-size: 3.2vw;
    line-height: 1.83;
    width: 54.66vw;
  }
  .bsp.law .sec_cont .content_wrap dl dd p {
    font-size: 3.2vw;
    line-height: 1.83;
  }
}