@charset "UTF-8";
/* CSS Document */
#fv {
  height: 700px;
  width: 100%;
  position: relative;
  z-index: 2;
}
#fv .wrap {
  width: 1370px;
  padding: 220px 0 0;
}
@media screen and (max-width: 768px) {
  #fv .wrap {
    padding: 26.0416666667vw 0 0;
  }
}

.fvtextbox {
  width: 43%;
  border: 1px solid #163b7b;
  position: relative;
  background: #fff;
}
.fvtextbox p {
  width: 80%;
  margin: 0 auto;
  text-align: left;
}

.fvttleng {
  font-size: 3rem;
  font-weight: 600;
  color: #002043;
  position: relative;
  top: -18px;
  letter-spacing: 0.3rem;
}
.fvttleng span {
  font-size: 139%;
  font-weight: 500;
  color: #c99739;
}

.fvtextbox p.fvttl {
  font-weight: 500;
  font-size: 1.02rem;
  letter-spacing: 0.03rem;
  margin: 13px auto 20px;
  position: relative;
  padding-bottom: 16px;
}

.fvttl:before {
  content: "";
  background: #000;
  width: 40px;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 5px;
}

.fvtextbox p.ntext {
  font-family: "Noto Sans JP", sans-serif;
}

main {
  margin: 130px auto 110px;
}
main img {
  vertical-align: top;
}

@media screen and (max-width: 768px) {
  .fvtextbox {
    width: 90%;
    margin: 0 auto;
    padding-bottom: 20px;
  }
  .fvtextbox p.fvttleng {
    font-size: 1.6rem;
    letter-spacing: -0.03rem;
    text-align: center;
  }
  .fvtextbox p.fvttl {
    margin: 10px auto;
    font-size: 1.5rem;
  }
  .fvtextbox p.ntext {
    font-size: 0.7rem;
    line-height: 1.6rem;
  }
  main {
    margin: 70px auto;
  }
}
.visacontlinklist {
  margin: -45px auto 100px;
  text-align: center;
}
.visacontlinklist .ttltopeng {
  color: #b8b8b8;
  padding: 0 0 60px;
}
.visacontlinklist .ttltopeng:before {
  background: #b8b8b8;
  height: 40px;
  right: 50%;
  width: 1px;
  top: 44px;
}
.visacontlinklist ul {
  width: 75%;
  margin: 20px auto 125px;
  display: flex;
  justify-content: space-between;
}
.visacontlinklist li {
  width: 33.3333333333%;
  position: relative;
}
.visacontlinklist ul li:before {
  width: 1px;
  height: 100%;
  background: #fff;
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
}
.visacontlinklist ul li a:before {
  content: "";
  background: url("../img/common/yyjrs.png") no-repeat;
  width: 19px;
  height: 19px;
  position: absolute;
  right: 23px;
  top: 22px;
}
.visacontlinklist ul li:last-child:before {
  width: 0;
}
.visacontlinklist a {
  background: #a0a8b1;
  padding: 20px 0;
  text-align: center;
  display: block;
  width: 100%;
  color: #686868;
  position: relative;
  margin: 0 auto 11px;
}
.visacontlinklist ul li a:hover {
  background: #002043;
  color: #fff;
  padding: 25px 0;
  margin: 0 auto;
  opacity: 1;
}
.visacontlinklist ul li a:hover:before {
  top: 27px;
}

@media screen and (max-width: 768px) {
  .visacontlinklist {
    margin: -35px auto -50px;
  }
  .visacontlinklist ul {
    display: block;
    width: 90%;
  }
  .visacontlinklist li {
    width: 100%;
  }
  .visacontlinklist a {
    margin: 0 auto;
    padding: 15px 0;
  }
  .visacontlinklist ul li a:before {
    top: 20px;
  }
  .visacontlinklist ul li:before {
    width: 100%;
    height: 1px;
    top: auto;
    bottom: 0;
    right: auto;
    left: 0;
  }
  .visacontlinklist .ttltopeng {
    padding: 0 0 30px;
  }
  .visacontlinklist .ttltopeng:before {
    height: 30px;
    top: 30px;
  }
}
.contlrimgtext .ttltopeng:before {
  width: 100%;
  background: #b8b8b8;
}
.contlrimgtext .ttltopeng span {
  background: #fff;
  padding: 0 20px 0 0;
  position: relative;
  z-index: 1;
}

