@charset "UTF-8";
/* Rayout template
  ----------------------------------------*/
.lyt-block {
  display: flex;
  gap: 6%;
  align-items: center;
  max-width: 810px;
  margin: 60px auto 0;
  position: relative;
}
.lyt-block:first-child {
  margin-top: 0;
}
.lyt-block-image {
  width: 47%;
  text-align: center;
}
.lyt-block-content {
  width: 47%;
  position: relative;
  z-index: 1;
}
.lyt-block-content p {
  margin-top: 1em;
  text-align: justify;
  text-justify: inter-ideograph;
}
.lyt-block-content > *:first-child {
  margin-top: 0 !important;
}
.lyt-block-head2 {
  font-size: 18px;
  margin-top: 1em;
  line-height: 1.3;
  font-weight: 700;
}
.lyt-block--evo {
  flex-wrap: wrap;
  margin-top: 30px !important;
}
.lyt-block--evo .lyt-block-image .img-card {
  margin-left: auto;
  margin-right: auto;
}
.lyt-block--evo .lyt-block-evo {
  width: 47.5%;
  text-align: center;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .lyt-block--evo .lyt-block-evo {
    width: 100%;
  }
}
.lyt-block--evo1, .lyt-block--evo2 {
  flex-wrap: wrap;
  margin-top: 0 !important;
  gap: 3%;
}
.lyt-block--evo1 .lyt-block-image, .lyt-block--evo2 .lyt-block-image {
  width: 47%;
}
.lyt-block--evo1 .lyt-block-image .img-card, .lyt-block--evo2 .lyt-block-image .img-card {
  margin-left: auto;
  margin-right: auto;
}
.lyt-block--evo1 .lyt-block-image2, .lyt-block--evo2 .lyt-block-image2 {
  width: 33%;
  padding-top: 25px;
}
.lyt-block--evo1 .lyt-block-image2 .img-card, .lyt-block--evo2 .lyt-block-image2 .img-card {
  margin-left: auto;
  margin-right: auto;
}
.lyt-block--evo1 .lyt-block-image2 .img-card-head, .lyt-block--evo2 .lyt-block-image2 .img-card-head {
  margin-top: 45px;
}
.lyt-block--evo1 .lyt-block-evo, .lyt-block--evo2 .lyt-block-evo {
  width: 20%;
  margin-left: -5%;
  margin-right: -1%;
  text-align: center;
  padding-bottom: 10%;
}
@media screen and (max-width: 768px) {
  .lyt-block--evo1 .lyt-block-evo, .lyt-block--evo2 .lyt-block-evo {
    width: 100%;
  }
}
.lyt-block--evo1.lyt-block--reverse .lyt-block-image, .lyt-block--evo2.lyt-block--reverse .lyt-block-image {
  order: 3;
}
.lyt-block--evo1.lyt-block--reverse .lyt-block-evo, .lyt-block--evo2.lyt-block--reverse .lyt-block-evo {
  order: 2;
  margin-right: -5%;
  margin-left: -1%;
}
.lyt-block--evo1.lyt-block--reverse .lyt-block-image2, .lyt-block--evo2.lyt-block--reverse .lyt-block-image2 {
  order: 1;
}
.lyt-block--evo1 .img-card-head, .lyt-block--evo2 .img-card-head {
  margin-left: -34px;
  margin-right: -34px;
}
.lyt-block--reverse .lyt-block-image {
  order: 2;
}
.lyt-block--reverse .lyt-block-content {
  order: 1;
}
.lyt-block--reverse .lyt-block-evo {
  margin-left: auto;
}
.lyt-block--card .lyt-block-image {
  width: 35%;
}
.lyt-block--card .lyt-block-content {
  width: 59%;
}
.lyt-block--card + .lyt-block--card {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .lyt-block {
    flex-wrap: wrap;
    margin-top: 30px;
    max-width: 300px;
  }
  .lyt-block-content {
    width: 100%;
    margin-top: 16px;
    order: 2;
    text-align: left;
    display: block;
  }
  .lyt-block-content small {
    font-size: 14px;
  }
  .lyt-block-head {
    padding-top: 15px;
    text-align: center;
  }
  .lyt-block-head img {
    width: auto;
    height: 40px;
  }
  .lyt-block-head2 {
    text-align: center;
    font-size: 20px;
    line-height: 1.5;
    margin-top: 0.8em;
  }
  .lyt-block-image {
    order: 1;
    width: 100%;
  }
  .lyt-block--reverse .lyt-block-image {
    order: 1;
  }
  .lyt-block--reverse .lyt-block-content {
    order: 2;
  }
  .lyt-block + .lyt-block {
    margin-top: 40px;
  }
  .lyt-block--evo2 .lyt-block-evo {
    order: 2;
    width: 100%;
    margin: 0;
    padding-top: 10%;
  }
  .lyt-block--evo2 .lyt-block-image {
    order: 1;
    width: 100%;
    padding-top: 0;
  }
  .lyt-block--evo2 .lyt-block-image2 {
    order: 3;
    width: 100%;
    padding: 0;
  }
  .lyt-block--evo2 .lyt-block-image2 .img-card-head {
    margin-top: 16px;
  }
  .lyt-block--evo2.lyt-block--reverse .lyt-block-image {
    order: 1;
  }
  .lyt-block--evo2.lyt-block--reverse .lyt-block-evo {
    order: 2;
    margin: 0;
  }
  .lyt-block--evo2.lyt-block--reverse .lyt-block-image2 {
    order: 3;
  }
  .lyt-block--card .lyt-block-image,
  .lyt-block--card .lyt-block-content {
    width: 100%;
  }
}

.lyt-column {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  margin-top: 70px;
  gap: 24px;
}
.lyt-column-item {
  position: relative;
}
.lyt-column-item > *:first-child {
  margin-top: 0 !important;
}
.lyt-column-item .lyt-column-card {
  text-align: center;
}
.lyt-column-item .lyt-column-name {
  text-align: center;
  margin-top: 10px;
}
.lyt-column--col2 {
  gap: 60px;
}
.lyt-column--col2 .lyt-column-item {
  flex: 0 0 calc((100% - 60px) / 2);
}
.lyt-column--col3 {
  gap: 40px;
}
.lyt-column--col3 .lyt-column-item {
  flex: 0 0 calc((100% - 80px) / 3);
}
.lyt-column--col4 {
  gap: 24px;
}
.lyt-column--col4 .lyt-column-item {
  flex: 0 0 calc((100% - 72px) / 4);
}
.lyt-column--product {
  gap: 50px;
  margin-top: 60px;
}
.lyt-column--product .lyt-column-item:first-child {
  flex: 0 0 calc(45% - 25px);
}
.lyt-column--product .lyt-column-item:nth-child(2) {
  flex: 0 0 calc(55% - 25px);
}
.lyt-column--rule {
  gap: 0;
}
.lyt-column--rule .lyt-column-item:nth-child(2n-1) {
  flex: 0 0 38%;
}
@media screen and (max-width: 768px) {
  .lyt-column--rule .lyt-column-item:nth-child(2n-1) {
    padding-right: 20px;
  }
}
.lyt-column--rule .lyt-column-item:nth-child(2n) {
  flex: 0 0 62%;
}
.lyt-column--rule .lyt-column-item:nth-child(n+3) {
  border-top: 1px solid #fff;
  padding-top: 40px;
  margin-top: 40px;
}
.lyt-column--rule .lyt-column-item h4 {
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .lyt-column--rule .lyt-column-item h4 {
    font-size: 18px;
  }
}
.lyt-column--jcenter {
  justify-content: center;
}
.lyt-column--center {
  align-items: center;
}
.lyt-column + .lyt-column {
  margin-top: 120px;
}
.lyt-column--sp-col2 {
  gap: 30px;
}
.lyt-column--sp-col2 + .lyt-column--sp-col2 {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .lyt-column {
    margin-top: 40px;
    max-width: 310px;
  }
  .lyt-column--col2 {
    gap: 40px 16px;
  }
  .lyt-column--col2 .lyt-column-item {
    flex: 0 0 100%;
  }
  .lyt-column--col3 {
    gap: 16px;
  }
  .lyt-column--col3 .lyt-column-item {
    flex: 0 0 calc((100% - 32px) / 3);
  }
  .lyt-column--col4 {
    gap: 12px;
  }
  .lyt-column--col4 .lyt-column-item {
    flex: 0 0 calc((100% - 24px) / 3);
  }
  .lyt-column--product {
    gap: 0;
  }
  .lyt-column--product .lyt-column-item {
    flex: 0 0 100% !important;
  }
  .lyt-column + .lyt-column {
    margin-top: 160px;
  }
  .lyt-column + .lyt-column.lyt-column--product {
    margin-top: 80px;
  }
  .lyt-column--sp-col1 {
    gap: 30px;
  }
  .lyt-column--sp-col1 .lyt-column-item {
    flex: 0 0 100%;
  }
  .lyt-column--sp-col2 + .lyt-column--sp-col2 {
    margin-top: 20px;
  }
  .lyt-column--sp-col2 .lyt-column-item {
    flex: 0 0 calc((100% - 20px) / 2);
  }
  .lyt-column--sp-reverse .lyt-column-item:first-child {
    order: 2;
  }
  .lyt-column--sp-reverse .lyt-column-item:nth-child(2) {
    order: 1;
  }
}

