/*-------------
基本設定
---------------*/
body{
  font-size: 18px;
  line-height: 1.8;
  font-family: "游明朝","Yu Mincho","Hiragino Mincho Pro","ヒラギノ明朝 ProN",serif;
}
.pc{
  display: block;
}
.tab{
  display: none;
}
.pc.tab{
  display: block;
}
.tab.mobi{
  display: none;
}
.mobi{
  display: none;
}
.wrapper{
  max-width: 1200px;
  width: 100%;
  margin: auto;
}
h2{
  font-size: 32px;
  font-weight: bold;
  color: #282f5f;
  text-align: center;
}
.t-white{
  color: #fff;
}

/*-------------
header
---------------*/
header{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: #fff;
  z-index: 999;
}
.header-wrap{
  display: flex;
  justify-content: space-between;
  max-width: 1600px;
  width: 100%;
  height: 100px;
  margin: auto;
}
.header-wrap .logo{
  display: flex;
  align-items: center;
  margin-left: 30px;
  flex-shrink: 1;
}
.header-wrap ul{
  display: flex;
  column-gap: 50px;
  flex-shrink: 0;
  align-items: center;
}
.header-wrap li{
  display: flex;
  align-items: center;
  justify-content: center;
}
.header-wrap li a{
  padding: 2.625rem 1rem 2.625rem 1rem;
  display: block;
  line-height: 1;
  font-size: 16px;
  position: relative;
  font-weight: bold;
}
.header-wrap li:last-of-type a::after{
  content: "";
  background: url(images/mail.png)no-repeat;
  background-size: cover;
  aspect-ratio: 19/14;
  width: 24px;
  height: auto;
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
}
.header-wrap li .btn{
  padding-left: 65px;
  width: 200px;
}
.btn{
  background: #282f5f;
  color: #fff;
  /*height: auto;*/
  transition: all ease .3s;
  position: relative;
  overflow: hidden;
}
.btn::before{
  content: "";
  position: absolute;
  top: 0;
  width: 200%;
  height: 200%;
  display: block;
  background: linear-gradient(120deg,transparent 0%, rgb(255 255 255 / 0.2) 50%, transparent 100%);
  transform: rotate(10deg) translateX(-150%);
  transition: all ease .7s;
}
.btn:hover::before{
  transform: rotate(10deg) translateX(100%);
}
/*-------------
top
---------------*/
.top{
  margin-top: 100px;
  background: url(images/fv.jpg) no-repeat;
  background-size: 100% 100%;
  aspect-ratio: 800/457;
  position: relative;
}
.top h1{
  position: absolute;
  bottom: 15%;
  left: 50%;
  transform: translateX(-50%);
  max-width: 1400px;
  width: 100%;
  color: #fff;
  line-height: 1.8;
  text-align: left;
}
/*-------------
about
---------------*/
.about{
  padding: 60px 0;
  background-image: linear-gradient(90deg, rgba(247, 247, 247, 1) 75%, rgba(255, 255, 255, 1) 75%);
}
.about-wrap{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.about-wrap h2{
  margin-bottom: 60px;
  text-align: left;
}
.about-txt{
  width: 50%;
}
.about-txt p{
  margin-bottom: 50px;
}
.about-txt .btn{
  width: 300px;
  padding: 1.175rem;
  display: block;
  box-sizing: border-box;
  text-align: center;
  margin: auto;
}
.about-txt a::after{
  content: "";
  position: absolute;
  background: url(images/right-arrow.png) no-repeat;
  background-size: cover;
  aspect-ratio: 11/17;
  width: 11px;
  height: auto;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
}
/*-------------
service
---------------*/
.service_audit{
	padding:50px 0 0;
}
.service_audit h2{
  margin: 50px auto;
}
.service-wrap{
  display: flex;
  align-items: flex-start;
  column-gap: 45px;
}
.service-txt p{
  margin-bottom: 40px;
}
.service_audit-about{
  background: #f7f7f7;
  padding: 60px 0;
  margin-top: 70px;
}
.content-ttl{
  color: #282f5f;
  font-weight: bold;
  font-size: 24px;
  margin-bottom: 30px;
  position: relative;
  z-index: 0;
}

.content-ttl::before{
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background: #004ca0;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
}
.content-ttl span{
  background: #f7f7f7;
  display: inline-block;
  padding: 0 30px 0 0;
}
.service_audit-about-txt:first-of-type{
  margin-bottom: 75px;
}
.service_audit-about-txt li{
  position: relative;
  padding-left: 40px;
  margin-bottom: 30px;
}
.service_audit-about-txt li:last-of-type{
  margin-bottom: 0;
}
.service_audit-about-txt li span{
  font-weight: bold;
  display: block;
}
.service_audit-about-txt li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 5px;
  background: url(images/check.png) no-repeat;
  background-size: cover;
  aspect-ratio: 25/23;
  width: 25px;
  height: 23px;
}
.service_audit-type{
  background: url(images/service-audit-bg.jpg) no-repeat;
  background-size: cover;
  padding: 50px 0 80px;
}
.service_audit-type h3 span{
  background: #fff;
}
.service-boxes-border{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  column-gap: 40px;
  margin-bottom: 90px;
}
.service-boxes-border dl{
  background: #fff;
  border-top: 10px solid #00489d;
  padding: 30px 15px;
  height: 310px;
  width: 370px;
  box-shadow: 2px 2px 7px rgb(0 0 0 / .3);
  margin-top: 50px;
}
.service-boxes-border dt{
  font-size: 20px;
  text-align: center;
  color: #282f5f;
  font-weight: bold;
}
.service-boxes-border dt .icon{
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.service_audit-optional{
  background: #f7f7f7;
  padding: 60px 0 70px;
}
.service_audit-merit{
  background: url(images/service-audit-merit.jpg) no-repeat;
  background-position: bottom center;
  background-size: 100%;
}
.service_audit-merit h3 span{
  background: #fff;
}
.service_audit-merit .service-boxes{
  margin-bottom: 50px;
}
.service_audit-merit .service-boxes dl{
  background: #fff!important;
}
.service_audit-merit .service-boxes dt{
  color: #282f5f;
}
.service_audit-merit .service-boxes dd{
  color: #000;
}
.service_audit-optional-txt:first-of-type{
  margin-bottom: 100px;
}
.service_audit-optional-txt p:first-of-type{
  margin-bottom: 40px;
}
.service_audit-optional ul{
  margin: 45px 0;
}
.service_audit-optional li{
  margin-bottom: 20px;
}
.service_audit-optional li span{
  color: #fff;
  background: #b99325;
  width: 270px;
  display: inline-block;
  padding: 5px 20px;
  margin-right: 20px;
}
.service_audit-merit{
  padding: 50px 0 60px;
}
.service-boxes{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: auto;
}
.service-boxes dl{
  background: #fff;
  width: 560px;
  height: 250px;
  box-shadow: 2px 2px 7px rgb(0 0 0 / .3);
  margin-top: 50px;
  padding: 30px 50px;
}
.service-boxes dt{
  color: #282f5f;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}
.service-boxes .icon{
  height: 85px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.service-boxes img{
  margin: auto;
  display: block;
}
.service_audit-other{
  position: relative;
  padding-bottom: 210px;
  padding: 60px 0;
}
.service_audit-other h2{
  margin-top: 0;
}
.service_audit-achievement{
  padding: 50px 0;
  box-shadow: 2px 2px 7px rgb(0 0 0 / .3);
  box-sizing: border-box;
  background: #f7f7f7;
  z-index: 9;
  position: relative;
  margin-top: 50px;
}
.service_audit-achievement h2{
  color: #b99325;
  margin: 0;
}
.service_audit-achievement ul{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  column-gap: 55px;
}
.service_audit-achievement li{
  background: #fff;
  width: 307px;
  height: 73px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 2px 2px 7px rgb(0 0 0 / .3);
  box-sizing: border-box;
  margin-top: 40px;
}
/*-------------
cta
---------------*/
.cta{
  background: url(images/cta-bg.jpg) no-repeat;
  background-size: cover;
  aspect-ratio: 80/33;
  width: 100%;
  position: relative;
  z-index: 0;
  margin-top: -270px;
}
.page-wrap .cta{
  background: url(images/page-cta-bg.jpg) no-repeat;
  aspect-ratio: 200/61;
  background-size: cover;
  margin-top: 0;
}
.cta-inner{
  background: #fff;
  position: absolute;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 90px 70px;
  box-shadow: 2px 2px 7px rgb(0 0 0 / .3);
  box-sizing: border-box;
}
.cta-inner p{
  font-size: 28px;
  color: #282f5f;
  font-weight: bold;
}
.cta-inner a{
  color: #fff;
  background: #282f5f;
  font-size: 24px;
  position: relative;
  display: block;
  padding: 30px 70px 30px 140px;
  width: 465px;
}
.cta-inner a::after{
  content: "";
  position: absolute;
  left: 50px;
  top: 50%;
  transform: translateY(-50%);
  background: url(images/mail.png) no-repeat;
  background-size: cover;
  aspect-ratio: 4/3;
  width: 38px;
  height: auto;
}
/*-------------
税務業務
---------------*/
.service_taxation{
  padding: 80px 0 0;
}
.service_taxation .service-wrap{
  margin: 50px 0 60px;
}

.service_taxation-corporate{
  background: #f7f7f7;
  padding: 70px 0 50px;
}
.service_taxation-corporate .service-boxes{
  margin: 0 auto 50px;
}
 .service-boxes dl{
  height: 260px;
}
.service-boxes dl:nth-of-type(1),
.service-boxes dl:nth-of-type(4){
  background: #00489d;
}
.service-boxes dl:nth-of-type(2),
.service-boxes dl:nth-of-type(3){
  background: #282f5f;
}
.service-boxes dt{
  color: #fff;
}
.service-boxes dd{
  color: #fff;
}
.service_taxation-individual{
  padding: 50px 0 100px;
  background: linear-gradient(to top , #282f5f 0 150px, transparent 150px);
}
.service_taxation-individual h3 span{
  background: #fff;
}
.service_taxation-individual .service-boxes-border{
  margin-bottom: 50px;
}
.service_taxation-individual-flex{
  display: flex;
  justify-content: space-between;
  column-gap: 30px;
  margin: 50px auto 95px;
  align-items: flex-start;
}

.service_taxation-individual-flex:last-of-type{
  margin-bottom: 0;
}
.service_taxation-individual-txt P:first-of-type{
  margin-bottom: 40px;
}
.service_taxation-individual-txt .big{
  font-size: 24px;
  position: relative;
  margin-top: 100px;
  font-weight: bold;
}
.service_taxation-individual-txt .big::before{
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background: url(images/triangle.png) no-repeat;
  background-size: cover;
  aspect-ratio: 53/11;
  width: 159px;
  height: auto;
  top: -70px;
}
.service_advisory{
  padding: 70px 0;
}
.service_advisory h2{
  margin-bottom: 50px;
}
/*-------------
info
---------------*/
.info{
  background: #f7f7f7;
  padding: 60px 0 70px;
}
.info table{
  border-collapse: collapse;
  margin: 50px auto;
  width: 100%;
}
.info table th{
  background: #282f5f;
  color: #fff;
  border-bottom: 1px solid #fff;
  padding: 20px 30px;
}
.info table td{
  background: #fff;
  border-bottom: 1px solid #282f5f;
  padding: 20px 30px;
}
.info table tr:last-of-type th,
.info table tr:last-of-type td{
  border-bottom: 0;
}
.info-img{
  display: flex;
  justify-content: space-between;
  margin-bottom: 50px;
}
.info iframe{
  width: 100%;
}
.greeting{
  padding: 60px 0 90px;
}
.greeting-inner{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  column-gap: 50px;
  margin-top: 70px;
}
.greeting-txt p{
  margin-bottom: 40px;
}
.greeting-txt p:first-of-type{
  font-size: 22px;
  font-weight: bold;
  margin-bottom: 45px;
}
/*-------------
footer
---------------*/
footer{
  background-image: linear-gradient(130deg, rgba(25, 122, 190, 1), rgba(3, 97, 168, 1) 28%, rgba(1, 62, 129, 1) 60%, rgba(7, 82, 150, 1) 82%, rgba(43, 104, 159, 1));
}
.footer-wrap{
  color: #fff;
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 1300px;
  margin: auto;
  padding: 75px 0 60px;
}
.footer-wrap .logo{
  margin-bottom: 60px;
  display: block;
}
.footer-nav{
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  column-gap: 70px;
}
.footer-nav li{
  margin-bottom: 10px;
}
.footer-copy{
  text-align: center;
  padding: 10px;
  background: #fff;
  font-size: 15px;
}

/*-------------
page
---------------*/
.page-wrap{
  margin: 100px 0 0;
}
.page-wrap h1{
  text-align: center;
  font-size: 32px;
  margin: 0 auto 50px;
  padding-top: 50px;
  line-height: 1.5;
}
.page-content{
  margin-bottom: 50px;
}
.page-content > p{
  margin-bottom: 40px;
}
.page-inner{
  background: url(images/profile-bg.png) no-repeat;
  background-size: cover;
  padding: 20px 0 60px;
}
.breadcrumbs{
  margin-bottom: 50px;
}
.page-ttl{
  background: url(images/page-ttl-bg.jpg) no-repeat;
  background-size: cover;
  aspect-ratio: 8/1;
  display: flex;
  justify-content: center;
  align-items: center;
   box-shadow: 0px 10px 8px -6px rgb(0 0 0 / 0.5);
}
.page-ttl h1{
  color: #fff;
  font-size: 30px;
  margin: 0;
  padding: 0;
}
/*-------------
page company
---------------*/
.profile{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  column-gap: 50px;
}
.profile-txt{
  color: #282f5f;
}
.profile-txt p{
  font-size: 32px;
  font-weight: bold;
  margin-bottom: 40px;
}
.profile-txt p:first-of-type{
  margin-bottom: 50px;
}
.profile-txt p span{
  font-size: 24px;
  margin-right: 30px;
}
.profile-txt li {
  padding-left: 125px;
  position: relative;
  font-weight: bold;
  margin-bottom: 30px;
}
.profile-txt li span{
  left: 0;
  position: absolute;
  
}
.profile-txt li span::before{
  content: "";
  position: absolute;
  left: 80px;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 1px;
  background: #282f5f;
}
/*-------------
page contact
---------------*/
.contact{
  background: #f7f7f7;
  padding: 30px;
  width: 100%;
  max-width: 900px;
  margin: auto;
  box-shadow: 2px 2px 7px rgb(0 0 0 / .3);
}
.contact table{
  margin: auto;
  border-collapse: collapse;
  width: 100%;
}
.contact table th{
  vertical-align: text-top;
  border-bottom: 1px solid #282f5f;
  padding: 30px 20px 30px 0;
  text-align: left;
}
.contact table td{
  border-bottom: 1px solid #282f5f;
  padding: 30px 0 30px 20px;
}
.contact table td input,
.contact table td textarea{
  width: 100%;
  padding: 5px;
  background: #fff;
  border: none;
  border: 1px solid #ccc;
}
.required{
  color: #fff;
  background: #282f5f;
  padding: 0 5px;
  font-size: 15px;
  margin-left: 20px;
}
.contact-check{
  text-align: center;
  margin: 50px auto;
}
.contact-check input[type="text"]{
  width: 50px;
  height: 40px;
  display: inline-block;
  border: 1px solid #ccc;
}
.contact .submit{
  padding: 10px;
  width: 200px;
  border: none;
  cursor: pointer;
  margin: auto;
  display: block;
  background: #282f5f;
  color: #fff;
  font-weight: bold;
}

@media screen and (max-width:1400px){
  .header-wrap ul{
    column-gap: 20px;
  }
  .header-wrap li .btn{
    width: 190px;
    padding-left: 55px;
  }
  .header-wrap li a::after{
    width: 20px;
    left: 15px;
  }
  .header-wrap li a{
    font-size: 1.4vw;
  }
  .header-wrap .logo{
    margin-left: 10px;
  }
  .top h1{
    width: 95%;
  }
  .wrapper{
    margin: auto;
    width: 95%;
  }
  .service-boxes-border{
    column-gap: 2.5%;
    justify-content: center;
    margin-bottom: 50px;
  }
  .service-boxes-border dl{
    width: calc(95% / 3);
    margin-top: 30px;
    height: 310px;
    padding: 20px 15px;
  }
  .service-boxes dl{
    width: calc(95% / 2);
  }
  .service_audit-achievement{
    margin-top: 50px;
    padding: 50px 20px;
  }
  .service_audit-achievement ul{
    column-gap: 2.5%;
  }
  .service_audit-achievement li{
    width: calc(95% / 3);
  }
  .cta{
    margin-top: -190px;
  }
  .cta-inner{
    padding: 50px;
  }
  .info-img img{
    width: calc(100% / 3);
  }
  .footer-wrap{
    width: 95%;
  }
  .breadcrumbs{
    margin-bottom: 30px;
  }
}
@media screen and (max-width:1200px){
  .about-wrap img{
    width: 45%;
  }
  .service_taxation-individual-flex{
    column-gap: 20px;
  }
  .service_taxation-individual-flex img{
    width: 45%;
  }
  .service-boxes-border dl{
    height: 350px;
  }
  .service-boxes-border dt{
    font-size: 1.8vw;
  }
  .cta-inner{
    bottom: 50px;
  }
  .cta-inner p{
    font-size: 2.2vw;
  }
  .cta-inner a{
    font-size: 2vw;
    width: 50%;
  }
  .service-wrap img{
    width: 45%;
  }
  .service-boxes dl{
    padding: 20px 30px 20px;
  }
  .footer-nav{
    column-gap: 30px;
  }
}