/********************visa01****************/
.visa01fv {
  background: url("../img/visa/01/fv.jpg") no-repeat center;
  background-size: cover;
}

.visacontlinklist ul {
  width: 85%;
}

/****************visa02*****************/
.visa02fv {
  background: url("../img/visa/02/fv.jpg") no-repeat center;
  background-size: cover;
}

#visa02interarea .visacontlinklist li {
  width: 50%;
}

@media screen and (max-width: 768px) {
  #visa02interarea .visacontlinklist ul {
    width: 90%;
  }
  #visa02interarea .visacontlinklist li {
    width: 100%;
  }
}
/************************visa03**********/
.visa03fv {
  background: url("../img/visa/03/fv.jpg") no-repeat center;
  background-size: cover;
}

/*************************visa04***************/
.visa04fv {
  background: url("../img/visa/04/fv.jpg") no-repeat right;
  background-size: cover;
}
.visa04fv .fvttleng {
  letter-spacing: -0.01rem;
}

#visa04interarea .visacontlinklist ul {
  flex-wrap: wrap;
}
#visa04interarea .visacontlinklist a {
  line-height: 1.2rem;
  max-height: 100px;
  min-height: 40px;
}
#visa04interarea .visacontlinklist ul li a:before {
  top: 30px;
}
#visa04interarea .visacontlinklist ul li:first-child a, #visa04interarea .visacontlinklist ul li:last-child a {
  padding: 30px 0 10px;
}
#visa04interarea .visacontlinklist ul li:first-child a:hover, #visa04interarea .visacontlinklist ul li:last-child a:hover {
  padding: 30px 0 20px;
}

/**********************visa05*****************/
.visa05fv {
  background: url("../img/visa/05/fv.jpg") no-repeat top center;
  background-size: cover;
}
.visa05fv .fvttleng {
  letter-spacing: -0.01rem;
  font-size: 2.2rem;
}

#visa05interarea .visacontlinklist ul {
  width: 50%;
}
#visa05interarea .visacontlinklist li {
  width: 50%;
  position: relative;
}

@media screen and (max-width: 768px) {
  #visa05interarea .visacontlinklist li {
    width: 100%;
    position: relative;
  }
  #visa05interarea .visacontlinklist ul {
    display: block;
    width: 90%;
  }
}
/*******************visa06*****************/
.visa06fv {
  background: url("../img/visa/06/fv.jpg") no-repeat top center;
  background-size: cover;
}
.visa06fv p.fvttleng {
  font-size: 2.4rem;
  letter-spacing: -0.01rem;
}

/*******************visa07**********/
.visa07fv {
  background: url(../img/visa/07/fv.jpg) no-repeat top center;
  background-size: cover;
}
.visa07fv p.fvttleng {
  font-size: 2rem;
  letter-spacing: -0.01rem;
}

/********************visa08*************/
.visa08fv {
  background: url("../img/visa/08/fv.jpg") no-repeat top center;
  background-size: cover;
}

#visa08interarea {
  margin: -70px auto 0;
}

.contlrunderlink {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 723px;
  margin: 90px auto 120px;
}
.contlrunderlink li {
  max-width: 337px;
  width: 48%;
  box-shadow: 0px 18px 27px 0px rgba(7, 0, 2, 0.1);
}
.contlrunderlink li a {
  display: block;
  font-size: 16px;
  color: #002043;
  letter-spacing: 0.1em;
  font-weight: 500;
  padding: 3px;
  text-align: center;
  background: #bbbbbb;
}
.contlrunderlink li a span {
  border: 1px solid #c99739;
  display: block;
  padding: 31px;
  line-height: 1;
}
.contlrunderlink li.-contact a span {
  background: #fff;
}

#visatopics {
  text-align: center;
  margin: 120px auto;
}
#visatopics .ntext {
  margin: 65px auto;
}

.visatopicslist div {
  text-align: center;
}
.visatopicslist div img {
  width: 80%;
  height: auto;
  margin: 0 auto;
}
.visatopicslist div .date {
  text-align: left;
  font-size: 0.9rem;
  width: 80%;
  margin: 12px auto 0;
}