.lyt-evo {
  margin-top: 60px;
  display: flex;
  flex-wrap: wrap;
  gap: 6%;
  margin-left: auto;
  margin-right: auto;
  max-width: 700px;
}
.lyt-evo-item {
  width: 47%;
}
@media screen and (max-width: 768px) {
  .lyt-evo {
    max-width: 300px;
  }
  .lyt-evo-item {
    width: 100%;
  }
}

.lyt-evoChild {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}
.lyt-evoChild-item {
  display: flex;
  align-items: center;
  gap: 4%;
}
.lyt-evoChild-item .img-card,
.lyt-evoChild-item .lyt-evoChild-arrow {
  width: 48%;
  text-align: center;
}
.lyt-evoChild-item .img-card picture,
.lyt-evoChild-item .lyt-evoChild-arrow picture {
  display: block;
}
@media screen and (max-width: 768px) {
  .lyt-evoChild {
    flex-direction: row;
    gap: 8%;
    height: inherit;
  }
  .lyt-evoChild-item {
    flex-direction: column;
    width: 46%;
    gap: 0;
  }
  .lyt-evoChild-item .img-card,
  .lyt-evoChild-item .lyt-evoChild-arrow {
    width: 100%;
  }
  .lyt-evoChild-item .lyt-evoChild-arrow {
    height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

.img-card {
  text-align: center;
  position: relative;
}
.img-card > * {
  position: relative;
}
.img-card > *:first-child {
  margin-top: 0;
}
.img-card p {
  text-align: left;
  margin-top: 20px;
  text-align: justify;
  text-justify: inter-ideograph;
}
.img-card p small {
  font-size: 16px;
}
.img-card p > a {
  text-decoration: underline;
}
.img-card p > a:hover {
  text-decoration: none;
}
.img-card p.img-card-head {
  text-align: center;
}
.img-card-image {
  text-align: center;
}
.img-card-logo {
  margin-top: 1.4em;
}
.img-card-head {
  text-align: center;
  margin-top: 20px;
}
.img-card-head + .img-card-text {
  margin-top: 1.5em;
}
.img-card-btn {
  text-align: center;
  margin-top: 2em;
}
.img-card-head2 {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  margin-top: 12px;
  line-height: 1.4;
}
@media screen and (max-width: 1000px) {
  .img-card-head2 {
    font-size: 18px;
  }
}
.img-card-bg {
  mix-blend-mode: screen;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  width: 800px;
  height: 751px;
  max-width: inherit;
}
@media screen and (max-width: 768px) {
  .img-card {
    text-align: center;
  }
  .img-card p {
    margin-top: 1em;
  }
  .img-card p small {
    font-size: 14px;
  }
  .img-card-head {
    margin-top: 16px;
  }
  .img-card-head + .img-card-text {
    margin-top: 15px;
  }
  .img-card-bg {
    width: 550px;
    height: 500px;
  }
}

.lyt-card {
  display: flex;
}
@media screen and (max-width: 768px) {
  .lyt-card {
    flex-wrap: wrap;
  }
}
.lyt-card--box, .lyt-card--box2 {
  margin: 0 auto 0;
  max-width: 1080px;
  gap: 3%;
}
.lyt-card--box .lyt-card-item, .lyt-card--box2 .lyt-card-item {
  width: 38%;
  margin-top: 35px;
  text-align: center;
}
.lyt-card--box .lyt-card-box, .lyt-card--box2 .lyt-card-box {
  width: 59%;
}
.lyt-card--box .lyt-card-box .box-card, .lyt-card--box2 .lyt-card-box .box-card {
  margin-top: 60px;
}
.lyt-card--box .lyt-card-box .box-card p, .lyt-card--box2 .lyt-card-box .box-card p {
  margin-top: 20px;
}
.lyt-card--box .lyt-card-box .box-card-card, .lyt-card--box2 .lyt-card-box .box-card-card {
  width: 100%;
  text-align: center;
}
.lyt-card--box .lyt-card-box .box-card-inner, .lyt-card--box2 .lyt-card-box .box-card-inner {
  padding-top: 20px;
  display: flex;
  gap: 6%;
}
.lyt-card--box .lyt-card-box .box-card-inner .box-card-item, .lyt-card--box2 .lyt-card-box .box-card-inner .box-card-item {
  width: 47%;
}
.lyt-card--box .lyt-card-name, .lyt-card--box2 .lyt-card-name {
  text-align: center;
}
.lyt-card--box .box-card-name, .lyt-card--box2 .box-card-name {
  text-align: center;
  margin-top: 12px;
}
@media screen and (max-width: 768px) {
  .lyt-card--box, .lyt-card--box2 {
    margin-top: 15px;
    gap: 20px 4%;
  }
  .lyt-card--box .lyt-card-item, .lyt-card--box2 .lyt-card-item {
    width: 100%;
    margin-top: 0;
  }
  .lyt-card--box .lyt-card-item .lyt-card-name, .lyt-card--box2 .lyt-card-item .lyt-card-name {
    margin-top: 0;
  }
  .lyt-card--box .lyt-card-item .lty-card-card, .lyt-card--box2 .lyt-card-item .lty-card-card {
    max-width: 300px;
    margin: 0 auto;
  }
  .lyt-card--box .lyt-card-box, .lyt-card--box2 .lyt-card-box {
    width: 100%;
  }
  .lyt-card--box .lyt-card-box .box-card, .lyt-card--box2 .lyt-card-box .box-card {
    margin-top: 30px;
  }
  .lyt-card--box .lyt-card-box .box-card-inner, .lyt-card--box2 .lyt-card-box .box-card-inner {
    padding-top: 10px !important;
    display: block;
  }
  .lyt-card--box .lyt-card-box .box-card-item, .lyt-card--box2 .lyt-card-box .box-card-item {
    width: 100% !important;
    display: flex;
    align-items: center;
    gap: 20px;
  }
  .lyt-card--box .lyt-card-box .box-card-item:not(:first-child), .lyt-card--box2 .lyt-card-box .box-card-item:not(:first-child) {
    margin-top: 10px;
  }
  .lyt-card--box .lyt-card-box .box-card-item .box-card-card, .lyt-card--box2 .lyt-card-box .box-card-item .box-card-card {
    width: calc(50% - 10px);
  }
  .lyt-card--box .lyt-card-box .box-card-item .box-card-contents, .lyt-card--box2 .lyt-card-box .box-card-item .box-card-contents {
    width: calc(50% - 10px);
  }
  .lyt-card--box .lyt-card-box .box-card-item .box-card-name, .lyt-card--box2 .lyt-card-box .box-card-item .box-card-name {
    margin-top: 0;
  }
  .lyt-card--box .lyt-card-box .box-card-item p, .lyt-card--box2 .lyt-card-box .box-card-item p {
    margin-top: 10px;
  }
}
.lyt-card--box2 {
  gap: 4%;
  justify-content: center;
}
.lyt-card--box2 .lyt-card-item {
  width: 38%;
}
.lyt-card--box2 .lyt-card-box {
  width: 38%;
}
.lyt-card--box2 .lyt-card-box .box-card {
  margin-top: 60px;
  max-width: 350px;
}
.lyt-card--box2 .lyt-card-box .box-card-inner {
  padding-top: 20px;
  display: flex;
  gap: 6%;
}
.lyt-card--box2 .lyt-card-box .box-card-inner .box-card-item {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .lyt-card--box2 {
    gap: 20px 0;
  }
  .lyt-card--box2 .lyt-card-box {
    width: 100%;
    order: 2;
  }
  .lyt-card--box2 .lyt-card-box .box-card {
    margin-top: 20px;
  }
  .lyt-card--box2 .lyt-card-item {
    width: 100%;
    order: 1;
  }
}
.lyt-card--evo1, .lyt-card--evo2 {
  margin: 60px auto 0;
  max-width: 1080px;
  gap: 3%;
  align-items: flex-end;
  justify-content: center;
}
.lyt-card--evo1 .lyt-card-item, .lyt-card--evo2 .lyt-card-item {
  width: 28%;
  text-align: center;
}
.lyt-card--evo1 .lyt-card-item:first-child, .lyt-card--evo2 .lyt-card-item:first-child {
  width: 38%;
}
.lyt-card--evo1 .lyt-card-item:first-child .lyt-card-name, .lyt-card--evo2 .lyt-card-item:first-child .lyt-card-name {
  margin-top: -6px;
}
.lyt-card--evo1 .lyt-card-item:first-child .lyt-card-name img, .lyt-card--evo2 .lyt-card-item:first-child .lyt-card-name img {
  position: relative;
  left: 12px;
}
@media screen and (max-width: 768px) {
  .lyt-card--evo1 .lyt-card-item:first-child .lyt-card-name img, .lyt-card--evo2 .lyt-card-item:first-child .lyt-card-name img {
    left: 7px;
  }
}
.lyt-card--evo1 .lyt-card-item:nth-child(2) .lty-card-evo, .lyt-card--evo1 .lyt-card-item:nth-child(3) .lty-card-evo, .lyt-card--evo2 .lyt-card-item:nth-child(2) .lty-card-evo, .lyt-card--evo2 .lyt-card-item:nth-child(3) .lty-card-evo {
  text-align: left;
  margin-left: -17%;
  margin-bottom: 2px;
}
.lyt-card--evo1 .lyt-card-name, .lyt-card--evo2 .lyt-card-name {
  margin-top: 12px;
}
@media screen and (max-width: 768px) {
  .lyt-card--evo1, .lyt-card--evo2 {
    margin-top: 15px;
    gap: 20px 4%;
  }
  .lyt-card--evo1 .lyt-card-item:first-child, .lyt-card--evo2 .lyt-card-item:first-child {
    width: 100%;
    order: 1;
  }
  .lyt-card--evo1 .lyt-card-item:first-child .lyt-card-name, .lyt-card--evo2 .lyt-card-item:first-child .lyt-card-name {
    margin-top: 0;
  }
  .lyt-card--evo1 .lyt-card-item:first-child .lty-card-card, .lyt-card--evo2 .lyt-card-item:first-child .lty-card-card {
    max-width: 260px;
    margin: 0 auto;
  }
  .lyt-card--evo1 .lyt-card-item:nth-child(2), .lyt-card--evo1 .lyt-card-item:nth-child(3), .lyt-card--evo2 .lyt-card-item:nth-child(2), .lyt-card--evo2 .lyt-card-item:nth-child(3) {
    width: 48%;
  }
  .lyt-card--evo1 .lyt-card-item:nth-child(2), .lyt-card--evo2 .lyt-card-item:nth-child(2) {
    order: 3;
  }
  .lyt-card--evo1 .lyt-card-item:nth-child(2) .lty-card-evo, .lyt-card--evo2 .lyt-card-item:nth-child(2) .lty-card-evo {
    text-align: right;
    margin-left: 0;
    margin-right: -10px;
    margin-bottom: 30px;
    margin-top: -50px;
  }
  .lyt-card--evo1 .lyt-card-item:nth-child(3), .lyt-card--evo2 .lyt-card-item:nth-child(3) {
    order: 2;
  }
  .lyt-card--evo1 .lyt-card-item:nth-child(3) .lty-card-evo, .lyt-card--evo2 .lyt-card-item:nth-child(3) .lty-card-evo {
    text-align: right;
    margin-left: 0;
    margin-right: -70px;
    margin-bottom: 5px;
  }
}
@media screen and (max-width: 768px) {
  .lyt-card--evo1 .lyt-card-item:nth-child(2) .lty-card-evo {
    margin-top: -40px;
    margin-right: -70px;
    margin-bottom: -25px;
  }
}

.head-h2 {
  margin-top: 100px;
  text-align: center;
}
.head-h2 + .head-h3 {
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .head-h2 {
    margin-top: 60px;
  }
  .head-h2 + .head-h3 {
    margin-top: 40px;
  }
}

.head-h3 {
  margin-top: 70px;
  text-align: center;
  width: 100%;
}
.head-h3 > span {
  color: #004F9C;
  font-size: 28px;
  display: inline-block;
  font-weight: 900;
}
.head-h3 + .lyt-movie {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .head-h3 {
    margin-top: 40px;
  }
  .head-h3 > span {
    font-size: 20px;
  }
}

.head-h4 {
  margin-top: 40px;
}

.list-card {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  margin-top: 40px;
}
.list-card > li {
  width: calc(33.333% - 13.3333333333px);
}
.list-card > li img {
  max-width: 100%;
}
.list-card--col4 > li {
  width: calc(25% - 15px);
}
@media screen and (max-width: 768px) {
  .list-card--col4 > li {
    width: calc(33.333% - 6.6666666667px);
  }
}
@media screen and (max-width: 768px) {
  .list-card {
    gap: 10px;
    margin-top: 36px;
  }
  .list-card > li {
    width: calc(33.333% - 6.6666666667px);
  }
}

.box-fill {
  background: #FFFBD1;
  border-radius: 30px;
  margin: 75px auto 0;
  padding: 100px 60px;
  max-width: 928px;
}
.box-fill > *:first-child {
  margin-top: 0;
}
.box-fill + .box-fill {
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  .box-fill {
    border-radius: 12px;
    padding: 40px 22px;
    margin-top: 40px;
    max-width: 500px;
  }
  .box-fill + .box-fill {
    margin-top: 25px;
  }
}

.bnr-float {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 1000;
  display: none;
  max-width: 230px;
}
.bnr-float > a {
  display: inline-block;
}
.bnr-float > a img {
  transition: 0.3s;
}
.bnr-float > a:hover img {
  opacity: 0.6;
}
.bnr-float-text {
  margin-bottom: 5px;
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  color: #fdfdfd;
  -webkit-text-stroke: 3px #82838A;
  text-stroke: 3px #82838A;
  paint-order: stroke;
}
@media screen and (max-width: 768px) {
  .bnr-float {
    bottom: 10px;
    right: 10px;
  }
}

ul.list-bullet {
  margin-top: 2em;
}
ul.list-bullet > li {
  padding-left: 1em;
  position: relative;
}
ul.list-bullet > li:before {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  background: #fff;
  position: absolute;
  top: 0.6em;
  left: 0;
  border-radius: 10em;
}
ul.list-bullet > li:not(:first-child) {
  margin-top: 0.3em;
}

p.text {
  margin-top: 2em;
  line-height: 1.7;
}
p.text > b {
  font-weight: bold;
}
p.text--notice {
  padding-left: 1em;
  text-indent: -1em;
  font-size: 16px;
}
p.text--lead {
  font-size: 20px;
  font-weight: bold;
}
p.text--center {
  text-align: center;
}
@media screen and (max-width: 768px) {
  p.text {
    text-align: justify;
    text-justify: inter-ideograph;
  }
  p.text + p.text {
    margin-top: 1em;
  }
  p.text--notice {
    font-size: 14px;
  }
  p.text--lead {
    font-size: 15px;
  }
  p.text--center {
    text-align: center;
  }
}

.lyt-movie {
  text-align: center;
  margin: 40px auto 0;
  max-width: 840px;
  background: rgba(0, 0, 0, 0.1);
}
.lyt-movie-inner {
  padding-top: 56.25%;
  position: relative;
}
.lyt-movie-inner > iframe {
  width: 100% !important;
  height: 100% !important;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 768px) {
  .lyt-movie {
    margin-top: 20px;
  }
}

.lyt-cardlist {
  text-align: center;
  display: flex;
  max-width: 1208px;
  margin-top: 18px;
  margin-left: auto;
  margin-right: auto;
  gap: 0 16px;
}
.lyt-cardlist-item {
  width: calc(50% - 8px);
  text-align: center;
}
.lyt-cardlist-item > a {
  display: inline-block;
}
.lyt-cardlist-item > a:hover {
  opacity: 0.6;
}
@media screen and (max-width: 768px) {
  .lyt-cardlist {
    flex-wrap: wrap;
    margin-top: 5px;
  }
  .lyt-cardlist-item {
    width: 100%;
  }
  .lyt-cardlist-item:nth-child(n+2) {
    margin-top: 0;
  }
}

.lyt-image {
  text-align: center;
  margin: 4em auto 0;
}
.lyt-image-item {
  display: inline-block;
}
.lyt-image a {
  display: inline-block;
}
.lyt-image a:hover {
  opacity: 0.6;
}
.lyt-image-caption {
  display: inline-block;
  margin-top: 10px;
  font-size: 16px;
  font-weight: normal;
  text-align: left;
}
@media screen and (max-width: 768px) {
  .lyt-image {
    margin-top: 3em;
    max-width: 500px;
  }
  .lyt-image-caption {
    font-size: 15px;
  }
}

.lyt-image2 {
  text-align: center;
}
.lyt-image2 > img {
  width: 100%;
  max-width: inherit;
}
.btn-wrap {
  margin-top: 60px;
  text-align: center;
}
.btn-wrap a {
  display: inline-block;
}
.btn-wrap a:hover {
  opacity: 0.6;
}
.btn-wrap-caption {
  margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .btn-wrap {
    margin-top: 40px;
  }
}

body {
  background: #041F28;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  position: relative;
  line-height: 1.5;
}
body:before {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: url("/ex/m4/assets/images/common-bg-01-msyax.png") repeat center bottom/cover;
  content: "";
  z-index: -2;
  opacity: 0.12;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 15px;
  }
  body:before {
    background: url("/ex/m4/assets/images/common-bg-01-msyax_sp.png") repeat center bottom/cover;
  }
}
body.is-modal-open main {
  filter: blur(10px);
}

main {
  overflow: hidden;
}

.btn-wrap {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  border: none;
  padding: 0;
  margin: 0;
  background: none;
  font: inherit;
  color: inherit;
  text-align: inherit;
  cursor: pointer;
  line-height: 0;
  transition: 0.3s;
}
@media (hover: hover) {
  .btn-wrap:hover .btn-img {
    opacity: 0.8;
  }
}
.btn-wrap .btn-img {
  transition: 0.3s;
}

.box-border {
  max-width: 1060px;
  margin: 0 auto;
}
.box-border > *:first-child {
  margin-top: 0;
}
.box-border-inner {
  margin: 0 auto;
}
.box-border-inner > *:first-child {
  margin-top: 0;
}
.box-border-head {
  text-align: center;
  margin-top: 100px;
}
@media screen and (max-width: 768px) {
  .box-border-head {
    margin-top: 77px;
  }
}

.section {
  padding: 0 20px;
  position: relative;
}
.section .section-inner {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
}
.section .section-inner > *:first-child {
  margin-top: 0 !important;
}
.section .section-inner--full {
  max-width: inherit;
}
.section.section-hero {
  padding: 0;
  background: #041F28;
}
.section.section-intro {
  position: relative;
  padding: 60px 0 0;
}
@media screen and (max-width: 768px) {
  .section.section-intro {
    padding-top: 118px;
  }
}
.section.section-intro::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 200px;
  background: linear-gradient(to bottom, #041F28 5.02%, rgba(0, 35, 47, 0.92) 29.79%, rgba(0, 35, 47, 0.62) 66.25%, rgba(0, 35, 47, 0) 97.85%);
  z-index: 5;
}
@media screen and (max-width: 768px) {
  .section.section-intro::before {
    height: 100px;
  }
}
.section.section-intro > .section-inner {
  max-width: 100%;
  position: relative;
  z-index: 10;
}
.section.section-intro > .section-inner::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 1240px;
  aspect-ratio: 1240/441;
  border-radius: 1240px;
  background: linear-gradient(269deg, #27458A 40.88%, #0083BF 120.19%);
  background-blend-mode: overlay;
  filter: blur(100px);
}
@media screen and (max-width: 768px) {
  .section.section-intro > .section-inner::before {
    width: 89.7435897436%;
    max-width: 350px;
    aspect-ratio: 350/400;
    border-radius: 400px;
    background: linear-gradient(270deg, #27458A 34.43%, #0083BF 105.57%);
    filter: blur(75px);
  }
}
.section.section-intro > .section-inner::after {
  content: "";
  position: absolute;
  top: -6%;
  left: 52%;
  transform: translateX(-50%);
  background: url("/ex/m4/assets/images/intro-effect-02.png") no-repeat center top;
  width: 189.3055555556%;
  aspect-ratio: 2726/788;
}
@media screen and (max-width: 1439px) {
  .section.section-intro > .section-inner::after {
    width: 100%;
    background: url("/ex/m4/assets/images/intro-effect-03.png") no-repeat center top/contain;
    aspect-ratio: 1440/788;
    left: 50%;
  }
}
@media screen and (max-width: 768px) {
  .section.section-intro > .section-inner::after {
    background: url("/ex/m4/assets/images/intro-effect-02_sp.png") no-repeat center top/contain;
    width: 908px;
    aspect-ratio: 908/356;
    top: -32%;
    left: 45%;
  }
}
.section.section-mega {
  padding-top: 70px;
}
@media screen and (max-width: 768px) {
  .section.section-mega {
    padding: 0 14px;
  }
}
.section.section-mega .section-inner {
  max-width: 1440px;
}
.section.section-mega .box-border {
  max-width: 1440px;
}
.section.section-pokemon {
  position: relative;
  padding: 0;
  margin-top: 120px;
}
@media screen and (max-width: 768px) {
  .section.section-pokemon {
    margin-top: 54px;
  }
}
.section.section-pokemon > .section-inner {
  max-width: 100%;
  background: url("/ex/m4/assets/images/pokemon-bg-01.png") no-repeat center top;
  position: relative;
  padding: 379px 20px 310px;
}
@media screen and (max-width: 768px) {
  .section.section-pokemon > .section-inner {
    background: url("/ex/m4/assets/images/pokemon-bg-01_sp.png") no-repeat 0 0/cover;
    padding: 138px 20px 128px;
  }
}
@media screen and (min-width: 2001px) {
  .section.section-pokemon > .section-inner {
    background: url("/ex/m4/assets/images/pokemon-bg-01.png") no-repeat 0 0/100% auto;
  }
}
.section.section-product {
  padding: 0;
}
.section.section-product:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100%;
  background: url("/ex/m4/assets/images/common-bg-01-msyax.png") repeat center bottom/cover;
  content: "";
  z-index: -2;
}
@media screen and (max-width: 768px) {
  .section.section-product:before {
    background: url("/ex/m4/assets/images/common-bg-01-msyax_sp.png") repeat center bottom/cover;
  }
}
.section.section-product .section-inner {
  max-width: 100%;
  background: rgba(8, 28, 51, 0.9);
  padding: 40px 0 0;
}
@media screen and (max-width: 768px) {
  .section.section-product .section-inner {
    background: rgba(8, 28, 51, 0.8);
    padding: 20px 0 0;
  }
}
.section.section-product .section-inner::before {
  content: "";
  position: absolute;
  top: -213px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  max-height: 333px;
  background: url("/ex/m4/assets/images/product-bg-01.png") no-repeat center top;
  z-index: 5;
}
@media screen and (max-width: 768px) {
  .section.section-product .section-inner::before {
    top: -79px;
    height: 169px;
    max-height: 169px;
    background: url("/ex/m4/assets/images/product-bg-01_sp.png") no-repeat 0 0/100% 100%;
  }
}
@media screen and (min-width: 2001px) {
  .section.section-product .section-inner::before {
    background: url("/ex/m4/assets/images/product-bg-01.png") no-repeat 0 0/100% auto;
  }
}
.section.section-product .section-inner .box-border {
  position: relative;
  z-index: 10;
}

.img-size {
  max-height: var(--h-pc);
}
@media (max-width: 768px) {
  .img-size {
    max-height: var(--h-sp);
  }
}

.img-card-effect {
  border-radius: 20px;
}
@media screen and (min-width: 769px) {
  .img-card-effect.ani-zoom {
    transition: 0.3s;
  }
  .img-card-effect.ani-zoom:hover {
    transform: scale(1.3);
    position: relative;
    z-index: 100;
  }
}
.img-card-effect--01 {
  box-shadow: 0 0 18px 8px #00A3DA;
}
.img-card-effect--02 {
  box-shadow: 0 0 14px 8px rgba(1, 161, 227, 0.5);
}

.hero-visual img {
  width: 100%;
}

.intro-wrap {
  position: relative;
  display: grid;
  grid-template-columns: 49.4017094017% 51.2820512821%;
  align-items: center;
  max-width: 1270px;
  margin: 0 auto;
  padding: 0 50px;
}
@media screen and (max-width: 768px) {
  .intro-wrap {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    max-width: 390px;
    margin: 0 auto 24px;
    padding: 0 20px;
    gap: 12px;
  }
}
.intro-wrap.is-show .intro-item:nth-child(2) {
  opacity: 1;
  transform: translateX(0);
}
.intro-item:nth-child(2) {
  opacity: 0;
  transition: 0.3s;
}
.intro-item:nth-child(2) {
  transform: translateX(100vw);
}
@media screen and (max-width: 768px) {
  .intro-item:nth-child(2) {
    padding: 0 30px 0 10px;
  }
}
.intro-item-text {
  position: relative;
  width: 100%;
  margin: 0 0 43px 5px;
}
@media screen and (max-width: 768px) {
  .intro-item-text {
    margin: 0 auto;
    max-width: 329px;
  }
}
.intro-item-text::before {
  content: "";
  background: url("/ex/m4/assets/images/intro-effect-01.png") no-repeat center center/contain;
  width: 133.9100346021%;
  aspect-ratio: 774/587;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px) {
  .intro-item-text::before {
    width: 390px;
    aspect-ratio: 390/302;
  }
}
.intro-item-text img {
  position: relative;
  z-index: 15;
}

.cardlist-wrap {
  position: absolute;
  bottom: 63px;
  left: 68.2638888889%;
  padding-right: 20px;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  .cardlist-wrap {
    bottom: 4%;
    left: 50%;
    transform: translateX(-50%);
    width: 83.0769230769%;
    max-width: 324px;
    padding: 0;
  }
}
.cardlist-wrap a {
  display: inline-block;
}
.cardlist-wrap a:hover {
  opacity: 0.8;
}

.mega-ex-wrap {
  position: relative;
  background: url("/ex/m4/assets/images/mega-bg-01-xzc5d.png") no-repeat center center/contain;
  max-width: 1274px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .mega-ex-wrap {
    background: url("/ex/m4/assets/images/mega-bg-01-xzc5d_sp.png") no-repeat center top/contain;
    padding: 52px 0 0 0;
  }
}
.mega-ex-wrap::before {
  content: "";
  width: 98.0376766091%;
  max-width: 1249px;
  aspect-ratio: 1/1;
  background: url("/ex/m4/assets/images/mega-bg-02.png") no-repeat center center/contain;
  position: absolute;
  top: -78%;
  right: -50%;
  z-index: -1;
}
.mega-ex-wrap::after {
  content: "";
  width: 113.579277865%;
  max-width: 1447px;
  aspect-ratio: 1/1;
  background: url("/ex/m4/assets/images/mega-bg-03.png") no-repeat center center/contain;
  position: absolute;
  top: 10%;
  left: -65%;
  z-index: -1;
}
.mega-ex-inner {
  max-width: 1145px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  padding: 84px 72px 140px 63px;
  margin: 0 auto;
  gap: 50px;
}
@media screen and (max-width: 768px) {
  .mega-ex-inner {
    padding: 0;
    flex-direction: column;
    gap: 46px;
  }
}
.mega-ex-img {
  position: relative;
}
.mega-ex-img::before {
  content: "";
  position: absolute;
  top: 48%;
  left: 23%;
  transform: translate(-50%, -50%);
  width: 230.2857142857%;
  aspect-ratio: 806/668;
  background: url("/ex/m4/assets/images/mega-effect-01.png") no-repeat 0 0/100%;
}
@media screen and (max-width: 768px) {
  .mega-ex-img::before {
    width: 475px;
    aspect-ratio: 475/411;
    background: url("/ex/m4/assets/images/mega-effect-01_sp.png") no-repeat 0 0/100%;
    top: 44%;
    left: 34%;
  }
}
.mega-ex-img > .img-card-effect {
  position: relative;
  transform: rotate(-4deg);
}
@media screen and (max-width: 768px) {
  .mega-ex-img > .img-card-effect {
    transform: rotate(4deg);
  }
}
@media (hover: hover) {
  .mega-ex-img > .img-card-effect.ani-zoom:hover {
    transform: rotate(-4deg) scale(1.3);
  }
}
.mega-ex-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.mega-ex-btn {
  position: absolute;
  top: 84%;
  right: 8.5%;
  width: 41.9152276295%;
}
@media screen and (max-width: 768px) {
  .mega-ex-btn {
    position: static;
    width: 100%;
    max-width: 342px;
    margin: 36px auto 0;
  }
}
.mega-ex-btn .btn-wrap {
  position: relative;
  width: 100%;
}
@media (hover: hover) {
  .mega-ex-btn .btn-wrap:hover .mega-ex-btn-img {
    opacity: 1;
  }
  .mega-ex-btn .btn-wrap:hover::before {
    opacity: 0.8;
  }
}
.mega-ex-btn .btn-wrap::before {
  content: "";
  display: block;
  width: 100%;
  max-width: 534px;
  aspect-ratio: 534/139;
  background: url("/ex/m4/assets/images/mega-btn-03.png") no-repeat 0 0/100%;
  transition: 0.3s;
}
@media screen and (max-width: 768px) {
  .mega-ex-btn .btn-wrap::before {
    background: url("/ex/m4/assets/images/mega-btn-03_sp.png") no-repeat 0 0/100%;
    aspect-ratio: 342/103;
  }
}
.mega-ex-btn-text {
  position: absolute;
  top: 45%;
  right: 7%;
  transform: translateY(-50%);
  max-width: 228px;
  width: 42.6966292135%;
}
@media screen and (max-width: 768px) {
  .mega-ex-btn-text {
    right: 6%;
  }
}
.mega-ex-btn-img {
  position: absolute;
  top: -21%;
  left: 6.5%;
  width: 37.8277153558%;
}
@media screen and (max-width: 768px) {
  .mega-ex-btn-img {
    top: -8%;
    left: 8%;
    width: 37.7192982456%;
    max-width: 129px;
  }
}
.mega-ex-name {
  position: relative;
  margin-top: 15px;
  margin-bottom: 12px;
  padding-right: 4px;
}
.mega-ex-name.is-show::before {
  clip-path: polygon(0 -10px, calc(100% + 10px) -10px, calc(100% + 10px) calc(100% + 10px), 0 calc(100% + 10px));
}
.mega-ex-name.is-show > picture > img {
  clip-path: polygon(0 -10px, calc(100% + 10px) -10px, calc(100% + 10px) calc(100% + 10px), 0 calc(100% + 10px));
}
.mega-ex-name::before {
  content: "";
  width: 111.1349036403%;
  aspect-ratio: 519/73;
  background: url("/ex/m4/assets/images/mega-name-02.png") no-repeat 0 0/contain;
  position: absolute;
  top: 50%;
  left: 51%;
  transform: translate(-50%, -50%);
  clip-path: polygon(0 -10px, 0 -10px, 0 calc(100% + 10px), 0 calc(100% + 10px));
  transition: clip-path 0.3s ease-in-out;
  transition-delay: 0s;
}
@media screen and (max-width: 768px) {
  .mega-ex-name::before {
    background: url("/ex/m4/assets/images/mega-name-02_sp.png") no-repeat 0 0/100%;
    width: 115.5893536122%;
    aspect-ratio: 304/52;
    top: 55%;
    left: 50%;
  }
}
.mega-ex-name > picture > img {
  position: relative;
  clip-path: polygon(0 -10px, 0 -10px, 0 calc(100% + 10px), 0 calc(100% + 10px));
  transition: clip-path 0.3s ease-in-out;
  transition-delay: 0.11s;
}

.mega-wrap {
  border-radius: 20px;
  background: linear-gradient(to bottom, rgba(41, 73, 144, 0.7), rgba(28, 52, 105, 0.7));
  max-width: 1040px;
  padding: 60px 50px;
  margin: 92px auto 0;
  position: relative;
}
@media screen and (max-width: 768px) {
  .mega-wrap {
    max-width: 310px;
    padding: 30px 20px 27px;
    margin-top: 22px;
  }
}
.mega-wrap::before {
  content: "";
  width: 148.5576923077%;
  max-width: 1545px;
  aspect-ratio: 1/1;
  background: url("/ex/m4/assets/images/mega-bg-04.png") no-repeat center center/contain;
  position: absolute;
  bottom: -190%;
  right: -74%;
  z-index: -1;
}
.mega-inner {
  max-width: 840px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 80px;
}
@media screen and (max-width: 768px) {
  .mega-inner {
    flex-direction: column;
    gap: 4px;
  }
}
.mega-inner > .img-card-effect > img {
  max-width: -moz-fit-content;
  max-width: fit-content;
}
.mega-content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  position: relative;
  margin-top: 8px;
}
@media screen and (max-width: 768px) {
  .mega-content {
    gap: 10px;
    padding: 13px 0;
  }
}
.mega-content::before {
  content: "";
  position: absolute;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 351px;
  aspect-ratio: 1/1;
  background: url("/ex/m4/assets/images/mega-img-01-bprak.png") no-repeat 0 0/100%;
}
@media screen and (max-width: 768px) {
  .mega-content::before {
    width: 120px;
    top: 50%;
  }
}
@media screen and (max-width: 768px) {
  .mega-name {
    text-align: center;
  }
}
.mega-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .mega-text {
    font-size: 15px;
  }
}

