@charset "UTF-8";
h1.title-who {
  width: 34.2%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  h1.title-who {
    width: 218px;
  }
}
h1.title-who span {
  display: inline-block;
  position: relative;
}

h1.cormorant-garamond,
h2.cormorant-garamond {
  font-size: 3.6rem;
  letter-spacing: -0.03em;
  text-align: center;
  font-weight: bold;
  transform: scaleX(0.9);
  margin-bottom: 6%;
}
@media screen and (min-width: 768px) {
  h1.cormorant-garamond,
  h2.cormorant-garamond {
    margin-bottom: 0;
  }
}

h1.page-sub-title01,
h2.page-sub-title01 {
  text-align: center;
  font-size: 2.82rem;
  /*    line-height: 1.2em;*/
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  h1.page-sub-title01,
  h2.page-sub-title01 {
    margin-bottom: 10px;
  }
}
h1.page-sub-title01 span.en,
h2.page-sub-title01 span.en {
  display: inline-block;
}
h1.page-sub-title01 span.jp,
h2.page-sub-title01 span.jp {
  display: block;
  text-align: center;
  font-size: 0.8rem;
  font-weight: 500;
  margin-top: 2%;
}
@media screen and (min-width: 768px) {
  h1.page-sub-title01 span.jp,
  h2.page-sub-title01 span.jp {
    margin-top: 10px;
  }
}

h1.archive,
h1.whoweare,
h2.whoweare {
  position: relative;
  padding-bottom: 4%;
}
@media screen and (min-width: 768px) {
  h1.archive,
  h1.whoweare,
  h2.whoweare {
    padding-bottom: 25px;
  }
}
h1.archive::after,
h1.whoweare::after,
h2.whoweare::after {
  content: " ";
  display: block;
  width: 50%;
  height: 1px;
  background: #000;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
}
@media screen and (min-width: 768px) {
  h1.archive::after,
  h1.whoweare::after,
  h2.whoweare::after {
    width: 6.1em;
  }
}

h1.wing,
h1.teamsdrivers,
h2.wing,
h2.teamsdrivers {
  position: relative;
  padding-bottom: 4%;
  margin-bottom: 10%;
}
@media screen and (min-width: 768px) {
  h1.wing,
  h1.teamsdrivers,
  h2.wing,
  h2.teamsdrivers {
    margin-bottom: 40px;
    padding-bottom: 25px;
  }
}
h1.wing::after,
h1.teamsdrivers::after,
h2.wing::after,
h2.teamsdrivers::after {
  content: " ";
  display: block;
  width: 50%;
  height: 1px;
  background: #000;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
}
@media screen and (min-width: 768px) {
  h1.wing::after,
  h1.teamsdrivers::after,
  h2.wing::after,
  h2.teamsdrivers::after {
    width: 6.1em;
  }
}

p.page-txt01 {
  font-size: 0.88rem;
  line-height: 1.6em;
  margin-top: 5%;
}
@media screen and (min-width: 768px) {
  p.page-txt01 {
    font-size: 16px;
    line-height: 1.8em;
  }
}

section.page-cont {
  width: calc(100% - 4em);
  max-width: 1360px;
  margin: 0 auto;
  margin-top: 8%;
}
@media screen and (min-width: 768px) {
  section.page-cont {
    margin-top: 60px;
  }
}

div.who-image01 {
  width: 90%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  div.who-image01 {
    max-width: 1080px;
  }
}

div.who-cont01-box {
  margin-bottom: 8%;
  /*who-image-box01*/
}
@media screen and (min-width: 768px) {
  div.who-cont01-box {
    display: flex;
    max-width: 1080px;
    margin: 0 auto;
    margin-bottom: 60px;
  }
}
@media screen and (min-width: 768px) {
  div.who-cont01-box div.who-image-box01 {
    width: 46%;
    order: 2;
  }
}
@media screen and (min-width: 768px) {
  div.who-cont01-box div.who-txt-box {
    width: 49%;
    margin-right: 5%;
    order: 1;
  }
}
@media screen and (min-width: 1000px) {
  div.who-cont01-box div.who-txt-box {
    width: 47%;
    margin-right: 7%;
  }
}
div.who-cont01-box div.who-txt-box h3 {
  font-size: 1.25rem;
  line-height: 1.4em;
  margin-top: 5%;
}
@media screen and (min-width: 768px) {
  div.who-cont01-box div.who-txt-box h3 {
    font-size: 30px;
    margin: 0;
  }
}

/*who-cont01-box*/
section.who02 {
  background: #c7d4db;
  padding: 10% 0;
}
@media screen and (min-width: 768px) {
  section.who02 {
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
    padding: 80px 0;
  }
}
section.who02 h2.page-sub-title01 {
  margin-bottom: 10%;
}
@media screen and (min-width: 768px) {
  section.who02 h2.page-sub-title01 {
    margin-bottom: 40px;
  }
}
section.who02 p {
  width: 90%;
  margin: 0 auto;
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  section.who02 p {
    width: 87.8%;
    margin-bottom: 30px;
  }
}
section.who02 figure {
  width: 90%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  section.who02 figure {
    width: 87.8%;
  }
}

/*section.who02*/
section.who03 {
  padding: 10% 0;
}
@media screen and (min-width: 768px) {
  section.who03 {
    padding: 150px 0 0 0;
  }
}

div.greeting-box {
  /*greeting-img*/
  /*greeting-txt*/
}
@media screen and (min-width: 768px) {
  div.greeting-box {
    width: 90%;
    max-width: 1080px;
    margin: 0 auto;
    margin-top: 60px;
    display: flex;
  }
}
@media screen and (min-width: 768px) {
  div.greeting-box div.greeting-img {
    width: 48%;
  }
}
@media screen and (min-width: 768px) {
  div.greeting-box div.greeting-txt {
    width: 48%;
    margin-left: 4%;
  }
}
@media screen and (min-width: 768px) {
  div.greeting-box div.greeting-txt p.page-txt01 {
    margin-top: 0;
    line-height: 2em;
  }
}
div.greeting-box div.greeting-txt dl {
  margin-top: 8%;
}
@media screen and (min-width: 768px) {
  div.greeting-box div.greeting-txt dl {
    margin-top: 30px;
    max-width: 200px;
    position: relative;
    float: right;
  }
  div.greeting-box div.greeting-txt dl::after {
    content: " ";
    display: block;
    clear: both;
  }
}
div.greeting-box div.greeting-txt dl dt {
  font-size: 0.8rem;
  text-align: center;
  font-weight: 600;
}
div.greeting-box div.greeting-txt dl dd span.sign {
  display: block;
  width: 44.2%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  div.greeting-box div.greeting-txt dl dd span.sign {
    width: 100%;
  }
}
div.greeting-box div.greeting-txt dl dd a {
  display: block;
  width: 80%;
  margin: 0 auto;
  margin-top: 6%;
  padding: 2% 0;
  text-align: center;
  border: solid 1px #555;
  border-radius: 60px;
}
@media screen and (min-width: 768px) {
  div.greeting-box div.greeting-txt dl dd a {
    width: 96%;
    margin: 0 auto;
    margin-top: 40px;
  }
}

section.team04,
section.who04 {
  width: 100%;
  background: #c7d4db;
  padding: 10% 0;
}
@media screen and (min-width: 768px) {
  section.team04,
  section.who04 {
    max-width: 1360px;
    margin: 0 auto;
    margin-top: 100px;
    padding: 90px 0;
  }
}

div.team04-cont-wrap,
div.who04-cont-wrap {
  width: 90%;
  margin: 0 auto;
}
div.team04-cont-wrap h2.page-sub-title01,
div.who04-cont-wrap h2.page-sub-title01 {
  line-height: 1.1em;
}
div.team04-cont-wrap h2.page-sub-title01 span.jp,
div.who04-cont-wrap h2.page-sub-title01 span.jp {
  line-height: 1em;
  margin-top: 2%;
}
@media screen and (min-width: 768px) {
  div.team04-cont-wrap p.page-txt01,
  div.who04-cont-wrap p.page-txt01 {
    max-width: 950px;
    margin: 0 auto;
    text-align: justify;
    margin-top: 0;
  }
}
div.team04-cont-wrap div.boostar-logo,
div.who04-cont-wrap div.boostar-logo {
  width: 54.4%;
  max-width: 280px;
  margin: 0 auto;
  margin-top: 10%;
  margin-bottom: 10%;
}
@media screen and (min-width: 768px) {
  div.team04-cont-wrap div.boostar-logo,
  div.who04-cont-wrap div.boostar-logo {
    margin-top: 60px;
    margin-bottom: 60px;
  }
}
div.team04-cont-wrap h3,
div.who04-cont-wrap h3 {
  font-size: 1.3rem;
  font-weight: 500;
  max-width: 950px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  div.team04-cont-wrap h3,
  div.who04-cont-wrap h3 {
    font-size: 1.6rem;
    width: 100%;
    margin-bottom: 20px;
  }
}

