@charset "UTF-8";

/*****************************
  headsec
*****************************/
.headsec .fbgbox{
  aspect-ratio: 34 / 23;
  background: url(../../../images/page/qualification-support/head.webp) no-repeat center / cover ;
  width: 40%;
}
.headsec .fbox{
  background: #ECF9FF;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 5%;
  width: 60%;
}
.headsec .inbox {
  max-width: 700px;
}
.headsec .inbox .ttl{
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.6;
}
.headsec .inbox ul {
  margin: 2rem 0;
}
.headsec .inbox li:not(:last-of-type){
  margin-bottom: 1rem;
}
.headsec .inbox li span{
  background: #E37EB7;
  color: #fff;
  font-size: 2rem;
  margin-right: 1rem;
  padding: .5rem 1rem;
}
.headsec .inbox li:first-of-type span{
  background: #7EB0E3;
}

@media only screen and (max-width: 1400px) {
  .headsec .fbox {
    padding: 4vw;
  }
  .headsec .inbox .ttl {
    font-size: 2.5vw;
  }
  .headsec .inbox li span{
    font-size: 2vw;
  }
}
@media only screen and (max-width: 1180px) {
}
@media only screen and (max-width: 1024px) {
}
@media only screen and (max-width: 820px) {
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
  .headsec .fbgbox {
    aspect-ratio: 3 / 2;
    width: 100%;
  }
  .headsec .fbox{
    padding: 2rem 2rem 3rem;
    width: 100%;
  }
  .headsec .inbox .ttl {
    font-size: 2.2rem;
  }
  .headsec .inbox li span{
    display: inline-block;
    font-size: 1.8rem;
  }
}

/*****************************
pagesec-qualification
*****************************/
.pagesec-qualification {
  padding-bottom: 6rem;
}
.pagesec-qualification .qualification{
  gap: 2rem;
}
.pagesec-qualification .fbox{
  aspect-ratio: 1/1;
  background: #7EB0E3;
  border-radius: 50%;
  box-shadow: 4px 4px 10px #ccc;
  color: #fff;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  line-height: 1.4;
  text-shadow: 2px 2px 1px #5a5a5a;
  width: calc(50% - 45px - 4rem);
}
.pagesec-qualification .fbox:last-of-type{
  background: #E37EB7;
}
.pagesec-qualification .plus{
  display: block;
  font-size: 7rem;
  font-weight: bold;
  text-align: center;
  width: 45px;
}

