@charset "UTF-8";

:root {
  --kp-dot-in: 0.15s;
  --kp-ring: 0.55s;
  --kp-line: 0.35s;
  --kp-text: 0.45s;

  --kp-delay-dot: 0s;
  --kp-delay-ring: calc(var(--kp-delay-dot) + var(--kp-dot-in) + var(--kp-blink));
  --kp-delay-line: calc(var(--kp-delay-ring) + var(--kp-ring));
  --kp-delay-text: calc(var(--kp-delay-line) + var(--kp-line));
  --kp-block: calc(var(--kp-dot-in) + var(--kp-ring) + var(--kp-line) + var(--kp-text) + 0.30s);

  --animals-start: calc(var(--kp-block));
  --animals-step: 0.18s;
  --animals-pop: 0.40s;
  --line-start: calc(var(--animals-start) + (var(--animals-step) * 3) + 0.35s);
  --line-step: 0.06s;


  --secret-dot-in: 0.15s;
  --secret-ring: 0.55s;
  --secret-line: 0.35s;
  --secret-text: 0.45s;

  --secret-delay-dot: 0s;
  --secret-delay-ring: calc(var(--secret-delay-dot) + var(--secret-dot-in) + var(--secret-blink));
  --secret-delay-line: calc(var(--secret-delay-ring) + var(--secret-ring));
  --secret-delay-text: calc(var(--secret-delay-line) + var(--secret-line));
  --secret-block: calc(var(--secret-dot-in) + var(--secret-ring) + var(--secret-line) + var(--secret-text) + 0.30s);
  
}

picture {
  display: block;
}
.l-main {
  background: #fdd135;
  font-family: zen-maru-gothic, sans-serif;
  font-feature-settings: "palt" 1;
  font-kerning: normal;
  color: #ff6800;
  margin-top: -110px;
  font-size: calc(16vw /14);
}
.u-font_heisei {
  font-family: heisei-kaku-gothic-std, sans-serif;
}
.u-font_nas {
  font-family: new-astro-soft, sans-serif;
}
.u-font_mmb {
  font-family: ads-mambo, sans-serif;
}
.p-recommended,
.l-footer {
  background: #fdd135;
  position: relative;
}
.p-share {
  background-color: #0d6fb8
}
@media (min-width: 768px) {
  .p-recommended {
      padding-top: 170px;
  }
}
@media (max-width: 767px) {
  .p-share__list img {
      width: auto;
  }
  .l-gnav img {
    width: auto;
  }
  .l-main {
    margin-top: 0;
    font-size: calc(20vw /7.5);
  }
}

/* kv */
.kv {
  background: #fac300;
  display: flex;
  padding-bottom: calc(75vw / 14);
  position: relative;
}
.kv-ttlBlock {
  width: 46%;
  margin-right: 20px;
  background: #fdfbf3;
  box-shadow: 9px 9px 19px -7px rgba(202,141,41,0.3);
  border-radius: 0 0 71px 0;
  padding: calc(145vw /14) 0 calc(75vw /14);
  position: relative;
  z-index: 1;
}
.kv-ttlBlock__inner {
  width: calc(470vw /14);
  height: calc(718vw /14);
  margin: 0 calc(70vw /14) 0 auto;
  text-align: center;
  position: relative;
  border: 1px solid #ff9a00;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #fedfb0 calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #fedfb0 calc(100% - 1px));
  background-size: 30px 30px;
  background-repeat: repeat;
  background-position: center center;
}
.kv-ttlBlock__inner::before {
  display: block;
  position: absolute;
  content: '';
  top: 0;
  right: 0;
  width: calc(100% - 2px);
  height: calc(374vw /14);
  background: #fdfbf3;
}
.kv-ttlBlock__inner::after {
  display: block;
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: calc(32vw /14);
  height: calc(374vw /14);
  background: #ff9a00;
}
.kv-ttlBlock__border {
  display: block;
  position: absolute;
  content: '';
  top: calc(374vw /14);
  left: 0;
  width: 100%;
  height: 1px;
  background: #ff9a00;
}
.kv h1 {
  width: calc(340vw /14);
  margin: 0 auto;
  position: relative;
  padding-top: calc(15vw /14);
}
.kv-copy {
  width: fit-content;
  margin: calc(40vw /14) auto 0;
  position: relative;
  color: #fff;
  font-size: calc(16vw /14);
  font-style: italic;
}
.kv-copy span {
  display: block;
  background: #fb7702;
  line-height: 1;
  padding: .7em 1em .8em;
  margin-top: 1.2em;
}