#visatopics .visatopicslist div .ntext {
  line-height: 1.5rem;
  margin: 1px auto;
  width: 80%;
  font-size: 0.8rem;
  letter-spacing: -0.05rem;
  text-align: left;
}

.visatopicsmore {
  margin: 180px auto 10px;
  display: inline-block;
  width: 240px;
  position: relative;
  text-align: center;
  transition: 0.6s;
  background: #0b233d;
  color: #fff;
  display: block;
  font-size: 14px;
  font-family: "EB Garamond", serif;
  font-weight: 400;
  line-height: 1;
  padding: 18px;
}
.visatopicsmore:before {
  position: absolute;
  left: 6px;
  top: 6px;
  width: 2px;
  height: calc(100% - 12px);
  content: "";
  background: #c99739;
}
.visatopicsmore:after {
  content: "";
  background: url(../img/common/yyjrs.png) no-repeat;
  width: 19px;
  height: 19px;
  top: calc(50% - 9.5px);
  right: 8px;
  position: absolute;
  transform: rotate(-90deg);
}
.visatopicsmore:hover {
  background: #a0a8b1;
  color: #676767;
  opacity: 1;
}

.slick-next:before {
  background: url("../img/visa/next.png") no-repeat;
  width: 211px;
  height: 33px;
  content: "";
  display: inline-block;
}

.slick-prev:before {
  background: url("../img/visa/prev.png") no-repeat;
  width: 209px;
  height: 32px;
  content: "";
  display: inline-block;
}

#visatopics .slick-prev,
#visatopics .slick-next {
  top: 133%;
}
#visatopics .slick-prev {
  left: 20%;
}
#visatopics .slick-next {
  right: 39%;
}

.visatopicslist .slider-num {
  position: absolute;
  width: 8%;
  left: 46%;
  bottom: -80px;
  font-size: 2.2rem;
  color: #002043;
  text-align: left;
}

.now-count {
  position: relative;
}
.now-count:before {
  width: 1px;
  height: 90px;
  content: "";
  background: #002043;
  transform: rotate(45deg);
  display: inline-block;
  position: absolute;
  top: 5px;
  left: 40px;
}

.visaundercont {
  background: url("../img/visa/visaunderbg.jpg") no-repeat center;
  background-size: cover;
  border: 1px solid;
  color: #fff;
  padding: 116px 0 88px;
  text-align: center;
  margin: 0 auto 110px;
}
.visaundercont .ttltopeng {
  color: #b8b8b8;
  padding-bottom: 63px;
}
.visaundercont .ttltopeng:before {
  width: 1px;
  height: 40px;
  background: #b8b8b8;
  right: 50%;
  top: 2.55rem;
}
.visaundercont .visaunderbox .ttltext {
  margin-bottom: 35px;
  text-align: left;
  padding-left: 55px;
  position: relative;
}

.visaundercont_bengttl {
  margin: 140px auto 40px;
  font-size: 4.5rem;
  color: #002043;
  opacity: 0.5;
  letter-spacing: 0.15rem;
}

.visaunderbox {
  margin: 30px auto 50px;
  background: #fff;
  color: #000;
  padding: 50px 4%;
}
.visaunderbox .flowBtn {
  max-width: 337px;
  width: 100%;
  margin: auto;
  box-shadow: 0px 17px 24px 0px rgba(7, 0, 2, 0.31);
  display: block;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
  padding: 3px;
  text-align: center;
  background: #d3d3d3;
}
.visaunderbox .flowBtn span {
  border: 1px solid #c99739;
  display: block;
  padding: 28px 0;
  line-height: 1;
  background: #001833;
  color: #fff;
  transition: 0.6s;
}
.visaunderbox .flowBtn:hover span {
  color: #002043;
  background: #d3d3d3;
}