.pagesec-qualification .fbox .sub{
  color: #FFEC00;
  font-size: 3rem;
  font-weight: bold;
}
.pagesec-qualification .fbox .ttl{
  font-size: 5rem;
  font-weight: bold;
}
.pagesec-qualification .fbox span{
  font-size: 2rem;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  .pagesec-qualification .fbox{
    width: calc(50% - 25px - 2rem);
  }
  .pagesec-qualification .plus {
    font-size: 4rem;
    width: 25px;
  }
  .pagesec-qualification .fbox .ttl {
    font-size: 4rem;
  }
  .pagesec-qualification .fbox .sub {
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .pagesec-qualification .qualification {
    gap: 1rem;
  }
  .pagesec-qualification .fbox {
    aspect-ratio: auto;
    border-radius: 6px;
    height: 150px;
    width: 100%;
  }
  .pagesec-qualification .plus {
    line-height: 1;
  }
}

/*****************************
  pagesec-license
*****************************/
.pagesec-license {
  padding: 6rem 0 10rem;
}

.pagesec-license .fieldslist{
  display: flex;
  flex-direction: column;
  gap: 10rem;
  margin-top: 8rem;
}
.pagesec-license .fieldslist .fielditem{
  width: 100%;
}
.pagesec-license .fieldslist .content-ttl{
  background: #DEE4EB;
  display: inline-block;
  position: relative;
  padding: .5rem 2rem .5rem 1rem;
}
.pagesec-license .fieldslist .content-ttl::before{
  content: "";
  background: #DEE4EB;
  position: absolute;
  top: 0;
  left: calc((-100vw + 100%) / 2);
  height: 100%;
  width: calc((100vw - 100% ) / 2);
}
.pagesec-license .fieldslist .content-ttl .ttl{
  font-size: 2.4rem;
  font-weight: 500;
  position: relative;
  z-index: 1;
}
.pagesec-license .fieldslist .content-ttl .ttl span{
  font-size: 1.8rem;
  font-weight: 500;
}
.pagesec-license .fieldslist .content-ttl .ttl::before,
.pagesec-license .fieldslist .content-ttl .ttl::after{
  content: "";
  position: absolute;
  z-index: -1;
}
.pagesec-license .fieldslist .fielditem:nth-of-type(1) .content-ttl .ttl::before{
  aspect-ratio: 41/53;
  background: url(../../../images/page/qualification-support/license_num1.svg) no-repeat center / contain ;
  top: -25px;
  left: -25px;
  width: 30px;
}
.pagesec-license .fieldslist .fielditem:nth-of-type(2) .content-ttl .ttl::before{
  aspect-ratio: 55/54;
  background: url(../../../images/page/qualification-support/license_num2.svg) no-repeat center / contain ;
  top: -25px;
  left: -35px;
  width: 35px;
}
.pagesec-license .fieldslist .fielditem .content-ttl .ttl::after{
  background: url(../../../images/page/qualification-support/license_txt.svg) no-repeat center / contain ;
  aspect-ratio: 73 / 31;
  right: -80px;
  bottom: -30px;
  width: 160px;
}

.pagesec-license .fieldslist .imgbox{
  margin: 4rem 0 1rem;
  gap: .5rem;
}
.pagesec-license .fieldslist .imgbox > .fimgbox{
  width: calc(65% - .25rem);
}
.pagesec-license .fieldslist .imgbox > .fimgboxgr{
  flex-direction: column;
  gap: .5rem;
  width: calc(35% - .25rem);
}
.pagesec-license .fieldslist .imgbox > .fimgboxgr .fimgbox{
  height: calc(50% - .25rem);
  width: 100%;
}
.pagesec-license .fieldslist .imgbox > .fimgbox img,
.pagesec-license .fieldslist .imgbox > .fimgboxgr .fimgbox img{
  object-fit: cover;
  width: 100%;
}

.pagesec-license .fieldslist .subttl{
  color: #7EB0E3;
  font-size: 3rem;
  font-weight: bold;
}
.pagesec-license .fieldslist .txt{
  margin: 1rem 0 3rem;
}
.pagesec-license .fieldslist .info > div{
  border-top: 2px dotted #7EB0E3;
  gap: 2rem;
  margin-top: 1rem;
  padding: 2rem 1rem 1rem;
}
.pagesec-license .fieldslist .info > div > dt{
  background: #7EB0E3;
  border-radius: 30px;
  color: #fff;
  font-weight: bold;
  text-align: center;
  width: 170px;
}
.pagesec-license .fieldslist .info > div > dd{
  width: calc(100% - 190px);
}
.pagesec-license .fieldslist .info > div > dd dl{
  margin-top: 2rem;
}
.pagesec-license .fieldslist .info > div > dd dl > div{
  margin-top: 1rem;
}
.pagesec-license .fieldslist .info > div > dd dl > div dt{
  background: #D4ECEA;
  text-align: center;
  width: 80px;
}
.pagesec-license .fieldslist .info > div > dd dl > div:nth-of-type(2) dt{
  background: #FADCE2;
}
.pagesec-license .fieldslist .info > div > dd dl > div:nth-of-type(3) dt{
  background: #dacef5;
}
.pagesec-license .fieldslist .info > div > dd dl > div dd{
  width: calc(100% - 100px);
}

@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  .pagesec-license .fieldslist .content-ttl {
    padding: .5rem 2rem .5rem 4rem;
  }
}
@media only screen and (max-width: 820px) {
  .pagesec-license .fieldslist .subttl{
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .pagesec-license .fieldslist{
    margin-top: 5rem;
  }
  .pagesec-license .fieldslist .content-ttl {
    padding: .5rem 1rem .5rem 0;
  }
  .pagesec-license .fieldslist .content-ttl .ttl {
    font-size: 2rem;
  }
  .pagesec-license .fieldslist .fielditem:nth-of-type(1) .content-ttl .ttl::before {
    top: -25px;
    left: -10px;
    width: 20px;
  }
  .pagesec-license .fieldslist .fielditem:nth-of-type(2) .content-ttl .ttl::before {
    top: -20px;
    left: -15px;
    width: 25px;
  }
  .pagesec-license .fieldslist .fielditem .content-ttl .ttl::after {
    right: -50px;
    width: 120px;
  }

  .pagesec-license .fieldslist .imgbox > .fimgbox,
  .pagesec-license .fieldslist .imgbox > .fimgboxgr,
  .pagesec-license .fieldslist .info > div > dt,
  .pagesec-license .fieldslist .info > div > dd,
  .pagesec-license .fieldslist .info > div > dd dl > div dd{
    width: 100%;
  }
  .pagesec-license .fieldslist .imgbox > .fimgboxgr{
    flex-direction: row;
    gap: .5rem;
  }
  .pagesec-license .fieldslist .imgbox > .fimgboxgr .fimgbox{
    height: 100%;
    width: calc(50% - .25rem);
  }
  .pagesec-license .fieldslist .imgbox > .fimgboxgr .fimgbox img{
    object-fit: contain;
  }

  .pagesec-license .fieldslist .subttl {
    font-size: 2rem;
  }
  .pagesec-license .fieldslist .info > div{
    gap: 1rem;
  }
  .pagesec-license .fieldslist .info > div > dd dl > div dd{
    margin-top: 1rem;
  }
}

/*****************************
pagesec-contest
*****************************/
.pagesec-contest .contest{
  margin: 4rem 0 ;
}
.pagesec-contest .contest .ttl{
  color: #7EB0E3;
  font-size: 3rem;
  font-weight: bold;
  margin-bottom: 2rem;
}
.pagesec-contest .contest .ttl span{
  background: #7EB0E3;
  border-radius: 50px;
  color: #fff;
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  max-width: 260px;
  padding: .5rem 2rem;
  text-align: center;
}

.pagesec-contest .info {
  border: 1px solid #7EB0E3;
  border-radius: 6px;
  padding: 3rem 4rem;
}
.pagesec-contest .info .fimgbox p{
  margin-top: 1rem;
  text-align: left;
}
@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  .pagesec-contest .contest .ttl{
    font-size: 2.8rem;
  }
}
@media only screen and (max-width: 820px) {
  .pagesec-contest .contest .fimgbox{
    margin: 0 auto ;
    width: 80%;
  }
  .pagesec-contest .contest .fbox{
    margin-top: 4rem;
    width: 100%;
  }
  .pagesec-contest .info{
    padding: 2rem;
  }
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .pagesec-contest .contest .fimgbox{
    width: 100%;
  }
  .pagesec-contest .contest .ttl span{
    margin-bottom: 1rem;
  }
  .pagesec-contest .contest .ttl{
    font-size: 2.8rem;
    line-height: 1.4;
  }
  .pagesec-contest .info{
    gap: 2rem;
  }
  .pagesec-contest .info .fimgbox{
    width: 100%;
  }
}

