@charset "UTF-8";
@use './base/base' as *;
html {
  overflow-x: hidden;
  overflow-anchor: none;
}
@media screen and (max-width: 768px) {
  html {
    overflow-x: hidden;
  }
}

body {
  min-width: auto;
  font-family: "M PLUS Rounded 1c", sans-serif;
  color: #7b553d;
}

.forPC {
  display: block;
}
@media screen and (max-width: 768px) {
  .forPC {
    display: none;
  }
}

.forSP {
  display: none;
}
@media screen and (max-width: 768px) {
  .forSP {
    display: block;
  }
}

img {
  height: auto;
}

a {
  transition: all 0.4s ease;
}

a:hover {
  opacity: 0.7;
}

main {
  font-size: 0.6666666667vw;
  width: 100%;
  background: #FFFCF0;
  overflow: clip;
}
@media screen and (max-width: 768px) {
  main {
    font-size: 1.3333333333vw;
    padding-bottom: 0;
  }
}
@media screen and (min-width: 1500px) {
  main {
    font-size: 10px;
  }
}

/**********************************
 *
 * pankuzu
 *
**********************************/
#pankuzu {
  width: 100%;
  height: auto;
  background-color: #f7f4ee;
  font-size: 11px;
  letter-spacing: 2.2px;
  color: #6c5b52;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 6px 0 0 0;
}

#pankuzu ul {
  margin: auto;
}

#pankuzu ul li {
  float: left;
  margin: 5px 30px 6px 0;
  border-radius: 2px;
  background-color: #669219;
  position: relative;
  vertical-align: middle;
}

#pankuzu ul li a {
  color: #fff;
  padding: 5px 10px;
}

#pankuzu ul li:last-child {
  background-color: #fff;
  padding: 5px 10px;
  margin: 0 0 6px 0;
}

#pankuzu ul li:after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: -15px;
  margin: auto;
  width: 8px;
  height: 8px;
  border-top: 1px solid #669219;
  border-right: 1px solid #669219;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

#pankuzu ul li:last-child::after {
  display: none;
}

#ouboBox {
  position: fixed;
  bottom: min(40px, 2.6vw);
  left: 53px;
  width: 138px;
  /* 177px */
  height: 105px;
  /* 134px */
  transition: all 0.6s ease;
  opacity: 0;
  visibility: hidden;
  z-index: 4;
}
@media screen and (max-width: 1500px) {
  #ouboBox {
    width: 9.2vw;
    /* 11.8vw */
    height: 7vw;
    /* 8.93vw */
    bottom: min(40px, 2.6vw);
    left: 53px;
  }
}
@media screen and (max-width: 768px) {
  #ouboBox {
    width: 20.4vw;
    height: 17.3vw;
    right: auto;
    left: 4.8vw;
    bottom: 4.8vw;
  }
}
#ouboBox.fixed {
  opacity: 1;
  visibility: visible;
}
#ouboBox.bottomEnd {
  bottom: 530px;
}
@media screen and (max-width: 768px) {
  #ouboBox.bottomEnd {
    bottom: 222vw;
  }
}
#ouboBox a {
  width: 100%;
  height: 100%;
  display: block;
}
@media screen and (max-width: 768px) {
  #ouboBox a {
    width: 100%;
    height: 100%;
  }
}
#ouboBox a img {
  height: auto;
  width: 100%;
}