.visaundercont .visaunderbox .ttltext:before {
  content: "";
  background: url("../img/common/01.png") no-repeat;
  width: 44px;
  height: 44px;
  position: absolute;
  left: 0;
  top: 10px;
}
.visaundercont .visaunderbox.visaunderbox02 .ttltext:before {
  background: url("../img/common/02.png") no-repeat;
}
.visaundercont .ttltext span {
  display: block;
  color: #002043;
  font-size: 0.9rem;
  letter-spacing: 0.02rem;
  line-height: 2rem;
}
.visaundercont .visa09flowttl {
  margin: 35px auto 80px;
}
.visaundercont .visa09flowttl li:nth-child(odd) {
  width: 28%;
  text-align: left;
}
.visaundercont .visa09flowmain p.ntext {
  text-align: center;
  margin-bottom: 14px;
}

.visaunderbox02textbox {
  border: 1px solid #c99739;
  box-shadow: 0px 0px 0px 6px #dbdbdb;
  text-align: center;
  background: #dbdbdb;
  margin: 45px auto 40px;
  padding: 35px 0 5px;
}

.visaundercont .visaunderbox02textbox .ttltext {
  text-align: center;
  padding: 0;
  font-size: 1rem;
  margin: 0 auto -10px;
}
.visaundercont .visaunderbox.visaunderbox02 .visaunderbox02textbox .ttltext:before {
  width: 0;
  height: 0;
}

.visaunderbox02textbox .ntext {
  line-height: 1.7rem;
}
.visaunderbox02textbox .ntext span {
  display: block;
  margin: 17px auto 0;
  font-size: 0.6rem;
  color: #686868;
}

#visatopics .slick-prev:before,
#visatopics .slick-next:before {
  font-size: 0;
}

@media screen and (max-width: 768px) {
  .visaundercont {
    background: url("../img/visa/visaunderbg.jpg") no-repeat center;
    background-size: 1100%;
  }
  .visaundercont .visa09flowmain p.ntext {
    width: 50%;
    margin: 0 0 0 auto;
    text-align: left;
    font-size: 0.85rem;
  }
  .visaundercont .visa09flowmain img {
    margin-left: 30%;
  }
  .contlrunderlink {
    display: block;
    margin: 3.90625vw auto;
  }
  .contlrunderlink li {
    display: block;
    max-width: none;
    margin-bottom: 3.90625vw;
    width: 78.125vw;
  }
  .contlrunderlink li a {
    font-size: 4.1666666667vw;
    padding: 0.390625vw;
    margin-bottom: 3.90625vw;
  }
  .contlrunderlink li a span {
    padding: 7.8125vw;
    border: 0.1302083333vw solid #c99739;
  }
  #visatopics {
    margin: 60px auto;
    width: 90%;
  }
  #visatopics .ntext {
    margin: 35px auto;
  }
  .slick-next:before {
    background: url("../img/visa/next_sp.png") no-repeat;
    width: 105px;
    height: 33px;
    content: "";
    display: inline-block;
  }
  .slick-prev:before {
    background: url("../img/visa/prev_sp.png") no-repeat;
    width: 105px;
    height: 32px;
    content: "";
    display: inline-block;
  }
  #visatopics .slick-prev {
    left: 0;
  }
  #visatopics .slick-next {
    right: 23%;
  }
  .visatopicslist .slider-num {
    left: 40%;
  }
  .visaundercont {
    padding: 66px 0 20px;
  }
  .visaundercont p.ntext {
    width: 90%;
  }
  .visaundercont_bengttl {
    margin: 50px auto 20px;
    font-size: 3.5rem;
    letter-spacing: -0.15rem;
    line-height: 5rem;
  }
  .visaunderbox {
    width: 80%;
    padding: 50px 5% 20px;
  }
  .visaundercont {
    margin: 0 auto 60px;
  }
  .visaundercont .ttltext span {
    line-height: 1rem;
    padding-bottom: 10px;
  }
}
/********************visa09*************/
.visa09fv {
  background: url("../img/visa/09/fv.jpg") no-repeat top center;
  background-size: cover;
}

.visa0901 {
  margin: -40px auto 0;
}

.visa0901img {
  display: flex;
  justify-content: space-between;
  margin: 0 auto 88px;
}
.visa0901img li {
  width: 50%;
}
.visa0901img li:last-child {
  text-align: right;
  position: relative;
}
.visa0901img li:last-child .visa09img3 {
  position: absolute;
  bottom: 0;
  right: 0;
}