.pokemon-box {
  padding: 112px 50px 25px;
  max-width: 1040px;
  position: relative;
  margin: 100px auto;
}
@media screen and (max-width: 768px) {
  .pokemon-box {
    margin: 31px 0;
    padding: 88px 20px 42px;
  }
}
.pokemon-box-bg {
  background: linear-gradient(to bottom, rgb(28, 38, 67), rgb(39, 53, 92));
  position: absolute;
  inset: 0;
  opacity: 0.8;
}
@media screen and (max-width: 768px) {
  .pokemon-box-bg {
    background: #1C2643;
    opacity: 0.6;
  }
}
.pokemon-box-bg::before {
  content: "";
  position: absolute;
  top: -90px;
  left: 0;
  width: 100%;
  height: 91px;
  background: url("/ex/m4/assets/images/pokemon-bg-02.png") no-repeat 0 0/100% 100%;
}
@media screen and (max-width: 768px) {
  .pokemon-box-bg::before {
    background: url("/ex/m4/assets/images/pokemon-bg-02_sp.png") no-repeat 0 0/100% 100%;
    top: -26px;
    height: 27px;
  }
}
.pokemon-box-bg::after {
  content: "";
  position: absolute;
  bottom: -90px;
  left: 0;
  width: 100%;
  height: 91px;
  background: url("/ex/m4/assets/images/pokemon-bg-03.png") no-repeat 0 0/100% 100%;
}
@media screen and (max-width: 768px) {
  .pokemon-box-bg::after {
    background: url("/ex/m4/assets/images/pokemon-bg-03_sp.png") no-repeat 0 0/100% 100%;
    bottom: -26px;
    height: 27px;
  }
}
.pokemon-box .box-border-head {
  position: absolute;
  top: -2.5%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .pokemon-box .box-border-head {
    top: 1.5%;
  }
}
.pokemon-wrap {
  max-width: 840px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .pokemon-wrap {
    max-width: 310px;
  }
}
.pokemon-list {
  display: flex;
  justify-content: space-between;
  gap: 30px;
  margin-top: 53px;
}
@media screen and (max-width: 768px) {
  .pokemon-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr;
    gap: 52px 20px;
    margin-top: 17px;
  }
}
.pokemon-list:not(:first-of-type) {
  margin-top: 104px;
}
@media screen and (max-width: 768px) {
  .pokemon-list:not(:first-of-type) {
    margin-top: 62px;
  }
}
.pokemon-item {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr 32px;
  align-items: end;
  gap: 16px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .pokemon-item {
    grid-template-rows: 1fr 20px;
    gap: 12px;
  }
}
@media screen and (max-width: 768px) {
  .pokemon-item:first-of-type {
    grid-column: 1/3;
    grid-row: 1/2;
  }
}
@media screen and (max-width: 768px) {
  .pokemon-item:nth-of-type(2) {
    grid-column: 2/3;
    grid-row: 2/3;
  }
}
.pokemon-item:nth-of-type(2) .pokemon-evo {
  left: -12%;
}
@media screen and (max-width: 768px) {
  .pokemon-item:nth-of-type(2) .pokemon-evo {
    top: -30%;
    left: 38%;
    width: 52.7586206897%;
    max-width: 76.5px;
  }
}
@media screen and (max-width: 768px) {
  .pokemon-item:nth-of-type(3) {
    grid-column: 1/2;
    grid-row: 2/3;
  }
}
.pokemon-item:nth-of-type(3) .pokemon-evo {
  left: -31%;
}
@media screen and (max-width: 768px) {
  .pokemon-item:nth-of-type(3) .pokemon-evo {
    top: -22%;
    left: auto;
    right: -39%;
    width: 55.1724137931%;
    max-width: 80px;
  }
}
.pokemon-img {
  margin: 0 auto;
}
.pokemon-name {
  display: flex;
  align-items: center;
  justify-content: center;
}
.pokemon-evo {
  position: absolute;
  top: -6%;
  width: 38.8%;
  max-width: 97px;
}