.kv-mvBlock {
  width: 54%;
  position: relative;
  z-index: 0;
}
.kv-mv {
  width: 95%;
  margin-top: calc(300vw /14);
  margin-left: calc(-30vw /14);
}

.kv-point {
  position: absolute;
  --kp-start: calc(var(--kp-i, 0) * var(--kp-block));

  --kp-delay-dot: var(--kp-start);
  --kp-delay-ring: calc(var(--kp-start) + var(--kp-dot-in));
  --kp-delay-line: calc(var(--kp-delay-ring) + var(--kp-ring));
  --kp-delay-text: calc(var(--kp-delay-line) + var(--kp-line));
}
.kv-point01 {
  left: calc(30vw / 14);
  top: calc(235vw / 14);
/*  --kp-i: 0;*/
}
.kv-point02 {
  left: calc(375vw / 14);
  top: calc(345vw / 14);
/*  --kp-i: 1;*/
}
.kv-point03 {
  left: calc(30vw / 14);
  bottom: calc(-15vw / 14);
/*  --kp-i: 2;*/
}

.kv-point p {
  border: 1px solid;
  border-radius: calc(20vw /14);
  width: fit-content;
  padding: 1.2em 1.5em;
  position: relative;
  z-index: 1;
  background-color: #fac300;
  opacity: 0;
  transform: translateY(6px);
  animation: kpTextIn var(--kp-text) ease-out forwards;
  animation-delay: var(--kp-delay-text);
}
.kv-point p {
  color: #fff;
  font-size: calc(14vw / 14);
}
.kv-point p span {
  color: #ff6800;
  font-size: calc(18vw / 14);
  background-color: #fffc00;
  padding: .1em .3em .2em;
  font-weight: bold;
  margin: 0 0.2em;
}
.kv-point__dot {
  background: #f82626;
  border-radius: 50%;
  width: calc(14vw / 14);
  height: calc(14vw / 14);
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  opacity: 0;
  transform: scale(0.2);
  transform-origin: center;
  animation: kpDotPop var(--kp-dot-in) ease-out forwards;
  animation-delay: var(--kp-delay-dot);
}
.kv-point01 .kv-point__dot {
  bottom: calc(-103vw / 14);
}
.kv-point02 .kv-point__dot {
  left: calc(-124vw / 14);
  bottom: calc(-150vw / 14);
}
.kv-point03 .kv-point__dot {
  left: calc(-55vw / 14);
  top: calc(-120vw / 14);
}