p.ntext {
  font-family: "Noto Sans JP", sans-serif;
  margin: 20px auto;
}

.ttltext {
  margin: 0 auto;
  font-size: 1.5rem;
  font-weight: 500;
}

.visa0901link {
  display: flex;
  justify-content: center;
  margin: 80px auto 0;
  width: 83%;
}
.visa0901link li:first-child, .visa0901link li:last-child {
  padding-top: 20px;
}
.visa0901link li.Btn {
  max-width: 337px;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .visa0901link li.Btn {
    max-width: 60%;
  }
}
.visa0901link li.Btn a {
  margin: auto;
  box-shadow: 0px 17px 24px 0px rgba(7, 0, 2, 0.31);
  display: block;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
  padding: 3px;
  text-align: center;
  background: #d3d3d3;
}
@media screen and (max-width: 768px) {
  .visa0901link li.Btn a {
    font-size: 1.3888888889vw;
    padding: 3px;
  }
}
.visa0901link li.Btn a span {
  border: 1px solid #c99739;
  display: block;
  padding: 28px 0;
  line-height: 1;
  background: #001833;
  color: #fff;
  transition: 0.6s;
}
@media screen and (max-width: 768px) {
  .visa0901link li.Btn a span {
    padding: 3.4722222222vw;
  }
}

.visa0902 {
  margin: 50px auto;
  padding: 90px 0 40px;
  background: rgb(0, 16, 36);
  background: linear-gradient(0deg, rgb(0, 16, 36) 0%, rgb(0, 24, 51) 100%);
}

.visa09area,
.visa09flow,
.visa09price {
  padding: 55px 40px;
  margin: 0 auto 60px;
  background: #fff;
  position: relative;
}
.visa09area__Btn,
.visa09flow__Btn,
.visa09price__Btn {
  max-width: 337px;
  width: 100%;
  margin: auto;
  box-shadow: 0px 17px 24px 0px rgba(7, 0, 2, 0.31);
  display: block;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
  padding: 3px;
  text-align: center;
  background: #d3d3d3;
}
.visa09area__Btn span,
.visa09flow__Btn span,
.visa09price__Btn span {
  border: 1px solid #c99739;
  display: block;
  padding: 28px 0;
  line-height: 1;
  background: #001833;
  color: #fff;
  transition: 0.6s;
}

.visa09area div {
  display: flex;
  justify-content: space-between;
  margin: 20px auto;
}
.visa09area div ul {
  width: 25%;
  text-align: left;
  position: relative;
  padding: 0 0 0 30px;
}
.visa09area div ul:before {
  width: 1px;
  height: 70%;
  background: #002043;
  content: "";
  position: absolute;
  right: 0;
  top: 0;
}
.visa09area div li {
  font-size: 0.85rem;
  padding: 0 0 10px 23px;
  position: relative;
}
.visa09area div li:before {
  content: "";
  width: 5px;
  height: 5px;
  border-right: 2px solid #163b7b;
  border-top: 2px solid #163b7b;
  transform: rotate(45deg);
  position: absolute;
  left: 3px;
  top: 10px;
}
.visa09area div ul.visa09arealast:before {
  width: 0;
}

p.ntext.visa09undertext {
  margin: 0 auto;
  font-size: 0.73rem;
  line-height: 1rem;
}

.visa09flowttl {
  margin: 35px auto;
  display: flex;
  justify-content: space-between;
}
.visa09flowttl li:nth-child(odd) {
  width: 20%;
  border: 1px solid #002043;
  padding: 9px 0 9px 2%;
}
.visa09flowttl li:nth-child(even) {
  width: 4%;
  text-align: center;
  border: none;
  padding: 20px 0 0;
}
.visa09flowttl li span {
  font-size: 1.6rem;
  color: #dbdbdb;
  padding-right: 10px;
}
.visa09flowttl li:nth-child(3) span {
  color: #bdbdbd;
}
.visa09flowttl li:nth-child(5) span {
  color: #686868;
}
.visa09flowttl li:nth-child(7) span {
  color: #4a4a4a;
}