.section-product .lyt-column--product {
  max-width: 938px;
  justify-content: space-between;
  margin-top: 35px;
  padding: 0 60px;
}
@media screen and (max-width: 768px) {
  .section-product .lyt-column--product {
    max-width: 310px;
    padding: 0 20px;
    margin-top: 12px;
  }
}
.section-product .lyt-column--product .lyt-column-item:first-child {
  flex: none;
  width: 268px;
}
@media screen and (max-width: 768px) {
  .section-product .lyt-column--product .lyt-column-item:first-child {
    text-align: center;
  }
}
.section-product .lyt-column--product .lyt-column-item:nth-child(2) {
  flex: none;
  width: calc(100% - 268px - 96px);
}

.product-dl {
  display: flex;
}
.product-dl dt {
  white-space: nowrap;
}

.product-list > li {
  padding-left: 1.5em;
  position: relative;
  margin-top: 2px;
}
.product-list > li:before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
  position: absolute;
  top: 0.6em;
  left: 0.5em;
}

.text-product {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 1em;
  font-feature-settings: "palt";
}
.text-product + p {
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .text-product {
    font-size: 20px;
    margin-bottom: 36px;
  }
  .text-product + p {
    font-size: 15px !important;
  }
}

.data-product {
  font-size: 16px;
  font-weight: 500;
}
.data-product > *:not(:first-child) {
  margin-top: 2px;
}
@media screen and (max-width: 768px) {
  .data-product {
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    font-size: 15px;
  }
}
.data-product--notice {
  display: block;
  font-feature-settings: "palt";
}
.data-product--notice::before {
  content: "※";
}