.kv-point__dot::before {
  content:"";
  position:absolute;
  inset: 0px;
  border: 2px solid #fff;
  border-radius: 50%;
  opacity: 0;
  transform: scale(0.7);
  background: conic-gradient(#fff 0turn, #fff 0turn, transparent 0turn);
  -webkit-mask: radial-gradient(closest-side, transparent calc(100% - 2px), #000 calc(100% - 1px));
          mask: radial-gradient(closest-side, transparent calc(100% - 2px), #000 calc(100% - 1px));
  animation: kpRingDraw var(--kp-ring) ease-out forwards;
  animation-delay: var(--kp-delay-ring);
}
.kv-point__dot::after {
  content:"";
  position:absolute;
  left: 50%;
  bottom: 100%;
  transform: translateX(-50%);
  width: 2px;
  background: repeating-linear-gradient(to top, #fff 0 5px, transparent 5px 10px);
  clip-path: inset(100% 0 0 0);
  animation: kpDottedLine var(--kp-line) linear forwards;
  animation-delay: var(--kp-delay-line);
}
.kv-point01 .kv-point__dot::after {
  height: calc(88vw / 14);
}
.kv-point02 .kv-point__dot::after {
  height: calc(134vw / 14);
}
.kv-point03 .kv-point__dot::after {
  height: calc(104vw / 14);
  top: 100%;
  left: 35%;
  bottom: inherit;
  transform: rotate(180deg) translateX(-38%);
}
.kp-reveal {
  overflow: hidden;
  position: relative;
}
.kp-reveal::after {
  content:"";
  position:absolute;
  right: 0;
  height: 90%;
  width: 100%;
  background: #fffc00;
  animation: kpCharUnmask 0.45s ease-in forwards;
  animation-delay: calc(var(--kp-delay-text) + 0.15s + (var(--i, 0) * 0.08s));
}

@keyframes kpDotPop{
  to { opacity: 1; transform: scale(1); }
}
@keyframes kpRingDraw{
  0%{
    opacity: 0;
    transform: scale(1.7);
    background: conic-gradient(#fff 0turn, transparent 0turn);
  }
  10%{ opacity: 1; }
  100%{
    opacity: 1;
    transform: scale(1);
    background: conic-gradient(#fff 1turn, transparent 0turn);
  }
}
@keyframes kpDottedLine{
  to { clip-path: inset(0 0 0 0); }
}
@keyframes kpStrokeDown{
  to { transform: translateX(-50%) scaleY(1); }
}
@keyframes kpTextIn{
  to { opacity: 1; transform: translateY(0); }
}
@keyframes kpCharUnmask{
  to { width: 0%; }
}


@media (max-width: 767px) {
.kv {
  display: block;
  padding-bottom: calc(87vw / 7.5);
}
.kv-ttlBlock {
  width: 100%;
  height: calc(570vw /7.5);
  margin-right: 0;
  box-shadow: 9px 9px 19px -7px rgba(202,141,41,0.3);
  border-radius: 0 0 calc(118vw /7.5) calc(118vw /7.5);
  padding: 0;
}
.kv-ttlBlock__inner {
  width: calc(569vw /7.5);
  height: calc(489vw /7.5);
  margin: calc(60vw /7.5) auto 0;
  background-size: 16px 16px;
  background-position: bottom right;
}
.kv-ttlBlock__inner::before {
  display: none;
}
.kv-ttlBlock__inner::after {
  width: calc(32vw /7.5);
  height: 100%;
}
.kv-ttlBlock__border {
  display: none
}
.kv h1 {
  width: calc(460vw /7.5);
  padding: 0;
  position: absolute;
  left: calc(20vw /7.5);
  right: 0;
  margin: auto;
  top: calc(15vw /7.5);
}
.kv-copy {
  margin: calc(90vw /7.5) auto 0;
  font-size: calc(20vw /7.5);
}
.kv-copy span {
  padding: .4em 1em .5em 2em;
}
.kv-mvBlock {
  width: 100%;
}
.kv-mv {
  width: 95%;
  margin: calc(150vw /7.5) auto calc(50vw /7.5);
}
.kv-point01 {
  left: calc(22vw / 7.5);
  top: calc(-85vw / 7.5);
}
.kv-point02 {
  left: calc(425vw / 7.5);
  top: calc(24vw / 7.5);
}
.kv-point03 {
  left: calc(116vw / 7.5);
  bottom: calc(-29vw / 7.5);
}

.kv-point p {
  border-radius: calc(20vw /7.5);
  font-size: calc(20vw / 7.5);
  padding: 0.8em;
  letter-spacing: -0.01em;
}
.kv-point p span {
  font-size: calc(26vw / 7.5);
  padding: .05em .3em .1em;
}
.kv-point__dot {
  width: calc(27vw / 7.5);
  height: calc(27vw / 7.5);
}
.kv-point01 .kv-point__dot {
  bottom: calc(-75vw / 7.5);
}
.kv-point02 .kv-point__dot {
  left: calc(-150vw / 7.5);
  top: calc(248vw / 7.5);
}
.kv-point03 .kv-point__dot {
  left: calc(-253vw / 7.5);
  top: calc(-87vw / 7.5);
}

.kv-point__dot::before {
  border: 2px solid #fff;
}
.kv-point__dot::after {
  width: 1px;
  background: repeating-linear-gradient(
    to top,
    #fff 0 3px,
    transparent 2px 5px
  )
}
.kv-point01 .kv-point__dot::after {
  height: calc(66vw / 7.5);
}
.kv-point02 .kv-point__dot::after {
  height: calc(134vw / 7.5);
}
.kv-point03 .kv-point__dot::after {
  height: calc(74vw / 7.5);
  top: 100%;
}
}

.kv-animals {
  position: absolute;
  bottom: 0;
  right: calc(-35vw /14);
  height: calc(335vw /14);
  width: calc(245vw /14);
}
.kv-animals img {
  width: calc(71vw /14);
  right: calc(-20vw /14);
  transform: rotate(-23deg);
  position: absolute;
  opacity: 0;
  transform: translate(10px, 10px) rotate(-23deg) scale(0.96);
  transform-origin: right bottom;
  will-change: opacity, transform;
  animation: kvAnimalPop var(--animals-pop) cubic-bezier(.2,.9,.2,1) forwards;
  animation-delay: calc(var(--animals-start) + (var(--ai, 0) * var(--animals-step)));
}
.kv-animals__01 {
  bottom: calc(190vw /14);
}
.kv-animals__02 {
  bottom: calc(120vw /14);
}
.kv-animals__03 {
  bottom: calc(35vw /14);
}
.kv-animals__04 {
  bottom: calc(-35vw /14);
}
.kv-animals__line {
  position: absolute;
  bottom: calc(10vw /14);
  width: 9em;
  left: calc(0vw /14);
  font-size: calc(18vw /14);
  letter-spacing: -0.2em;
}
.kv-animals__04{ --ai: 3; }
.kv-animals__03{ --ai: 2; }
.kv-animals__02{ --ai: 1; }
.kv-animals__01{ --ai: 0; }
.kv-animals__line .kv-ch{
  display: inline-block;
  opacity: 0;
  transform: translateX(6px);
  will-change: opacity, transform;
  animation: kvCharIn 0.28s ease-out forwards;
  animation-delay: calc(var(--line-start) + (var(--ci, 0) * var(--line-step)));
}
@keyframes kvAnimalPop{
  0%{
    opacity: 0;
    transform: translate(14px, 14px) rotate(-23deg) scale(0.92);
  }
  60%{
    opacity: 1;
    transform: translate(0px, 0px) rotate(-23deg) scale(1.03);
  }
  100%{
    opacity: 1;
    transform: translate(0px, 0px) rotate(-23deg) scale(1);
  }
}
@keyframes kvCharIn{
  to{
    opacity: 1;
    transform: translateX(0);
  }
}


/* intro */
.intro {
  width: 100%;
}
.intro-mv{
  width: 200%;
  margin-left: -50%;
  height: clamp(375px, 65vw, 1476px);
  position: relative;
  overflow: hidden;
  background-image: url("./img/mainimg.jpg");
  background-size: 50% auto;
  background-repeat: no-repeat;
  background-position: 30% 50%;
  clip-path: ellipse(40% 85% at 50% 0%);
  -webkit-clip-path: ellipse(40% 85% at 50% 0%);
}
.intro p {
  text-align: center;
  margin-top: calc(-80vw / 14);
  line-height: 2;
}

@media (max-width: 767px) {
.intro-mv{
  width: 220%;
  margin-left: -60%;
}
.intro p {
  margin-top: calc(-60vw / 7.5);
  font-size: calc(18vw /7.5);
}
}


.secret-ft {
  width: 100%;
  margin: calc(240vw /14) auto 0;
  position: relative;
  background-image: linear-gradient(0deg, transparent calc(100% - 1px), #feedae calc(100% - 1px)), linear-gradient(90deg, transparent calc(100% - 1px), #feedae calc(100% - 1px));
  background-size: 30px 30px;
  background-repeat: repeat;
  background-position: top center;
  padding: calc(170vw / 14) 0 calc(160vw / 14);
}
.secret-ft__btn {
  position: relative;
  color: #fff;
  font-size: calc(14vw / 14);
  padding: 1.5em 0;
  background: #398cca;
  border-radius: calc(35vw / 14);
  width: calc(400vw / 14);
  text-align: center;
  transition: all .3s;
  margin: 0 auto;
  transition: all 0.3s;
  font-weight: bold;
  font-style: italic;
}
.secret-ft__btn::after {
  display: block;
  content: '';
  position: absolute;
  right: 1.5em;
  top: 0;
  bottom: 0;
  margin: auto;
  background-color: #fff;
  width: calc(6vw / 14);
  height: calc(8vw / 14);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
.secret-ft__pkg {
  position: absolute;
  width: calc(251vw / 14);
  right: calc(50% - 35vw);
  top: 15%;
  animation: secretFtPkg 1s linear infinite;
}
@keyframes secretFtPkg {
  0%{
    transform: rotate(-10deg);
  }
  49%{
    transform: rotate(-10deg);
  }
  50%{
    transform: rotate(5deg);
  }
  99%{
    transform: rotate(5deg);
  }
  100%{
    transform: rotate(-10deg);
  }
}
.secret-ft__comm {
  position: absolute;
  bottom: calc(-360vw /14);
  width: fit-content;
  left: 0;
  right: 0;
  margin: auto;
  animation-duration: 0.5s;
  opacity:1;
}
.is-state_scroll.secret-ft__comm {
  animation: secreFtComm 1s ease-in forwards;
}
@keyframes secreFtComm {
  0% { bottom: calc(-360vw /14);opacity:1; }
  90% { bottom: calc(-105vw /14);opacity:1; }
  100% { bottom: calc(-125vw /14);opacity:1; }
}
.secret-ft__animal {
  width: calc(109vw /14);
  margin: auto;
}
.secret-ft__comm p {
  position: absolute;
  top: calc(50vw / 14);
  font-size: calc(18vw / 14);
  width: 22em;
  display: flex;
  justify-content: space-around;
  left: -7em;
  opacity: 0;
}
.secret-ft__comm.is-state_scroll p {
  animation: secreFtCommP 0.1s 1s ease-in forwards;
}
@keyframes secreFtCommP {
  0% { opacity: 0; }
  60% { opacity: 1; }
  100% { opacity: 1; }
}

@media (min-width: 768px) {
.secret-ft__btn:hover {
  color: #398cca;
  background: #fff;
}
.secret-ft__btn:hover::after {
  background-color: #398cca;
}
}
@media (max-width: 767px) {
.secret-ft {
  margin: calc(100vw /7.5) auto 0;
  background-size: 17px 17px;
  padding: calc(120vw / 7.5) 0 calc(160vw / 7.5);
}
.secret-ft__btn {
  font-size: calc(20vw / 7.5);
  border-radius: 25px;
  width: calc(450vw / 7.5);
  margin-left: 5%;
  padding: 1.7em 0;
}
.secret-ft__btn::after {
  width: calc(12vw / 7.5);
  height: calc(14vw / 7.5);
}
.secret-ft__pkg {
  width: calc(251vw / 7.5);
  right: 3%;
  top: 15%;
}
.secret-ft__comm {
  bottom: calc(-135vw /7.5);
  right: inherit;
  left: 9%;
}
@keyframes secreFtComm {
  0% { bottom: calc(-360vw /7.5);opacity:1; }
  90% { bottom: calc(-115vw /7.5);opacity:1; }
  100% { bottom: calc(-135vw /7.5);opacity:1; }
}
.secret-ft__animal {
  width: calc(120vw /7.5);
}
.secret-ft__comm p {
  top: calc(55vw / 7.5);
  font-size: calc(18vw / 7.5);
  width: 24em;
  left: calc(130vw /7.5);
  justify-content: flex-start;
}
}








