.charge{
  background-color: #d3d3d3;
  padding-bottom: 0!important;
}
.flow{
  background-color: #ADADAD;
  padding-bottom: 0!important;
}
@media screen and (min-width:769px) {
  section > .flex {
    gap: 5rem;
  }
}
@media screen and (min-width:769px) {
  section:not(.page-intro) > .inner {
    padding-top: 16rem;
    padding-bottom: 16rem;
  }
}
@media (max-width:768px){
  section:not(.page-intro) > .inner {
    padding-top: 16%;
    padding-bottom: 12%;
    flex-wrap: wrap;
  }
}
@media screen and (min-width:769px) {
  .service-table + .service-table{
    margin-top: 6rem;
  }
}
@media (max-width:768px){
  .service-table + .service-table{
    margin-top: 3.2rem;
  }
}
@media screen and (min-width:769px) {
  .service-title{
    flex:1;
  }
}
@media (max-width:768px){
  .service-title{
    width: 100%;
  }
}
.service-contants {
  font-family: var(--font-mix);
}
@media screen and (min-width:769px) {
  .service-contants {
    max-width: 1000px;
    width: 76%;
    font-family: var(--font-mix);
  }
}
@media (max-width:768px){
  .service-contants {
    width: 100%;
    font-family: var(--font-mix);
  }
}
.service-head{
  padding: .8rem 1.6rem .8rem 2.4rem;
  box-sizing: border-box;
  border:1px solid #111;
  border-bottom: unset;
}
@media screen and (min-width:769px) {
  .service-head{
    width: 50%;
  }
}
@media (max-width:768px){
  .service-head{
    width: 100%;
  }
}
.service-head .tit{
  font-weight: var(--font-weight-semibold);
  line-height: 1;
}
@media screen and (min-width:769px) {
  .service-head .tit{
    font-size: 6rem;
  }
}
@media (max-width:768px){
  .service-head .tit{
    font-size: 3.6rem;
  }
}
.service-body{
  border:1px solid #111;
  font-size: 1.4rem;
}
.service-body * {
  line-height: 1.5;
}
.service-cell{
  padding: 2.4rem;
  box-sizing: border-box;
}
@media screen and (min-width:769px) {
  .service-cell{
    font-size: 1.5rem;
  }
}
@media (max-width:768px){
  .service-cell{
    font-size: 1.4rem;
  }
}
.service-cell .tit{
  margin-bottom: .125em;
}
@media screen and (min-width:769px) {
  .service-cell .tit{
    font-size: 3.2rem;
  }
}
@media (max-width:768px){
  .service-cell .tit{
    font-size: 2rem;
  }
}
.service-price{
  margin-bottom: .25em;
}
@media screen and (min-width:769px) {
  .service-price{
    font-size: 2.2rem;
  }
}
@media (max-width:768px){
  .service-price{
    font-size: 1.8rem;
  }
}
.service-price span{
  font-size: 1.4rem;
}
.service-cell p + p{
  margin-top: 1rem;
}
.service-cell strong,
.service-cell b{
  color: #de0019;
}
.service-body:has(.service-cell:nth-of-type(2)){
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width:769px) {
  .service-body:has(.service-cell:nth-of-type(2)) .service-cell{
    width: 50%;
  }
}
@media (max-width:768px){
  .service-body:has(.service-cell:nth-of-type(2)) .service-cell{
    width: 100%;
  }
}
@media screen and (min-width:769px) {
  .service-body:has(.service-cell:nth-of-type(2)) .service-cell:nth-of-type(2n-1){
    border-right: 1px solid #111;
  }
}
@media (max-width:768px){
  .service-body:has(.service-cell:nth-of-type(2)) .service-cell:nth-of-type(2n-1){
    border-bottom: 1px solid #111;
  }
}
#faq{
  padding-bottom: 0!important;
}
#faq .inner{
  gap: 5rem;
}
#faq .sticky{
  top: 10rem;
}
#faq .tit_wrap{
  flex:1
}
#faq .tit_wrap .tit{
  border-top: 1px solid #111;
  padding-top: 4.6rem;
  font-size: 6.2rem;
  line-height: 1;
}
#faq .tit_wrap p{
  margin-top: .5em;
  font-size: 1.6rem;
}
#faq .lists{
  max-width: 1000px;
  width: 78%;
  border-bottom: 1px solid #ccc;
}
#faq .lists dl{
  border-top: 1px solid #ccc;
  padding: 3rem 0 3rem 0;
  cursor: pointer;
}
#faq .lists dt{
  position: relative;
  padding-right: 17rem;
  padding-left: 1.6rem;
  box-sizing: border-box;
  font-size: 1.6rem;
  line-height: 1.62;
}
#faq .lists dt::before,
#faq .lists dt::after{
  content: "";
  width: 1.6rem;
  height: 1.5px;
  margin: auto;
  background-color: #111;
  position: absolute;
  right: 6.8rem;
  top: 0;
  bottom: 0;
  transition: all 1.5s cubic-bezier(0.55, 0.05, 0.22, 0.99);
}
#faq .lists dt::after{
  transform: rotate(90deg);
}
#faq .lists dl:has( .active) dt::after{
  opacity: 0;
}
#faq .lists dd{
  overflow-y: hidden;
  width: 100%;
  max-height: 0;
  padding-right: 18rem;
  padding-left: 1.6rem;
  box-sizing: border-box;
  font-size: 1.5rem;
  transition: all .5s cubic-bezier(0.55, 0.05, 0.22, 0.99);
}
#faq .lists dd.active{
  padding-top: 3rem;
  max-height: 300vh;
}
#faq .btn_wrap{
  margin-top:6rem;
}
@media screen and (max-width:768px) {
  #faq .inner{
    display: block;
    padding: 16% 4% 12%;
  }
  #faq .inner > .flex{
    flex-wrap: wrap;
  }
  #faq .tit_wrap{
    width: 100%;
  }
  #faq .sticky{
    display: flex;
    align-items: center;
    gap: 1.6rem;
    position: relative;
    top: 0;
  }
  #faq .tit_wrap .tit {
    font-size: 3.2rem;
    border: unset;
    padding-top: 0;
  }
  #faq .tit_wrap p{
    margin-top: 0;
    font-size: 1.4rem;
  }
  #faq .lists{
    flex: unset;
    width: 100%;
    border-bottom: 1px solid #ccc;
  }
  #faq .lists dl{
    border-top: 1px solid #ccc;
    padding: 3.2rem 0 3.2rem 0;
  }
  #faq .lists dt {
    padding-right: 4.8rem;
    padding-left: 0;
    font-size: 1.6rem;
  }
  #faq .lists dt::before,
  #faq .lists dt::after {
    right: 1.6rem;
  }
  #faq .lists dt::after{
    transform: rotate(90deg);
  }
  #faq .lists dl:has( .active) dt::after{
    opacity: 0;
  }
  #faq .lists dd{
    padding-right: 4.8rem;
    padding-left: 0;
    font-size: 1.3rem;
  }
  #faq .lists dd.active{
    padding-top: 1.6rem;
  }
  #faq .btn_wrap{
    margin-top:4rem;
  }
}