.button-product {
  margin-top: 2em;
}
.button-product > a {
  display: inline-block;
}
.button-product > a img {
  width: 100%;
}
.button-product > a:hover {
  opacity: 0.8;
}
@media screen and (max-width: 768px) {
  .button-product {
    text-align: center;
  }
}

.modal-content {
  position: absolute;
  z-index: 8000;
  width: calc(100% + 20px);
  height: 100vh;
  overflow-y: scroll;
  color: #000;
  display: none;
  top: 0;
  left: 0;
}
@media screen and (max-width: 768px) {
  .modal-content {
    width: 100%;
    position: fixed;
  }
}
.modal-content:before {
  content: "";
  display: block;
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  background: rgba(39, 69, 138, 0.75);
  backdrop-filter: blur(15px);
}
.modal-content-cardlist:before {
  background: url("/ex/m4/assets/images/common-bg-01-msyax.png") no-repeat center center/cover;
}
.modal-content-cardlist::after {
  content: "";
  display: block;
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  background: rgba(39, 69, 138, 0.2);
}
.modal-content-close {
  text-align: center;
  margin-top: 20px;
}
.modal-content-close > a {
  transition: 0.3s;
  display: inline-block;
}
.modal-content-close > a:hover {
  opacity: 0.8;
}
.modal-content-close2 {
  position: absolute;
  top: 0;
  right: -1%;
  z-index: 1;
  text-align: right;
  padding: 20px 16px 0px 0px;
}
.modal-content-close2 > a {
  display: inline-block;
}
.modal-content-close2 > a:hover {
  opacity: 0.8;
}
@media screen and (max-width: 768px) {
  .modal-content-close2 {
    width: 100%;
    position: static;
    transform: none;
    z-index: inherit;
    padding: 0;
    margin-left: 4px;
  }
}
.modal-content-wrap {
  position: relative;
  padding: 80px 0 80px;
}
@media screen and (max-width: 768px) {
  .modal-content-wrap {
    padding: 36px 20px 40px;
  }
}
.modal-content-wrap > * {
  position: relative;
  z-index: 2;
}
.modal-content-inner {
  position: relative;
  width: 100%;
  max-width: 1084px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .modal-content {
    height: 100%;
  }
  .modal-content-close {
    margin-top: 15px;
  }
}