.visa09flowmain {
  display: flex;
  justify-content: space-between;
  text-align: center;
  margin: 50px auto 35px;
}
.visa09flowmain li:nth-child(odd) {
  width: 20%;
}
.visa09flowmain li:nth-child(even) {
  width: 4%;
}
.visa09flowmain p.ntext {
  margin: 30px auto 0;
  font-size: 0.75rem;
  line-height: 1.2rem;
  text-align: left;
  letter-spacing: 0;
}

.visa09price {
  text-align: center;
  padding: 55px 40px 20px;
}
.visa09price p.ntext {
  position: absolute;
  right: 40px;
  top: 60px;
}
.visa09price ul {
  margin: 38px auto 20px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  border: 1px solid #052d5b;
  border-bottom: 0px;
  text-align: left;
}
.visa09price ul li:nth-child(odd) {
  width: 56%;
  border-bottom: 1px solid #052d5b;
  position: relative;
  background: #dbdbdb;
  padding: 17px 0px 17px 3%;
}
.visa09price ul li:nth-child(odd):before {
  width: 1px;
  height: 100%;
  background: #052d5b;
  position: absolute;
  right: 0;
  top: 0;
  content: "";
}
.visa09price ul li:nth-child(even) {
  width: 36%;
  border-bottom: 1px solid #052d5b;
  padding: 17px 0px 17px 5%;
  font-family: "Noto Sans JP", sans-serif;
}
.visa09price ul li:last-child {
  font-size: 0.8rem;
}
.visa09price p {
  text-align: left;
}

#visa09interarea {
  margin: 150px auto 80px;
}

.contlrimgtext {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media screen and (max-width: 1245px) {
  .contlrimgtext {
    padding: 0 2%;
    display: block;
  }
}
.contlrimgtext img {
  width: 48%;
}
@media screen and (max-width: 1245px) {
  .contlrimgtext img {
    width: 100%;
  }
}
.contlrimgtext div {
  width: 48%;
}
@media screen and (max-width: 1245px) {
  .contlrimgtext div {
    width: 100%;
    margin-top: 30px;
  }
}
@media screen and (max-width: 768px) {
  .contlrimgtext div {
    margin-top: 3.90625vw;
  }
}
.contlrimgtext .ttltopeng {
  color: #b8b8b8;
}

.ttlsubtext {
  margin: 7px auto;
  font-size: 0.9rem;
  letter-spacing: 0.07rem;
  color: #002043;
}

.contlrimgtext p.ntext {
  margin: 20px auto 0 0;
  width: 90%;
}

.staff {
  margin: 55px auto 80px;
  display: flex;
  justify-content: space-between;
  border: 1px solid #c99739;
  box-shadow: 0px 0px 0px 6px #001833;
  color: #fff;
  padding: 45px 35px;
  align-items: center;
  width: 93%;
  background: url("../img/visa/09/img6bg.jpg") no-repeat left center #001833;
}
.staff img {
  width: 48%;
}
@media screen and (max-width: 768px) {
  .staff img {
    width: 100%;
  }
}
.staff div {
  width: 50%;
}
.staff div .ttltext {
  margin-bottom: 20px;
}

#visa09interarea a {
  display: table;
  margin: 0 auto;
}

#visa09interarea .Btn {
  max-width: 337px;
  width: 100%;
  margin: auto;
  box-shadow: 0px 17px 24px 0px rgba(7, 0, 2, 0.31);
  display: block;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-weight: 500;
  padding: 3px;
  text-align: center;
  background: #d3d3d3;
}
#visa09interarea .Btn span {
  border: 1px solid #c99739;
  display: block;
  padding: 28px 0;
  line-height: 1;
  background: #001833;
  color: #fff;
  transition: 0.6s;
}

.contlrimgtext.lefttext {
  margin: 90px auto 55px;
  flex-direction: row-reverse;
}

.staff.rightimg {
  flex-direction: row-reverse;
  background: url("../img/visa/09/img7bg.jpg") no-repeat right center #001833;
}