div.who04-cont-wrap p.who04-list-txt {
  font-size: 0.9rem;
  line-height: 1.6em;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  div.who04-cont-wrap p.who04-list-txt {
    max-width: 1080px;
    margin: 0 auto;
    text-align: left;
    margin-top: 5px;
  }
}

/*div.who04-cont-wrap*/
div.who04-image-list {
  margin-top: 6%;
}
@media screen and (min-width: 768px) {
  div.who04-image-list {
    max-width: 1080px;
    margin: 0 auto;
    margin-top: 50px;
  }
}
div.who04-image-list div.who04-img:first-child {
  margin-bottom: 2%;
}
div.who04-image-list div.who04-img02 {
  width: 100%;
  margin-bottom: 1%;
}
@media screen and (min-width: 768px) {
  div.who04-image-list div.who04-img02 {
    display: flex;
    justify-content: space-between;
    margin: 0;
  }
}
div.who04-image-list div.who04-img02 div {
  margin-top: 8%;
}
@media screen and (min-width: 768px) {
  div.who04-image-list div.who04-img02 div {
    width: calc(50% - 15px);
    margin-top: 30px;
  }
}
div.who04-image-list div.who04-img02 div p {
  font-size: 0.9rem;
  line-height: 1.8em;
}

/*who04-image-list*/
/***********************************/
section.teamsdrivers {
  width: 100%;
}
section.teamsdrivers p.page-txt01 {
  width: calc(100% - 4em);
  max-width: 1360px;
  margin: 0 auto;
  margin-top: 8%;
}
@media screen and (min-width: 768px) {
  section.teamsdrivers p.page-txt01 {
    margin-top: 30px;
  }
}
section.teamsdrivers .race-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 10%;
}
@media screen and (min-width: 768px) {
  section.teamsdrivers .race-list {
    width: calc(100% - 4em);
    max-width: 1360px;
    margin: 0 auto;
    margin-bottom: 60px;
  }
}
section.teamsdrivers .race-list li {
  font-size: 0.6rem;
  padding: 0.1em 2em 0 2em;
  font-weight: bold;
  text-align: center;
  white-space: nowrap;
  border: 1px solid #000;
  border-radius: 60px;
}
section.teamsdrivers .race-list li.active {
  background: #222;
  color: #FFF;
}
section.teamsdrivers .race-list li.active a {
  color: #FFF;
}
section.teamsdrivers .race-list li a {
  display: block;
}
@media screen and (min-width: 768px) {
  section.teamsdrivers .race-list li a:hover {
    background: #222;
    color: #FFF;
    border-radius: 60px;
    transition: all 0.4s;
  }
}
@media screen and (min-width: 768px) {
  section.teamsdrivers .race-list li {
    font-size: 0.7rem;
    letter-spacing: -0.04em;
    display: block;
    width: calc((100% - 30px) / 4);
    padding: 0;
  }
}
@media screen and (min-width: 1000px) {
  section.teamsdrivers .race-list li {
    font-size: 1rem;
  }
}
section.teamsdrivers div.page-mv-box {
  position: relative;
}
@media screen and (min-width: 768px) {
  section.teamsdrivers div.page-mv-box {
    width: calc(100% - 4em);
    max-width: 1360px;
    margin: 0 auto;
  }
}
section.teamsdrivers div.page-mv-box p {
  font-size: 1.8rem;
  font-weight: bolder;
  color: #FFF;
  position: absolute;
  right: 6%;
  bottom: 10%;
}
@media screen and (min-width: 768px) {
  section.teamsdrivers div.page-mv-box p {
    font-size: 3rem;
    right: 5%;
    line-height: 1em;
  }
}
section.teamsdrivers div.page-mv-box p.worldchallengeasia {
  text-align: right;
}
@media screen and (min-width: 768px) {
  section.teamsdrivers div.page-mv-box p.worldchallengeasia {
    text-align: right;
  }
}
section.teamsdrivers div.page-mv-box p.okayamachallengecup {
  width: 100%;
  text-align: right;
}
/*section.teamsdrivers*/
section.team02 {
  margin-top: 15%;
  /*schedule-wrap*/
}
@media screen and (min-width: 768px) {
  section.team02 {
    margin-top: 100px;
  }
}
section.team02 div.schedule-wrap {
  width: 90%;
  margin: 0 auto;
  border-top: solid 1px #000;
  border-bottom: solid 1px #000;
  padding: 6% 0;
  /*ul*/
  /*ul.schedule-list02{*/
  /*ul.schedule-list03{*/
  /*ul.schedule-list04{*/
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap {
    max-width: 1360px;
    margin: 0 auto;
    padding: 0;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03,
  section.team02 div.schedule-wrap ul.schedule-list02,
  section.team02 div.schedule-wrap ul.schedule-list01 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding: 20px 0;
  }
}
section.team02 div.schedule-wrap ul.schedule-list03 li,
section.team02 div.schedule-wrap ul.schedule-list02 li,
section.team02 div.schedule-wrap ul.schedule-list01 li {
  margin-bottom: 5%;
  line-height: 1.3em;
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li,
  section.team02 div.schedule-wrap ul.schedule-list02 li,
  section.team02 div.schedule-wrap ul.schedule-list01 li {
    width: 45%;
    display: flex;
    margin-bottom: 10px;
    /*@include mq(pc-middle) {*/
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(1) {
    order: 1;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(2) {
    order: 3;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(3) {
    order: 5;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(4) {
    order: 7;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(5),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(5),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(5) {
    order: 2;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(6),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(6),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(6) {
    order: 4;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(7),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(7),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(7) {
    order: 6;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(8),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(8),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(8) {
    order: 8;
  }
}
@media screen and (min-width: 768px) and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(1),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(2),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(3),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(4) {
    width: 48%;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(1) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(2) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(3) div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(4) div span.venue-en {
    width: 38%;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(1) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(2) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(3) div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(4) div span.venue-ja {
    width: 62%;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(5), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(6), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(7), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(8),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(5),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(6),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(7),
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(8),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(5),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(6),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(7),
  section.team02 div.schedule-wrap ul.schedule-list01 li:nth-child(8) {
    padding-left: 1em;
  }
}
section.team02 div.schedule-wrap ul.schedule-list03 li span.day, section.team02 div.schedule-wrap ul.schedule-list03 li span.venue-en,
section.team02 div.schedule-wrap ul.schedule-list02 li span.day,
section.team02 div.schedule-wrap ul.schedule-list02 li span.venue-en,
section.team02 div.schedule-wrap ul.schedule-list01 li span.day,
section.team02 div.schedule-wrap ul.schedule-list01 li span.venue-en {
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li span.day, section.team02 div.schedule-wrap ul.schedule-list03 li span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li span.day,
  section.team02 div.schedule-wrap ul.schedule-list02 li span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li span.day,
  section.team02 div.schedule-wrap ul.schedule-list01 li span.venue-en {
    font-size: 0.8rem;
  }
}
@media screen and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li span.day, section.team02 div.schedule-wrap ul.schedule-list03 li span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li span.day,
  section.team02 div.schedule-wrap ul.schedule-list02 li span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li span.day,
  section.team02 div.schedule-wrap ul.schedule-list01 li span.venue-en {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li span.day,
  section.team02 div.schedule-wrap ul.schedule-list02 li span.day,
  section.team02 div.schedule-wrap ul.schedule-list01 li span.day {
    width: 6em;
    background: #FFF;
  }
}
section.team02 div.schedule-wrap ul.schedule-list03 li span.venue-ja,
section.team02 div.schedule-wrap ul.schedule-list02 li span.venue-ja,
section.team02 div.schedule-wrap ul.schedule-list01 li span.venue-ja {
  font-size: 0.9rem;
  display: block;
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list02 li span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list01 li span.venue-ja {
    font-size: 0.7rem;
    line-height: 1.6em;
  }
}
@media screen and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list02 li span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list01 li span.venue-ja {
    font-size: 0.9rem;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li div,
  section.team02 div.schedule-wrap ul.schedule-list02 li div,
  section.team02 div.schedule-wrap ul.schedule-list01 li div {
    display: flex;
    width: calc(100% - 6em);
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li div span.venue-en {
    width: 50%;
  }
}
@media screen and (min-width: 768px) and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list02 li div span.venue-en,
  section.team02 div.schedule-wrap ul.schedule-list01 li div span.venue-en {
    width: 45%;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list02 li div span.venue-ja,
  section.team02 div.schedule-wrap ul.schedule-list01 li div span.venue-ja {
    width: 50%;
  }
}
section.team02 div.schedule-wrap ul.schedule-list02 {
  display: block;
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list02 {
    margin-left: 5%;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list02 li {
    width: 60%;
    display: flex;
    margin-bottom: 10px;
    /*@include mq(pc-middle) {*/
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1) {
    order: 1;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2) {
    order: 2;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3) {
    order: 3;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4) {
    order: 4;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(5) {
    order: 5;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(6) {
    order: 6;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(7) {
    order: 7;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(8) {
    order: 8;
  }
}
@media screen and (min-width: 768px) and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1), section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2), section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3), section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4), section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(5) {
    width: 80%;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(5) div span.venue-en {
    width: 64%;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(1) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(2) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(3) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(4) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(5) div span.venue-ja {
    width: 32%;
  }
  section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(5), section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(6), section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(7), section.team02 div.schedule-wrap ul.schedule-list02 li:nth-child(8) {
    padding-left: 0;
  }
}
section.team02 div.schedule-wrap ul.schedule-list03 {
  display: block;
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 {
    margin-left: 5%;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li {
    width: 60%;
    display: flex;
    margin-bottom: 10px;
    /*@include mq(pc-middle) {*/
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1) {
    order: 1;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2) {
    order: 2;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3) {
    order: 3;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4) {
    order: 4;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(5) {
    order: 5;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(6) {
    order: 6;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(7) {
    order: 7;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(8) {
    order: 8;
  }
}
@media screen and (min-width: 768px) and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4) {
    width: 60%;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3) div span.venue-en, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4) div span.venue-en {
    width: 30%;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(1) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(2) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(3) div span.venue-ja, section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(4) div span.venue-ja {
    width: 62%;
  }
  section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(5), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(6), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(7), section.team02 div.schedule-wrap ul.schedule-list03 li:nth-child(8) {
    padding-left: none;
  }
}
section.team02 div.schedule-wrap ul.schedule-list04 {
  /*li*/
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list04 {
    display: flex;
    flex-wrap: wrap;
    /*                justify-content: center;*/
    padding: 20px 0;
  }
}
section.team02 div.schedule-wrap ul.schedule-list04 li {
  margin-bottom: 5%;
  line-height: 1.3em;
  /*span*/
  /*div*/
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li {
    width: 45%;
    display: flex;
    margin-bottom: 10px;
    margin-left: 5%;
  }
  section.team02 div.schedule-wrap ul.schedule-list04 li:nth-child(2) {
    order: 3;
    margin-right: 50%;
  }
  section.team02 div.schedule-wrap ul.schedule-list04 li:nth-child(3) {
    order: 4;
    margin-right: 50%;
  }
  section.team02 div.schedule-wrap ul.schedule-list04 li:nth-child(4) {
    order: 5;
    margin-right: 50%;
  }
  section.team02 div.schedule-wrap ul.schedule-list04 li:nth-child(5) {
    order: 2;
  }
}
section.team02 div.schedule-wrap ul.schedule-list04 li span.day, section.team02 div.schedule-wrap ul.schedule-list04 li span.venue-en {
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li span.day, section.team02 div.schedule-wrap ul.schedule-list04 li span.venue-en {
    font-size: 0.8rem;
  }
}
@media screen and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li span.day, section.team02 div.schedule-wrap ul.schedule-list04 li span.venue-en {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li span.day {
    width: 6em;
    background: #FFF;
  }
}
section.team02 div.schedule-wrap ul.schedule-list04 li span.venue-ja {
  font-size: 0.9rem;
  display: block;
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li span.venue-ja {
    font-size: 0.7rem;
    line-height: 1.6em;
  }
}
@media screen and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li span.venue-ja {
    font-size: 0.9rem;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li div {
    display: flex;
    width: calc(100% - 6em);
  }
  section.team02 div.schedule-wrap ul.schedule-list04 li div span.venue-en {
    width: 50%;
  }
}
@media screen and (min-width: 768px) and (min-width: 1000px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li div span.venue-en {
    width: 45%;
  }
}
@media screen and (min-width: 768px) {
  section.team02 div.schedule-wrap ul.schedule-list04 li div span.venue-ja {
    width: 50%;
  }
}

section.team03 {
  margin-top: 15%;
}
@media screen and (min-width: 768px) {
  section.team03 {
    margin-top: 120px;
  }
}

ul.members-list {
  width: 90%;
  margin: 0 auto;
  /*li*/
}
@media screen and (min-width: 768px) {
  ul.members-list {
    max-width: 1080px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
  }
}
ul.members-list li {
  margin-bottom: 10%;
  /* @include mq(pc) */
}
@media screen and (min-width: 768px) {
  ul.members-list li {
    width: 32%;
    margin-left: 2%;
  }
  ul.members-list li:nth-child(3n+1) {
    margin-left: 0;
  }
}
@media screen and (min-width: 768px) {
  ul.members-list li.no-comment {
    margin-bottom: 30px;
  }
}
ul.members-list li dl {
  margin-top: 4%;
}
ul.members-list li dl dt {
  font-size: 1.4rem;
}
ul.members-list li dl dt span.small-txt {
  display: inline-block;
  font-size: 0.6em;
  margin-left: 1em;
}
@media screen and (min-width: 768px) {
  ul.members-list.members-list-center {
    justify-content: center;
  }
}

/*ul.members-list*/
@media screen and (min-width: 768px) {
  ul.members-list-worldchallenge {
    max-width: 780px;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
ul.members-list-worldchallenge li {
  /* @include mq(pc) */
}
@media screen and (min-width: 768px) {
  ul.members-list-worldchallenge li {
    width: 47.5%;
    margin-left: 0;
  }
  ul.members-list-worldchallenge li:nth-child(3n+1) {
    margin-left: 0;
  }
}
ul.members-list-worldchallenge li div.profile-box dl dt span.small-txt {
  display: block;
  margin-left: 0;
}

/**/
@media screen and (min-width: 768px) {
  ul.members-list-okayamachallenge {
    justify-content: center;
  }
}

div.machin-list {
  margin-bottom: 15%;
}
div.machin-list:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  div.machin-list {
    margin-bottom: 100px;
  }
}

p.machine-name {
  text-align: center;
  font-size: 1.2rem;
  font-weight: bold;
  margin-bottom: 3%;
}
@media screen and (min-width: 768px) {
  p.machine-name {
    font-size: 2.25rem;
    transform: scaleX(1.2);
    margin-bottom: 20px;
    margin-top: 40px;
  }
}
@media screen and (min-width: 1280px) {
  p.machine-name {
    font-size: 2.4rem;
  }
}

div.machine-specs-wrap {
  /*machine-specbox*/
  /*machine-specbox03*/
  /*machine-specbox03*/
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap {
    display: flex;
    justify-content: center;
    margin-top: 30px;
  }
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox {
    width: 40%;
  }
}
@media screen and (min-width: 1000px) {
  div.machine-specs-wrap div.machine-specbox {
    width: 38%;
  }
}
div.machine-specs-wrap div.machine-specbox:last-child {
  margin-top: 5%;
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox:last-child {
    margin-top: 0;
  }
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox h4 {
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 5px;
  }
}
div.machine-specs-wrap div.machine-specbox dl {
  display: flex;
  font-size: 0.8rem;
  line-height: 1.6em;
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox dl {
    font-size: 1rem;
    margin-bottom: 5px;
  }
}
@media screen and (min-width: 1000px) {
  div.machine-specs-wrap div.machine-specbox dl {
    letter-spacing: 0.2rem;
  }
}
div.machine-specs-wrap div.machine-specbox dl dt {
  width: 40%;
}
div.machine-specs-wrap div.machine-specbox dl dd {
  width: 60%;
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox02 {
    width: 45%;
  }
}
div.machine-specs-wrap div.machine-specbox03 {
  width: 100%;
  /*dl*/
}
div.machine-specs-wrap div.machine-specbox03 p {
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox03 p {
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 1280px) {
  div.machine-specs-wrap div.machine-specbox03 {
    width: 90%;
    margin: 0 auto;
  }
}
@media screen and (min-width: 1280px) {
  div.machine-specs-wrap div.machine-specbox03 dl dt {
    width: 30%;
  }
}
@media screen and (min-width: 1280px) {
  div.machine-specs-wrap div.machine-specbox03 dl dd {
    width: 60%;
  }
}
div.machine-specs-wrap div.machine-specbox04 {
  width: 100%;
  /*dl*/
}
div.machine-specs-wrap div.machine-specbox04 h4 {
  margin-top: 5%;
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox04 h4 {
    margin-top: 30px;
  }
}
div.machine-specs-wrap div.machine-specbox04 p {
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  div.machine-specs-wrap div.machine-specbox04 p {
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 1280px) {
  div.machine-specs-wrap div.machine-specbox04 {
    width: 90%;
    margin: 0 auto;
  }
}
@media screen and (min-width: 1280px) {
  div.machine-specs-wrap div.machine-specbox04 dl dt {
    width: 30%;
  }
}
@media screen and (min-width: 1280px) {
  div.machine-specs-wrap div.machine-specbox04 dl dd {
    width: 60%;
  }
}

/*****************company******************/
div.company-box01 {
  margin-top: 15%;
}
@media screen and (min-width: 768px) {
  div.company-box01 {
    margin-top: 70px;
  }
}
div.company-box01 div.company-logo {
  width: 58.6%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  div.company-box01 div.company-logo {
    max-width: 370px;
  }
}

div.company-prof {
  border-top: solid 1px #222;
  border-bottom: solid 1px #222;
  margin-top: 8%;
  padding: 8% 0;
}
@media screen and (min-width: 768px) {
  div.company-prof {
    margin-top: 60px;
    padding: 60px 0;
  }
}
div.company-prof ul li {
  margin-bottom: 6%;
}
div.company-prof ul li:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  div.company-prof ul li {
    margin-bottom: 10px;
  }
}
@media screen and (min-width: 768px) {
  div.company-prof ul li dl {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
div.company-prof ul li dl dt {
  font-size: 0.815rem;
  line-height: 1.4em;
}
@media screen and (min-width: 768px) {
  div.company-prof ul li dl dt {
    font-size: 1.25rem;
    text-align: justify;
    width: 8em;
    padding: 0.3em;
  }
}
div.company-prof ul li dl dd {
  font-size: 1.2rem;
}
@media screen and (min-width: 768px) {
  div.company-prof ul li dl dd {
    font-size: 1.25rem;
    width: calc(100% - 8em - 30%);
    padding: 0.2em;
  }
}
@media screen and (min-width: 1000px) {
  div.company-prof ul li dl dd {
    font-size: 1.25rem;
    width: calc(100% - 8em - 50%);
    padding: 0.2em;
  }
}

div.group-logo {
  margin-bottom: 18%;
}
@media screen and (min-width: 768px) {
  div.group-logo {
    margin-bottom: 80px;
  }
}
div.group-logo span {
  display: block;
  width: 70%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  div.group-logo span {
    max-width: 310px;
  }
}
div.group-logo p {
  font-size: 0.9rem;
  line-height: 1.6em;
  text-align: center;
  margin-top: 8%;
}
@media screen and (min-width: 768px) {
  div.group-logo p {
    margin-top: 30px;
  }
}

h2.group-list-sub-title {
  line-height: 1.3em;
}

div.group-list {
  margin-top: 15%;
  /*ul*/
}
@media screen and (min-width: 768px) {
  div.group-list {
    width: 96%;
    max-width: 1080px;
    margin: 0 auto;
    margin-top: 60px;
  }
}
div.group-list ul {
  /*li*/
}
@media screen and (min-width: 768px) {
  div.group-list ul {
    display: flex;
    flex-wrap: wrap;
  }
}
div.group-list ul li {
  position: relative;
  margin-bottom: 15%;
  /*group-prof*/
}
@media screen and (min-width: 768px) {
  div.group-list ul li {
    width: 48%;
    position: relative;
    margin-bottom: 30px;
  }
  div.group-list ul li:nth-child(odd) {
    margin-right: 4%;
  }
}
@media screen and (min-width: 768px) {
  div.group-list ul li div.group-prof {
    display: flex;
    flex-wrap: wrap;
  }
}
@media screen and (min-width: 768px) {
  div.group-list ul li div.group-prof div.group-img {
    width: 49%;
    order: 2;
  }
}
@media screen and (min-width: 768px) {
  div.group-list ul li div.group-prof div.group-company-logo {
    width: 100%;
    order: 1;
  }
}
div.group-list ul li div.group-prof div.group-prof-txt {
  /*dl*/
}
@media screen and (min-width: 768px) {
  div.group-list ul li div.group-prof div.group-prof-txt {
    width: 48%;
    margin-left: 3%;
    order: 3;
    font-size: 12px;
  }
}
div.group-list ul li div.group-prof div.group-prof-txt dl {
  padding: 2% 0 0 0;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  border-top: solid 1px #333;
  border-bottom: solid 1px #333;
}
div.group-list ul li div.group-prof div.group-prof-txt dl dt {
  width: 4em;
}
div.group-list ul li div.group-prof div.group-prof-txt dl dd {
  width: calc(100% - 4em);
  line-height: 1.5em;
  margin-bottom: 0.3em;
}
div.group-list ul li div.group-prof div.group-prof-txt p {
  line-height: 1.5em;
}
@media screen and (min-width: 768px) {
  div.group-list ul li div.group-prof div.group-prof-txt p {
    font-size: 12px;
  }
}

/*group-list*/
/***************************/
section.wing {
  /*div.page-mv-box*/
  /*div.member-wrap*/
}
section.wing h2.wing-title span {
  display: block;
  width: 40%;
  max-width: 215px;
  margin: 0 auto;
  margin-bottom: 8%;
}
@media screen and (min-width: 768px) {
  section.wing h2.wing-title span {
    margin-bottom: 60px;
  }
}
section.wing div.page-mv-box {
  position: relative;
  /*        background: #000; */
  /*
  p{
      width: 100%;
      font-size: 2rem;
      line-height: 1em;
      padding: 1rem 0 1.6rem 0;
      font-weight: bolder;
      text-align: center;
      color: #FFF;
      @include mq(pc) {
          font-size: 2.2rem;
          line-height: 0.8em;
          position: absolute;
          left: auto;
          top: auto;
          bottom: 10%;
          right: 3%;
          transform: translate( 0%, 0);
          text-align: right;
      }
      @include mq(pc-middle) {
          font-size: 3.8rem;
          bottom: 5%;
      }
      span.small{
          display: inline-block;
          font-size: 0.6em;
          position: relative;
          top: 0;
          left: 0;
          @include mq(pc) {
              display: block;
              top: 0;
              left: 0;
          }
      }
      span.wing-logo{
          display: block;
          width: 6rem;
          margin: 0 auto;
           @include mq(pc) {
              width: 20%;
              max-width: 214px;
              margin: 0;
              margin-left: auto;
           }
      }
  }
  */
}
@media screen and (min-width: 768px) {
  section.wing div.page-mv-box {
    width: calc(100% - 4em);
    max-width: 1360px;
    margin: 0 auto;
    padding-top: 0;
  }
}
section.wing div.member-wrap {
  margin-top: 15%;
  /*profile-box*/
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap {
    margin-top: 80px;
  }
}
@media screen and (min-width: 1000px) {
  section.wing div.member-wrap {
    margin-top: 120px;
  }
}
section.wing div.member-wrap div.profile-box {
  margin-bottom: 10%;
  /*div.prof-sns*/
  /*div.image*/
  /*profile-inner*/
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box {
    margin-bottom: 100px;
  }
}
section.wing div.member-wrap div.profile-box h3.profile-name {
  font-size: 1.6rem;
  text-align: center;
  line-height: 1em;
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box h3.profile-name {
    font-size: 3.75rem;
    line-height: 0.9em;
    margin-bottom: 0;
  }
}
section.wing div.member-wrap div.profile-box h3.profile-name span {
  display: block;
}
section.wing div.member-wrap div.profile-box h3.profile-name span.ja {
  font-size: 0.5em;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box h3.profile-name span.ja {
    font-size: 0.3em;
  }
}
section.wing div.member-wrap div.profile-box div.prof-sns {
  margin-bottom: 5%;
}
section.wing div.member-wrap div.profile-box div.prof-sns ul {
  display: flex;
  justify-content: center;
}
section.wing div.member-wrap div.profile-box div.prof-sns ul li {
  display: block;
  width: 32px;
}
section.wing div.member-wrap div.profile-box div.prof-sns ul li:last-child {
  margin-left: 30px;
}
section.wing div.member-wrap div.profile-box div.prof-sns ul li a {
  display: block;
}
section.wing div.member-wrap div.profile-box div.image {
  background: #CCC;
}
section.wing div.member-wrap div.profile-box div.image span {
  display: block;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box div.image span {
    width: 45%;
    max-width: 465px;
    margin: 0 auto;
  }
}
section.wing div.member-wrap div.profile-box div.profile-inner {
  margin-top: 3%;
}
@media screen and (min-width: 1000px) {
  section.wing div.member-wrap div.profile-box div.profile-inner {
    padding-left: 15%;
  }
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box div.profile-inner dl.profile {
    margin-bottom: 40px;
  }
}
section.wing div.member-wrap div.profile-box div.profile-inner dl.profile dt {
  font-size: 1.4rem;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box div.profile-inner dl.profile dt {
    font-size: 1.75rem;
  }
}
section.wing div.member-wrap div.profile-box div.profile-inner dl.profile dd {
  font-size: 0.785rem;
  line-height: 1.8em;
  margin-top: 2%;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box div.profile-inner dl.profile dd {
    font-size: 1rem;
  }
}
section.wing div.member-wrap div.profile-box div.profile-inner dl.works {
  margin-bottom: 3%;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box div.profile-inner dl.works {
    margin-bottom: 0;
  }
}
section.wing div.member-wrap div.profile-box div.profile-inner dl.works dt {
  font-size: 1.1rem;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box div.profile-inner dl.works dt {
    font-size: 1.125rem;
  }
}
section.wing div.member-wrap div.profile-box div.profile-inner dl.works dd {
  font-size: 0.785rem;
  line-height: 1.8em;
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  section.wing div.member-wrap div.profile-box div.profile-inner dl.works dd {
    font-size: 1rem;
  }
}

/*section.wing*/
/*************************/
section.shingle-cont {
  width: calc(100% - 4em);
  max-width: 1360px;
  margin: 0 auto;
  /*div.single-read-box{*/
}
section.shingle-cont div.single-read-box h1, section.shingle-cont div.single-read-box h2 {
  width: 100%;
  margin: 0 auto;
  font-size: 1.125rem;
  line-height: 1.4em;
  text-align: center;
  padding-top: 2%;
  margin-bottom: 4%;
}
section.shingle-cont div.single-read-box h1 span, section.shingle-cont div.single-read-box h2 span {
  display: block;
  font-size: 0.75em;
}
@media screen and (min-width: 768px) {
  section.shingle-cont div.single-read-box h1, section.shingle-cont div.single-read-box h2 {
    font-size: 28px;
    font-weight: 500;
    line-height: 1.3em;
    padding-top: 1%;
    margin-bottom: 10px;
  }
}
@media screen and (min-width: 1000px) {
  section.shingle-cont div.single-read-box h1, section.shingle-cont div.single-read-box h2 {
    font-size: 36px;
    margin-bottom: 15px;
  }
}
section.shingle-cont div.single-read-box p.excerpt-txt {
  text-align: center;
  word-break: break-all;
  font-size: 0.875rem;
  line-height: 1.6em;
}
@media screen and (min-width: 768px) {
  section.shingle-cont div.single-read-box p.excerpt-txt {
    text-align: center;
  }
}
section.shingle-cont div.single-read-box div.author-box {
  word-break: break-all;
  font-size: 0.75rem;
  line-height: 1.6em;
  margin-top: 4%;
}
@media screen and (min-width: 768px) {
  section.shingle-cont div.single-read-box div.author-box {
    margin-top: 8px;
  }
}
section.shingle-cont div.single-read-box div.author-box p {
  text-align: center;
}
section.shingle-cont div.single-read-box p.sokuho-txt01 {
  text-align: center;
  line-height: 1em;
  margin-top: 2%;
}
section.shingle-cont div.single-read-box p.sokuho-date {
  text-align: center;
  line-height: 1em;
  font-size: 0.9rem;
  color: #777;
}

div.single-contents {
  max-width: 780px;
  margin: 0 auto;
  margin-top: 8%;
  /* div.whois{*/
}
@media screen and (min-width: 768px) {
  div.single-contents {
    margin-top: 60px;
  }
}
div.single-contents div.prologue p {
  font-size: 1.1rem;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  div.single-contents div.prologue p {
    font-size: 1.2rem;
  }
}
div.single-contents h2, div.single-contents h3, div.single-contents h4 {
  font-size: 1.35rem;
  margin-top: 15%;
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  div.single-contents h2, div.single-contents h3, div.single-contents h4 {
    font-size: 1.75rem;
    font-weight: 500;
    margin-top: 80px;
    margin-bottom: 30px;
  }
}
div.single-contents h4 {
  font-size: 1.15rem;
  text-align: justify;
  margin-top: 15%;
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  div.single-contents h4 {
    font-size: 1.25rem;
    text-align: left;
  }
}
div.single-contents p {
  font-size: 0.9rem;
  line-height: 1.6em;
  margin-bottom: 8%;
}
@media screen and (min-width: 768px) {
  div.single-contents p {
    font-size: 0.95rem;
    margin-bottom: 35px;
  }
}
div.single-contents a {
  color: #3c64aa;
  text-decoration: underline;
}
div.single-contents img {
  width: auto;
}
div.single-contents figure {
  margin-bottom: 10%;
}
@media screen and (min-width: 768px) {
  div.single-contents figure {
    margin-bottom: 35px;
  }
}
div.single-contents figure figcaption {
  font-size: 0.86em;
  line-height: 1.6em;
  color: #8d8d8d;
}
div.single-contents div.ft-profile-box,
div.single-contents div.whois {
  margin-top: 10%;
}
div.single-contents div.ft-profile-box figure,
div.single-contents div.whois figure {
  max-width: 384px;
  margin-bottom: 5%;
}
@media screen and (min-width: 768px) {
  div.single-contents div.ft-profile-box figure,
  div.single-contents div.whois figure {
    margin-bottom: 20px;
  }
}
div.single-contents div.ft-profile-box dl,
div.single-contents div.whois dl {
  margin-bottom: 10%;
}
@media screen and (min-width: 768px) {
  div.single-contents div.ft-profile-box dl,
  div.single-contents div.whois dl {
    margin-bottom: 60px;
  }
}
div.single-contents div.ft-profile-box dl dt,
div.single-contents div.whois dl dt {
  font-weight: 600;
  margin-bottom: 4%;
}
@media screen and (min-width: 768px) {
  div.single-contents div.ft-profile-box dl dt,
  div.single-contents div.whois dl dt {
    margin-bottom: 10px;
  }
}
div.single-contents div.ft-profile-box dl dd,
div.single-contents div.whois dl dd {
  font-size: 0.9rem;
  line-height: 1.6em;
}
div.single-contents div.ft-profile-box figure {
  position: relative;
}
div.single-contents div.ft-profile-box figure img {
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
}

div.article-category-list {
  margin-top: 5%;
}
@media screen and (min-width: 768px) {
  div.article-category-list {
    margin-top: 15px;
  }
}
div.article-category-list ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2%;
}
@media screen and (min-width: 768px) {
  div.article-category-list ul {
    gap: 8px;
  }
}
div.article-category-list ul li {
  text-align: center;
  width: 49%;
  margin-bottom: 2%;
}
@media screen and (min-width: 768px) {
  div.article-category-list ul li {
    width: auto;
    margin-bottom: 0;
  }
}
div.article-category-list ul li a {
  display: block;
  white-space: nowrap;
  line-height: 1.5em;
  border: solid 1px #333;
  border-radius: 30px;
  font-size: 0.875rem;
  padding: 1% 15px;
  transition: all 0.4s;
  position: relative;
  /*                pointer-events: none; /*リンク無効*/
  /*@include mq(pc) {*/
}
@media screen and (min-width: 768px) {
  div.article-category-list ul li a {
    display: inline-block;
    font-size: 0.9rem;
    min-width: 165px;
  }
  div.article-category-list ul li a:hover {
    background: #333;
    color: #FFF;
    transition: all 0.4s;
  }
}
@media screen and (min-width: 1280px) {
  div.article-category-list ul li a {
    min-width: 184px;
  }
}

/*new-article-category-list*/
div.shingle-comments-box {
  width: 90%;
  max-width: 1360px;
  padding-top: 15%;
  margin: 0 auto;
  margin-top: 30%;
  position: relative;
  z-index: 1;
  /*ul*/
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box {
    padding-top: 60px;
    margin-top: 100px;
  }
}
@media screen and (min-width: 1280px) {
  div.shingle-comments-box {
    padding-top: 80px;
    margin-top: 150px;
  }
}
div.shingle-comments-box::before {
  content: " ";
  display: block;
  width: 100%;
  height: 1px;
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(0, 0);
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box::before {
    width: 90%;
    max-width: 780px;
    left: 50%;
    top: 0;
    transform: translate(-50%, 0);
  }
}
div.shingle-comments-box h2 {
  font-size: 2.8rem;
  letter-spacing: -0.03em;
  text-align: left;
  font-weight: bold;
  margin-bottom: 3%;
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box h2 {
    font-size: 3.6rem;
    max-width: 780px;
    margin: 0 auto;
    margin-bottom: 25px;
  }
}
div.shingle-comments-box p.comments-read {
  font-weight: 600;
  text-align: left;
  margin-bottom: 8%;
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box p.comments-read {
    max-width: 780px;
    margin: 0 auto;
    margin-bottom: 45px;
  }
}
div.shingle-comments-box ul {
  /*li*/
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box ul {
    max-width: 780px;
    margin: 0 auto;
  }
}
div.shingle-comments-box ul li {
  margin-bottom: 12%;
  /*div.comment-inner01{*/
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box ul li {
    margin-bottom: 50px;
  }
}
div.shingle-comments-box ul li div.comment-inner01 {
  width: 100%;
  /*p.name{*/
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box ul li div.comment-inner01 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
  }
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box ul li div.comment-inner01 figure {
    width: 51.6%;
  }
}
div.shingle-comments-box ul li div.comment-inner01 p.name {
  line-height: 1.6em;
  margin-top: 5%;
  margin-bottom: 3%;
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box ul li div.comment-inner01 p.name {
    width: 45%;
    margin: 0;
  }
}
div.shingle-comments-box ul li div.comment-inner01 p.name span.en {
  font-size: 1.8rem;
  font-weight: 600;
  display: block;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box ul li div.comment-inner01 p.name span.en {
    font-size: 1.8rem;
    margin-bottom: 10px;
  }
}
div.shingle-comments-box ul li div.comment-inner01 p.name span.ja {
  font-size: 0.9em;
}
@media screen and (min-width: 768px) {
  div.shingle-comments-box ul li div.comment-inner01 p.name span.ja {
    font-size: 1.1rem;
  }
}
div.shingle-comments-box ul li div.comment-inner01 p.name span.ja span.small {
  display: inline-block;
  font-size: 0.9em;
  padding-left: 1.4em;
  position: relative;
}
div.shingle-comments-box ul li div.comment-inner01 p.name span.ja span.small::before {
  content: " ";
  display: block;
  width: 1px;
  height: 70%;
  background: #333;
  position: absolute;
  left: 0.7em;
  top: 50%;
  transform: translate(0, -50%);
}
div.shingle-comments-box ul li p.comment-txt {
  font-size: 0.9rem;
  line-height: 1.5em;
  text-align: justify;
}
/*div.shingle-comments-box{*/
div.results-wrap {
  width: 100%;
  position: relative;
  z-index: 1;
  padding: 15% 0;
  margin-top: 15%;
  /*h2*/
  /*h3*/
  /*results-inner01*/
}
@media screen and (min-width: 768px) {
  div.results-wrap {
    margin-top: 100px;
    padding: 80px;
  }
}
div.results-wrap::before {
  content: " ";
  display: block;
  width: 100vw;
  height: 100%;
  background: #F0F0F0;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, 0);
  z-index: -1;
}
div.results-wrap h2 {
  font-size: 2.8rem;
  letter-spacing: -0.03em;
  text-align: left;
  font-weight: bold;
  margin-bottom: 3%;
}
@media screen and (min-width: 768px) {
  div.results-wrap h2 {
    font-size: 3.6rem;
    max-width: 780px;
    margin: 0 auto;
    margin-bottom: 25px;
  }
}
div.results-wrap h3 {
  font-size: 1.2rem;
  line-height: 1.5em;
  font-weight: 500;
  text-align: left;
  margin-bottom: 8%;
  word-break: break-word;
  overflow-wrap: break-word;
}
@media screen and (min-width: 768px) {
  div.results-wrap h3 {
    max-width: 780px;
    margin: 0 auto;
    margin-bottom: 45px;
  }
}
div.results-wrap div.results-inner01 {
  margin-bottom: 5%;
  padding-top: 5%;
  border-top: solid 1px #333;
}
div.results-wrap div.results-inner01:first-of-type {
  border-top: none;
}
@media screen and (min-width: 768px) {
  div.results-wrap div.results-inner01 {
    max-width: 780px;
    margin: 0 auto;
    margin-bottom: 0;
    padding-top: 20px;
    padding-bottom: 20px;
  }
}
div.results-wrap div.results-inner01 p {
  word-break: keep-all; /* 単語の途中での改行を制御 */
  overflow-wrap: break-word; /* 必要に応じて単語を分割して改行 */
  line-height: 1.6em;
  margin-bottom: 2%;
}
@media screen and (min-width: 768px) {
  div.results-wrap div.results-inner01 p {
    margin-bottom: 0;
  }
}
div.results-wrap div.results-inner01 ul {
  /*li*/
}
div.results-wrap div.results-inner01 ul li {
  /*dl*/
}
div.results-wrap div.results-inner01 ul li dl {
  display: flex;
}
div.results-wrap div.results-inner01 ul li dl dt {
  width: 6em;
}
div.results-wrap div.results-inner01 ul li dl dd {
  width: calc(100% - 7em);
}

/*results-wrap*/
div.k-tunes-recommends {
  width: 90%;
  max-width: 1360px;
  padding-top: 15%;
  margin: 0 auto;
  margin-top: 30%;
  position: relative;
  z-index: 1;
  /*ul*/
}
@media screen and (min-width: 768px) {
  div.k-tunes-recommends {
    padding-top: 60px;
    margin-top: 100px;
  }
}
@media screen and (min-width: 1280px) {
  div.k-tunes-recommends {
    padding-top: 80px;
    margin-top: 100px;
  }
}
div.k-tunes-recommends::before {
  content: " ";
  display: block;
  width: 100%;
  height: 1px;
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(0, 0);
}
@media screen and (min-width: 768px) {
  div.k-tunes-recommends::before {
    width: 90%;
    max-width: 780px;
    left: 50%;
    top: 0;
    transform: translate(-50%, 0);
  }
}
div.k-tunes-recommends h2 {
  font-size: 2.8rem;
  letter-spacing: -0.03em;
  text-align: center;
  font-weight: bold;
  margin-bottom: 6%;
}
@media screen and (min-width: 768px) {
  div.k-tunes-recommends h2 {
    font-size: 3.2rem;
  }
}
div.k-tunes-recommends ul {
  /*li*/
}
@media screen and (min-width: 768px) {
  div.k-tunes-recommends ul {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 2%;
  }
}
div.k-tunes-recommends ul li {
  width: 100%;
  margin-bottom: 8%;
  /*a*/
  /*thumnail-imgサムネイル画像*/
}
@media screen and (min-width: 768px) {
  div.k-tunes-recommends ul li {
    width: 32%;
    margin-bottom: 50px;
  }
}
div.k-tunes-recommends ul li a {
  display: block;
  position: relative;
  /* @include mq(pc) */
}
@media screen and (min-width: 768px) {
  div.k-tunes-recommends ul li a {
    /*hover*/
  }
  div.k-tunes-recommends ul li a:hover article {
    /*div.thumnail-img*/
  }
  div.k-tunes-recommends ul li a:hover article div.thumnail-img span.img-span::before {
    animation: img-flash 0.6s ease forwards;
  }
  div.k-tunes-recommends ul li a:hover article div.thumnail-img span.img-span img {
    transform: scale(1.1);
    transition: all 0.6s;
    filter: grayscale(0%);
  }
  div.k-tunes-recommends ul li a:hover article div.thumnail-img span.border-top {
    transform: scaleX(0);
    transform-origin: left center;
    background: linear-gradient(90deg, rgb(255, 255, 255) 0%, rgb(0, 0, 0) 100%);
    background-size: 200% 100%;
    animation: gradientAnimation 0.2s ease infinite, main-border-top 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  div.k-tunes-recommends ul li a:hover article div.thumnail-img span.border-right {
    transform: scaleY(0);
    transform-origin: center top;
    background: linear-gradient(180deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-size: 100% 200%;
    animation: gradientAnimation-C 0.2s ease infinite, main-border-right 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  div.k-tunes-recommends ul li a:hover article div.thumnail-img span.border-bottom {
    transform: scaleX(0);
    transform-origin: right center;
    background: linear-gradient(90deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-size: 200% 100%;
    animation: gradientAnimation-B 0.2s ease infinite, main-border-bottom 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  div.k-tunes-recommends ul li a:hover article div.thumnail-img span.border-left {
    transform-origin: center bottom;
    background: linear-gradient(180deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-size: 100% 200%;
    animation: gradientAnimation-D 0.2s ease infinite, main-border-left 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  div.k-tunes-recommends ul li a:hover h3 {
    position: relative;
    z-index: 1;
  }
}
div.k-tunes-recommends ul li div.thumnail-img {
  width: 100%;
  position: relative;
  padding-top: 68.75%;
  overflow: hidden;
  /*span*/
}
div.k-tunes-recommends ul li div.thumnail-img span.img-span {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
}
div.k-tunes-recommends ul li div.thumnail-img span.img-span::before {
  content: " ";
  display: block;
  width: 100%;
  height: 100%;
  background: #FFF;
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(0, 0);
  z-index: 1;
  opacity: 0;
}
div.k-tunes-recommends ul li div.thumnail-img span.img-span img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.6s;
  filter: grayscale(100%);
}
div.k-tunes-recommends ul li div.thumnail-img span.border-top, div.k-tunes-recommends ul li div.thumnail-img span.border-right, div.k-tunes-recommends ul li div.thumnail-img span.border-bottom, div.k-tunes-recommends ul li div.thumnail-img span.border-left {
  display: block;
  position: absolute;
  z-index: 6;
}
div.k-tunes-recommends ul li div.thumnail-img span.border-top {
  width: 100%;
  height: 3px;
  left: 0;
  top: 0;
}
div.k-tunes-recommends ul li div.thumnail-img span.border-right {
  width: 3px;
  height: 100%;
  right: 0;
  top: 0;
}
div.k-tunes-recommends ul li div.thumnail-img span.border-bottom {
  width: 100%;
  height: 3px;
  left: 0;
  bottom: 0;
}
div.k-tunes-recommends ul li div.thumnail-img span.border-left {
  width: 3px;
  height: 100%;
  left: 0;
  top: 0;
}
div.k-tunes-recommends ul li h3 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5em;
  margin-top: 3%;
  margin-bottom: 2%;
  word-break: break-all;
}
div.k-tunes-recommends ul li p {
  font-size: 0.875rem;
  line-height: 1.6em;
}

span.more-txtA {
  opacity: 0;
  transform: translate(100%, 0);
  animation: title-txt-ani-partA 0.6s 0.2s ease forwards, title-txt-position-ani-partF 0.6s 0.2s ease forwards;
}

span.more-txtB {
  opacity: 0;
  transform: translate(100%, 0);
  animation: title-txt-ani-partB 0.6s 0.2s ease forwards, title-txt-position-ani-partB 0.6s 0.2s ease forwards;
}

span.more-txtC {
  opacity: 0;
  transform: translate(100%, 0);
  animation: title-txt-ani-partD 0.4s 0.2s ease forwards, title-txt-position-ani-partC 0.6s 0.2s ease forwards;
}

span.more-txtD {
  opacity: 0;
  transform: translate(100%, 0);
  animation: title-txt-ani-partD 0.4s 0.2s ease forwards, title-txt-position-ani-partF 0.6s 0.2s ease forwards;
}

span.more-txtE {
  opacity: 0;
  transform: translate(100%, 0);
  animation: title-txt-ani-partE 0.4s 0.2s ease forwards, title-txt-position-ani-partE 0.6s 0.2s ease forwards;
}

@keyframes bg-cartain {
  0% {
    transform: translate(0) scaleX(0);
  }
  100% {
    transform: translate(0) scaleX(1);
  }
}
@keyframes dot-move {
  0% {
    background-position: 0 0, 2px 2px;
  }
  50% {
    background-position: 4px 4px, 8px 8px; /* 中間の位置 */
  }
  100% {
    background-position: 0 0, 2px 2px; /* 最終的に元に戻る */
  }
}
@keyframes img-flash {
  0% {
    opacity: 0.5;
  }
  100% {
    opacity: 0;
  }
}
@keyframes gradientAnimation {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 200% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}
@keyframes gradientAnimation-B {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 200% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}
@keyframes gradientAnimation-C {
  0% {
    background-position: 50% 0%;
  }
  50% {
    background-position: 50% 200%;
  }
  100% {
    background-position: 50% 100%;
  }
}
@keyframes gradientAnimation-D {
  0% {
    background-position: 50% 0%;
  }
  50% {
    background-position: 50% 200%;
  }
  100% {
    background-position: 50% 100%;
  }
}
@keyframes main-border-top {
  0% {
    transform: scaleX(0);
    transform-origin: left center;
  }
  50% {
    transform: scaleX(1);
    transform-origin: left center;
  }
  51% {
    transform: scaleX(1);
    transform-origin: right center;
  }
  100% {
    transform: scaleX(0);
    transform-origin: right center;
  }
}
@keyframes main-border-right {
  0% {
    transform: scaleY(0);
    transform-origin: center top;
  }
  50% {
    transform: scaleY(1);
    transform-origin: center top;
  }
  51% {
    transform: scaleY(1);
    transform-origin: center bottom;
  }
  100% {
    transform: scaleY(0);
    transform-origin: center bottom;
  }
}
@keyframes main-border-bottom {
  0% {
    transform: scaleX(0);
    transform-origin: right center;
  }
  50% {
    transform: scaleX(1);
    transform-origin: right center;
  }
  51% {
    transform: scaleX(1);
    transform-origin: left center;
  }
  100% {
    transform: scaleX(0);
    transform-origin: left center;
  }
}
@keyframes main-border-left {
  0% {
    transform: scaleY(0);
    transform-origin: center bottom;
  }
  50% {
    transform: scaleY(1);
    transform-origin: center bottom;
  }
  51% {
    transform: scaleY(1);
    transform-origin: center top;
  }
  100% {
    transform: scaleY(0);
    transform-origin: center top;
  }
}
@keyframes title-txt-ani-partA {
  0% {
    opacity: 0;
  }
  15% {
    opacity: 1;
  }
  30% {
    opacity: 0;
  }
  65% {
    opacity: 1;
  }
  80% {
    opacity: 0.5;
  }
  100% {
    opacity: 1;
  }
}
@keyframes title-txt-ani-partB {
  0% {
    opacity: 1;
  }
  15% {
    opacity: 0;
  }
  30% {
    opacity: 1;
  }
  65% {
    opacity: 0;
  }
  80% {
    opacity: 0.5;
  }
  100% {
    opacity: 1;
  }
}
@keyframes title-txt-ani-partC {
  0% {
    opacity: 0;
  }
  15% {
    opacity: 0.5;
  }
  30% {
    opacity: 0.8;
  }
  65% {
    opacity: 0.6;
  }
  80% {
    opacity: 0.8;
  }
  100% {
    opacity: 1;
  }
}
@keyframes title-txt-ani-partD {
  0% {
    opacity: 1;
  }
  15% {
    opacity: 0.5;
  }
  30% {
    opacity: 0.8;
  }
  65% {
    opacity: 0.6;
  }
  80% {
    opacity: 0.8;
  }
  100% {
    opacity: 1;
  }
}
@keyframes title-txt-ani-partE {
  0% {
    opacity: 0.5;
  }
  15% {
    opacity: 1;
  }
  30% {
    opacity: 0.5;
  }
  65% {
    opacity: 1;
  }
  80% {
    opacity: 0.2;
  }
  100% {
    opacity: 1;
  }
}
@keyframes title-txt-position-ani-partA {
  0% {
    transform: translate(150%, 0);
  }
  100% {
    transform: translate(0%, 0);
  }
}
@keyframes title-txt-position-ani-partB {
  0% {
    transform: translate(0%, -150%);
  }
  100% {
    transform: translate(0%, 0);
  }
}
@keyframes title-txt-position-ani-partC {
  0% {
    transform: translate(-100%, 0%);
  }
  100% {
    transform: translate(0%, 0);
  }
}
@keyframes title-txt-position-ani-partD {
  0% {
    transform: translate(100%, 100%);
  }
  100% {
    transform: translate(0%, 0);
  }
}
@keyframes title-txt-position-ani-partE {
  0% {
    transform: translate(-100%, -100%);
  }
  100% {
    transform: translate(0%, 0);
  }
}
@keyframes title-txt-position-ani-partF {
  0% {
    transform: translate(100%, 0%);
  }
  100% {
    transform: translate(0%, 0);
  }
}
div.share-sns-wrap {
  margin-top: 5%;
  margin-bottom: 15%;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 768px) {
  div.share-sns-wrap {
    margin-top: 30px;
    margin-bottom: 60px;
  }
}
div.share-sns-wrap p.sns-title {
  font-size: 1.375rem;
  line-height: 1.4em;
  letter-spacing: -0.03em;
  text-align: center;
  font-weight: bold;
  transform: scaleX(0.9);
  margin-bottom: 1%;
}
@media screen and (min-width: 768px) {
  div.share-sns-wrap p.sns-title {
    margin-bottom: 0;
  }
}
div.share-sns-wrap ul {
  display: flex;
  justify-content: center;
  margin-left: 15px;
}
@media screen and (min-width: 768px) {
  div.share-sns-wrap ul {
    margin-left: 30px;
  }
}
div.share-sns-wrap ul li {
  display: block;
  width: 32px;
}
div.share-sns-wrap ul li:last-child {
  margin-left: 15px;
}
@media screen and (min-width: 768px) {
  div.share-sns-wrap ul li:last-child {
    margin-left: 30px;
  }
}
div.share-sns-wrap ul li a {
  display: block;
}

/*share-sns-wrap*/
div.archive-bnr {
  width: 100%;
  margin-top: 15%;
}
@media screen and (min-width: 768px) {
  div.archive-bnr {
    width: 86%;
    max-width: 1080px;
    margin: 0 auto;
    margin-top: 120px;
  }
}
div.archive-bnr a {
  display: block;
  position: relative;
}
@media screen and (min-width: 768px) {
  div.archive-bnr a:hover {
    opacity: 0.6;
    transition: all 0.4s;
  }
}
div.archive-bnr a div {
  position: absolute;
  width: 100%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
div.archive-bnr a div p {
  color: #FFF;
}
div.archive-bnr a div p.large {
  font-size: 3.6rem;
  letter-spacing: 0.1em;
  text-align: center;
  font-weight: bold;
  transform: scaleX(0.9);
}
div.archive-bnr a div p.small {
  text-align: center;
  font-weight: bold;
  margin-top: 3%;
}

/*アーカイブページ*/
div.archive-wrap {
  width: calc(100% - 4em);
  max-width: 1360px;
  margin: 0 auto;
  margin-top: 5%;
}
@media screen and (min-width: 768px) {
  div.archive-wrap {
    margin-top: 30px;
  }
}
div.archive-wrap p.error-text {
  text-align: center;
  margin-top: 10%;
}

div.category-list {
  width: calc(100% - 4em);
  max-width: 1360px;
  margin: 0 auto;
  margin-top: 5%;
  /**/
}
@media screen and (min-width: 768px) {
  div.category-list {
    margin-top: 30px;
  }
}
div.category-list ul {
  display: flex;
  flex-wrap: wrap;
  gap: 2%;
}
@media screen and (min-width: 768px) {
  div.category-list ul {
    gap: 8px;
  }
}
div.category-list ul li {
  text-align: center;
  width: 49%;
  margin-bottom: 2%;
}
@media screen and (min-width: 768px) {
  div.category-list ul li {
    width: auto;
    margin-bottom: 0;
  }
}
div.category-list ul li.active a {
  background: #333;
  color: #FFF;
}
div.category-list ul li a {
  display: block;
  white-space: collapse;
  line-height: 1.4em;
  letter-spacing: -0.02em;
  border: solid 1px #333;
  border-radius: 30px;
  font-size: 0.875rem;
  padding: 1% 15px;
  transition: all 0.4s;
  position: relative;
  /*@include mq(pc) {*/
}
@media screen and (min-width: 768px) {
  div.category-list ul li a {
    display: inline-block;
    font-size: 0.9rem;
    min-width: 165px;
  }
  div.category-list ul li a:hover {
    background: #333;
    color: #FFF;
    transition: all 0.4s;
  }
}
@media screen and (min-width: 1280px) {
  div.category-list ul li a {
    min-width: 184px;
  }
}

/**/
ul.post-list {
  margin-top: 5%;
  /*li*/
}
@media screen and (min-width: 768px) {
  ul.post-list {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 2%;
    margin-top: 30px;
  }
}
ul.post-list li {
  width: 100%;
  margin-bottom: 8%;
  /*a*/
  /*thumnail-imgサムネイル画像*/
}
@media screen and (min-width: 768px) {
  ul.post-list li {
    width: 32%;
    margin-bottom: 50px;
  }
}
ul.post-list li a {
  display: block;
  position: relative;
  /* @include mq(pc) */
}
@media screen and (min-width: 768px) {
  ul.post-list li a {
    /*hover*/
  }
  ul.post-list li a:hover article {
    /*div.thumnail-img*/
  }
  ul.post-list li a:hover article div.thumnail-img span.img-span::before {
    animation: img-flash 0.6s ease forwards;
  }
  ul.post-list li a:hover article div.thumnail-img span.img-span img {
    transform: scale(1.1);
    transition: all 0.6s;
    filter: grayscale(0%);
  }
  ul.post-list li a:hover article div.thumnail-img span.border-top {
    transform: scaleX(0);
    transform-origin: left center;
    background: linear-gradient(90deg, rgb(255, 255, 255) 0%, rgb(0, 0, 0) 100%);
    background-size: 200% 100%;
    animation: gradientAnimation 0.2s ease infinite, main-border-top 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  ul.post-list li a:hover article div.thumnail-img span.border-right {
    transform: scaleY(0);
    transform-origin: center top;
    background: linear-gradient(180deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-size: 100% 200%;
    animation: gradientAnimation-C 0.2s ease infinite, main-border-right 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  ul.post-list li a:hover article div.thumnail-img span.border-bottom {
    transform: scaleX(0);
    transform-origin: right center;
    background: linear-gradient(90deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-size: 200% 100%;
    animation: gradientAnimation-B 0.2s ease infinite, main-border-bottom 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  ul.post-list li a:hover article div.thumnail-img span.border-left {
    transform-origin: center bottom;
    background: linear-gradient(180deg, rgb(0, 0, 0) 0%, rgb(255, 255, 255) 100%);
    background-size: 100% 200%;
    animation: gradientAnimation-D 0.2s ease infinite, main-border-left 1.6s 0.4s cubic-bezier(0, 0.56, 0.75, 0.35) forwards;
  }
  ul.post-list li a:hover h3 {
    position: relative;
    z-index: 1;
    overflow-wrap: break-word; /* 必要に応じて単語を分割して改行 */
  }
}
ul.post-list li div.thumnail-img {
  width: 100%;
  position: relative;
  padding-top: 68.75%;
  overflow: hidden;
  /*span*/
}
ul.post-list li div.thumnail-img span.img-span {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
}
ul.post-list li div.thumnail-img span.img-span::before {
  content: " ";
  display: block;
  width: 100%;
  height: 100%;
  background: #FFF;
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(0, 0);
  z-index: 1;
  opacity: 0;
}
ul.post-list li div.thumnail-img span.img-span img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  ul.post-list li div.thumnail-img span.img-span img {
    transition: all 0.6s;
    filter: grayscale(100%);
  }
}
ul.post-list li div.thumnail-img span.border-top, ul.post-list li div.thumnail-img span.border-right, ul.post-list li div.thumnail-img span.border-bottom, ul.post-list li div.thumnail-img span.border-left {
  display: block;
  position: absolute;
  z-index: 6;
}
ul.post-list li div.thumnail-img span.border-top {
  width: 100%;
  height: 3px;
  left: 0;
  top: 0;
}
ul.post-list li div.thumnail-img span.border-right {
  width: 3px;
  height: 100%;
  right: 0;
  top: 0;
}
ul.post-list li div.thumnail-img span.border-bottom {
  width: 100%;
  height: 3px;
  left: 0;
  bottom: 0;
}
ul.post-list li div.thumnail-img span.border-left {
  width: 3px;
  height: 100%;
  left: 0;
  top: 0;
}
ul.post-list li h3 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5em;
  margin-top: 3%;
  margin-bottom: 2%;
}
ul.post-list li p {
  font-size: 0.875rem;
  line-height: 1.6em;
}

@keyframes bg-cartain {
  0% {
    transform: translate(0) scaleX(0);
  }
  100% {
    transform: translate(0) scaleX(1);
  }
}
@keyframes dot-move {
  0% {
    background-position: 0 0, 2px 2px;
  }
  50% {
    background-position: 4px 4px, 8px 8px; /* 中間の位置 */
  }
  100% {
    background-position: 0 0, 2px 2px; /* 最終的に元に戻る */
  }
}
@keyframes img-flash {
  0% {
    opacity: 0.5;
  }
  100% {
    opacity: 0;
  }
}
main.archive-page section.page-cont {
  width: 100%;
}/*# sourceMappingURL=page.css.map */