/*****************************
  qssec
*****************************/
.qssec{
  background: #fff;
  border-radius: 6px;
  padding: 20px;
  margin: 30px 0;
  position: relative;
}
.qssec::before{
  content: "";
  position: absolute;
  background: url(../../../images/page/qualification-support/ono.webp) no-repeat bottom / contain;
  right: 0;
  bottom: 0;
  width: 15%;
  z-index: 1;
  height: 100%;
}
.qsttl h3{
  background: #dcdef3;
  border-radius: 20px;
  color: #7a83ab;
  font-weight: bold;
  padding: 6px 10px;
  text-align: center;
}
.faqbox{
  margin: 20px 0;
  width: 80%;
}
.qtxt{
  color: #7a83ab;
  font-size: 18px;
  font-weight: bold;
}
.namebox{
  text-align: right;
  margin-top: 20px;
}
@media only screen and (max-width: 767px) {
  .qssec::before{
    display: none;
  }
  .faqbox{
    width: 100%;
  }
  .qtxt{
    font-size: 16px;
  }
}

/*****************************
  qssec2
*****************************/
.qssec2{
  margin-top: 30px;
}
.qs2box{
  width: 80%;
  margin: 0 auto;
}
.qssec2 p{
  text-align: center;
  font-weight: 500;
  font-size: 20px;
  margin: 20px 0;
}
@media only screen and (max-width: 820px) {
  .qs2box{
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .qssec2 p{
    font-size: 16px;
    text-align: left;
  }
}