#faq label {
  display: block;
  color: #000;
  background: #fff;
  cursor: pointer;
  padding: 45px 0 45px 93px;
  margin: 22px 0 0;
  font-size: 1.5rem;
  font-weight: 500;
  position: relative;
}
#faq label:before {
  content: "";
  background: url("../img/visa/q.png") no-repeat;
  width: 44px;
  height: 44px;
  position: absolute;
  left: 40px;
  top: 37px;
}
#faq label:after {
  content: "+";
  position: absolute;
  right: 30px;
  top: 45px;
  color: #052d5b;
  font-size: 1.8rem;
  font-weight: 100;
}

.faqopen:checked + label + .faqcont:before {
  content: "";
  background: url("../img/visa/a.png") no-repeat;
  width: 44px;
  height: 44px;
  position: absolute;
  left: 40px;
  top: 17px;
}
.faqopen:checked + label + .faqcont:after {
  width: 80%;
  content: "";
  height: 1px;
  top: 0;
  left: 10%;
  position: absolute;
  background: #000;
}

#faq input[type=checkbox] {
  display: none;
}

.faqcont {
  height: 0;
  padding: 0;
  overflow: hidden;
  margin-bottom: 10px;
}

#faq .faqopen:checked + label:after {
  content: "-";
}

.faqopen:checked + label + .faqcont {
  height: auto;
  background: #fff;
  padding: 10px 0 15px 93px;
  position: relative;
}

#faq .ttltext {
  color: #fff;
  text-align: center;
  margin-bottom: 55px;
}

.faqcontbox {
  max-height: 760px;
  overflow-y: scroll;
  padding-right: 15px;
  width: 101%;
}

#faq {
  padding: 125px 0px;
  background: #052d5b;
  --sb-track-color: #b8b8b8;
  --sb-thumb-color: #c1994b;
  --sb-size: 9px;
  scrollbar-color: var(--sb-thumb-color) var(--sb-track-color);
  margin: 0 auto 120px;
}
#faq ::-webkit-scrollbar {
  width: var(--sb-size);
}
#faq ::-webkit-scrollbar-track {
  background: var(--sb-track-color);
  border-radius: 1px;
}
#faq ::-webkit-scrollbar-thumb {
  background: var(--sb-thumb-color);
  border-radius: 1px;
}