@keyframes burstScale {
  0% {
    opacity: 0;
    transform: scale(0);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes fluffy01 {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}
@keyframes fadefrombelow {
  0% {
    opacity: 0;
    transform: translateY(1rem);
    filter: blur(1.5px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(100px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes zoomIn {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  30% {
    transform: scale(1.1);
  }
  60% {
    transform: scale(0.9);
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}
@keyframes popUp01 {
  0% {
    opacity: 0;
    transform: translateY(17rem);
  }
  70% {
    opacity: 1;
    transform: translateY(-6px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes biyoyonUp {
  0% {
    transform: translateY(3em) scaleY(0.8);
  }
  60% {
    transform: translateY(-0.4em) scaleY(1.05);
  }
  80% {
    transform: translateY(0.2em) scaleY(0.97);
  }
  100% {
    transform: translateY(0) scaleY(1);
  }
}
.mv {
  width: 100%;
  height: 88.69em;
  /* 88.69em */
  background: url("../images/pc/mv_max.jpg") no-repeat top center #f7edbf;
  background-size: 3000px;
  position: relative;
  will-change: transform;
  transform: translateZ(0);
  contain: layout paint;
}
@media screen and (max-width: 1500px) {
  .mv {
    height: 59.126vw;
    background: url("../images/pc/mv_1500.jpg") no-repeat top center #f7edbf;
    background-size: cover;
  }
}
@media screen and (max-width: 768px) {
  .mv {
    height: 183.845333vw;
    background: url("../images/sp/mv_sp.jpg") no-repeat top center #f7edbf;
    background-size: cover;
  }
}
.mv .inner {
  width: 150em;
  height: 100%;
  margin: auto;
  position: relative;
}
.mv .inner h1.mv_title {
  width: 69.1em;
  position: absolute;
  top: 5.58em;
  left: 22.6em;
  animation: fadefrombelow 1s ease 0.5s forwards;
  opacity: 0;
}
@media screen and (max-width: 768px) {
  .mv .inner h1.mv_title {
    width: 66.3804em;
    top: 6.2em;
    left: 4.8em;
  }
}
.mv .inner h1.mv_title img {
  aspect-ratio: 1385 / 540;
}
@media screen and (max-width: 768px) {
  .mv .inner h1.mv_title img {
    aspect-ratio: 1331 / 519;
  }
}
.mv .inner figure.mv_pika {
  width: 49.564em;
  position: absolute;
  top: 18.4em;
  left: 89.2em;
  opacity: 0;
  animation: fadefrombelow 0.9s ease 1.8s both;
  /* zoomIn */
}
@media screen and (max-width: 768px) {
  .mv .inner figure.mv_pika {
    width: 39.1452em;
    top: 32.21em;
    left: 38.89em;
  }
}
.mv .inner figure.mv_pika img {
  aspect-ratio: 998 / 1070;
  animation: fadeInUp 1.1s ease both;
}
@media screen and (max-width: 768px) {
  .mv .inner figure.mv_pika img {
    aspect-ratio: 798 / 857;
  }
}
.mv .inner figure.mv_products {
  width: 62.9em;
  position: absolute;
  top: 35em;
  left: 24.1em;
  animation: fadefrombelow 1s ease 0.5s forwards;
  opacity: 0;
}
@media screen and (max-width: 768px) {
  .mv .inner figure.mv_products {
    width: 69.748em;
    top: 60em;
    left: 3.49em;
  }
}
.mv .inner figure.mv_products img {
  aspect-ratio: 1259 / 822;
}
@media screen and (max-width: 768px) {
  .mv .inner figure.mv_products img {
    aspect-ratio: 1360 / 921;
  }
}
.mv .inner figure.mv_catch {
  width: 30.213em;
  position: absolute;
  top: 35em;
  left: 50.65em;
  opacity: 0;
  animation: fadefrombelow 0.65s ease 1.2s both;
  /* zoomIn */
}
@media screen and (max-width: 768px) {
  .mv .inner figure.mv_catch {
    width: 38.4em;
    top: 33.4em;
    left: 3.29em;
  }
}
.mv .inner figure.mv_catch img {
  animation: fadeInUp 0.85s ease both;
  aspect-ratio: 606 / 265;
}
@media screen and (max-width: 768px) {
  .mv .inner figure.mv_catch img {
    aspect-ratio: 768 / 523;
  }
}

.flowslide::before, .flowslide::after {
  display: none;
}

.flowing {
  width: 100%;
  height: 3.996em;
  position: absolute;
  bottom: 1.5em;
  left: 0;
}
@media screen and (max-width: 1500px) {
  .flowing {
    bottom: 1.5vw;
    height: 5.85em;
  }
}
@media screen and (max-width: 768px) {
  .flowing {
    bottom: 3.2em;
    height: 8.072em;
  }
}
.flowing ul li.slick-slide {
  width: 140.6em !important;
}
@media screen and (max-width: 768px) {
  .flowing ul li.slick-slide {
    width: 65.35em !important;
  }
}
.flowing ul li.slick-slide img {
  aspect-ratio: 2818 / 113;
}
@media screen and (max-width: 768px) {
  .flowing ul li.slick-slide img {
    aspect-ratio: 1341 / 117;
  }
}

section.innerlink {
  width: 100%;
  background: #f7edbf;
  padding-top: 4.5em;
  padding-bottom: 7.5em;
}
@media screen and (max-width: 768px) {
  section.innerlink {
    padding-top: 6.8em;
    padding-bottom: 9.6em;
  }
}
section.innerlink .inner.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
section.innerlink h2 {
  width: 65.34em;
  margin: auto auto 2.25em;
}
@media screen and (max-width: 768px) {
  section.innerlink h2 {
    width: 55.164em;
    margin: auto auto 4.4em;
  }
}
section.innerlink h2 img {
  aspect-ratio: 327 / 76;
}
@media screen and (max-width: 768px) {
  section.innerlink h2 img {
    aspect-ratio: 1104 / 575;
  }
}
section.innerlink figure.five_points {
  width: 33.579em;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.innerlink figure.five_points {
    width: 56.629em;
  }
}
section.innerlink figure.five_points img {
  aspect-ratio: 673 / 142;
}
@media screen and (max-width: 768px) {
  section.innerlink figure.five_points img {
    aspect-ratio: 1134 / 238;
  }
}
section.innerlink figure.bg_star {
  width: 97.582em;
  position: absolute;
  bottom: 2.4em;
  left: 50%;
  transform: translateX(-46.5em);
}
@media screen and (max-width: 768px) {
  section.innerlink figure.bg_star {
    width: 70.48em;
    bottom: -6em;
    left: 0;
    transform: none;
  }
}
section.innerlink figure.bg_star img {
  aspect-ratio: 488 / 25;
}
@media screen and (max-width: 768px) {
  section.innerlink figure.bg_star img {
    aspect-ratio: 70.48 / 4.87;
  }
}
section.innerlink ul.linkBtns {
  width: 108em;
  margin: 1.8em auto auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.9em;
  row-gap: 1.95em;
  position: relative;
  z-index: 2;
}
section.innerlink ul.linkBtns::before, section.innerlink ul.linkBtns::after {
  display: none;
}
@media screen and (max-width: 768px) {
  section.innerlink ul.linkBtns {
    width: 68em;
    justify-content: space-between;
    gap: 0.8em;
    row-gap: 2em;
  }
}
section.innerlink ul.linkBtns li {
  width: 35em;
}
@media screen and (max-width: 768px) {
  section.innerlink ul.linkBtns li {
    width: 33.4em;
    border-radius: 6em;
  }
}
section.innerlink ul.linkBtns li img {
  aspect-ratio: 350 / 84;
}
@media screen and (max-width: 768px) {
  section.innerlink ul.linkBtns li:nth-of-type(1) {
    width: 68em;
  }
}
section.innerlink ul.linkBtns li a {
  display: block;
  border-radius: 4.18889em;
  box-shadow: 0 0.6em 0 #764000;
  transition: all 0.2s ease;
}
@media screen and (max-width: 768px) {
  section.innerlink ul.linkBtns li a {
    border-radius: 6em;
  }
}
section.innerlink ul.linkBtns li a:hover {
  box-shadow: none;
  opacity: 1;
  transform: translateY(0.6em);
}
section.innerlink ul.linkBtns li a img {
  aspect-ratio: 701 / 169;
  object-fit: contain;
}
@media screen and (max-width: 768px) {
  section.innerlink ul.linkBtns li a img {
    aspect-ratio: 680 / 113;
  }
}
@media screen and (max-width: 768px) {
  section.innerlink ul.linkBtns li:nth-of-type(2) a img, section.innerlink ul.linkBtns li:nth-of-type(3) a img, section.innerlink ul.linkBtns li:nth-of-type(4) a img, section.innerlink ul.linkBtns li:nth-of-type(5) a img {
    aspect-ratio: 333 / 120;
  }
}

section.points {
  width: 100%;
  padding-top: 6.9em;
  padding-bottom: 16.6em;
  background: url("../images/pc/bg_points.png") repeat-y bottom center;
  background-size: 3000px;
  background-attachment: fixed;
}
@media screen and (max-width: 768px) {
  section.points {
    background: url("../images/sp/bg_points_sp.png") repeat-y top -4.5em center;
    background-size: 100%;
    padding-top: 8.4em;
    padding-bottom: 18.8em;
  }
}
section.points .flowslide02::before, section.points .flowslide02::after {
  display: none;
}
section.points .flowing02 {
  width: 100%;
  height: 5.558em;
  position: absolute;
  bottom: 1.5em;
  left: 0;
}
@media screen and (max-width: 1500px) {
  section.points .flowing02 {
    bottom: 1.5vw;
    height: 8.211em;
  }
}
@media screen and (max-width: 768px) {
  section.points .flowing02 {
    bottom: 3.5em;
  }
}
section.points .flowing02 ul li.slick-slide {
  width: 147.7em !important;
}
@media screen and (max-width: 768px) {
  section.points .flowing02 ul li.slick-slide {
    width: 72.7486em !important;
  }
}
section.points .inner {
  width: 110em;
  margin: auto;
}
@media screen and (max-width: 768px) {
  section.points .inner {
    width: 68em;
  }
}

.point01 {
  width: 100%;
  border-radius: 4em;
  background: url("../images/pc/bg_point01.png") no-repeat top center #fffae2;
  background-size: 100%;
  padding: 4.8em 10em 6em;
  margin-bottom: 3.8em;
}
@media screen and (max-width: 768px) {
  .point01 {
    border-radius: 6em;
    background: url("../images/sp/bg_point01_sp.png") no-repeat top center #fffae2;
    background-size: 100%;
    padding: 4.6em 0 6.6em;
  }
}
.point01.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
.point01 h3 {
  width: 45.72em;
  margin: auto auto 10em;
}
@media screen and (max-width: 768px) {
  .point01 h3 {
    width: 58.68em;
    margin: auto auto 13.6em;
  }
}
.point01 h3 img {
  aspect-ratio: 457 / 195;
}
.point01 h4 {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 3.2em;
  font-weight: 900;
  color: #764000;
  margin: auto auto 0.6em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .point01 h4 {
    font-size: 4.4em;
    margin: auto auto 0;
  }
}

.card {
  display: flex;
}
@media screen and (max-width: 768px) {
  .card {
    flex-direction: column;
  }
}
.card + .card {
  margin-top: 5.5em;
}
.card p.syutten {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 500;
  line-height: 1.57;
  color: #764000;
  letter-spacing: -0.1em;
  transform: rotate(0.05deg);
}
@media screen and (max-width: 768px) {
  .card p.syutten {
    font-size: 2em;
  }
}
@media screen and (max-width: 768px) {
  .card p.syutten.sp468 {
    width: 23.4em;
    margin: auto;
  }
}
.card p.syutten a {
  text-decoration: underline;
  color: #764000;
}
.card .cardLeft {
  width: 36.6em;
}
@media screen and (max-width: 768px) {
  .card .cardLeft {
    width: 100%;
  }
}
.card .cardRight {
  width: 53.4em;
}
@media screen and (max-width: 768px) {
  .card .cardRight {
    width: 100%;
  }
}
.card .cardRight .txts {
  width: 100%;
  background: #f7edbf;
  border-radius: 2em;
  padding: 3.2em 4.2em;
}
@media screen and (max-width: 768px) {
  .card .cardRight .txts {
    width: 58em;
    border-radius: 4em;
    margin: 2.6em auto auto;
    padding: 3.2em 4.2em 5em;
  }
}
.card .cardRight .txts p.ttl {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.8em;
  font-weight: 700;
  color: #764000;
  margin-bottom: 0.4em;
  transform: rotate(0.05deg);
}
@media screen and (max-width: 768px) {
  .card .cardRight .txts p.ttl {
    font-size: 3.2em;
    text-align: center;
  }
}
.card .cardRight .txts p.lead {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.4em;
  font-weight: 500;
  line-height: 1.57;
  color: #764000;
  margin-bottom: 1.4em;
  transform: rotate(0.05deg);
}
@media screen and (max-width: 768px) {
  .card .cardRight .txts p.lead {
    font-size: 2em;
    line-height: 1.5;
    margin-bottom: 1em;
    letter-spacing: -0.1em;
    text-align: justify;
  }
}

figure.fig_point01_01 {
  width: 31.8em;
  margin: 1.9em 0 0 2.2em;
}
@media screen and (max-width: 768px) {
  figure.fig_point01_01 {
    width: 46.46em;
    margin: auto;
  }
}
figure.fig_point01_01 img {
  aspect-ratio: 318 / 238;
}

figure.fig_point01_02 {
  width: 24.82em;
  margin: 0.4em 0 1em 5.2em;
}
@media screen and (max-width: 768px) {
  figure.fig_point01_02 {
    width: 47em;
    margin: auto auto 2.4em;
  }
}
figure.fig_point01_02 img {
  aspect-ratio: 248 / 279;
}
@media screen and (max-width: 768px) {
  figure.fig_point01_02 img {
    aspect-ratio: 470 / 358.8;
  }
}

h5.h5_point01_01 {
  width: 37.91em;
  margin-bottom: 2.5em;
}
@media screen and (max-width: 768px) {
  h5.h5_point01_01 {
    width: 51.88em;
    margin: 2em auto 2.8em;
  }
}
h5.h5_point01_01 img {
  aspect-ratio: 379 / 44;
}

h5.h5_point01_02 {
  width: 33.42em;
  margin-bottom: 2.5em;
}
@media screen and (max-width: 768px) {
  h5.h5_point01_02 {
    width: 46.8em;
    margin: auto auto 3em;
  }
}
h5.h5_point01_02 img {
  aspect-ratio: 334 / 26;
}

.voices {
  width: 100%;
  margin: 6.2em auto auto;
}
@media screen and (max-width: 768px) {
  .voices {
    margin: 9.8em auto auto;
  }
}
.voices h3.h3_voices {
  width: 24.81em;
  margin: auto auto 3.2em;
}
@media screen and (max-width: 768px) {
  .voices h3.h3_voices {
    width: 32.8em;
    margin: auto auto 4em;
  }
}
.voices h3.h3_voices img {
  aspect-ratio: 248 / 27;
}
.voices p.bottomAttention {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 500;
  color: #764000;
  display: flex;
  justify-content: flex-end;
  margin-top: 1.6em;
}
@media screen and (max-width: 768px) {
  .voices p.bottomAttention {
    font-size: 2em;
    font-weight: 700;
    justify-content: center;
    letter-spacing: -0.01em;
  }
}
.voices ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.6em;
}
@media screen and (max-width: 768px) {
  .voices ul {
    width: 58.6em;
    margin: auto;
    gap: 2.8em;
  }
}
.voices ul::before, .voices ul::after {
  display: none;
}
.voices ul li {
  width: 44em;
}
@media screen and (max-width: 768px) {
  .voices ul li {
    width: 100%;
  }
}
.voices ul li dl {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 2em;
}
.voices ul li dl::before, .voices ul li dl::after {
  display: none;
}
.voices ul li dl.revers {
  flex-direction: row-reverse;
}
.voices ul li dl.revers dd::before {
  content: '';
  width: 1.179em;
  height: 1.5506em;
  background: url("../images/pc/tri_r.png") no-repeat;
  background-size: cover;
  position: absolute;
  top: 50%;
  left: auto;
  right: -1.1em;
  transform: translateY(-50%);
}
.voices ul li dl dt {
  width: 9.5em;
}
@media screen and (max-width: 768px) {
  .voices ul li dl dt {
    width: 15.6em;
  }
}
.voices ul li dl dd {
  width: 32.58em;
  height: 13.1em;
  padding: 2.4em 2.4em;
  border-radius: 1.9em;
  background: #fbd6b4;
  position: relative;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .voices ul li dl dd {
    width: 40.3em;
    height: 21.9em;
    padding: 2.4em 0 2.4em 4.4em;
  }
}
.voices ul li dl dd.last {
  height: 10.36em;
  width: 27em;
}
@media screen and (max-width: 768px) {
  .voices ul li dl dd.last {
    height: 15.14em;
    width: 40.3em;
  }
}
.voices ul li dl dd::before {
  content: '';
  width: 1.179em;
  height: 1.5506em;
  background: url("../images/pc/tri_l.png") no-repeat;
  background-size: cover;
  position: absolute;
  top: 50%;
  left: -1.1em;
  transform: translateY(-50%);
}
.voices ul li dl dd p {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.7em;
  font-weight: 700;
  line-height: 1.7;
  color: #764000;
  transform: rotate(0.05deg);
  letter-spacing: -0.12em;
}
@media screen and (max-width: 768px) {
  .voices ul li dl dd p {
    font-size: 2.6em;
    line-height: 1.46;
  }
}
.voices ul li dl dd p span {
  font-size: 117.7%;
  font-weight: 900;
}
@media screen and (max-width: 768px) {
  .voices ul li dl dd p span {
    font-size: 107.7%;
  }
}

.point02 {
  width: 100%;
  border-radius: 4em;
  background: url("../images/pc/bg_point02.png") no-repeat top center #fffae2;
  background-size: 100%;
  padding: 4.8em 10em 6em;
  margin-bottom: 3.8em;
}
@media screen and (max-width: 768px) {
  .point02 {
    border-radius: 6em;
    background: url("../images/sp/bg_point02_sp.png") no-repeat top center #fffae2;
    background-size: 100%;
    padding: 4.6em 0 6.6em;
  }
}
.point02.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
.point02 h3 {
  width: 43.17em;
  margin: auto auto 9.5em;
}
@media screen and (max-width: 768px) {
  .point02 h3 {
    width: 50.59em;
    margin: auto auto 6em;
  }
}
@media screen and (max-width: 768px) {
  .point02 h3 img {
    aspect-ratio: 253 / 130;
  }
}

.card02 {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .card02 {
    flex-direction: column;
  }
}
.card02 figure {
  width: 52.9em;
  margin-top: 1.5em;
}
@media screen and (max-width: 768px) {
  .card02 figure {
    width: 58em;
    margin: auto auto 5.2em;
    aspect-ratio: 290 / 343;
  }
}
.card02 .txt {
  width: 32.6em;
  background: url("../images/pc/bg_point02_txt.png") no-repeat top 5.9em right;
  background-size: 32.6em;
}
@media screen and (max-width: 768px) {
  .card02 .txt {
    width: 58.5em;
    margin: auto;
    background: url("../images/sp/bg_point02_txt_sp.png") no-repeat top 7em center;
    background-size: 58.5em;
  }
}
.card02 .txt h4.h4_point02 {
  width: 24.81em;
  margin: auto auto 5.2em;
}
@media screen and (max-width: 768px) {
  .card02 .txt h4.h4_point02 {
    width: 32.87em;
    margin: auto;
  }
}
.card02 .txt p.lead {
  width: 10em;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.7em;
  font-weight: 700;
  line-height: 1.7;
  color: #764000;
  transform: rotate(0.05deg);
  letter-spacing: -0.01em;
  margin: 0 0 0 1.5em;
}
@media screen and (max-width: 768px) {
  .card02 .txt p.lead {
    width: 12.4em;
    font-size: 2.6em;
    line-height: 1.46;
    margin: 2.7em 0 0 8.6em;
    letter-spacing: -0.1em;
  }
}
.card02 .txt p.lead span {
  font-size: 111%;
  font-weight: 900;
}
@media screen and (max-width: 768px) {
  .card02 .txt p.lead span {
    font-size: 107.6%;
  }
}
.card02 .txt p.attention {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 500;
  color: #764000;
  transform: rotate(0.05deg);
  letter-spacing: -0.02em;
  margin-top: 2.5em;
}
@media screen and (max-width: 768px) {
  .card02 .txt p.attention {
    font-size: 2em;
    font-weight: 700;
    margin-top: 3.5em;
  }
}

.point03 {
  width: 100%;
  border-radius: 4em;
  background: url("../images/pc/bg_point03.png") no-repeat top center #fffae2;
  background-size: 100%;
  padding: 4.8em 10em 6em;
  margin-bottom: 3.8em;
}
@media screen and (max-width: 768px) {
  .point03 {
    border-radius: 6em;
    background: url("../images/sp/bg_point03_sp.png") no-repeat top center #fffae2;
    background-size: 100%;
    padding: 4.6em 0 4em;
    position: relative;
  }
}
.point03.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
.point03 h3.h3_point03 {
  width: 35em;
  margin: auto auto 10.5em;
}
@media screen and (max-width: 768px) {
  .point03 h3.h3_point03 {
    width: 41.3em;
    margin: auto auto 11.6em;
    aspect-ratio: 827 / 585;
  }
}

.card03 {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .card03 {
    flex-direction: column-reverse;
  }
}
.card03 figure.fig_point03_01 {
  width: 29.725em;
  margin-top: 0.8em;
}
@media screen and (max-width: 768px) {
  .card03 figure.fig_point03_01 {
    width: 29.725em;
    margin: 2rem 0 0 5rem;
  }
}
.card03 figure.fig_point03_01.inView {
  animation: pyokoUp 1s ease forwards;
  animation-delay: 0.1s;
  opacity: 0;
}
.card03 .txt {
  width: 51.78em;
}
@media screen and (max-width: 768px) {
  .card03 .txt {
    width: 59em;
    margin: auto;
  }
}
.card03 .txt h4.h4_point03 {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.4em;
  font-weight: 800;
  color: #764000;
  line-height: 1.4;
  transform: rotate(0.05deg);
  margin-bottom: 0.9em;
  letter-spacing: -0.02em;
}
@media screen and (max-width: 768px) {
  .card03 .txt h4.h4_point03 {
    font-size: 3.4em;
    line-height: 1.4;
    text-align: center;
  }
}
.card03 .txt h4.h4_point03::first-letter {
  margin-left: -0.5em;
}
.card03 .txt h5 {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.6em;
  font-weight: 800;
  color: #764000;
  transform: rotate(0.05deg);
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  .card03 .txt h5 {
    font-size: 2.3em;
  }
}
.card03 .txt p.lead {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 700;
  line-height: 1.67;
  color: #764000;
  transform: rotate(0.05deg);
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  .card03 .txt p.lead {
    font-size: 2em;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 0;
  }
}
.card03 .txt p.syutten {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 500;
  color: #764000;
  transform: rotate(0.05deg);
  letter-spacing: -0.02em;
  margin-bottom: 1.5em;
}
@media screen and (max-width: 768px) {
  .card03 .txt p.syutten {
    font-size: 2em;
    margin-bottom: 1.2em;
  }
}
.card03 .txt p.syutten a {
  color: #764000;
  text-decoration: underline;
}
.card03 .txt p.attention {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 500;
  color: #764000;
  line-height: 1.5;
  transform: rotate(0.05deg);
  letter-spacing: -0.02em;
}
@media screen and (max-width: 768px) {
  .card03 .txt p.attention {
    font-size: 2em;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: -0.1em;
  }
}

.point03.inView figure.fig_point03_01 {
  animation: pyokoUp 1s cubic-bezier(0.25, 1.3, 0.35, 1) forwards;
  animation-delay: 1s;
  opacity: 0;
}

/*
@keyframes pyokoUp {
  0% {
    transform: translateY(100%);
	  opacity: 0;
  }
  70% {
    transform: translateY(-30%);
	  opacity: 1;
  }
  100% {
    transform: translateY(0);
	  opacity: 1;
  }
}
*/
/*
@keyframes pyokoUp {
  0% {
    transform: translate3d(0, 100%, 0);
    opacity: 0;
  }
  30% {
    transform: translate3d(0, -40%, 0);
    opacity: 1;
  }
  45% {
    transform: translate3d(0, 0, 0);
  }
  65% {
    transform: translate3d(0, -15%, 0);
  }
  80% {
    transform: translate3d(0, 0, 0);
  }
  90% {
    transform: translate3d(0, -5%, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
*/
@keyframes pyokoUp {
  0% {
    transform: translate3d(0, 100%, 0) scale(0.96);
    opacity: 0;
  }
  /* ふわっと上昇 */
  45% {
    transform: translate3d(0, -35%, 0) scale(1.02);
    opacity: 1;
  }
  /* 1回目の着地（少し潰れる） */
  55% {
    transform: translate3d(0, 0, 0) scale(0.98);
  }
  /* 2回目：余韻のバウンド */
  72% {
    transform: translate3d(0, -12%, 0) scale(1.01);
  }
  /* 安定 */
  85% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  /* 最後の小さな弾み */
  93% {
    transform: translate3d(0, -3%, 0) scale(1.005);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 1;
  }
}
@keyframes pyokoUp02 {
  0% {
    transform: translateY(100%);
    opacity: 0;
  }
  70% {
    transform: translateY(-30%);
    opacity: 1;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
/*
@keyframes pikaUp {
  0% {
    transform: translate3d(-50%, 100%, 0) scale(0.5);
    opacity: 0;
  }
  40% {
    transform: translate3d(5%, -40%, 0) scale(1.1);
    opacity: 1;
  }
  55% {
    transform: translate3d(0, 0, 0) scale(1.0);
  }
  75% {
    transform: translate3d(0, -15%, 0) scale(1.0);
  }
  85% {
    transform: translate3d(0, 0, 0) scale(1.0);
  }
  93% {
    transform: translate3d(0, -4%, 0) scale(1.0);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1.0);
    opacity: 1;
  }
}
*/
@keyframes pikaUp {
  0% {
    transform: translate3d(-30%, 80%, 0) scale(0.45);
    opacity: 0;
  }
  /* ふわっと飛び出す */
  45% {
    transform: translate3d(8%, -25%, 0) scale(1.08);
    opacity: 1;
  }
  /* 1回目の着地（少し潰れる） */
  55% {
    transform: translate3d(0, 0, 0) scale(0.98);
  }
  /* 反発 */
  70% {
    transform: translate3d(0, -12%, 0) scale(1.02);
  }
  /* 2回目の着地 */
  82% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  /* 最後の小さな弾み */
  92% {
    transform: translate3d(0, -3%, 0) scale(1.01);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 1;
  }
}
.point04 {
  width: 100%;
  border-radius: 4em;
  background: url("../images/pc/bg_point04.png") no-repeat top center #fffae2;
  background-size: 100%;
  padding: 4.8em 10em 6em;
  margin-bottom: 3.8em;
}
@media screen and (max-width: 768px) {
  .point04 {
    border-radius: 6em;
    background: url("../images/sp/bg_point04_sp.png") no-repeat top center #fffae2;
    background-size: 100%;
    padding: 4.6em 0 5.4em;
    position: relative;
  }
}
.point04.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
.point04 h3.h3_point04 {
  width: 56.38em;
  margin: auto auto 9.3em;
}
@media screen and (max-width: 768px) {
  .point04 h3.h3_point04 {
    width: 41.3em;
  }
}
@media screen and (max-width: 768px) {
  .point04 h3.h3_point04 img {
    aspect-ratio: 827 / 564;
  }
}

.card04 {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .card04 {
    flex-direction: column-reverse;
  }
}
.card04 figure {
  width: 37.89em;
  margin-top: 0.8em;
}
@media screen and (max-width: 768px) {
  .card04 figure {
    width: 52em;
    margin: auto;
  }
}
.card04 .txt {
  width: 50.3em;
  padding-top: 8.5em;
}
@media screen and (max-width: 768px) {
  .card04 .txt {
    padding-top: 1em;
    width: 100%;
  }
}
.card04 .txt h4.h4_point04 {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.4em;
  font-weight: 800;
  color: #764000;
  transform: rotate(0.05deg);
  margin-bottom: 0.3em;
  letter-spacing: -0.02em;
}
@media screen and (max-width: 768px) {
  .card04 .txt h4.h4_point04 {
    font-size: 3.4em;
    line-height: 1.4;
    text-align: center;
  }
}
.card04 .txt p.attention {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 500;
  color: #764000;
  line-height: 1.5;
  transform: rotate(0.05deg);
  letter-spacing: -0.02em;
}
@media screen and (max-width: 768px) {
  .card04 .txt p.attention {
    font-size: 2em;
    text-align: center;
    margin-bottom: 1.5em;
  }
}

.point05 {
  width: 100%;
  border-radius: 4em;
  background: url("../images/pc/bg_point05.png") no-repeat top center #fffae2;
  background-size: 100%;
  padding: 4.8em 10em 8.4em;
  position: relative;
  margin-bottom: -1px;
  /*
  &::after {
  	content:'';
  	width:100%;
  	height:40.4em;
  	background:url("../images/pc/bg_point05_bottom.png") no-repeat bottom center;
  	background-size:100%;
  	position:absolute;
  	bottom:0;
  	left:0;
  	
  	@media screen and (max-width: 768px) {
  		height:50.04em;
  		background:url("../images/sp/bg_point05_bottom_sp.png") no-repeat bottom center;
  		background-size:100%;
  	}
  }
  */
}
@media screen and (max-width: 768px) {
  .point05 {
    border-radius: 6em;
    background: url("../images/sp/bg_point05_sp.png") no-repeat top center #fffae2;
    background-size: 100%;
    padding: 4.6em 0 10em;
    position: relative;
  }
}
.point05::after {
  content: '';
  width: 100%;
  height: 40.4em;
  background: url("../images/pc/bg_point05_bottom.png") no-repeat bottom center;
  background-size: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 768px) {
  .point05::after {
    height: 50.04em;
    background: url("../images/sp/bg_point05_bottom_sp.png") no-repeat bottom center;
    background-size: 100%;
  }
}
.point05.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
.point05 h3.h3_point05 {
  width: 43.17em;
  margin: auto auto 7em;
}
@media screen and (max-width: 768px) {
  .point05 h3.h3_point05 {
    width: 49.5em;
    margin: auto auto 8.8em;
  }
}
@media screen and (max-width: 768px) {
  .point05 h3.h3_point05 img {
    aspect-ratio: 990 / 521;
  }
}
.point05 figure.full4 {
  width: 20.18em;
  margin: auto auto 1em;
  transform: translateX(-1.5em);
}
@media screen and (max-width: 768px) {
  .point05 figure.full4 {
    width: 27.2115em;
    transform: none;
    margin-left: 18em;
  }
}
.point05 figure.fig_point05_01 {
  width: 65.48em;
  margin: auto auto 2em;
}
@media screen and (max-width: 768px) {
  .point05 figure.fig_point05_01 {
    width: 61.7em;
    margin: auto auto 2em;
  }
}
.point05 figure.fig_point05_02 {
  width: 41.6931em;
  margin: auto auto 3em 21em;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .point05 figure.fig_point05_02 {
    width: 50em;
    margin: auto auto 4.5em 6.5em;
  }
}
.point05 figure.fig_point05_02.inView {
  animation: pikaUp 0.9s ease forwards;
  animation-delay: 0.1s;
}
.point05 p.btn_pika {
  width: 32.48em;
  height: 5.488em;
  border-radius: 2.744em;
  box-shadow: 0 0.6em 0 #764000;
  margin: auto;
  position: relative;
  z-index: 2;
  cursor: pointer;
  transition: all 0.2s ease;
}
@media screen and (max-width: 768px) {
  .point05 p.btn_pika {
    width: 58em;
    height: 9.8em;
    border-radius: 5em;
    box-shadow: 0 1em 0 #764000;
  }
}
.point05 p.btn_pika.inView {
  animation: pyokoUp02 0.9s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  animation-delay: 0.3s;
}
.point05 p.btn_pika:hover {
  box-shadow: none;
  opacity: 1;
  transform: translateY(0.6em);
}

.point05plus {
  width: 100%;
  border-radius: 0 0 4em 4em;
  background: #fffae2;
  position: relative;
  padding-bottom: 8.4em;
}
@media screen and (max-width: 768px) {
  .point05plus {
    padding-bottom: 9.7em;
    border-radius: 0 0 6em 6em;
  }
}
.point05plus::after {
  content: '';
  width: 100%;
  height: 40.4em;
  background: url("../images/pc/bg_point05_bottom.png") no-repeat bottom center;
  background-size: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 768px) {
  .point05plus::after {
    height: 50.04em;
    background: url("../images/sp/bg_point05_bottom_sp.png") no-repeat bottom center;
    background-size: 100%;
  }
}
.point05plus figure.fig_point05_02 {
  width: 41.5894em;
  margin: auto auto 3em;
  transform: translateX(-3.2em);
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .point05plus figure.fig_point05_02 {
    width: 49.3707em;
    transform: translateX(-2.8em);
  }
}
.point05plus p.btn_pika {
  width: 32.48em;
  height: 5.488em;
  border-radius: 2.744em;
  margin: auto;
  position: relative;
  z-index: 2;
  cursor: pointer;
  transition: all 0.2s ease;
  box-shadow: 0 0.6em 0 #764000;
  border-radius: 2.744em;
}
@media screen and (max-width: 768px) {
  .point05plus p.btn_pika {
    width: 58em;
    height: 9.8em;
  }
}
.point05plus p.btn_pika:hover {
  box-shadow: none;
  opacity: 1;
}

.btn_pika .btnAnim {
  display: inline-block;
  /* ← 必須 */
  box-shadow: 0 0.6em 0 #764000;
  border-radius: 2.744em;
}
@media screen and (max-width: 768px) {
  .btn_pika .btnAnim {
    box-shadow: 0 1em 0 #764000;
    border-radius: 5em;
  }
}
.btn_pika .btnAnim img {
  transition: all 0.2s ease;
}
.btn_pika .btnAnim:hover {
  box-shadow: none;
}
.btn_pika .btnAnim:hover img {
  transform: translateY(0.6em);
}

section.product_info {
  width: 100%;
  position: relative;
  background: #fffae2;
  padding-bottom: 6.5em;
}
@media screen and (max-width: 768px) {
  section.product_info {
    padding-bottom: 12.4em;
  }
}
section.product_info::after {
  content: '';
  width: 3000px;
  height: 214.5px;
  background: url("../images/pc/bg_product_info_max.png") no-repeat bottom center;
  background-size: 3000px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 1500px) {
  section.product_info::after {
    width: 100%;
    height: 21.4em;
    background: url("../images/pc/bg_product_info.png") no-repeat top center;
    background-size: 100%;
  }
}
@media screen and (max-width: 768px) {
  section.product_info::after {
    width: 100%;
    height: 108.05em;
    background: url("../images/sp/bg_product_info_sp.png") no-repeat top center;
    background-size: 100%;
    bottom: 0;
    left: 0;
    transform: none;
  }
}
section.product_info .inner {
  width: 150em;
  margin: auto;
  background: url("../images/pc/ball.png") no-repeat top 3.6em center;
  background-size: 139.7em;
  padding-top: 8.7em;
}
@media screen and (max-width: 1500px) {
  section.product_info .inner {
    background: url("../images/pc/ball.png") no-repeat top 3.6em center;
    background-size: 93.1vw;
  }
}
@media screen and (max-width: 768px) {
  section.product_info .inner {
    width: 100%;
    background: url("../images/sp/ball_sp.png") no-repeat top 2.6em center;
    background-size: 70.6596em;
  }
}
section.product_info .inner h2.h2_product_info {
  width: 42.42em;
  margin: auto auto 2.2em;
}
@media screen and (max-width: 768px) {
  section.product_info .inner h2.h2_product_info {
    width: 49.8149em;
    margin: auto auto 2.2em;
    transform: translateX(-1em);
  }
}
section.product_info .inner h2.h2_product_info.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
@media screen and (max-width: 768px) {
  section.product_info .inner h2.h2_product_info img {
    aspect-ratio: 1001 / 239;
  }
}
section.product_info .inner .productBox {
  width: 94em;
  margin: auto;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox {
    flex-direction: column;
    width: 100%;
  }
}
section.product_info .inner .productBox figure {
  width: 50%;
  padding-left: 6.75em;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox figure {
    width: 100%;
    padding-left: 0;
  }
}
section.product_info .inner .productBox figure.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
section.product_info .inner .productBox figure img {
  width: 36.149em;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox figure img {
    width: 50.9652em;
    margin: auto;
  }
}
section.product_info .inner .productBox .txts {
  width: 50%;
  padding: 9em 0 0 1em;
  animation-delay: 1.5s;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts {
    width: 100%;
    padding: 0;
    margin-top: 3.8em;
  }
}
section.product_info .inner .productBox .txts.inView {
  animation: fadeInUp 0.6s ease 0.5s forwards;
}
section.product_info .inner .productBox .txts h3 {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 4.3em;
  font-weight: 800;
  color: #764000;
  transform: rotate(0.05deg);
  margin-bottom: 0.4em;
  line-height: 1;
  letter-spacing: -0.05em;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts h3 {
    font-size: 5.4em;
    text-align: center;
  }
}
section.product_info .inner .productBox .txts p.add {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.4em;
  font-weight: 800;
  color: #764000;
  transform: rotate(0.05deg);
  letter-spacing: -0.05em;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts p.add {
    font-size: 3em;
    justify-content: center;
  }
}
section.product_info .inner .productBox .txts p.add span {
  font-size: 70%;
  display: inline-block;
  width: 5.1em;
  height: 2em;
  text-align: center;
  line-height: 1.8em;
  border-radius: 1em;
  border: 0.15em solid #764000;
  margin-left: 1em;
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts p.add span {
    font-size: 80%;
    width: 4.5em;
    height: 1.8em;
    line-height: 1.8em;
    border-radius: 0.9em;
  }
}
section.product_info .inner .productBox .txts .details {
  margin-top: 3em;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts .details {
    width: 68em;
    margin: 4em auto auto;
    border-radius: 6em;
    background: #fffae2;
    background-size: 44em;
    padding-top: 5.4em;
    padding-bottom: 7em;
  }
}
section.product_info .inner .productBox .txts .details p.lead {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.2em;
  font-weight: 700;
  color: #764000;
  line-height: 1.6;
  transform: rotate(0.05deg);
  margin-bottom: 0.7em;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts .details p.lead {
    font-size: 3.4em;
    line-height: 1.58;
    text-align: center;
    letter-spacing: -0.1em;
  }
}
section.product_info .inner .productBox .txts .details p.lead span.nuki {
  color: #764000;
  border-radius: 0.2em;
  display: inline-block;
  letter-spacing: 0;
  width: 5.4em;
  height: 1.5em;
  text-align: center;
  line-height: 1.5em;
  text-decoration: underline;
  font-weight: 900;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts .details p.lead span.nuki {
    letter-spacing: -0.1em;
    width: 5.2em;
  }
}
section.product_info .inner .productBox .txts .details p.lead span.underline {
  text-decoration: underline;
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts .details p.lead span.underline {
    letter-spacing: -0.1em;
  }
}
section.product_info .inner .productBox .txts .details p.lead span.ls_1 {
  letter-spacing: -0.1em;
}
section.product_info .inner .productBox .txts .details p.attention {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.2em;
  font-weight: 500;
  color: #764000;
  transform: rotate(0.05deg);
  margin-bottom: 1em;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts .details p.attention {
    font-size: 2em;
    text-align: center;
  }
}
section.product_info .inner .productBox .txts .details p.btn_to_detail {
  width: 32.48em;
  height: 5.488em;
  border-radius: 2.744em;
  box-shadow: 0 0.6em 0 #764000;
  transition: all 0.2s ease;
}
@media screen and (max-width: 768px) {
  section.product_info .inner .productBox .txts .details p.btn_to_detail {
    width: 58em;
    height: 9.8em;
    margin: auto;
    border-radius: 5em;
    font-size: 1em;
    box-shadow: 0 1em 0 #764000;
  }
}
section.product_info .inner .productBox .txts .details p.btn_to_detail:hover {
  box-shadow: none;
  opacity: 1;
  transform: translateY(0.6em);
}
section.product_info .inner .productBox .txts .details p.btn_to_detail a:hover {
  opacity: 1;
}

section.quiz {
  width: 100%;
  padding-top: 9.4em;
  padding-bottom: 0;
  background: url("../images/pc/bg_quiz.jpg") repeat-y top center;
  background-size: 3000px;
}
@media screen and (max-width: 768px) {
  section.quiz {
    background: url("../images/sp/bg_quiz_sp.jpg") repeat-y top center;
    background-size: 100%;
    padding-top: 8em;
  }
}
section.quiz h2 {
  width: 68.16em;
  margin: auto auto 4.2em;
}
@media screen and (max-width: 768px) {
  section.quiz h2 {
    width: 65.7em;
  }
}
@media screen and (max-width: 768px) {
  section.quiz h2 img {
    aspect-ratio: 1315 / 367;
  }
}
section.quiz .inner {
  width: 110em;
  margin: auto;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  section.quiz .inner {
    width: 100%;
  }
}

.quizPanelOuter {
  height: 62em;
  padding-top: 6.5em;
}
@media screen and (max-width: 768px) {
  .quizPanelOuter {
    height: auto;
    padding-top: 9.65em;
  }
}
@media screen and (max-width: 768px) {
  .quizPanelOuter + .quizPanelOuter {
    padding-top: 0;
  }
}

.quizPanel {
  width: 53em;
  background: #009944;
  border-radius: 8em;
  position: relative;
  padding: 3.6em 3em 4.2em;
  float: left;
}
@media screen and (max-width: 768px) {
  .quizPanel {
    width: 68em;
    margin: auto;
    float: none;
    margin-bottom: 13.4em;
    border-radius: 6em;
  }
}
.quizPanel.inView {
  animation: fadeInUp 0.6s ease 0.5s forwards;
}
.quizPanel:nth-of-type(2) {
  animation-delay: 0.9s !important;
}
.quizPanel:nth-of-type(3) {
  animation-delay: 0.5s !important;
}
.quizPanel:nth-of-type(4) {
  animation-delay: 0.9s !important;
}
.quizPanel:nth-of-type(2), .quizPanel:nth-of-type(4) {
  float: right;
}
@media screen and (max-width: 768px) {
  .quizPanel:nth-of-type(2), .quizPanel:nth-of-type(4) {
    float: none;
  }
}
.quizPanel h3 {
  width: 18.089em;
  height: 18.089em;
  position: absolute;
  top: -6.4em;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .quizPanel h3 {
    width: 25.8em;
    height: 25.8em;
    top: -9.6em;
  }
}
@media screen and (max-width: 768px) {
  .quizPanel h3 img {
    aspect-ratio: 129 / 129;
  }
}
.quizPanel p {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.2em;
  font-weight: 800;
  line-height: 1.54;
  transform: rotate(0.05deg);
  color: #fff;
  text-align: center;
  position: relative;
  z-index: 2;
  letter-spacing: -0.01em;
}
@media screen and (max-width: 768px) {
  .quizPanel p {
    font-size: 3.6em;
  }
}
.quizPanel p span {
  font-size: 127%;
  font-weight: 900;
  color: #f6ea00;
}
@media screen and (max-width: 768px) {
  .quizPanel p span {
    font-size: 116%;
  }
}
.quizPanel figure {
  width: 100%;
  margin: 1.8em auto 1.4em;
}
@media screen and (max-width: 768px) {
  .quizPanel figure img {
    aspect-ratio: 1261 / 591;
  }
}
.quizPanel dl {
  width: 100%;
  overflow: hidden;
  border-radius: 3em;
  background: #f6ea00;
  padding: 2.3em 2.3em 0;
  letter-spacing: -0.01em;
}
@media screen and (max-width: 768px) {
  .quizPanel dl {
    border-radius: 4em;
  }
}
.quizPanel dl dt {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.96em;
  font-weight: 800;
  transform: rotate(0.05deg);
  color: #764000;
  text-align: center;
  background: url("../images/pc/bg_quiz_dt.png") no-repeat center top;
  background-size: 19.6em;
  margin-bottom: 0.7em;
  display: flex;
  justify-content: center;
  align-items: baseline;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .quizPanel dl dt {
    font-size: 2.8em;
    background: url("../images/sp/bg_quiz_dt_sp.png") no-repeat center top;
    background-size: 19.5em;
  }
}
.quizPanel dl dt.open {
  background: url("../images/pc/bg_quiz_dt_open.png") no-repeat center top;
  background-size: 19.6em;
}
@media screen and (max-width: 768px) {
  .quizPanel dl dt.open {
    background: url("../images/sp/bg_quiz_dt_open_sp.png") no-repeat center top;
    background-size: 19.5em;
  }
}
.quizPanel dl dd {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.4em;
  font-weight: 800;
  transform: rotate(0.05deg);
  color: #764000;
  text-align: center;
  background: url("../images/pc/bg_answer.png") no-repeat top center;
  background-size: contain;
  height: 3.1em;
  display: flex;
  justify-content: center;
  align-items: center;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-4px);
  transition: max-height 0.6s ease, opacity 0.7s ease, transform 0.7s ease;
  will-change: max-height, opacity, transform;
}
@media screen and (max-width: 768px) {
  .quizPanel dl dd {
    font-size: 3.6em;
  }
}
.quizPanel dl dd.open {
  max-height: 500px;
  /* 中身より十分大きければOK */
  opacity: 1;
  transform: translateY(0);
}
.quizPanel dl dd img {
  display: inline-block;
}
.quizPanel dl dd img.fig_a01 {
  width: 1.2em;
  margin-left: 0.5em;
}
@media screen and (max-width: 768px) {
  .quizPanel dl dd img.fig_a01 {
    width: 1.37em;
  }
}
.quizPanel dl dd img.fig_a02 {
  width: 4.58em;
  margin-left: 0.5em;
}
@media screen and (max-width: 768px) {
  .quizPanel dl dd img.fig_a02 {
    width: 4.07em;
  }
}
.quizPanel dl dd img.fig_a03 {
  width: 2.4em;
  margin-left: 0.5em;
}
@media screen and (max-width: 768px) {
  .quizPanel dl dd img.fig_a03 {
    width: 2.55em;
  }
}

section.recomend {
  width: 100%;
  padding-top: 9.5em;
  padding-bottom: 14.8em;
  border-top: 0.6em solid #764000;
  background: url("../images/pc/bg_recomend.jpg") no-repeat top center;
  background-size: 3000px;
}
@media screen and (max-width: 768px) {
  section.recomend {
    border-top: 1em solid #764000;
    background: url("../images/sp/bg_recomend_sp.jpg") no-repeat top center;
    background-size: 100%;
    padding-top: 9.8em;
    padding-bottom: 31em;
  }
}
section.recomend .inner.inView {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}
section.recomend h2 {
  width: 44.19em;
  margin: auto auto 5.5em;
}
@media screen and (max-width: 768px) {
  section.recomend h2 {
    width: 63.13em;
  }
}
section.recomend ul.links {
  width: 100em;
  margin: auto;
  display: flex;
  justify-content: center;
  gap: 4em;
}
@media screen and (max-width: 768px) {
  section.recomend ul.links {
    width: 67em;
    flex-direction: column;
    gap: 6.8em;
  }
}
section.recomend ul.links::before, section.recomend ul.links::after {
  display: none;
}
section.recomend ul.links li {
  width: 48%;
}
@media screen and (max-width: 768px) {
  section.recomend ul.links li {
    width: 100%;
  }
}
section.recomend ul.links li a {
  display: block;
}
section.recomend ul.links li a span {
  font-size: 2.7em;
  font-weight: 700;
  color: #764000;
  text-align: center;
  margin-bottom: 0.8em;
  letter-spacing: -0.1em;
  display: block;
  transform: rotate(0.05deg);
}
@media screen and (max-width: 768px) {
  section.recomend ul.links li a span {
    font-size: 3.8em;
    line-height: 1.39;
    margin-bottom: 0.4em;
  }
}

.modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
}
@media (prefers-reduced-motion: reduce) {
  .modal .pikaAnim,
  .modal .btnAnim {
    animation: none;
  }
}

.modal.active {
  display: block;
}

.modal__bg {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
}

.modal_outer {
  position: absolute;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.modal__content {
  position: relative;
  width: 110em;
  height: 63.2em;
  margin: auto;
  border-radius: 8em;
  padding: 7.9em 5.6em 7.8em 13.2em;
}
@media screen and (max-width: 768px) {
  .modal__content {
    width: 67em;
    height: 90.9em;
    padding: 11.4em 0 0;
    border-radius: 4em;
  }
}
.modal__content::before {
  position: absolute;
  inset: 0;
  background: url("../images/pc/bg_modal.png") no-repeat;
  background-size: 100%;
  opacity: 1;
  /* ← 最初から表示 */
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .modal__content::before {
    background: url("../images/sp/bg_modal_sp.png") no-repeat;
    background-size: 100%;
  }
}
.modal__content figure.bg_modal {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.modal__content dl.intro {
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 5s ease, transform 5s ease;
}

.modal.active .modal__content dl.intro {
  opacity: 1;
  transform: translateY(0);
}

/* 閉じるボタン */
.modal__close {
  font-size: 1em;
  position: absolute;
  width: 2.125em;
  height: 2.125em;
  top: 4.8em;
  right: 5.4em;
  background: url("../images/pc/ico_close.png") no-repeat;
  background-size: 2.125em;
  border: none;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .modal__close {
    width: 4em;
    height: 4em;
    background: url("../images/pc/ico_close.png") no-repeat;
    background-size: 4em;
    top: 5.8em;
    right: 6em;
  }
}

dl.intro {
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 26em;
}
@media screen and (max-width: 768px) {
  dl.intro {
    flex-direction: column;
    gap: 12.8em;
  }
}
dl.intro::before, dl.intro::after {
  display: none;
}
dl.intro > dt {
  width: 33.3169em;
}
@media screen and (max-width: 768px) {
  dl.intro > dt {
    width: 53.484em;
    margin: auto;
  }
}
dl.intro > dd {
  width: 31.8em;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  dl.intro > dd {
    width: 100%;
    padding: 0 4em;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
dl.intro > dd p.detail {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.5em;
  font-weight: 700;
  line-height: 1.67;
  color: #764000;
  transform: rotate(0.05deg);
  letter-spacing: -0.02em;
  margin-top: -0.5em;
}
@media screen and (max-width: 768px) {
  dl.intro > dd p.detail {
    width: 45.37em;
    margin: auto 0 auto 2.8em;
    font-size: 2.2em;
    line-height: 1.45;
  }
}
dl.intro > dd dl.spec {
  width: 24.6em;
  height: 3.7em;
  border-radius: 1.85em;
  overflow: hidden;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  margin-bottom: 2.4em;
}
@media screen and (max-width: 768px) {
  dl.intro > dd dl.spec {
    width: 31.3em;
    height: 4.5em;
    border-radius: 2.25em;
    margin-bottom: 1.8em;
  }
}
@media screen and (max-width: 768px) {
  dl.intro > dd dl.spec:nth-of-type(2), dl.intro > dd dl.spec:nth-of-type(4) {
    width: 25.6em;
  }
}
@media screen and (max-width: 768px) {
  dl.intro > dd dl.spec:nth-of-type(2) dt, dl.intro > dd dl.spec:nth-of-type(4) dt {
    width: 41%;
  }
}
dl.intro > dd dl.spec::before, dl.intro > dd dl.spec::after {
  display: none;
}
dl.intro > dd dl.spec dt {
  width: 33%;
  height: 100%;
  background: #764000;
  border-radius: 1.85em;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 1.8em;
  font-weight: 800;
  color: #fff;
  transform: rotate(0.05deg);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 768px) {
  dl.intro > dd dl.spec dt {
    width: 34.1%;
    font-size: 2.4em;
  }
}
dl.intro > dd dl.spec dd {
  width: 67%;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2em;
  font-weight: 800;
  color: #764000;
  transform: rotate(0.05deg);
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-left: 0.6em;
  letter-spacing: -0.05em;
}
@media screen and (max-width: 768px) {
  dl.intro > dd dl.spec dd {
    font-size: 2.6em;
    padding-left: 0.3em;
  }
}
dl.intro > dd dl.spec dd.denki {
  background: url("../images/pc/ico_elec.png") no-repeat center right 3.15em;
  background-size: 1.15em;
}
@media screen and (max-width: 768px) {
  dl.intro > dd dl.spec dd.denki {
    background: url("../images/pc/ico_elec.png") no-repeat center right 1.4em;
    background-size: 1.14em;
  }
}

.slick-slider {
  height: 100%;
}

.marquee {
  overflow: hidden;
  contain: layout paint;
  will-change: transform;
  transform: translateZ(0);
  width: 100%;
  height: 3.996em;
  position: absolute;
  bottom: 1.5em;
  left: 0;
}
@media screen and (max-width: 768px) {
  .marquee {
    height: 5.85em;
    bottom: 2.8em;
  }
}

.marquee__inner {
  display: flex;
  width: max-content;
  will-change: transform;
  transform: translateZ(0);
}
.marquee__inner li {
  width: 140.9em;
}
@media screen and (max-width: 768px) {
  .marquee__inner li {
    width: 67.05em;
  }
}
@media screen and (max-width: 768px) {
  .marquee__inner li:nth-of-type(1) {
    margin-left: 1.2em;
  }
}

@keyframes marquee {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-50vw, 0, 0);
  }
}
/* 全体のスクロールを滑らかにする */
html {
  scroll-behavior: smooth;
}

/* アニメーションや大きな画像がある要素にGPUハックを適用 */
.mv, .marquee, .points, .pikaAnim {
  will-change: transform;
  transform: translateZ(0);
  /* ハードウェアアクセラレーションを有効化 */
}

/* スクロール中のカクつき（Jank）を抑える */
img {
  content-visibility: auto;
  /* 画面外のレンダリングをスキップ */
}

[id^="point"] {
  contain: layout paint;
  transition-delay: 0s;
}

[id^="point"].is-show .fadeIn:nth-child(1) {
  transition-delay: 0s;
}

[id^="point"].is-show .fadeIn:nth-child(2) {
  transition-delay: .1s;
}

[id^="point"].is-show .fadeIn:nth-child(3) {
  transition-delay: .2s;
}

.fadeIn {
  opacity: 0;
  transform: translateY(40px);
  transition: transform 0.8s ease, opacity 0.8s ease;
}

.fadeIn.is-show {
  opacity: 1;
  transform: translateY(0);
}

html {
  -webkit-overflow-scrolling: touch;
}

@supports (-webkit-touch-callout: none) {
  img[loading="lazy"] {
    loading: eager;
  }
}