.modal-head {
  text-align: center;
  margin-top: 120px;
}
@media screen and (max-width: 768px) {
  .modal-head {
    margin-top: 80px;
  }
}

.modal-box {
  overflow: hidden;
  position: relative;
  padding: 0 122px;
}
@media screen and (max-width: 768px) {
  .modal-box {
    padding: 0;
  }
}
.modal-box-bg {
  background: linear-gradient(to bottom, rgb(26, 25, 25), rgb(39, 53, 92));
  position: absolute;
  inset: 0;
  opacity: 0.8;
}
.modal-box-bg::before {
  content: "";
  position: absolute;
  top: -90px;
  left: 0;
  width: 100%;
  height: 91px;
  background: url("/ex/m4/assets/images/modal/modal-bg-01.png") no-repeat 0 0/100% 100%;
}
@media screen and (max-width: 768px) {
  .modal-box-bg::before {
    background: url("/ex/m4/assets/images/modal/modal-bg-01_sp.png") no-repeat 0 0/100% 100%;
    top: -26px;
    height: 27px;
  }
}
.modal-box-bg::after {
  content: "";
  position: absolute;
  bottom: -90px;
  left: 0;
  width: 100%;
  height: 91px;
  background: url("/ex/m4/assets/images/modal/modal-bg-02.png") no-repeat 0 0/100% 100%;
}
@media screen and (max-width: 768px) {
  .modal-box-bg::after {
    background: url("/ex/m4/assets/images/modal/modal-bg-02_sp.png") no-repeat 0 0/100% 100%;
    bottom: -26px;
    height: 27px;
  }
}
.modal-box-contents {
  padding: 20px 50px 25px;
  max-width: 840px;
  position: relative;
  margin: 100px 0;
}
@media screen and (max-width: 768px) {
  .modal-box-contents {
    margin: 31px 0;
    padding: 40px 20px 42px;
  }
}
.modal-box-contents > *:first-child {
  margin-top: 0;
}
.modal-box-contents p {
  color: #fff;
}
.modal-box-contents .modal-head {
  margin-top: 48px;
}
@media screen and (max-width: 768px) {
  .modal-box-contents .modal-head {
    margin-top: 54px;
  }
}
.modal-box-inner {
  max-width: 540px;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .modal-box-inner {
    max-width: 310px;
  }
}