@media screen and (max-width: 768px) {
  .visa09fv .fvtextbox {
    padding-bottom: 30px;
  }
  .visa0901img {
    display: block;
    margin: 0 auto 40px;
  }
  .visa0901img li {
    width: 100%;
  }
  .visa0901img li:last-child .visa09img3 {
    position: relative;
  }
  .visa0901img li img {
    width: 100%;
  }
  .visa0901 .wrap1000 {
    width: 90%;
  }
  .visa0901link {
    width: 100%;
    margin: 40px auto;
  }
  .visa0902 {
    padding: 60px 0 20px;
  }
  .visa0902 .wrap1000 {
    width: 90%;
  }
  .visa09area,
.visa09flow,
.visa09price {
    padding: 45px 20px;
  }
  .visa09area div {
    display: block;
  }
  .visa09area div ul {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    padding: 15px 0 6px 0;
  }
  .visa09area div li {
    width: 44%;
    padding: 0 0 10px 6%;
    margin: 0;
  }
  .visa09area div ul:before {
    width: 100%;
    height: 1px;
    right: 0;
    bottom: 0;
    top: auto;
  }
  .visa09flowttl {
    display: none;
  }
  .visa09flowmain {
    display: block;
  }
  .visa09flowmain li:nth-child(odd) {
    width: 100%;
    position: relative;
  }
  .visa09flowmain li:nth-child(even) {
    width: 100%;
    position: relative;
    transform: rotate(90deg);
    width: 10%;
    margin: 0 auto 0 10px;
    bottom: 50px;
    left: 0;
  }
  .visa09flowmain li:nth-child(odd) {
    padding: 60px 0 0;
    display: flex;
    align-items: center;
    margin: 0 0 0 auto;
  }
  .visa09flowmain li:nth-child(odd):before {
    position: absolute;
    width: 100%;
    padding: 5px 0 3px;
    text-align: center;
    left: 0;
    top: 0;
    border: 1px solid #002043;
    font-size: 0.8rem;
  }
  .visa09flowmain li:first-child:before {
    content: "お問い合わせ";
  }
  .visa09flowmain li:nth-child(3):before {
    content: "お見積り";
  }
  .visa09flowmain li:nth-child(5):before {
    content: "受注、打ち合わせ";
  }
  .visa09flowmain li:nth-child(7):before {
    content: "事前準備～当日";
  }
  .visa09flowmain li:nth-child(odd):after {
    position: absolute;
    left: 10px;
    top: 5px;
    font-size: 1.6rem;
  }
  .visa09flowmain li:first-child:after {
    content: "01";
    color: #dbdbdb;
  }
  .visa09flowmain li:nth-child(3):after {
    content: "02";
    color: #b8b8b8;
  }
  .visa09flowmain li:nth-child(5):after {
    content: "03";
    color: #757575;
  }
  .visa09flowmain li:nth-child(7):after {
    content: "04";
    color: #5c5c5c;
  }
  .visa09price {
    padding-bottom: 10px;
  }
  .visa09price p.ntext {
    right: 4%;
    top: 80px;
  }
  .visa09price ul {
    display: block;
    line-height: 1.2rem;
  }
  .visa09price ul li:nth-child(odd), .visa09price ul li:nth-child(even) {
    width: 94%;
    padding: 15px 3%;
    font-size: 0.8rem;
  }
  .visa09price ul li:nth-child(odd):before {
    width: 0;
  }
  #visa09interarea {
    margin: 80px auto 80px;
  }
  .contlrimgtext {
    display: block;
  }
  .contlrimgtext div {
    margin: 20px auto 0;
  }
  .staff {
    width: 80%;
    display: block;
    padding: 20px 4%;
    background: #001833;
    margin: 50px auto 20px;
  }
  .staff.rightimg {
    width: 80%;
    display: block;
    padding: 20px 4%;
    background: #001833;
    margin: 50px auto 20px;
  }
  .staff div {
    margin: 20px auto 0;
    width: 100%;
  }
  .staff div .ttltext {
    margin-bottom: 0px;
  }
  .staff div p.ntext {
    margin: 10px auto;
    line-height: 1.4rem;
  }
  .contlrimgtext.lefttext {
    margin: 50px auto 55px;
  }
  #faq {
    padding: 80px 0;
  }
  #faq .ttltext {
    margin-bottom: 30px;
  }
  .faqcontbox {
    width: 90%;
    margin: 0 auto;
    height: 500px;
    padding-right: 5px;
  }
  #faq label {
    padding: 25px 30px 25px 73px;
    font-size: 1.2rem;
  }
  #faq label:before {
    left: 20px;
    top: 17px;
  }
  #faq label:after {
    right: 20px;
    top: 40%;
  }
  .faqopen:checked + label + .faqcont {
    padding: 15px 30px 25px 73px;
    font-size: 0.9rem;
    line-height: 1.2rem;
  }
  .faqopen:checked + label + .faqcont:before {
    left: 20px;
    top: 27px;
  }
}
/****************************visa10***********************/
.visa10fv {
  background: url("../img/visa/10/fv.jpg") no-repeat center;
  background-size: cover;
}

.visa10main {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 auto 123px;
}
.visa10main li {
  margin: 0;
  background: #5a7fa8;
  position: relative;
}
.visa10main li a img {
  mix-blend-mode: multiply;
}
.visa10main li a img.visa10mainttl {
  mix-blend-mode: normal;
  top: 100px;
  position: absolute;
  left: 0;
}
@media screen and (max-width: 768px) {
  .visa10main li a img.visa10mainttl {
    top: 50%;
    transform: translateY(-50%);
    width: 39.0625vw;
  }
}
.visa10main li a:hover {
  opacity: 1;
}
.visa10main li a:hover img {
  mix-blend-mode: normal;
  opacity: 1;
}

@media screen and (max-width: 768px) {
  .visa10main {
    justify-content: flex-start;
    margin: 0 auto 70px;
  }
  .visa10main li {
    width: 50%;
  }
  .visa10main img {
    width: 100%;
    height: auto;
  }
  .contlrimgtext p.ntext {
    width: 100%;
  }
  #fv {
    height: auto;
  }
  #fv .wrap {
    width: 100%;
  }
}
.visatopicslist .slider-num .all-count {
  position: relative;
  top: 50px;
  left: 30px;
}