@charset "UTF-8";

/******************************
  common
******************************/
.imgbox{
  text-align: center;
}
.link-txtunder,
.singlecontent a{
  color: #004B9E;
  text-decoration: underline;
}
.link-txtunder:hover,
.singlecontent a:hover{
  text-decoration: none;
}
.singlecontent p,
.txtbox p:not(:last-of-type){
  margin-bottom: 1rem;
}
.kome,
.ten{
  padding-left: 2rem;
  position: relative;
}
.kome::before,
.ten::before{
  content:"※";
  position: absolute;
  top: 0;
  left: 0;
}
.ten::before{
  content:"・";
}
.box{
  margin-top: 2rem;
  padding-top: 2rem;
}
.bg1{
  background: #F7F4F1;
}
.anchor{
  margin-top: -90px;
  padding-top: 90px;
}

/* 202604newcss */
.cmnbg1{
  background: repeating-linear-gradient(60deg, #e7ebef, #e7ebef 10px, #e5e9ee 0, #e5e9ee 25px);
}
.cmnbg2{
  background: repeating-linear-gradient(60deg, #174e77, #174e77 10px, #0f4873 0, #0f4873 25px);
}
.cmnbg3{
  background: #e6ebf0;
}


/******************************
  font
******************************/
.ffRbt {
  font-family: "Roboto", serif;
}
.ffBN {
  font-family: "Bebas Neue", sans-serif;
}

/******************************
  inner
******************************/
.inner1,
.inner2,
.inner3{
  margin: 0 auto;
  max-width: 1120px;
  padding: 0 2rem;
}
.inner2{
  max-width: 1920px;
}
.inner3{
  max-width: 1280px;
}
.innernp{
  margin: 0 auto;
  max-width: 1920px;
}
.inner2 .inner1,
.inner2 .inner3,
.inner3 .inner1{
  padding: 0 !important;
}

@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) {
    
}

/******************************
  flex
******************************/
.flexbox1{
  display: flex;
  flex-wrap: wrap;
}
.flexbox2{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.flexbox3{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.flex{
  display: flex;
}
.frr{
  flex-direction: row-reverse;
}
.fac{
  align-items: center;
}
.fast{
  align-items: stretch;
}
.fafe{
  align-items: flex-end;
}
.fafs{
  align-items: flex-start;
}
.fabl{
  align-items: baseline;
}

.fbox,
.ftxtbox,
.fimgbox{
  width: 48%;
}
.fimgbox{
  text-align: center;
}

/******************************
  ttl
******************************/
.ttlbox1{
  text-align: center;
}
.ttlbox1 span{
  background: linear-gradient(65deg ,#7EB0E3 , #F0AAC8);
  display: inline-block;
  line-height: 1;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
}
.ttlbox1 .ttl span{
  font-size: 1.8rem;
  font-weight: bold;
}
.ttlbox1 .enttl span{
  font-family: "Roboto", serif;
  font-size: 5rem;
  font-weight: 500;
}

.ttlbox2{
  text-align: center;
}
.ttlbox2 .ttl{
  font-size: 4rem;
  font-weight: bold;
}
.ttlbox2.white_text .ttl{
font-size: 4rem;
font-weight: bold;
color: #fff;
text-shadow: 0px 0px 6px #414141;
}
@media screen and (max-width: 820px) {
.ttlbox2.white_text .ttl{
font-size: 3rem;
}
}
@media screen and (max-width: 767px) {
.ttlbox2.white_text .ttl{
font-size: 2.4rem;
}
}

.ttlbox3{
  position: relative;
}
.ttlbox3::before{
  content: "";
  background-image: linear-gradient(to left, #46463E 3px, transparent 3px);
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 14px 2px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  height: 2px;
  width: 100%;;
}
.ttlbox3 .ttl{
  background: #fff;
  color: #7EB0E3;
  display: inline-block;
  font-size: 3.2rem;
  font-weight: 500;
  padding-right: 2rem;
  position: relative;
}

.ttlbox4 {
  text-align: center;
}
.ttlbox4 .ttl{
  display: inline-block;
  font-size: 4rem;
  font-weight: bold;
  position: relative;
  padding-left: 4rem;
}
.ttlbox4 .ttl::before{
  content: "";
  aspect-ratio: 1/1;
  background: #B5CEE6;
  border-radius: 50%;
  position: absolute;
  top: 52%;
  left: 0;
  transform: translateY(-50%);
  width: 2rem;
}

.ttlbox5{
  text-align: center;
}
.ttlbox5 .ttl{
  background: #7EB0E3;
  border-radius: 20px;
  color: #fff;
  display: inline-block;
  font-size: 3.2rem;
  font-weight: bold;
  padding: 0 4rem;
}

/* 202604newcss */
.imgttl {
  text-align: center;
}
.imgttl picture{
  display: block;
  text-align: center;
}
.ttlbox6{
  text-align: center;
}
.ttlbox6 .ttl{
  border-right: 1px solid #fff;
  border-left: 1px solid #fff;
  color: #fff;
  display: inline-block;
  font-size: 4rem;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 4px;
  padding: 0 4rem;
}

@media only screen and (max-width: 1180px) {
  
}
@media only screen and (max-width: 1024px) {
  
}
@media only screen and (max-width: 820px) {
  .ttlbox2 .ttl,
  .ttlbox4 .ttl{
    font-size: 3rem;
  }
  .ttlbox5 .ttl{
    font-size: 2.8rem;
  }
}
@media only screen and (max-width: 768px) {
  
}
@media only screen and (max-width: 767px) {
  .ttlbox1 .ttl {
    line-height: 1;
  }
  .ttlbox1 .enttl span{
    font-size: 4rem;
  }
  .ttlbox2 .ttl,
  .ttlbox3 .ttl{
    font-size: 2.4rem;
  }

  .ttlbox4 .ttl {
    padding-left: 2rem;
  }
  .ttlbox4 .ttl::before {
    width: 1rem;
  }
  .ttlbox5 .ttl{
    font-size: 2.2rem;
  }

  /* 202604newcss */
  .ttlbox6 .ttl{
    font-size: 3rem;
    padding: 0 3rem;
  }
}

/******************************
  btn
******************************/
.morebtn1,
.morebtn3 {
  text-align: center;
}
.morebtn1 a,
.morebtn3 a{
  background: #7EB0E3;
  border: 2px solid #7EB0E3;
  border-radius: 30px;
  color: #fff;
  display: inline-block;
  font-weight: 500;
  width: 350px;
  max-width: 100%;
  opacity: 1;
  padding: .5rem 2rem;
  position: relative;
  transition: .5s;
}
.morebtn1 a::before{
  content: "";
  aspect-ratio: 3 / 4;
  background: #fff;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  position: absolute;
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
  transition: .5s;
  width: 10px;
}
.morebtn3 a i{
  color: #fff;
  position: absolute;
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
  transition: .5s;
}
.morebtn1 a:hover,
.morebtn3 a:hover{
  background: #fff;
  color: #7EB0E3;
}
.morebtn1 a:hover::before{
  background: #7EB0E3;
}
.morebtn3 a:hover i{
  color: #7EB0E3;
}

/* pink */
.morebtn1 a.pink,
.morebtn3 a.pink{
  background: #E5BCCE;
  border-color: #E5BCCE;
}
.morebtn1 a.pink:hover,
.morebtn3 a.pink:hover{
  background: #fff;
  color: #E5BCCE;
}
.morebtn1 a.pink:hover::before{
  background: #E5BCCE;
}

.morebtn3 a.pink:hover i{
  color: #E5BCCE;
}

/* purple */
.morebtn1 a.purple,
.morebtn3 a.purple{
  background: #e661a7;
  border-color: #e661a7;
}
.morebtn1 a.purple:hover,
.morebtn3 a.purple:hover{
  background: #fff;
  color: #e661a7;
}
.morebtn1 a.purple:hover::before{
  background: #e661a7;
}

.morebtn3 a.purple:hover i{
  color: #e661a7;
}



.morebtn2 {
  text-align: center;
}
.morebtn2 a{
  background: #7EB0E3;
  border: 2px solid #7EB0E3;
  border-radius: 6px;
  color: #fff;
  display: block;
  opacity: 1;
  padding: 1rem 0;
  position: relative;
  transition: .5s;
}
.morebtn2 a::before{
  content: "";
  aspect-ratio: 1/1;
  background: #3369A0;
  clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  border-radius: 0 0 6px 0;
  position: absolute;
  right: 2px;
  bottom: 2px;
  width: 15px;
}
.morebtn2 a:hover{
  background: #fff;
  color: #7EB0E3;
}


.openbtn {
  background: #7EB0E3;
  border: 2px solid #7EB0E3;
  border-radius: 30px;
  color: #fff;
  display: block;
  opacity: 1 !important;
  margin: 0 auto;
  max-width: 250px;
  padding: .5rem 2rem;
  transition: .5s;
  text-align: center;
}
.openbtn span{
  display: inline-block;
  font-weight: 500;
  position: relative;
  padding-left: 2rem;
}
.openbtn span::before{
  content: "";
  aspect-ratio: 3 / 4;
  background: #fff;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  transition: .5s;
  width: 10px;
}
.openbtn:hover{
  background: #fff;
  color: #7EB0E3;
}
.openbtn:hover span::before{
  background: #7EB0E3;
}
.standbybox{
  display: none;
}


/* 202604newcss */
.mbtn1,
.mbtn2{
  text-align: center;
}
.mbtn1 a{
  background: #fff;
  box-shadow: 3px 4px rgba(0, 75, 120, .3);
  border-radius: 50px;
  display: inline-block;
  max-width: 650px;
  opacity: 1;
  padding: 1rem 2rem;
  position: relative;
  transition: .5s;
  width: 100%;
}
.mbtn1 a span{
  display: inline-block;
  font-weight: bold;
  padding-right: 1.6rem;
  position: relative;
}
.mbtn1 a span::before{
  content: "\f105";
  font: var(--fa-font-solid);
  position: absolute;
  top: 52%;
  right: 0;
  transform: translateY(-50%);
}
.mbtn1 a:hover{
  background: #004b78;
  box-shadow: 0 0 rgba(0, 75, 120, .3);
  color: #fff;
}

.mbtn2 a{
  background: #fff;
  border: 1px solid #004b78;
  display: block;
  margin: 0 auto;
  max-width: 350px;
  opacity: 1;
  padding: .8rem 2rem;
  position: relative;
  transition: .5s;
}
.mbtn2 a::before{
  content: "\f105";
  font: var(--fa-font-solid);
  position: absolute;
  top: 50%;
  right: 1.2rem;
  transform: translateY(-50%);
}
.mbtn2 a span{
  display: inline-block;
  font-weight: bold;
  padding-right: 1.6rem;
  position: relative;
}
.mbtn2 a:hover{
  background: #004b78;
  color: #fff;
}

@media only screen and (max-width: 1180px) {
}
@media only screen and (max-width: 1024px) {
}
@media only screen and (max-width: 820px) {
  .mbtn1 a{
    max-width: 500px;
  }
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
}

/******************************
  tbl
******************************/

/******************************
  header
******************************/
.cmnhead{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;
}
.cmnhead .inner{
  background: rgba(0,75,120,.8);
  padding: 0 2rem;
}
.cmnhead .logo{
  width: 80px;
}

.pcnavgr .cmnnav{
  gap: 1rem;
}
.pcnavgr .nav > li > a{
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 75px;
  opacity: 1;
  padding: 0 1.5rem;
  position: relative;
  transition: .5s;
}
.pcnavgr .nav > li > a.nowpage,
.pcnavgr .nav > li > a:hover,
.headbtn a:hover{
  background: #fff;
  color: #004b78;
  opacity: 1;
}
.pcnavgr .nav2 > li:first-of-type{
  position: relative;
}
.pcnavgr .nav2 > li:first-of-type::before{
  content: "";
  background: #fff;
  position: absolute;
  top: 50%;
  left: -.5rem;
  transform: translateY(-50%);
  height: 50%;
  width: 1px;
}

.mega{
  background: rgba(255, 255, 255,.9);
  padding: 10rem 2rem 4rem;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  transition: .5s;
  z-index: -1;
}
.pcnavgr .haschild:hover .mega{
  pointer-events: all;
  opacity: 1;
  transform: translateY(0);
}
.megainner{
  max-width: 800px;
  margin: 0 auto;
}
/* .mega1 .megainner{
  max-width: 1060px;
} */
.pcnavgr .mega a,
.pcnavgr .mega a p{
  font-weight: 500;
}
.pcnavgr .mega a{
  display: block;
  overflow: hidden;
}
.pcnavgr .mega .coursemm{
  margin-top: 1rem;
}
.pcnavgr .mega .megapointer{
  font-size: 1.8rem;
  font-weight: bold;
  padding-left: 2rem;
  position: relative;
}
.pcnavgr .mega .megapointer::before{
  content: "";
  aspect-ratio: 2 / 3;
  background: #004b78;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 12px;
}

.pcnavgr .mega .megapointer,
.pcnavgr .mega .imgbox{
  font-weight: bold;
}
.pcnavgr .mega .megapointer2,
.pcnavgr .mega .megapointer3,
.pcnavgr .mega .imgbox{
  margin-bottom: .5rem;
}
.pcnavgr .mega ul{
  gap: 2rem
}
.pcnavgr .mega li{
  width: calc(100% / 3 - 2rem);
}
/* .pcnavgr .mega1 li{
  width: calc(100% / 4 - 2rem);
} */
.pcnavgr .mega li .imgbox{
  overflow: hidden;
}
.pcnavgr .mega li .imgbox img{
  transition: .5s;
}
.pcnavgr .mega li a:hover .imgbox img{
  transform: scale(1.3);
}
.pcnavgr .mega a.nowpage,
.pcnavgr .mega a:hover{
  color: #f29600;
  opacity: 1;
  text-decoration: underline;
}
.headbtn a{
  border: 1px solid #fff;
  border-radius: 50px;
  color: #fff;
  display: inline-block;
  padding: .2rem 2rem;
  transition: .5s;
}

.spbtn {
  aspect-ratio: 1/1;
  border-radius: 5px;
  cursor: pointer;
  display: block;
  position: absolute;
  top: 1rem;
  right: 1rem;
  transition: .5s;
  width: 50px;
  z-index: 9999;
}
.spbtn span{
  background: #fff;
  border-radius: 2px;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  height: 2px;
  transition: all .4s;
  transform: translate(-50%,-50%);
  width: 45%;
}
.spbtn span:nth-of-type(1) {
  top: 35%;
}
.spbtn span:nth-of-type(3) {
  top: 65%;
}
.spbtn.active span{
  background: #004b78;
  top: 50%;
  left: 50%;
  width: 30%;
}
.spbtn.active span:nth-of-type(1) {
  transform: translate(-50%,-50%) rotate(-135deg);
}
.spbtn.active span:nth-of-type(2) {
  opacity: 0;
}
.spbtn.active span:nth-of-type(3){
  transform: translate(-50%,-50%) rotate(135deg);
  width: 30%;
}
.splogo {
  max-width: 130px;
  margin-bottom: 2rem;
}
.splogo img{
  width: 100%;
}

.spnavgr{
  display: none;
}

@media only screen and (max-width: 1350px) {
  .pcnavgr .nav > li > a{
    padding: 0 1rem;
  }
}
@media only screen and (max-width: 1250px) {
  .pcnavgr .nav > li > a{
    padding: 0 .5rem;
  }
  .headbtn a{
    padding: .2rem 1rem;
  }
}
@media only screen and (max-width: 1180px) {
}
@media only screen and (max-width: 1179px) {
  .cmnhead .inner {
    padding: 1rem 1rem 1rem 2rem;
  }
  .pcnavgr,
  .spnavgr .child{
    display: none;
  }
  .spnavgr{
    display: block;
    position: fixed;
    top: 0;
    right: 0;
  }
  .spnavgr .cmnnav a{
    display: block;
  }
  .spnavgr .cmnnav{
    background: rgba(0,75,120,1);
    background: rgba(255,255,255,.9);
    overflow-y: scroll;
    max-width: 350px;
    padding: 2.5rem 2.5rem 3rem;
    position: fixed;
    top: 0;
    right: -400px;
    scrollbar-color: #004b78 white;
    scrollbar-width: thin;
    height: 100vh;
    width: 100%;
    transition: .5s;
  }
  .spnavgr .cmnnav.active{
    right: 0;
  }
  .spnavgr .cmnnav > ul > li{
    margin-top: 1rem;
  }
  .spnavgr .cmnnav > ul > li > a{
    background: rgba(0,75,120,.8);
    color: #fff;
    display: block;
    padding: .2rem .5rem;
    position: relative;
  }
  .spnavgr .cmnnav .haschild::before,
  .spnavgr .cmnnav .haschild::after{
    content: "";
    background: #fff;
    position: absolute;
    top: 45%;
    right: 1.5rem;
    height: 3px;
    width: 15px;
  }
  .spnavgr .cmnnav .haschild::after{
    transform: rotate(90deg);
    transition: transform .3s linear;
  }
  .spnavgr .cmnnav .haschild.active::after{
    transform: rotate(360deg);
  }
  .spnavgr .cmnnav .child{
    padding-bottom: 1rem;
  }
  .spnavgr .cmnnav .child{
    margin-left: 1rem;
  }
  .spnavgr .cmnnav .child ul{
    margin-left: 1.5rem;
  }
  .spnavgr .cmnnav .child ul,
  .spnavgr .cmnnav .child > li,
  .spnavgr .cmnnav .child > li li{
    margin-top: .5rem;
  }
  .spnavgr .cmnnav .child a{
    border-bottom: 2px solid #004b78;
    font-weight: 500;
    padding-left: .5rem;
  }
  .spnavgr .cmnnav > ul > li > a.nowpage,
  .spnavgr .cmnnav .child a.nowpage{
    background: #e6ebf0;
    border-color: #004b78;
    font-weight: bold;
    opacity: 1;
  }
  .spnavgr .cmnnav > ul > li > a.nowpage{
    background: #004b78;
    color: #fff;
  }
  .spnavgr .cmnnav .child a.nowpage{
    border-width: 3px;
  }
}
@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) {
}


/******************************
  footer
******************************/
.cmnfot1{
  background: #fff;
  padding: 4rem 0 5rem;
}
.cmnfot1 > .inner{
  padding-top: 5rem ;
}
.cmnfot1 > .inner::before{
  content: "";
  background: #004b78;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  height: 1px;
  width: calc(100% - 4rem);
}
.cmnfot1 a{
  display: block;
  opacity: 1;
  transition: .5s;
}
.cmnfot1 a:hover{
  background: #e6ebf0;
}
.cmnfot1 .flist {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 28%;
}
.cmnfot1 .flist:not(:first-of-type){
  border-left: 1px solid #004b78;
  padding-left: 4rem;
  width: calc(28% + 4rem);
}
.cmnfot1 .flist > li > a{
  display: block;
  font-weight: 500;
  padding-left: 1.8rem;
  position: relative;
}
.cmnfot1 .flist > li > a::before{
  content: "\f105";
  font: var(--fa-font-solid);
  position: absolute;
  top: 6px;
  left: 0;
  /* top: 50%;
  transform: translateY(-50%); */
}
.cmnfot1 .flist > li.bnr a{
  border: none;
  display: inline-block;
  margin-top: 1.5rem;
  padding: 0;
}
.cmnfot1 .flist > li.bnr a::before{
  display: none;
}
.cmnfot1 .flist > li > ul,
.cmnfot1 .flist > li > ul > li > ul{
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-top: .5rem;
  margin-left: 2rem;
}
.cmnfot1 .flist > li > ul > li > ul{
  margin-left: 1.5rem;
}

.cmnfot2{
  background: #e6ebf0;
  color: #46463E;
  padding: 2rem 0;
}
.cmnfot2 .finfo{
  gap: 1rem;
}
.cmnfot2 address{
  font-style: normal;
}
.cmnfot2 address p{
  line-height: 1.6;
}
.cmnfot2 address p:first-of-type{
  font-weight: 500;
}
.cmnfot2 address a{
  color: #46463E;
  margin-right: 1rem;
}
.cmnfot2 .fcopy{
  text-align: right;
}
.cmnfot2 .fcopy ul{
  justify-content: end;
}
.cmnfot2 .fcopy li:first-of-type{
  margin-right: 2rem;
}
.cmnfot2 .fcopy a,
.cmnfot2 .fotcopy{
  color: #46463E;
  font-size: 1.4rem;
}
.cmnfot2 .fcopy a:hover{
  text-decoration: underline;
}

.fixbnr.hide,
.fixbnr.fothide,
.spfixbnr.hide,
.spfixbnr.fothide{
  pointer-events: none;
  opacity: 0;
}
.fotfix,
.spfotfix{
  position: fixed;
  transition: .5s;
  z-index: 5;
}
.fotfixgr{
  display: flex;
  flex-direction: column;
  gap: 2rem;
  top: 100px;
  right: 0;
}
.fotfixgr li{
  writing-mode: vertical-lr;
}
.fotfixgr li a{
  background: #004b78;
  border-radius: 10px 0 0 10px;
  border: 1px solid #fff;
  border-right: none;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 2px;
  gap: .5rem;
  height: 150px;
  opacity: 1;
  padding: 1rem .5rem;
  position: relative;
  width: 5rem;
  transition: .5s;
}
.fotfix-request a::after,
.fotfix-blog a::after{
  content: "";
  aspect-ratio: 221/150;
  background: url(../images/common/fix_pc_request.svg) no-repeat center / contain;
  display: block;
  width: 4rem;
}
.fotfix-blog a::after{
  background: url(../images/common/fix_pc_blog.svg) no-repeat center / contain;
}
.fotfixgr li a:hover{
  background: #f29600;
}

.fotfix-oc{
  filter: drop-shadow(0 0 5px rgba(0, 75, 120,.2));
  right: 1rem;
  bottom: 1rem;
  width: 170px;
}
.fotfix-oc #ocfixclzbtn{
  aspect-ratio: 1 / 1;
  background: #fff;
  border: 2px solid #004b78;
  border-radius: 50px;
  position: absolute;
  top: -4px;
  left: -4px;
  width: 2rem;
}
.fotfix-oc #ocfixclzbtn::before,
.fotfix-oc #ocfixclzbtn::after{
  content: "";
  background: #004b78;
  position: absolute;
  top: 7px;
  left: 3px;
  height: 2px;
  width: 1rem;
}
.fotfix-oc #ocfixclzbtn::before{
  transform: rotate(45deg) ;
}
.fotfix-oc #ocfixclzbtn::after{
  transform: rotate(-45deg) ;
}
.fotfix-oc svg{
  width: 100%;
}
.fotfix-oc .cls-1 {
  mask: url(#fixoc-mask);
}
.fotfix-oc .cls-2 {
  filter: url(#fixoc-luminosity-noclip);
}
.fotfix-oc .cls-3 {
  filter: url(#fixoc-drop-shadow-1);
}
.fotfix-oc .cls-4 {
  fill: #fff;
}
.fotfix-oc .cls-5 {
  fill: #008caa;
}
.fotfix-oc .cls-6 {
  opacity: .5;
}
.fotfix-oc .cls-7 {
  fill: none;
  stroke: #fff;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.spfotfix{
  display: none;
  position: fixed;
  text-align: center;
}

.spfotfixgr{
  left: 1rem;
  bottom: 0;
  width: calc(100% - 2rem);
}
.spfotfixgr li{
  width: calc(50% - .5rem);
}
.spfotfixgr li a{
  background: #004b78;
  border: 1px solid #fff;
  border-bottom: none;
  border-radius: 10px 10px 0 0;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  gap: .5rem;
  line-height: 1.6;
  padding: 1rem 0 ;
}
.spfotfixgr li:nth-of-type(2) a{
  background: #008caa;
}
.spfotfixgr li a::before{
  content: "";
  display: block;
}
.spfotfixgr li:nth-of-type(1) a::before{
  aspect-ratio: 181/150;
  background: url(../images/common/fix_sp_request.svg) no-repeat center / contain;
  width: 2.6rem;
}
.spfotfixgr li:nth-of-type(2) a::before{
  aspect-ratio: 139/150;
  background: url(../images/common/fix_sp_oc.svg) no-repeat center / contain;
  width: 2.2rem;
}

.spblogfix{
  left: auto;
  right: .5rem;
  bottom: 6.5rem;
  z-index: 1;
}
.spblogfix a{
  aspect-ratio: 1 / 1;
  background: #f29600;
  border-radius: 100px;
  border: 1px solid #fff;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-size: 1.5rem;
  padding: .6rem 1rem 0;
  position: relative;
  text-align: center;
  width: 80px;
}
.spblogfix a::before{
  content: "";
  aspect-ratio: 37/25;
  background: url(../images/common/fix_sp_blog.svg) no-repeat center / contain;
  display: block;
  width: 3.8rem;
}



@media only screen and (max-width: 1180px) {
  .cmnfot1 .flist {
    width: 30%;
  }
  .cmnfot1 .flist:not(:first-of-type) {
    width: calc(30% + 4rem);
  }
}
@media only screen and (max-width: 1024px) {
  .cmnfot1 > .inner {
    padding: 4rem 4rem 0;
  }
}
@media only screen and (max-width: 820px) {
  .cmnfot1 > .inner {
    padding: 4rem 3rem 0;
  }
  .cmnfot1 .flist,
  .cmnfot1 .flist:not(:first-of-type) {
    width: 30%;
  }
  .cmnfot1 .flist:not(:first-of-type){
    padding-left: 2.5rem;
  }
  .cmnfot1 .flist > li > a {
    padding-left: 1.6rem;
  }
  .cmnfot1 .flist > li > a::before {
    font-size: 1.4rem;
    top: 8px;
  }

  .cmnfot2 .fcopy {
    margin-left: auto;
  }
}
@media only screen and (max-width: 768px) {
}
@media only screen and (max-width: 767px) {
  .cmnfot1 {
    padding: 4rem 0 5rem;
  }
  .cmnfot1 > .inner,
  .cmnfot1 .flist{
    gap: .8rem;
  }
  .cmnfot1 > .inner{
    padding: 3rem 2rem 0;
  }
  .cmnfot1 .flist,
  .cmnfot1 .flist:not(:first-of-type) {
    margin: 0 auto;
    width: 90%;
  }
  .cmnfot1 .flist:not(:first-of-type){
    border: none;
    padding-left: 0;
  }
  .cmnfot1 .flist > li > ul,
  .cmnfot1 .flist > li > ul > li > ul {
    margin-left: 1.5rem;
  }
  .cmnfot1 .flist > li.bnr {
    margin-top: 2rem;
    text-align: center;
  }

  .cmnfot2{
    padding: 3rem 0 1rem;
  }
  .cmnfot2 .finfo,
  .cmnfot2 .fcopy {
    width: 100%;
  }
  .cmnfot2 .finfo{
    align-items: flex-start;
  }
  .cmnfot2 .finfo address{
    font-size: 3.5vw;
  }
  .cmnfot2 .fcopy {
    margin-top: 1rem;
  }

  .fotfix{
    display: none;
  }
  .spfotfixgr{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
  }
  .spfotfix-blog{
    display: block;
  }
  .spblogfix{
    display: block;
  }
}
@media only screen and (max-width: 400px) {
  .spfotfixgr {
    left: .5rem;
    bottom: 0;
    width: calc(100% - 1rem);
  }
  .spfotfixgr li {
    width: calc(50% - .25rem);
  }
  .spfotfixgr li a{
    font-size: 4vw;
  }
}

/* OC ブログ詳細ボタン */
.blogbtn a{
  background: #b69ef0;
  border-radius: 5px;
  color: #fff;
  display: inline-block;
  margin-top: 1rem;
  padding: .5rem;
  text-align: center;
  width: 100%;
}

.fotimg{
  text-align: center;
  margin-bottom: 30px;
}