.modal-cardlist {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  max-width: 720px;
  margin: 27px auto 0;
}
@media screen and (max-width: 768px) {
  .modal-cardlist {
    gap: 10px;
    margin-top: 42px;
  }
}
.modal-cardlist > li {
  width: calc(25% - 15px);
}
@media screen and (max-width: 768px) {
  .modal-cardlist > li {
    width: calc(33.3333333333% - 6.6666666667px);
  }
}

.modal-evo-col3-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto 1fr;
  gap: 86px 40px;
}
@media screen and (max-width: 768px) {
  .modal-evo-col3-content {
    gap: 62px 20px;
  }
}
.modal-evo-col3-item {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr 32px;
  align-items: end;
  gap: 18px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .modal-evo-col3-item {
    grid-template-rows: 1fr 20px;
    gap: 10px;
  }
}
.modal-evo-col3-item:first-of-type {
  grid-template-rows: 1fr 36px;
  gap: 28px;
  grid-column: 1/3;
  grid-row: 1/2;
}
@media screen and (max-width: 768px) {
  .modal-evo-col3-item:first-of-type {
    grid-template-rows: 1fr 20px;
    gap: 18px;
  }
}
.modal-evo-col3-item:nth-of-type(2) {
  grid-column: 2/3;
  grid-row: 2/3;
}
.modal-evo-col3-item:nth-of-type(2) .modal-evo-col3-evo {
  top: -26%;
  right: -1%;
  width: 45.2%;
  max-width: 113px;
}
@media screen and (max-width: 768px) {
  .modal-evo-col3-item:nth-of-type(2) .modal-evo-col3-evo {
    top: -37%;
    right: -12%;
    width: 56.5517241379%;
    max-width: 82px;
  }
}
.modal-evo-col3-item:nth-of-type(3) {
  grid-column: 1/2;
  grid-row: 2/3;
}
.modal-evo-col3-item:nth-of-type(3) .modal-evo-col3-evo {
  top: -17%;
  right: -32%;
  width: 38.8%;
  max-width: 97px;
}
@media screen and (max-width: 768px) {
  .modal-evo-col3-item:nth-of-type(3) .modal-evo-col3-evo {
    top: -23%;
    right: -40%;
    width: 55.1724137931%;
    max-width: 80px;
  }
}
.modal-evo-col3-img {
  margin: 0 auto;
}
.modal-evo-col3-name {
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal-evo-col3-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
  margin-top: 36px;
}
@media screen and (max-width: 768px) {
  .modal-evo-col3-text {
    font-size: 15px;
    margin-top: 22px;
  }
}
.modal-evo-col3-evo {
  position: absolute;
}

