/* CSS Document */
/*Base*/
.js-keepHorizontalSlide {
  display: flex;
  justify-content: flex-start;
  flex-wrap: nowrap;
}
.js-handWritten {
  transition: 0.3s opacity;
}
.js-handWritten path {
  fill: none;
  stroke: #FFFFFF;
  stroke-miterlimit: 10;
  stroke-width: 10px;
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
}
.js-pieChart circle {
  fill: transparent;
  stroke-width: 32;
  stroke-dashoffset: 100;
  stroke-dasharray: 100;
  stroke: #DCDDDD;
  transform: rotate(-90deg);
  transform-origin: center;
}
.js-pieChart.stop {
  animation-duration: 0.5s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  animation-delay: 0s;
  animation-name: graphImgAnm01_none;
}
.js-pieChart.stop circle {
  animation-duration: 0.5s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  animation-delay: 0s;
  animation-name: graphImgAnm01_buck;
}
.js-pieChart.act {
  animation-delay: 0s;
  animation-duration: 0s;
  animation-fill-mode: forwards;
  animation-name: graphImgAnm01_on;
}
.js-pieChart.act circle {
  animation-duration: 0.5s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
  animation-delay: 0s;
  animation-name: graphImgAnm01;
}
@keyframes graphImgAnm01 {
  0% {
    opacity: 1;
    stroke-dashoffset: 100;
  }
  100% {
    opacity: 1;
    stroke-dashoffset: 0;
  }
}
@keyframes graphImgAnm01_buck {
  0% {
    opacity: 1;
    stroke-dashoffset: 0;
  }
  100% {
    opacity: 1;
    stroke-dashoffset: 100;
  }
}
@keyframes graphImgAnm01_none {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes graphImgAnm01_on {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.footerContainer {
  width: 100%;
  padding: 88px 0 0;
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footerContainer {
    padding: 6.28vw 0 0;
  }
}
@media screen and (max-width: 640px) {
  .footerContainer {
    padding: 5.8% 0 0;
    background: #fff;
  }
}
.footerInner {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 641px) {
  .footerInner {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.footerLayout01 {
  flex: 0 1 24.1%;
  margin: 0 1% 0 0;
  padding: 2.2% 0 0;
}
@media screen and (max-width: 640px) {
  .footerLayout01 {
    margin: 0 0 6%;
    padding: 0;
  }
}
.footerLayout02 {
  flex: 0 1 29%;
}
@media screen and (max-width: 640px) {
  .footerLayout02 {
    display: none;
  }
}
.footerLayout03 {
  flex: 0 1 16%;
}
@media screen and (max-width: 640px) {
  .footerLayout03 {
    display: none;
  }
}
.footerLayout04 {
  flex: 0 1 19.4%;
}
@media screen and (max-width: 640px) {
  .footerLayout04 {
    width: 90%;
    margin: 0 auto;
  }
}
.footerLayout05 {
  flex: 0 1 100%;
}
.footerList__item {
  position: relative;
  margin: 0 0 9px;
  padding: 0 0 0 12px;
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footerList__item {
    margin: 0 0 0.6428vw;
    padding: 0 0 0 0.8571vw;
  }
}
@media screen and (max-width: 640px) {
  .footerList__item {
    margin: 0;
    padding: 0 0 0 4%;
    border-bottom: #eb9b38 1px solid;
  }
}
.footerList__item::before {
  position: absolute;
  display: block;
  content: "";
  width: 7px;
  aspect-ratio: 0.55/1;
  inset: 10px 100% auto 0;
  margin: auto;
  background: #f49f35;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footerList__item::before {
    width: 0.5vw;
    inset: 0.7142vw 100% auto 0;
  }
}
@media screen and (max-width: 640px) {
  .footerList__item::before {
    width: 1.8%;
    inset: 3.5vw 95.2% auto 0;
  }
}
.footerList__link {
  display: inline-block;
  padding: 9px 0;
  font-size: 0.9375rem;
  letter-spacing: 0.05rem;
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footerList__link {
    padding: 0.6428vw 0;
    font-size: 1.07142vw;
    letter-spacing: 0.057vw;
  }
}
@media screen and (max-width: 640px) {
  .footerList__link {
    padding: 3.1% 0;
    font-size: 3.59375vw;
    letter-spacing: 0.114vw;
  }
}
.footer__logo {
  width: 49%;
  margin: 0 auto 14%;
  display: block;
}
@media screen and (max-width: 640px) {
  .footer__logo {
    width: 64%;
    margin: 0 auto 5%;
  }
}
.footer__contact {
  position: relative;
  display: flex;
  width: 48%;
  height: 44px;
  margin: 0 auto;
  border-radius: 22px;
  background: #86b8c9;
  align-items: center;
  justify-content: center;
  color: #fff;
  box-shadow: rgba(89, 87, 87, 0.3) 3px 3px 5px;
  font-size: 0.9375rem;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footer__contact {
    height: 3.14vw;
    border-radius: 1.57vw;
    box-shadow: rgba(89, 87, 87, 0.3) 0.214vw 0.214vw 0.357vw;
    font-size: 0.9375vw;
    letter-spacing: 0.114vw;
  }
}
@media screen and (max-width: 640px) {
  .footer__contact {
    width: 46%;
    height: 12vw;
    border-radius: 6vw;
    font-size: 3.59375vw;
    letter-spacing: 0.114vw;
    box-shadow: rgba(89, 87, 87, 0.3) 0.214vw 0.214vw 0.357vw;
  }
}
.footer__contact::after {
  position: absolute;
  display: block;
  content: "";
  width: 5%;
  aspect-ratio: 1/1;
  inset: 2% 0 0 72%;
  margin: auto;
  border-top: #fff 1px solid;
  border-right: #fff 1px solid;
  transform: rotate(45deg);
  transition: 0.2s all;
}
.footerSubList {
  position: relative;
  padding: 0 0 0 18px;
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footerSubList {
    padding: 0 0 0 1.28vw;
  }
}
.footerSubList::before {
  position: absolute;
  content: "";
  display: block;
  width: 1px;
  height: 101%;
  inset: 0 96.6% 0 0;
  margin: auto;
  background: #f49f35;
}
.footerSubList__link {
  display: inline-block;
  padding: 2% 0;
  font-size: 0.9375rem;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footerSubList__link {
    font-size: 1.07vw;
    letter-spacing: 0.11vw;
  }
}
.footer__cr {
  margin: 5% 0 0;
  padding: 0 0 2%;
  line-height: 1;
  font-size: 0.9375rem;
  text-align: center;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 641px) and (max-width: 1400px) {
  .footer__cr {
    font-size: 1.07vw;
    letter-spacing: 0.11vw;
  }
}
@media screen and (max-width: 640px) {
  .footer__cr {
    margin: 7.5% 0 0;
    font-size: 3.125vw;
  }
}/*# sourceMappingURL=law.css.map */