.modal-col2 {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  margin-top: 38px;
}
@media screen and (max-width: 768px) {
  .modal-col2 {
    flex-direction: column;
    gap: 26px;
    margin-top: 26px;
  }
}
.modal-col2-img {
  display: block;
  margin: 0 auto;
}
.modal-col2-name {
  margin-top: 20px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .modal-col2-name {
    margin-top: 10px;
  }
}
.modal-col2-text {
  margin-top: 16px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .modal-col2-text {
    font-size: 15px;
    margin-top: 2px;
  }
}

.modal-btn-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  justify-content: center;
  gap: 21px;
}
@media screen and (max-width: 768px) {
  .modal-btn-list {
    gap: 11px;
  }
}
.modal-btn-item {
  border-radius: 5px;
  border: 2px solid #FFF;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 48px;
  cursor: pointer;
  padding: 0 5px 5px 5px;
}
@media screen and (max-width: 768px) {
  .modal-btn-item {
    height: 42px;
    padding-bottom: 10px;
  }
  .modal-btn-item:first-of-type {
    padding-bottom: 0;
  }
}
.modal-btn-item.is-active {
  background: #00A3DA;
  border-color: #00A3DA;
}

.modal-content-cardlist .modal-head {
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .modal-content-cardlist .modal-head {
    margin-top: 0;
  }
}
@media screen and (max-width: 768px) {
  .modal-content-cardlist .modal-content-wrap {
    padding-top: 60px;
  }
}
.modal-content-cardlist .modal-box-contents {
  padding-bottom: 0px;
  margin: 140px 0 100px;
  padding-top: 22px;
}
@media screen and (max-width: 768px) {
  .modal-content-cardlist .modal-box-contents {
    margin: 58px 0 30px;
    padding: 40px 5.7142857143% 20px;
  }
}
.modal-content-cardlist .modal-btn-list {
  position: absolute;
  top: -5%;
  left: 50%;
  transform: translateX(-50%);
  width: 56.3095238095%;
  max-width: 473px;
}
@media screen and (max-width: 768px) {
  .modal-content-cardlist .modal-btn-list {
    top: 1.3%;
    width: 58%;
  }
}
.modal-content-cardlist .modal-content-close2 {
  top: 8%;
}
@media screen and (max-width: 768px) {
  .modal-content-cardlist .modal-content-close2 {
    position: absolute;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0;
    top: 0%;
  }
}
@media screen and (max-width: 768px) {
  .modal-content-cardlist .modal-content-close {
    margin-top: 20px;
  }
}

span.ex {
  font-size: 1.25em;
  display: inline-block;
  line-height: 1;
}

.sp-only {
  display: none !important;
}
@media screen and (max-width: 768px) {
  .sp-only {
    display: inline-block !important;
  }
}

@media screen and (max-width: 768px) {
  .pc-only {
    display: none !important;
  }
}

.ta-center {
  text-align: center !important;
}

.ta-left {
  text-align: left !important;
}

.ta-right {
  text-align: right !important;
}

.va-middle {
  display: flex;
  align-items: center;
}

@media screen and (min-width: 769px) {
  .pc-ta-center {
    text-align: center;
  }
}
.pt-0 {
  padding-top: 0;
}

.mt-0 {
  margin-top: 0;
}

.mt-7 {
  margin-top: 7px;
}

.mt-1em {
  margin-top: 1em !important;
}

.mt-2em {
  margin-top: 2em !important;
}

.mt-3em {
  margin-top: 3em !important;
}

.mt-4em {
  margin-top: 4em !important;
}

.mt-5em {
  margin-top: 5em !important;
}

.mt-8em {
  margin-top: 8em !important;
}
@media screen and (max-width: 768px) {
  .mt-8em {
    margin-top: 5em !important;
  }
}

.min-height-67 {
  min-height: 67px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .min-height-67 {
    min-height: inherit;
    display: block;
  }
}

.min-height-85 {
  min-height: 85px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .min-height-85 {
    min-height: inherit;
    display: block;
  }
}

.min-height-90 {
  min-height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .min-height-90 {
    min-height: inherit;
    display: block;
  }
}

.maw-240 {
  max-width: 240px;
}

.maw-200 {
  max-width: 200px;
}

.maw-335 {
  margin-left: auto;
  margin-right: auto;
  max-width: 335px;
}

.maw-440 {
  max-width: 440px;
}

.maw-550 {
  margin-left: auto;
  margin-right: auto;
  max-width: 550px;
}

.maw-610 {
  margin-left: auto;
  margin-right: auto;
  max-width: 610px;
}

.maw-680 {
  margin-left: auto;
  margin-right: auto;
  max-width: 680px;
}

.maw-720 {
  margin-left: auto;
  margin-right: auto;
  max-width: 720px;
}

.maw-850 {
  margin-left: auto;
  margin-right: auto;
  max-width: 850px;
}

.maw-860 {
  margin-left: auto;
  margin-right: auto;
  max-width: 860px;
}

.maw-900 {
  margin-left: auto;
  margin-right: auto;
  max-width: 900px;
}

.min-height-100 {
  min-height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .min-height-100 {
    min-height: inherit;
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .sp-ta-left {
    text-align: left !important;
  }
  .sp-ta-center {
    text-align: center !important;
  }
  .sp-mt-10 {
    margin-top: 10px !important;
  }
  .sp-mt-30 {
    margin-top: 30px !important;
  }
  .sp-mt-60 {
    margin-top: 60px !important;
  }
  .sp-mt-15 {
    margin-top: 15px !important;
  }
  .sp-mt-2em {
    margin-top: 2em !important;
  }
  .sp-mt-3em {
    margin-top: 3em !important;
  }
  .sp-width-100 {
    width: 100%;
  }
  .sp-maw-150 {
    max-width: 150px;
  }
  .sp-maw-180 {
    max-width: 180px;
  }
  .sp-maw-200 {
    max-width: 200px !important;
  }
  .sp-maw-210 {
    max-width: 210px !important;
  }
  .sp-maw-230 {
    max-width: 230px;
  }
  .sp-maw-270 {
    max-width: 270px !important;
  }
  .sp-maw-280 {
    max-width: 280px !important;
  }
  .sp-maw-300 {
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
  }
  .sp-maw-346 {
    max-width: 346px;
    margin-left: auto;
    margin-right: auto;
  }
}
.style-1 {
  margin-top: -20px;
  text-align: right;
}
.style-1 + * {
  margin-top: -20px;
}
@media screen and (max-width: 768px) {
  .style-1 {
    margin-top: 40px;
    text-align: center;
  }
  .style-1 + * {
    margin-top: 30px;
  }
}