@charset "UTF-8";
*, ::before, ::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body, p, div, section {
  line-height: 1.4; /* 1〜1.5くらいで安定 */
}

img, svg, video {
  display: block;
  vertical-align: bottom; /* inline-blockの場合に隙間を抑える */
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}
@media screen and (min-width: 769px) {
  html {
    font-size: min(0.715vw, 10px);
    scroll-padding-top: 6rem;
  }
}
@media screen and (max-width: 768px) {
  html {
    font-size: 1.334vw;
  }
}

body {
  margin: 0;
  color: #662b1f;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
  overflow-x: hidden;
  margin-inline: auto;
  width: 100%;
}
@media screen and (min-width: 769px) {
  body {
    max-width: 2000px;
    overflow-y: hidden;
  }
}
body.bg-fixed {
  overflow: hidden;
}

main {
  display: block;
}
main a {
  color: #662b1f !important;
}

p, table, figure, dl, dt, dd, h1, h2, h3, h4, h5, h6, ul, ol {
  margin: 0;
  padding: 0;
  font-family: "Noto Sans JP", sans-serif;
}

ul, ol {
  list-style: none;
}

a {
  text-decoration: none;
  color: inherit;
}

svg, img {
  max-width: 100%;
  max-height: 100%;
  vertical-align: bottom;
}

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

@media screen and (min-width: 769px) {
  .sp-only {
    display: none !important;
  }
}

.globalFooter {
  border-top: 3px solid #662b1f;
}

.fadein {
  opacity: 0;
  visibility: hidden;
  transform: translate(0, 50px);
  transition: all 1s ease-in-out;
}
@media screen and (max-width: 768px) {
  .fadein {
    transform: translate(0, 5em);
  }
}
.fadein.is-fadein {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 0);
}

.anim01 {
  opacity: 0;
  transform: scale(0.2) rotate(-1deg);
  transition: opacity 240ms ease, transform 420ms cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.anim01.is-active {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.anim02 {
  animation: kf-anim02 4s infinite ease-in-out;
}

@keyframes kf-anim02 {
  0% {
    transform: translate(-50%, 0);
  }
  50% {
    transform: translate(-50%, -10px);
  }
  100% {
    transform: translate(-50%, 0);
  }
}
.anim02_1 {
  animation: kf-anim02_1 5.5s infinite ease-in-out;
}

@keyframes kf-anim02_1 {
  0% {
    transform: translate(-50%, 0);
  }
  50% {
    transform: translate(-50%, -10px);
  }
  100% {
    transform: translate(-50%, 0);
  }
}
.anim03 {
  animation: kf-anim03 3s infinite ease-in-out;
}

@keyframes kf-anim03 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, 10px);
  }
  100% {
    transform: translate(0, 0);
  }
}
.anim03_1 {
  animation: kf-anim03_1 4.5s infinite ease-in-out;
  display: inline-block;
  transform: rotate(2deg);
}

@keyframes kf-anim03_1 {
  50% {
    transform: rotate(-2deg);
  }
  100% {
    transform: rotate(2deg);
  }
}
.anim03_2 {
  animation: kf-anim03_2 4.5s infinite ease-in-out;
  display: inline-block;
  transform: rotate(-2deg);
}

@keyframes kf-anim03_2 {
  50% {
    transform: rotate(2deg);
  }
  100% {
    transform: rotate(-2deg);
  }
}
.anim04 {
  animation: kf-anim04 2s infinite;
  display: inline-block;
  transform: rotate(8deg);
}

@keyframes kf-anim04 {
  50% {
    transform: rotate(-8deg);
  }
  100% {
    transform: rotate(8deg);
  }
}
.anim05 {
  animation: kf-anim05 2s infinite;
  display: inline-block;
  transform: rotate(-8deg);
}

@keyframes kf-anim05 {
  50% {
    transform: rotate(8deg);
  }
  100% {
    transform: rotate(-8deg);
  }
}
.anim06 {
  backface-visibility: hidden;
  transform-style: preserve-3d;
}
@media screen and (min-width: 769px) {
  .anim06 {
    transform: translateY(-21rem);
    transition: transform 0.4s ease-out;
  }
}
@media screen and (max-width: 768px) {
  .anim06 {
    transform: translateY(-37rem);
    transition: transform 0.4s ease-out;
  }
}
.anim06.is-active {
  transform: translateY(0rem);
}

.anim07 {
  animation: kf-anim07 4s infinite ease;
}

@keyframes kf-anim07 {
  0% {
    transform: translate(0, 0);
  }
  4% {
    transform: translate(0, 0);
  }
  10% {
    transform: translate(0, 0);
  }
  15% {
    transform: translate(0, -15px);
  }
  19% {
    transform: translate(0, 0);
  }
  23% {
    transform: translate(0, -15px);
  }
  38% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}
.anim08 {
  animation: kf-anim08 3s infinite ease;
}

@keyframes kf-anim08 {
  0% {
    transform: translate(0, 0);
  }
  5% {
    transform: translate(0, 0);
  }
  10% {
    transform: translate(0, 0);
  }
  20% {
    transform: translate(0, -15px);
  }
  25% {
    transform: translate(0, 0);
  }
  30% {
    transform: translate(0, -15px);
  }
  50% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}
.anim09 {
  opacity: 0;
  transition: opacity 1s ease;
}
.anim09.is-active {
  opacity: 1;
}

.anim10 {
  opacity: 0;
  transform: scale(2.1);
  transition: all 0.5s ease;
}
.anim10.is-active {
  opacity: 1;
  transform: scale(1);
}

.center {
  text-align: center;
}

@media screen and (min-width: 769px) {
  .txt01 {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .txt01 {
    font-size: 3.6rem;
    line-height: 4.8rem;
  }
}

@media screen and (min-width: 769px) {
  .txt02 {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .txt02 {
    font-size: 3.2rem;
  }
}

.txt03 {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .txt03 {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .txt03 {
    font-size: 3.2rem;
    line-height: 5rem;
  }
}

.att {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .att {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .att {
    font-size: 2.8rem;
    line-height: 1.5;
  }
}

.accent {
  font-weight: bold;
  text-decoration: underline;
}

.container {
  font-family: "Noto Sans JP", sans-serif;
}

.cont_bg {
  position: relative;
  z-index: 2;
}
.cont_bg::before {
  content: "";
  height: 100%;
  background-position: center top;
  background-repeat: repeat-y;
  background-size: 100%;
  position: absolute;
  z-index: -1;
}
@media screen and (min-width: 769px) {
  .cont_bg::before {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .cont_bg::before {
    width: 75rem;
  }
}

.cont_inner {
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .cont_inner {
    width: 100%;
  }
}

@media screen and (min-width: 769px) {
  .swiper-button {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .swiper-button .prev, .swiper-button .next {
    width: 7.7rem;
    height: 7.7rem;
  }
}
@media screen and (max-width: 768px) {
  .swiper-button.colum01 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
    margin: 3.5rem auto 0;
    width: 57.8rem;
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (max-width: 768px) {
  .swiper-button.colum01 .prev {
    transform: rotateY(180deg);
  }
}
@media screen and (max-width: 768px) {
  .swiper-button.colum02 .prev, .swiper-button.colum02 .next {
    position: absolute;
    top: 28rem;
    z-index: 1;
  }
}
.swiper-button.colum02 .prev.swiper-button-disabled, .swiper-button.colum02 .next.swiper-button-disabled {
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  .swiper-button.colum02 .prev {
    left: -5rem;
    transform: rotateY(180deg);
  }
}
@media screen and (max-width: 768px) {
  .swiper-button.colum02 .next {
    right: -5rem;
  }
}
@media screen and (max-width: 768px) {
  .swiper-button.colum03 {
    margin: 3rem auto 0;
    width: 66.6rem;
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (max-width: 768px) {
  .swiper-button.colum03 .prev {
    transform: rotateY(180deg);
  }
}
.swiper-button.colum04 {
  width: stretch;
  width: -webkit-fill-available;
  width: -moz-available;
}
@media screen and (max-width: 768px) {
  .swiper-button.colum04 {
    display: flex;
    justify-content: space-between;
    margin: 5.6rem 2.5rem 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .swiper-button.colum04 .prev {
    transform: rotateY(180deg);
  }
}

@media screen and (min-width: 769px) {
  .acc {
    margin: 6rem auto 0;
    width: 85rem;
  }
}
@media screen and (max-width: 768px) {
  .acc {
    margin: 7.3rem auto 0;
    width: 66.6rem;
  }
}

.acc_btn {
  display: grid;
  place-content: center;
  background-color: #fff;
  border: 2px solid #662b1f;
  text-align: center;
  font-weight: bold;
  position: relative;
}
@media screen and (min-width: 769px) {
  .acc_btn {
    height: 5rem;
    font-size: 2rem;
    cursor: pointer;
  }
}
@media screen and (max-width: 768px) {
  .acc_btn {
    height: 7.5rem;
    font-size: 3rem;
  }
}
.acc_btn::after {
  content: "";
  background-image: url(../img/arrow03.png);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  right: 1.5rem;
}
@media screen and (min-width: 769px) {
  .acc_btn::after {
    width: 2.4rem;
    height: 1.4rem;
    top: 1.5rem;
  }
}
@media screen and (max-width: 768px) {
  .acc_btn::after {
    width: 3.6rem;
    height: 2.1rem;
    top: 2.5rem;
  }
}
.acc_btn.is-opened::after {
  transform: rotate(180deg);
}

@media screen and (min-width: 769px) {
  .acc_inner {
    padding-top: 4.5rem;
    font-size: 1.6rem;
    line-height: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .acc_inner {
    padding-top: 2.5rem;
    font-size: 2.6rem;
    line-height: 3.4rem;
  }
}
@media screen and (min-width: 769px) {
  .acc_inner > li + li {
    margin-top: 2.5rem;
  }
}
@media screen and (max-width: 768px) {
  .acc_inner > li + li {
    margin-top: 4rem;
  }
}

@media screen and (min-width: 769px) {
  .agree {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .agree {
    margin-top: 4rem;
  }
}

.agree_txt {
  text-align: center;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .agree_txt {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .agree_txt {
    font-size: 4.2rem;
    line-height: 5.5rem;
  }
}

.agree_check {
  display: flex;
  justify-content: center;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .agree_check {
    margin-top: 1.5rem;
    column-gap: 2rem;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .agree_check {
    margin-top: 2.5rem;
    column-gap: 5.5rem;
    font-size: 3rem;
    line-height: 4rem;
  }
}
.agree_check > label {
  cursor: pointer;
}
.agree_check input[type=checkbox] {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.agree_check input[type=checkbox] {
  cursor: pointer;
  padding-left: 3rem;
  vertical-align: middle;
  position: relative;
}
@media screen and (max-width: 768px) {
  .agree_check input[type=checkbox] {
    padding-left: 6rem;
  }
}
.agree_check input[type=checkbox]::before,
.agree_check input[type=checkbox]::after {
  content: "";
  display: block;
  position: absolute;
}
.agree_check input[type=checkbox]::before {
  background-color: #fff;
  border-radius: 0%;
  border: 2px solid #662b1f;
  width: 3rem;
  height: 3rem;
  top: 0;
  left: 0.5rem;
}
@media screen and (max-width: 768px) {
  .agree_check input[type=checkbox]::before {
    width: 8rem;
    height: 8rem;
  }
}
.agree_check input[type=checkbox]::after {
  border-bottom: 3px solid #662b1f;
  border-left: 3px solid #662b1f;
  opacity: 0;
  height: 1rem;
  width: 2rem;
  transform: rotate(-45deg);
  top: 0.8rem;
  left: 1rem;
}
@media screen and (max-width: 768px) {
  .agree_check input[type=checkbox]::after {
    width: 6rem;
    height: 3rem;
    top: 2.2rem;
    left: 1.5rem;
  }
}
.agree_check input[type=checkbox]:checked::before {
  background-color: #fff;
}
.agree_check input[type=checkbox]:checked::after {
  opacity: 1;
}

.agree_items {
  display: flex;
  align-items: flex-end;
}
@media screen and (min-width: 769px) {
  .agree_items {
    margin-top: 4.5rem;
    justify-content: center;
    column-gap: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .agree_items {
    margin-top: 5.5rem;
    flex-direction: column;
    align-items: center;
    row-gap: 4.5rem;
  }
}
.agree_items .btn_img {
  transition: all 0.3s ease;
}
@media screen and (min-width: 769px) {
  .agree_items .btn_img {
    width: 40.5rem;
  }
}
@media screen and (max-width: 768px) {
  .agree_items .btn_img {
    width: 60.7rem;
  }
}
.agree_items > a:hover {
  pointer-events: none;
}

.head {
  width: 100%;
  position: fixed;
  z-index: 9999;
}
@media screen and (min-width: 769px) {
  .head {
    max-width: 2000px;
    height: 6rem;
    background-color: #fff;
  }
}

.head_inner {
  height: 100%;
  display: flex;
  align-items: center;
}
@media screen and (min-width: 769px) {
  .head_inner {
    margin-inline: auto;
    width: 95rem;
  }
}
@media screen and (max-width: 768px) {
  .head_inner {
    position: relative;
  }
}

.head_logo {
  height: auto;
  position: relative;
}
@media screen and (min-width: 769px) {
  .head_logo {
    width: 7.2rem;
  }
}

@media screen and (max-width: 768px) {
  .ham {
    width: 13rem;
    height: 12rem;
    display: flex;
    align-items: center;
    background-image: url(../img/hamburger-open.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    top: 2rem;
    right: 0;
    z-index: 9999;
    cursor: pointer;
  }
  .ham.is-active {
    background-image: url(../img/hamburger-close.png);
  }
}

@media screen and (min-width: 769px) {
  .menu {
    margin-left: auto;
    padding-right: 1.5rem;
  }
}
@media screen and (max-width: 768px) {
  .menu {
    padding-top: 18rem;
    width: 100%;
    height: 100vh;
    opacity: 0;
    visibility: hidden;
    background-color: rgba(255, 255, 255, 0.9);
    position: fixed;
    inset: 0;
    z-index: 9998;
    transition: all 0.7s ease;
    overflow-y: auto;
  }
  .menu.is-open {
    opacity: 1;
    visibility: visible;
    inset: 0;
  }
}
@media screen and (max-width: 768px) {
  .menu > .head_logo {
    margin: 8.5rem auto 0;
    width: 17.1rem;
    display: block;
  }
}

@media screen and (min-width: 769px) {
  .menu_inner {
    display: flex;
  }
}
@media screen and (max-width: 768px) {
  .menu_inner {
    margin-inline: auto;
    width: 55.1rem;
    border-top: 2px solid #662b1f;
    border-bottom: 2px solid #662b1f;
  }
}

@media screen and (max-width: 768px) {
  .menu_link + .menu_link {
    border-top: 2px solid #662b1f;
  }
}
@media screen and (min-width: 769px) {
  .menu_link + .menu_link::before {
    content: "|";
    margin: 0 1.5rem;
    display: inline-block;
    color: #662b1f;
  }
}
@media screen and (min-width: 769px) {
  .menu_link {
    line-height: 1.5;
  }
}
@media screen and (max-width: 768px) {
  .menu_link {
    padding: 3.5rem 1.5rem;
  }
}
@media screen and (max-width: 768px) {
  .menu_link > a {
    width: 100%;
    display: block;
    position: relative;
  }
}
@media screen and (max-width: 768px) {
  .menu_link > a::after {
    content: "";
    width: 3.8rem;
    height: 3.5rem;
    background-image: url(../img/arrow04.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    top: 0.5rem;
    right: 0;
  }
}
.menu_link > a img {
  display: inline;
  height: auto;
}
@media screen and (min-width: 769px) {
  .menu_link .wid01 {
    width: 12rem;
  }
}
@media screen and (max-width: 768px) {
  .menu_link .wid01 {
    width: 26.6rem;
  }
}
@media screen and (min-width: 769px) {
  .menu_link .wid02 {
    width: 11.4rem;
  }
}
@media screen and (max-width: 768px) {
  .menu_link .wid02 {
    width: 24.9rem;
  }
}

.kv {
  margin-inline: auto;
  background-color: #fff;
}
@media screen and (min-width: 769px) {
  .kv {
    padding-top: 6rem;
    max-width: 2000px;
  }
}

.kv_wrap {
  background-position: center top;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .kv_wrap {
    padding-bottom: 7rem;
    background-image: url(../img/kv_bg_pc.png);
    background-size: 200rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_wrap {
    width: 75rem;
    height: 100%;
    padding-bottom: 16rem;
    background-image: url(../img/kv_bg_sp.png);
    background-size: 75rem auto;
  }
}

.kv_inner {
  margin-inline: auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .kv_inner {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .kv_inner {
    max-width: 95rem;
  }
}
.kv_inner::before {
  content: "";
  z-index: 1;
  position: absolute;
  top: 0;
  width: 75rem;
  height: 109.3rem;
  background-image: url(../img/kv_nigiyakashi_sp.png);
  background-size: 75rem auto;
  background-repeat: no-repeat;
  pointer-events: none;
  transform: scale(0.5); /* 初期は縮小 */
  animation: scaleUp 0.7s ease-out forwards; /* 1度だけ */
}
@media screen and (min-width: 769px) {
  .kv_inner::before {
    top: 2rem;
    left: 0;
    width: 95rem;
    height: 56.4rem;
    background-image: url(../img/kv_nigiyakashi_pc.png);
    background-position: center top;
    background-size: 95rem auto;
    background-repeat: no-repeat;
  }
}

.kv_ttl {
  height: auto;
}
@media screen and (min-width: 769px) {
  .kv_ttl {
    width: 74.65rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_ttl {
    width: 63rem;
  }
}

.kv_chara {
  height: auto;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (min-width: 769px) {
  .kv_chara {
    width: 85rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_chara {
    width: 70.4rem;
  }
}

.kv_copy {
  height: auto;
}
@media screen and (min-width: 769px) {
  .kv_copy {
    width: 31.3rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_copy {
    width: 56.7rem;
  }
}

.kv_pos {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (min-width: 769px) {
  .kv_pos.pos01 {
    top: 3rem;
    left: 50%;
    width: 78%;
  }
}
@media screen and (max-width: 768px) {
  .kv_pos.pos01 {
    top: 5.5rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_pos.pos02 {
    top: 2.5rem;
    left: 50%;
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  .kv_pos.pos02 {
    top: 9rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_pos.pos03 {
    top: 4.5rem;
    left: 80%;
  }
}
@media screen and (max-width: 768px) {
  .kv_pos.pos03 {
    top: 16.4rem;
  }
}

.kv_deco {
  margin-inline: auto;
  width: 200rem;
}

@media screen and (min-width: 769px) {
  .kv_balloon > figure {
    width: 13.8rem;
    height: auto;
    position: absolute;
  }
}
@media screen and (min-width: 769px) {
  .kv_balloon .pos01 {
    top: -0.1rem;
    left: -64rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_balloon .pos02 {
    top: -1rem;
    left: -39rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_balloon .pos03 {
    bottom: 7rem;
    left: -25rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_balloon .pos04 {
    top: 9.5rem;
    right: -27rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_balloon .pos05 {
    top: 1.5rem;
    right: -47rem;
  }
}

.kv_pkg > picture {
  height: auto;
  position: absolute;
}
@media screen and (min-width: 769px) {
  .kv_pkg > picture {
    width: 16.8rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_pkg > picture {
    width: 22.7rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_pkg .pos01 {
    top: 10rem;
    left: -12rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_pkg .pos01 {
    top: 31rem;
    left: -3rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_pkg .pos02 {
    bottom: 13rem;
    left: -17rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_pkg .pos02 {
    bottom: 24rem;
    left: -7rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_pkg .pos03 {
    top: 11rem;
    right: -6rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_pkg .pos03 {
    top: 31rem;
    right: -3rem;
  }
}
@media screen and (min-width: 769px) {
  .kv_pkg .pos04 {
    bottom: 14rem;
    right: -15rem;
  }
}
@media screen and (max-width: 768px) {
  .kv_pkg .pos04 {
    bottom: 22rem;
    right: -7rem;
  }
}

.intro {
  position: relative;
  z-index: 5;
  padding-top: 4.6rem;
}
.intro .cont_inner {
  z-index: 0;
}
@media screen and (min-width: 769px) {
  .intro .cont_inner {
    width: 95rem;
  }
}
.intro .cont_inner .fadein + .fadein {
  margin-top: 2.6rem;
  height: 46rem;
}

.intro_bg {
  position: relative;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .intro_bg {
    padding-bottom: 13.7rem;
  }
}
@media screen and (min-width: 769px) {
  .intro_bg {
    padding-bottom: 13.7rem;
  }
}
.intro_bg::before {
  position: absolute;
  content: "";
  bottom: 0;
}
@media screen and (min-width: 769px) {
  .intro_bg::before {
    bottom: -6.85rem;
    left: 50%;
    transform: translateX(-50%);
    width: 200rem;
    height: 12.7rem;
    background-image: url(../img/intro_bg_pc.png);
    background-size: 200rem auto;
    background-repeat: no-repeat;
  }
}
@media screen and (max-width: 768px) {
  .intro_bg::before {
    bottom: -6.5rem;
    width: 75rem;
    height: 12.9rem;
    background-image: url(../img/intro_bg_sp.png);
    background-size: 75rem auto;
    background-repeat: no-repeat;
  }
}

.intro_ttl {
  margin-inline: auto;
  height: auto;
}
@media screen and (min-width: 769px) {
  .intro_ttl {
    width: 34.2rem;
  }
}
@media screen and (max-width: 768px) {
  .intro_ttl {
    width: 48rem;
  }
}

.intro_txt {
  height: auto;
}
@media screen and (min-width: 769px) {
  .intro_txt {
    margin: 1.1rem auto 0;
    width: 28.4rem;
  }
}
@media screen and (max-width: 768px) {
  .intro_txt {
    margin: 3.2rem auto 0;
    width: 52.9rem;
  }
}

.char_wrap {
  position: relative;
}
@media screen and (min-width: 769px) {
  .char_wrap {
    overflow: visible;
  }
}
@media screen and (max-width: 768px) {
  .char_wrap {
    padding: 3.2rem 0 0 2.5rem;
  }
}

@media screen and (min-width: 769px) {
  .char_inner {
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

@media screen and (max-width: 768px) {
  .char {
    width: 30.4rem;
    height: 33.7rem;
  }
}
.char figure {
  position: absolute;
  width: 30.4rem;
  height: auto;
}
@media screen and (min-width: 769px) {
  .char figure {
    position: relative;
    width: 19.1rem;
  }
}
.char.pochacco {
  position: relative;
  top: -1.2rem;
}

.contact {
  position: relative;
}
@media screen and (max-width: 768px) {
  .contact {
    padding: 15.2rem 0 8rem;
  }
}
@media screen and (min-width: 769px) {
  .contact {
    padding: 5rem 0 4.5rem;
  }
}
.contact::before {
  content: "";
  position: absolute;
  z-index: 2;
  background-repeat: no-repeat;
  pointer-events: none;
}
@media screen and (min-width: 769px) {
  .contact::before {
    content: "";
    position: absolute;
    z-index: 2;
    top: 2rem;
    left: 2.8%;
    width: 175.02rem;
    height: 49.23rem;
    background-image: url(../img/contact_bg_nigiyakashi_pc.png);
    background-size: 175.02rem auto;
  }
}
@media screen and (min-width: 769px) {
  .contact .contact_ttl {
    margin-top: 0;
  }
}

.contact_ttl {
  text-align: center;
}
@media screen and (min-width: 769px) {
  .contact_ttl {
    margin-top: 4.5rem;
  }
}
.contact_ttl > p {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .contact_ttl > p {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_ttl > p {
    font-size: 3.6rem;
  }
}
.contact_ttl > h2 {
  font-weight: 900;
}
@media screen and (min-width: 769px) {
  .contact_ttl > h2 {
    font-size: 3rem;
    line-height: 1;
  }
}
@media screen and (max-width: 768px) {
  .contact_ttl > h2 {
    font-size: 4.5rem;
    line-height: 1.3;
  }
}

.contact_data {
  display: flex;
}
@media screen and (min-width: 769px) {
  .contact_data {
    margin-top: 0.417em;
    column-gap: 1.5rem;
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_data {
    flex-direction: column;
    row-gap: 1rem;
    font-size: 3.6rem;
  }
}
.contact_data > dt, .contact_data dd {
  font-weight: 900;
}
@media screen and (max-width: 768px) {
  .contact_data > dt, .contact_data dd {
    line-height: 1;
  }
}
@media screen and (max-width: 768px) {
  .contact_data dt {
    font-size: 3.2rem;
  }
}
.contact_data > dd p {
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .contact_data > dd p {
    margin-inline: auto;
    width: 46rem;
  }
}
.contact_data > dd span {
  display: block;
}
@media screen and (min-width: 769px) {
  .contact_data > dd span {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_data > dd span {
    text-align: center;
    font-size: 2.8rem;
  }
}
@media screen and (min-width: 769px) {
  .contact_data.col01 {
    margin-top: 3rem;
    justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  .contact_data.col01 {
    margin-top: 4rem;
    align-items: center;
  }
}
@media screen and (max-width: 768px) {
  .contact_data.col01 > dd {
    font-size: 5rem;
  }
}
@media screen and (min-width: 769px) {
  .contact_data.col02 {
    margin: 0.5rem auto 0;
    width: 74rem;
    justify-content: left;
  }
}
@media screen and (max-width: 768px) {
  .contact_data.col02 {
    margin: 3.3rem auto 0;
    width: 100%;
    align-items: center;
  }
}
.contact_data.col02 > dt, .contact_data.col02 dd {
  font-weight: bold;
}
.contact_data.col02 > dt {
  display: grid;
  place-content: center;
  padding-bottom: 0.25rem;
  background-color: #662b1f;
  color: #fff;
}
@media screen and (min-width: 769px) {
  .contact_data.col02 > dt {
    margin-top: 0.4em;
    width: 13.3rem;
    height: 3.2rem;
    border-radius: 2rem;
    font-size: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_data.col02 > dt {
    width: 20rem;
    height: 4.8rem;
    border-radius: 4rem;
    font-size: 3.3rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_data.col02 > dd {
    font-size: 4rem;
    line-height: 1.5;
    text-align: center;
  }
}

@media screen and (min-width: 769px) {
  .p-notblock {
    display: inline !important;
  }
}

.contact_btn {
  display: flex;
}
@media screen and (min-width: 769px) {
  .contact_btn {
    margin-top: 5.5rem;
    justify-content: center;
    align-items: flex-end;
    column-gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_btn {
    margin-top: 3.9rem;
    flex-direction: column;
    align-items: center;
    row-gap: 3.5rem;
  }
}
.contact_btn > li {
  height: auto;
}
@media screen and (min-width: 769px) {
  .contact_btn > li {
    width: 40.6rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_btn > li {
    width: 60.9rem;
  }
}

.contact_copy {
  margin-inline: auto;
  height: auto;
}
@media screen and (min-width: 769px) {
  .contact_copy {
    margin-top: 2rem;
    width: 32rem;
  }
}
@media screen and (max-width: 768px) {
  .contact_copy {
    margin-top: 5rem;
    width: 64.1rem;
  }
}
.contact_copy img {
  vertical-align: middle;
}

.contact_sns {
  display: flex;
  justify-content: center;
  margin-top: 4rem;
}
.contact_sns li {
  width: 8rem;
}
@media screen and (min-width: 769px) {
  .contact_sns li {
    width: 4rem;
  }
}
.contact_sns li a {
  display: flex;
  align-items: center;
  justify-content: center;
}
.contact_sns li a img {
  display: block;
  width: 100%;
  height: auto;
}

.to_top {
  position: fixed;
  z-index: 999;
  transition: all 0.15s ease-out;
  opacity: 0;
  visibility: hidden;
}
@media screen and (min-width: 769px) {
  .to_top {
    inset: auto 2rem 5rem auto;
  }
}
@media screen and (max-width: 768px) {
  .to_top {
    inset: auto 4rem 5rem auto;
  }
}
.to_top a img {
  height: auto;
}
@media screen and (min-width: 769px) {
  .to_top a img {
    width: 10rem;
  }
}
@media screen and (max-width: 768px) {
  .to_top a img {
    width: 15rem;
  }
}
.to_top.is-active {
  opacity: 1;
  visibility: visible;
}
.to_top .anim02 {
  animation: kf-anim02_totop 4s infinite ease-in-out;
}
@keyframes kf-anim02_totop {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(0, -10px);
  }
  100% {
    transform: translate(0, 0);
  }
}

.chara {
  height: auto;
  position: absolute;
}
.chara.wid01 {
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .chara.wid01 {
    width: 11.6rem;
    top: -18rem;
    left: 0;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid01 {
    width: 17.4rem;
    top: -23rem;
    left: -1rem;
  }
}
@media screen and (min-width: 769px) {
  .chara.wid02 {
    width: 10.5rem;
    top: 0;
    right: 0;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid02 {
    width: 16.8rem;
    top: -11rem;
    right: 4rem;
  }
}
@media screen and (min-width: 769px) {
  .chara.wid03 {
    width: 11.7rem;
    bottom: 3rem;
    left: 14rem;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid03 {
    width: 17.7rem;
    bottom: -2rem;
    left: 6rem;
  }
}
@media screen and (min-width: 769px) {
  .chara.wid04 {
    width: 14rem;
    bottom: 4rem;
    right: 13rem;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid04 {
    width: 20.9rem;
    bottom: 0;
    right: 4rem;
  }
}
@media screen and (min-width: 769px) {
  .chara.wid05 {
    width: 12.9rem;
    bottom: 14rem;
    right: 15rem;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid05 {
    width: 19.4rem;
    top: 26rem;
    right: -3rem;
    z-index: 1;
  }
}
.chara.wid06 {
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .chara.wid06 {
    width: 14rem;
    top: -11rem;
    left: -5rem;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid06 {
    width: 22.4rem;
    top: 55rem;
    left: -4.5rem;
  }
}
.chara.wid07 {
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .chara.wid07 {
    width: 9.5rem;
    bottom: -1rem;
    left: 23rem;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid07 {
    width: 17.4rem;
    bottom: -12rem;
    left: 5rem;
  }
}
@media screen and (min-width: 769px) {
  .chara.wid08 {
    z-index: 5;
    width: 14.43rem;
    bottom: 8rem;
    left: 35%;
  }
}
@media screen and (max-width: 768px) {
  .chara.wid08 {
    width: 23.1rem;
    bottom: 12.2rem;
    left: 10rem;
  }
}

.logo {
  height: auto;
  position: absolute;
}
@media screen and (min-width: 769px) {
  .logo {
    width: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .logo {
    width: 10rem;
  }
}
.logo.pos01 {
  right: -2rem;
}
@media screen and (min-width: 769px) {
  .logo.pos01 {
    bottom: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .logo.pos01 {
    bottom: -0.5rem;
  }
}
.logo.pos02 {
  right: 1rem;
}
@media screen and (min-width: 769px) {
  .logo.pos02 {
    bottom: -48rem;
  }
}
@media screen and (max-width: 768px) {
  .logo.pos02 {
    bottom: -49.5rem;
  }
}
@media screen and (min-width: 769px) {
  .logo.pos03 {
    bottom: -32rem;
    left: 28rem;
  }
}
@media screen and (max-width: 768px) {
  .logo.pos03 {
    bottom: -76rem;
    left: 21rem;
  }
}

.deco_bg {
  margin-inline: auto;
  background-repeat: no-repeat;
  position: relative;
}
@media screen and (max-width: 768px) {
  .deco_bg {
    width: 100%;
  }
}
.deco_bg.confetti::before, .deco_bg.confetti::after {
  content: "";
  z-index: 0;
  position: absolute;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti02 {
    padding: 7rem 0 8.5rem;
  }
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti02 {
    padding: 10.8rem 0;
  }
}
.deco_bg.confetti02::before {
  position: absolute;
  content: "";
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti02::before {
    top: 6.5rem;
    left: 50%;
    transform: translateX(-54%);
    width: 86.1rem;
    height: 163.4rem;
    background-image: url(../img/campaign01_nigiyakashi03_sp.png);
    background-size: 86.2rem auto;
    background-repeat: no-repeat;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti02::before {
    top: 6.5rem;
    left: 52%;
    transform: translateX(-54%);
    width: 176.55rem;
    height: 63rem;
    background-image: url(../img/campaign01_nigiyakashi03_pc.png);
    background-size: 176.55rem auto;
    background-repeat: no-repeat;
  }
}
.deco_bg.confetti02 .product_inner > h3 {
  padding-top: 0;
}
.deco_bg.confetti03 {
  position: relative;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti03 .chara.wid01 {
    width: 17.4rem;
    top: -12rem;
    left: 3rem;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti03 {
    width: 95rem;
    margin-inline: auto;
  }
}
.deco_bg.confetti04 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti04 {
    padding-bottom: 21.2rem;
  }
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti04 {
    padding-bottom: 11rem;
  }
}
.deco_bg.confetti04::before {
  position: absolute;
  content: "";
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti04::before {
    top: 15rem;
    left: 8%;
    width: 172.5rem;
    height: 38.44rem;
    background-image: url(../img/campaign01_nigiyakashi05_pc.png);
    background-size: 172.5rem auto;
  }
}
.deco_bg.confetti05 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti05 {
    padding-bottom: 4.5rem;
  }
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti05 {
    padding-top: 9.4rem;
    padding-bottom: 4rem;
  }
}
.deco_bg.confetti05::before {
  position: absolute;
  content: "";
  z-index: 1;
  width: 80.7rem;
  height: 100%;
  top: 4rem;
  left: 50%;
  transform: translateX(-45%);
  background-image: url(../img/campaign02_nigiyakashi01_sp.png);
  background-size: 80.7rem auto;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti05::before {
    width: 164.59rem;
    height: 42.92rem;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background-image: url(../img/campaign02_nigiyakashi01_pc.png);
    background-size: 164.59rem auto;
  }
}
.deco_bg.confetti05 .anim06 {
  transform: translateY(-36rem);
  transition: transform 0.5s ease-out;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti05 .anim06 {
    transform: translateY(-24rem);
  }
}
.deco_bg.confetti05 .anim06.is-active {
  transform: translateY(0rem);
}
.deco_bg.confetti05 .campaign_lead {
  position: relative;
  z-index: 2;
  margin-top: 2rem;
}
.deco_bg.confetti05 .campaign_lead > hgroup {
  position: relative;
  margin-top: 5.6rem;
}
.deco_bg.confetti05 .campaign_lead > hgroup::before {
  content: "";
  z-index: -1;
  position: absolute;
  background-repeat: no-repeat;
  animation: kf-anim02_1 6s infinite ease-in-out;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti05 .campaign_lead > hgroup::before {
    top: -2rem;
    left: 3rem;
    width: 17.9rem;
    height: 100%;
    background-image: url(../img/campaign02_anim-nigiyakashi-cloud_sp.png);
    background-size: 17.9rem auto;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti05 .campaign_lead > hgroup::before {
    top: 0;
    left: 26%;
    width: 17.86rem;
    height: 9.75rem;
    background-image: url(../img/campaign02_anim-nigiyakashi-cloud_sp.png);
    background-size: 17.86rem auto;
  }
}
.deco_bg.confetti06 {
  position: relative;
  width: 100%;
}
.deco_bg.confetti06::before {
  content: "";
  position: absolute;
  z-index: 0;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti06::before {
    left: -19%;
    width: 103.42rem;
    height: 92.16rem;
    background: url(../img/campaign02_swiperbg_sp.png) center top no-repeat;
    background-size: 103.42rem auto;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti06::before {
    top: -4rem;
    left: 50%;
    transform: translateX(-50%);
    width: 113.98rem;
    height: 56.21rem;
    background-image: url(../img/campaign02_swiperbg_pc.png);
    background-size: 113.98rem auto;
  }
}
.deco_bg.confetti06::after {
  content: "";
  position: absolute;
  z-index: 1;
  background-repeat: no-repeat;
  animation: kf-anim08 6s infinite ease-in-out;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti06::after {
    top: 88rem;
    left: 6rem;
    width: 18.4rem;
    height: 19.4rem;
    background-image: url(../img/character05.png);
    background-size: 18.4rem 19.4rem;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti06::after {
    top: -7.5rem;
    left: 74%;
    width: 11.5rem;
    height: 12.11rem;
    background-image: url(../img/character05.png);
    background-size: 11.5rem auto;
  }
}
.deco_bg.confetti07::before {
  content: "";
  position: absolute;
  z-index: 1;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti07 .application.colum01 {
    margin: 12.4rem auto 0;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti07 .application.colum01 {
    margin: 8.4rem auto 0;
  }
}
.deco_bg.confetti07 .application.colum01::before {
  position: absolute;
  content: "";
  z-index: 1;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti07 .application.colum01::before {
    top: -2rem;
    left: 50%;
    transform: translateX(-47%);
    width: 79.1rem;
    height: 100%;
    background-image: url(../img/campaign02_nigiyakashi02_sp.png);
    background-size: 79.1rem auto;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti07 .application.colum01::before {
    top: -3.1rem;
    left: 22%;
    width: 172.96rem;
    height: 104.51rem;
    background-image: url(../img/campaign02_nigiyakashi02_pc.png);
    background-size: 172.96rem auto;
  }
}
.deco_bg.confetti07 .application.colum01::after {
  position: absolute;
  content: "";
  z-index: 1;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti07 .application.colum01::after {
    top: 60%;
    right: -10.5rem;
    width: 8.56rem;
    height: 10.44rem;
    background-image: url(../img/campaign02_anim_nigiyakashi_sp.png);
    background-size: 8.56rem auto;
    animation: kf-anim04 2s infinite;
    display: inline-block;
    transform: rotate(8deg);
  }
}
.deco_bg.confetti07 .application.colum01 div h3 + .txt03 {
  z-index: 2;
}
.deco_bg.confetti07 .application.colum01 div h3 + .txt03::before {
  width: 0;
  height: 0;
  background-image: none;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti08 {
    padding-bottom: 12.5rem;
  }
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti08 {
    padding-bottom: 16rem;
  }
}
.deco_bg.confetti08::before {
  position: absolute;
  content: "";
  z-index: 0;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti08::before {
    top: -1rem;
    right: -7rem;
    width: 195.2rem;
    height: 50.88rem;
    background-image: url(../img/campaign02_nigiyakashi03_pc.png);
    background-size: 195.2rem auto;
  }
}
.deco_bg.confetti09 {
  position: relative;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti09::before {
    content: "";
    position: absolute;
    top: 50rem;
    right: -1.5rem;
    z-index: 1;
    width: 22.12rem;
    height: 21.3rem;
    background-image: url(../img/campaign03_subtitle_sp.png);
    background-size: 22.12rem auto;
    background-repeat: no-repeat;
  }
}
.deco_bg.confetti09 .campaign_ttl {
  position: relative;
  width: 62.1rem;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti09 .campaign_ttl {
    width: 37.93rem;
  }
}
.deco_bg.confetti09 .campaign_ttl::before {
  width: 0;
  height: 0;
  background: none;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti09 .campaign_ttl::before {
    content: "";
    position: absolute;
    top: 2.75rem;
    left: -40%;
    z-index: 1;
    width: 12.67rem;
    height: 14.62rem;
    background-image: url(../img/campaign03_subtitle_pc.png);
    background-size: 12.67rem auto;
    background-repeat: no-repeat;
  }
}
.deco_bg.confetti09 .campaign_ttl.anim06 {
  transform: translateY(-35rem);
  transition: transform 0.5s ease-out;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti09 .campaign_ttl.anim06 {
    transform: translateY(-26.5rem);
  }
}
.deco_bg.confetti09 .campaign_ttl.anim06.is-active {
  transform: translateY(0rem);
}
.deco_bg.confetti09 .campaign_lead {
  margin-top: 2.4rem;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti09 .campaign_lead {
    margin-top: 3.5rem;
  }
}
.deco_bg.confetti09 .campaign_lead > p {
  position: relative;
  width: 48.8rem;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti09 .campaign_lead > p {
    width: 85.2rem;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti09 .campaign_lead > p::before {
    content: "";
    position: absolute;
    top: 90%;
    right: -3.5%;
    z-index: 1;
    width: 11.59rem;
    height: 12.1rem;
    background: url(../img/character07.png);
    background-size: 11.59rem auto;
    background-repeat: no-repeat;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti09 .chara.wid07 {
    top: 37.33rem;
    left: 67.7%;
    width: 11.59rem;
  }
}
.deco_bg.confetti10 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti10 {
    margin-top: 4.5rem;
    width: 95rem;
  }
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti10 {
    margin-top: 4rem;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti10::before {
    content: "";
    position: absolute;
    z-index: 1;
    width: 24.56rem;
    height: 39.5rem;
    top: -1.5rem;
    left: -55rem;
    background-image: url(../img/campaign03_nigiyakashi02_pc.png);
    background-size: 24.56rem auto;
    background-repeat: no-repeat;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti10 .chara.wid07 {
    width: 8.5rem;
  }
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti10 .chara.wid07 {
    width: 18.5rem;
    height: 19.4rem;
    top: -14.5rem;
    left: -3.5rem;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti11 {
    padding-bottom: 31rem;
  }
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti11 {
    padding-bottom: 30rem;
  }
}
.deco_bg.confetti11::before {
  position: absolute;
  content: "";
  z-index: 4;
  pointer-events: none;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti11::before {
    z-index: 6;
    width: 147.47rem;
    height: 14.83rem;
    top: 13.8rem;
    left: 4.5%;
    background-image: url(../img/campaign03_nigiyakashi03_pc.png);
    background-size: 147.47rem auto;
    background-repeat: no-repeat;
  }
}
.deco_bg.confetti11::after {
  content: "";
  z-index: -1;
  position: absolute;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti11::after {
    top: 44rem;
    right: -12rem;
    width: 17.87rem;
    height: 9.76rem;
    background-image: url(../img/campaign03_anim_nigiyakashi-cloud_sp.png);
    background-size: 17.87rem auto;
    animation: kf-anim02_1 6s infinite ease-in-out;
  }
}
.deco_bg.confetti11 .cont_inner {
  position: relative;
  z-index: 5;
  max-width: 850px;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti11 .cont_inner {
    z-index: 5;
  }
}
.deco_bg.confetti11 .cont_inner::before {
  content: "";
  position: absolute;
  z-index: 5;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .deco_bg.confetti11 .cont_inner::before {
    width: 16.8rem;
    height: 19.4rem;
    top: 100%;
    translate: 0 100%;
    left: 65%;
    background-image: url(../img/character09.png);
    background-size: 16.8rem auto;
  }
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti11 .cont_inner::before {
    width: 10.5rem;
    height: 12.1rem;
    bottom: -120%;
    left: 80%;
    background-image: url(../img/character09.png);
    background-size: 10.5rem auto;
  }
}
.deco_bg.confetti11 .cont_inner .post {
  position: relative;
}
@media screen and (min-width: 769px) {
  .deco_bg.confetti11 .cont_inner .post::before {
    content: "";
    z-index: -1;
    position: absolute;
    top: 10.3rem;
    right: -36%;
    width: 17.87rem;
    height: 9.76rem;
    background-image: url(../img/campaign03_anim_nigiyakashi-cloud_sp.png);
    background-size: 17.87rem auto;
    background-repeat: no-repeat;
    animation: kf-anim02_1 6s infinite ease-in-out;
  }
}

.campaign_ttl {
  position: relative;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .campaign_ttl {
    width: 45.5rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign_ttl {
    width: 60.9rem;
  }
}
.campaign_ttl::before {
  content: "";
  z-index: 1;
  position: absolute;
  background-image: url(../img/campaign01_title_sub.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .campaign_ttl::before {
    top: 2.5rem;
    left: 51.4rem;
    width: 12rem;
    height: 7.8rem;
  }
}
@media screen and (min-width: 769px) {
  .campaign_ttl::before {
    top: 2.5rem;
    left: 97%;
    width: 30.6%;
    height: 100%;
  }
}

.campaign_lead {
  display: block;
}
@media screen and (min-width: 769px) {
  .campaign_lead {
    margin-top: 3.5rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign_lead {
    margin-top: 4.5rem;
  }
}
.campaign_lead > p {
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .campaign_lead > p {
    width: 78.1rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign_lead > p {
    width: 66.2rem;
  }
}
@media screen and (min-width: 769px) {
  .campaign_lead > hgroup {
    margin-top: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign_lead > hgroup {
    margin-top: 6rem;
  }
}
.campaign_lead > hgroup > h3 {
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .campaign_lead > hgroup .wid01 {
    width: 10.2rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign_lead > hgroup .wid01 {
    width: 17.1rem;
  }
}
.campaign_lead > hgroup .txt01 {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 768px) {
  .campaign_lead > hgroup .txt01 {
    margin-top: 2rem;
  }
}

.panels01 {
  display: flex;
  justify-content: center;
  flex-direction: column;
  row-gap: 10rem;
}
@media screen and (min-width: 769px) {
  .panels01 {
    flex-wrap: wrap;
    row-gap: 0;
  }
}
@media screen and (min-width: 769px) {
  .panels01 + .att {
    margin: -4rem auto 0 26.3%;
  }
}
@media screen and (max-width: 768px) {
  .panels01 + .att {
    margin-top: 3rem;
    padding-left: 3.5rem;
  }
}
.panels01 .panel {
  position: relative;
  width: 100%;
  margin-inline: auto;
  padding: 0 0 24.6rem 2rem;
  background-image: url(../img/campaign01_bg_cloud01_sp.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: 103.5rem auto;
}
@media screen and (min-width: 769px) {
  .panels01 .panel {
    left: -18rem;
    padding: 0 0 13rem;
    width: 146.15rem;
    height: 60.9rem;
    background-image: url(../img/campaign01_bg_cloud01_pc.png);
    background-position: 0 0;
    background-size: 146.15rem auto;
  }
}
.panels01 .panel_ttl {
  position: absolute;
  top: -6.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 64.7rem;
}
@media screen and (min-width: 769px) {
  .panels01 .panel_ttl {
    width: 40.4rem;
    top: 5rem;
    left: 40%;
  }
}
.panels01 .panel_txt {
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .panels01 .panel_txt.wid01 {
    width: 28.2rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01 .panel_txt.wid01 {
    width: 42rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01 .panel_txt.wid02 {
    width: 30.3rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01 .panel_txt.wid02 {
    width: 45.2rem;
  }
}
.panels01 .panel_note {
  display: grid;
  place-content: center;
  background-color: #662b1f;
  border-radius: 2rem;
}
@media screen and (min-width: 769px) {
  .panels01 .panel_note {
    margin: 1.4rem auto 0;
    width: 28.3rem;
    height: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01 .panel_note {
    margin: 2.5rem auto 0;
    width: 40.9rem;
    height: 4.2rem;
  }
}
.panels01 .panel_note.txt02 {
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 768px) {
  .panels01 .panel_note.txt02 {
    font-size: 2.4rem;
  }
}
.panels01 .panel_name {
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.06em;
  text-decoration: underline;
  text-decoration-thickness: 2.5px;
}
@media screen and (min-width: 769px) {
  .panels01 .panel_name {
    margin-top: 2.5rem;
    text-underline-offset: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01 .panel_name {
    margin-top: 2.5rem;
    text-underline-offset: 1rem;
  }
}
.panels01 .anim01 {
  position: relative;
  top: 15rem;
  left: 1rem;
  width: 17.4rem;
  height: 19.7rem;
}
@media screen and (min-width: 769px) {
  .panels01 .anim01 {
    top: 5rem;
    left: 80.4rem;
    width: 10.54rem;
    height: 12.16rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01 .anim01 .chara.wid01 {
    top: 0;
    width: 100%;
    height: 100%;
  }
}

.panels01-swiper {
  position: relative;
  overflow: visible;
  top: 10rem;
}
@media screen and (min-width: 769px) {
  .panels01-swiper {
    top: 8rem;
  }
}
.panels01-swiper .grd {
  display: grid;
  grid-template-columns: repeat(4, auto);
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd {
    width: 65%;
    margin-right: auto;
    margin-left: 36.5rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum01 {
    margin-left: 13rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum01 .panel_ht01 {
    height: 31rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum01 .panel_ht01.wid01 {
    width: 25.7rem;
    height: 33.6rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum01 .panel_ht01.wid01 {
    padding-top: 4.3rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum01 .panel_ht01.wid02 {
    width: 25.7rem;
    height: 33.6rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum01 .panel_ht01.wid02 {
    padding-top: 4.3rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum01 .panel_ht02 {
    height: 28.6rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum01 .panel_ht02.wid03 {
    width: 25.7rem;
    height: 33.6rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum01 .panel_ht02.wid03 {
    padding-top: 4.3rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum01 .panel_ht02.wid04 {
    width: 25.7rem;
    height: 33.6rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum01 .panel_ht02.wid04 {
    padding-top: 4.3rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum02 {
    margin-left: 1rem;
    row-gap: 4.2rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum02 .panel_ht01 {
    height: 26rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum02 .panel_ht01 {
    height: 59.4rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum02 .panel_ht01.wid01 {
    width: 19.8rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum02 .panel_ht01.wid01 {
    width: 38.3rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum02 .panel_ht01.wid02 {
    width: 19.7rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum02 .panel_ht01.wid02 {
    width: 38.3rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum02 .panel_ht02 {
    height: 25.6rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum02 .panel_ht02 {
    height: 59.4rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum02 .panel_ht02.wid03 {
    width: 19.6rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum02 .panel_ht02.wid03 {
    width: 38.3rem;
  }
}
@media screen and (min-width: 769px) {
  .panels01-swiper .grd.colum02 .panel_ht02.wid04 {
    width: 20.5rem;
  }
}
@media screen and (max-width: 768px) {
  .panels01-swiper .grd.colum02 .panel_ht02.wid04 {
    width: 38.3rem;
  }
}

.product {
  position: relative;
}

.product_inner {
  position: relative;
}
.product_inner > h3 {
  margin-inline: auto;
  height: auto;
}
@media screen and (min-width: 769px) {
  .product_inner > h3 {
    padding-top: 5.5rem;
    width: 12.5rem;
  }
}
@media screen and (max-width: 768px) {
  .product_inner > h3 {
    width: 17.1rem;
  }
}
.product_inner > picture {
  display: block;
  position: relative;
  z-index: 2;
  margin-inline: auto;
  height: auto;
}
@media screen and (min-width: 769px) {
  .product_inner > picture {
    padding-top: 3rem;
    width: 90rem;
  }
}
@media screen and (max-width: 768px) {
  .product_inner > picture {
    padding-top: 4.8rem;
    width: 56.6rem;
  }
}
.product_inner > picture + picture {
  margin-inline: auto;
  height: auto;
}
@media screen and (min-width: 769px) {
  .product_inner > picture + picture {
    padding-top: 4rem;
    width: 74.55rem;
  }
}
@media screen and (max-width: 768px) {
  .product_inner > picture + picture {
    padding-top: 4.7rem;
    width: 61.6rem;
  }
}

.application h3 {
  margin: 0 auto;
  height: auto;
}
@media screen and (min-width: 769px) {
  .application h3 {
    width: 11.4rem;
  }
}
@media screen and (max-width: 768px) {
  .application h3 {
    width: 17.1rem;
    position: relative;
    z-index: 1;
  }
}
@media screen and (min-width: 769px) {
  .application h3.h_oubo {
    width: 10.3rem;
  }
}
.application .desc {
  position: relative;
  margin-top: 2.3rem;
}
@media screen and (max-width: 768px) {
  .application .desc {
    margin-inline: auto;
    width: 60rem;
    position: relative;
  }
}
.application .desc .step {
  display: grid;
}
@media screen and (min-width: 769px) {
  .application .desc .step {
    padding: 2.5rem 0;
    grid-template-columns: repeat(3, auto);
    background-repeat: no-repeat;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step {
    grid-template-columns: repeat(3, 60rem);
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step .pos01 {
    margin-left: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step .pos01 {
    background-color: #ffffc8;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step .pos02 {
    margin-left: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step .pos02 {
    background-color: #fff08c;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step .pos03 {
    background-color: #ffdc78;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl {
    padding: 6rem 0 2.5rem;
    height: 60rem;
    border-radius: 2rem;
  }
}
.application .desc .step dl dt {
  margin-inline: auto;
  width: 100%;
  height: auto;
}
@media screen and (min-width: 769px) {
  .application .desc .step dl dt {
    width: 10rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl dt {
    width: 23rem;
  }
}
.application .desc .step dl .txt02 {
  text-align: center;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .application .desc .step dl .txt02 {
    margin-top: 1rem;
    line-height: 2.6rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl .txt02 {
    margin-top: 2.5rem;
    line-height: 4.6rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl .txt02.dwn {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl .txt02.dwn {
    font-size: 2.6rem;
  }
}
.application .desc .step dl figure .wid {
  margin-inline: auto;
  height: auto;
  display: block;
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid01 {
    margin-top: 2rem;
    width: 15.6rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid01 {
    margin-top: 3.5rem;
    width: 28.2rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid02 {
    margin-top: 1.5rem;
    width: 23.6rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid02 {
    margin-top: 3rem;
    width: 37.8rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid03 {
    margin-top: 1.5rem;
    width: 20.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid03 {
    margin-top: 1.5rem;
    width: 32.9rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid04 {
    margin-top: 1.5rem;
    width: 20.6rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid04 {
    margin-top: 3.5rem;
    width: 32.5rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid04.u-wid04 {
    width: 20.6rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid04.u-wid04 {
    width: 28.9rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid05 {
    margin-top: 2rem;
    width: 7rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid05 {
    margin-top: 9rem;
    width: 15.8rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid06 {
    margin-top: 0.5rem;
    width: 9.7rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid06 {
    margin-top: 3.5rem;
    width: 28.2rem;
  }
}
@media screen and (min-width: 769px) {
  .application .desc .step dl figure .wid.wid07 {
    margin-top: 1.5rem;
    width: 8.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application .desc .step dl figure .wid.wid07 {
    margin-top: 6rem;
    width: 25.7rem;
  }
}
.application.colum01 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .application.colum01 {
    width: 95rem;
  }
}
.application.colum01::before {
  position: absolute;
  content: "";
  z-index: 1;
  top: -5.4rem;
  left: 50%;
  transform: translateX(-47%);
  width: 74.7rem;
  height: 317.8rem;
  background-image: url(../img/campaign01_nigiyakashi04_sp.png);
  background-size: 74.7rem auto;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .application.colum01::before {
    top: 0;
    left: 50%;
    transform: translateX(-48%);
    width: 214.1rem;
    height: 112.9rem;
    background-image: url(../img/campaign01_nigiyakashi04_pc.png);
    background-size: 214.1rem auto;
    background-repeat: no-repeat;
  }
}
.application.colum01 > div > h3 + .txt03 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .application.colum01 > div > h3 + .txt03 {
    margin-top: 2.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > div > h3 + .txt03 {
    margin-top: 3rem;
  }
}
.application.colum01 > div > h3 + .txt03::before {
  content: "";
  z-index: -1;
  position: absolute;
  top: 21.6rem;
  left: 9rem;
  width: 26.9rem;
  height: 14.7rem;
  background-image: url(../img/campaign01_nigiyakashi-cloud02.png);
  background-size: 26.9rem auto;
  background-repeat: no-repeat;
  animation: kf-anim02_1 6s infinite ease-in-out;
}
@media screen and (min-width: 769px) {
  .application.colum01 > div > h3 + .txt03::before {
    top: -9rem;
    left: -5rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > div > .txt03 + .att {
    margin-top: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > div > .txt03 + .att {
    margin-top: 3rem;
  }
}
.application.colum01 > div > h3 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .application.colum01 > div > h3::before {
    left: 12.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > div > h3::before {
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > div > h3::after {
    right: 12.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > div > h3::after {
    display: none;
  }
}
.application.colum01 > .desc {
  border-radius: 2rem;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc {
    margin-top: 2.5rem;
    background-color: #fff;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc {
    margin-top: 4.5rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .step {
    background-image: url(../img/step_bg01.png);
    background-size: cover;
  }
}
.application.colum01 > .desc .box {
  display: grid;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .box {
    padding: 3.5rem 3.5rem 4rem;
    grid-template-columns: 22.6rem 1fr;
    gap: 2.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .box {
    margin-top: 4rem;
    padding: 6.5rem 3.5rem 7rem;
    grid-template-columns: 1fr;
    background-color: #fff;
    border-radius: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .box > dt {
    margin-inline: auto;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .box.wid01 {
    grid-template-columns: 22.6rem 1fr;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .box.wid01 > dt {
    width: 23.7rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .box.wid02 {
    grid-template-columns: 24rem 1fr;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .box.wid02 > dt {
    width: 21rem;
  }
}
.application.colum01 > .desc .box_desc {
  display: grid;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .box_desc {
    row-gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .box_desc {
    margin-top: 3rem;
    row-gap: 4rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .box_desc.ht01 {
    margin-top: 7rem;
    height: 32.5rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .box_desc.ht01 > .send > li {
    padding-left: 0;
    text-indent: 0;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .box_desc.ht01 > .good .conditions {
    display: block;
  }
}
.application.colum01 > .desc .send > li {
  padding-left: 1em;
  text-indent: -0.5em;
  font-weight: bold;
  font-feature-settings: "palt";
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .send > li {
    font-size: 1.8rem;
    line-height: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .send > li {
    font-size: 2.8rem;
    line-height: 4.6rem;
  }
}
.application.colum01 > .desc .send_sub {
  margin: 2rem auto 0;
  display: grid;
  column-gap: 2rem;
  place-content: center;
  background-color: #662b1f;
  color: #fff6d6;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .send_sub {
    width: 59rem;
    height: 5rem;
    grid-template-columns: repeat(4, auto);
    border-radius: 2.5rem;
    font-size: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .send_sub {
    width: 50rem;
    height: 16.3rem;
    grid-template-columns: repeat(2, auto);
    column-gap: 5rem;
    border-radius: 3.8rem;
    font-size: 3.2rem;
    line-height: 5.1rem;
  }
}
.application.colum01 > .desc .send_sub > li {
  font-weight: bold;
}
.application.colum01 > .desc .example {
  display: grid;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example {
    grid-template-columns: 7.4rem 1fr;
    grid-template-rows: auto 1fr;
    column-gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example {
    grid-template-columns: 9rem 1fr;
    grid-template-rows: auto 1fr;
    column-gap: 2rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.good h4 {
    grid-area: 1/1/3/2;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.good h4 {
    grid-area: 1/1/2/2;
  }
}
.application.colum01 > .desc .example.good .conditions {
  color: #b6002a;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.good .conditions {
    grid-area: 1/2/2/3;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.good .conditions {
    grid-area: 1/2/2/3;
  }
}
.application.colum01 > .desc .example.good .conditions li {
  font-size: 3rem;
  line-height: 1.4;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.good .conditions li {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.good .conditions_att {
    grid-area: 2/2/3/3;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.good .conditions_att {
    grid-area: 2/1/3/3;
  }
}
.application.colum01 > .desc .example.good .conditions_att li {
  font-size: 2.4rem;
  line-height: 1.6;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.good .conditions_att li {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.bad h4 {
    grid-area: 1/1/2/2;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.bad h4 {
    grid-area: 1/1/2/2;
  }
}
.application.colum01 > .desc .example.bad .conditions {
  color: #1677b5;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.bad .conditions {
    grid-area: 1/2/2/3;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.bad .conditions {
    display: flex;
    flex-wrap: wrap;
    column-gap: 2rem;
    grid-area: 1/2/2/3;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.bad .conditions > li {
    font-size: 3rem;
    line-height: 1.35;
    padding-left: 0.5em;
    text-indent: -0.5em;
  }
}
.application.colum01 > .desc .example.bad p {
  display: grid;
  place-content: center;
  background-color: #dae1ef;
  font-weight: bold;
  color: #1677b5;
  position: relative;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.bad p {
    margin-top: 0.5rem;
    width: 100%;
    height: 4.2rem;
    grid-area: 2/1/3/3;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.bad p {
    margin-top: 3rem;
    width: 100%;
    height: 18.6rem;
    grid-area: 2/1/3/3;
    text-align: center;
    font-size: 3rem;
  }
}
.application.colum01 > .desc .example.bad p::before {
  content: "";
  background-color: #dae1ef;
  position: absolute;
  clip-path: polygon(50% 0%, 0 50%, 100% 50%);
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .example.bad p::before {
    width: 2.5rem;
    height: 2.5rem;
    top: -0.7rem;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media screen and (max-width: 768px) {
  .application.colum01 > .desc .example.bad p::before {
    width: 4rem;
    height: 4rem;
    top: -2rem;
    left: 6rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .conditions {
    display: flex;
    flex-wrap: wrap;
    column-gap: 1.5rem;
    font-size: 1.8rem;
    line-height: 1.5;
  }
}
.application.colum01 > .desc .conditions > li {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .conditions > li {
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum01 > .desc .conditions_att {
    font-size: 1.6rem;
    line-height: 2.4rem;
  }
}
@media screen and (min-width: 769px) {
  .application.colum02 > .desc .step {
    background-image: url(../img/step_bg02.png);
    background-size: 100% 100%;
  }
}
@media screen and (min-width: 769px) {
  .application.colum02 > .desc .step .pos01 {
    margin-left: 1rem;
  }
}

.campaign01 {
  position: relative;
  z-index: 4;
}
.campaign01 .cont_bg {
  padding-top: 5rem;
  background: #a7dffa;
}
@media screen and (min-width: 769px) {
  .campaign01 .cont_bg {
    padding-top: 7rem;
  }
}
.campaign01 .cont_bg .deco_bg.confetti.block01::before {
  top: -1.5rem;
  left: 3.6rem;
  width: 66.8rem;
  height: 90.8rem;
  background-image: url(../img/campaign01_nigiyakashi01_sp.png);
  background-size: 66.8rem auto;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .campaign01 .cont_bg .deco_bg.confetti.block01::before {
    top: 0.75rem;
    left: 50%;
    transform: translateX(-50%);
    width: 171.95rem;
    height: 52.85rem;
    background-image: url(../img/campaign01_nigiyakashi01_pc.png);
    background-position: center top;
    background-size: 171.95rem auto;
    background-repeat: no-repeat;
  }
}
.campaign01 .cont_bg .deco_bg.confetti.block01 .cont_inner {
  position: relative;
}
.campaign01 .cont_bg .deco_bg.confetti.block01 .cont_inner::before {
  content: "";
  z-index: 0;
  position: absolute;
  background-repeat: no-repeat;
  animation: kf-anim02_1 6s infinite ease-in-out;
}
@media screen and (max-width: 768px) {
  .campaign01 .cont_bg .deco_bg.confetti.block01 .cont_inner::before {
    bottom: -5rem;
    right: -28rem;
    width: 32.6rem;
    height: 25.5rem;
    background-image: url(../img/campaign01_nigiyakashi-cloud01.png);
    background-size: 32.6rem auto;
  }
}
@media screen and (min-width: 769px) {
  .campaign01 .cont_bg .deco_bg.confetti.block01 .cont_inner::before {
    top: 32.2rem;
    right: -15rem;
    width: 32.6rem;
    height: 25.48rem;
    background-image: url(../img/campaign01_nigiyakashi-cloud01.png);
    background-size: 100% auto;
  }
}
.campaign01 .cont_bg .deco_bg.confetti.block02 {
  margin-top: 10.4rem;
}
.campaign01 .cont_bg .deco_bg.confetti.block02::before {
  top: -6rem;
  left: 50%;
  transform: translateX(-50%);
  width: 67.75rem;
  height: 212.15rem;
  background-image: url(../img/campaign01_nigiyakashi02_sp.png);
  background-size: 67.75rem auto;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  .campaign01 .cont_bg .deco_bg.confetti.block02::before {
    z-index: 1;
    top: 11rem;
    left: 45%;
    width: 182.4rem;
    height: 100%;
    background-image: url(../img/campaign01_nigiyakashi02_pc.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
  }
}
@media screen and (min-width: 769px) {
  .campaign01 .cont_bg .deco_bg.confetti.block02 {
    margin-top: 0;
  }
}
.campaign01 .campaign_lead {
  margin-top: 2.1rem;
}
.campaign01 .campaign_lead hgroup {
  margin-top: 4.2rem;
}
@media screen and (min-width: 769px) {
  .campaign01 .campaign_lead hgroup {
    margin-top: 2.1rem;
  }
}
.campaign01 .campaign_lead p {
  width: 70.3rem;
}
@media screen and (min-width: 769px) {
  .campaign01 .campaign_lead p {
    width: 83rem;
  }
}
.campaign01 .campaign_lead p.txt01 {
  width: auto;
}
.campaign01 .campaign_ttl {
  width: 60.9rem;
}
@media screen and (min-width: 769px) {
  .campaign01 .campaign_ttl {
    width: 39rem;
  }
}

@media screen and (max-width: 768px) {
  .panels02-swiper {
    padding-top: 14.6rem;
  }
}
@media screen and (min-width: 769px) {
  .panels02-swiper {
    padding-top: 6.6rem;
  }
}

.campaign02 {
  position: relative;
  z-index: 3;
}
.campaign02 .campaign_ttl {
  width: 62.5rem;
}
@media screen and (min-width: 769px) {
  .campaign02 .campaign_ttl {
    width: 43rem;
  }
}
.campaign02 .campaign_ttl::before {
  background-image: none;
}
@media screen and (max-width: 768px) {
  .campaign02 .cont_bg {
    background: linear-gradient(0deg, rgb(242, 163, 177) 0%, rgb(234, 168, 195) 7.48%, rgb(227, 173, 211) 17.06%, rgb(225, 175, 217) 24.38%, rgb(225, 176, 218) 24.65%, rgb(224, 186, 235) 31.28%, rgb(223, 193, 246) 39.5%, rgb(223, 197, 253) 51.08%, rgb(223, 198, 255) 83.22%, rgb(220, 199, 255) 88.85%, rgb(211, 203, 254) 92.75%, rgb(196, 210, 253) 96.13%, rgb(174, 220, 251) 99.19%, rgb(167, 223, 250) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#A7DFFA",endColorstr="#F2A3B1" , GradientType=0);
  }
}
@media screen and (min-width: 769px) {
  .campaign02 .cont_bg {
    padding-top: 6.2rem;
    background: linear-gradient(0deg, rgb(242, 163, 177) 0%, rgb(234, 168, 195) 7.48%, rgb(227, 173, 211) 17.06%, rgb(225, 175, 217) 24.38%, rgb(225, 176, 218) 24.65%, rgb(224, 186, 235) 31.28%, rgb(223, 193, 246) 39.5%, rgb(223, 197, 253) 51.08%, rgb(223, 198, 255) 83.22%, rgb(220, 199, 255) 88.85%, rgb(211, 203, 254) 92.75%, rgb(196, 210, 253) 96.13%, rgb(174, 220, 251) 99.19%, rgb(167, 223, 250) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#A7DFFA", endColorstr="#F2A3B1", GradientType=0);
  }
}
.campaign02 .campaign_subttl {
  position: absolute;
  top: -7rem;
  left: 6rem;
  width: 23.2rem;
  height: auto;
}
@media screen and (min-width: 769px) {
  .campaign02 .campaign_subttl {
    width: 14.4rem;
    top: -4rem;
    left: 35%;
  }
}
@media screen and (min-width: 769px) {
  .campaign02 .campaign_lead > p {
    width: 70.4rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign02 .campaign_lead > p {
    width: 66.6rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign02 .acc {
    margin: 6.2rem auto 0;
  }
}

.panels02 {
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .panels02 {
    width: 90.8rem;
    display: grid;
    grid-template-columns: repeat(2, auto);
    column-gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .panels02 {
    width: 65.7rem;
  }
}
.panels02 .panel {
  display: flex;
}
@media screen and (min-width: 769px) {
  .panels02 .panel {
    column-gap: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .panels02 .panel {
    column-gap: 3.5rem;
  }
}
.panels02 .panel > figure {
  height: auto;
}
@media screen and (min-width: 769px) {
  .panels02 .panel > figure {
    width: 20.5rem;
  }
}
@media screen and (max-width: 768px) {
  .panels02 .panel > figure {
    width: 30.7rem;
  }
}

.campaign03 {
  position: relative;
}
@media screen and (max-width: 768px) {
  .campaign03 .acc {
    margin: 7.8rem auto 0;
  }
}
.campaign03 .cont_bg {
  position: relative;
  background: #F2A3B1;
  background: linear-gradient(0deg, rgb(238, 202, 131) 0%, rgb(242, 163, 177) 100%);
}
@media screen and (min-width: 769px) {
  .campaign03 .cont_bg {
    padding-top: 8.5rem;
  }
}
.campaign03 .cont_bg::after {
  content: "";
  position: absolute;
  z-index: 3;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .campaign03 .cont_bg::after {
    bottom: -1px;
    left: 50%;
    transform: translateX(-50%);
    width: 75rem;
    height: 13.5rem;
    background-image: url(../img/contact_bg_sp.png);
    background-size: 75rem auto;
  }
}
@media screen and (min-width: 769px) {
  .campaign03 .cont_bg::after {
    bottom: -1px;
    left: 50%;
    transform: translateX(-50%);
    width: 200rem;
    height: 33.8rem;
    background-image: url(../img/contact_bg_pc.png);
    background-size: 200rem auto;
  }
}
.campaign03 .campaign_subttl {
  position: absolute;
  top: 2.6rem;
  left: 6rem;
  width: 23.2rem;
  height: auto;
}
@media screen and (min-width: 769px) {
  .campaign03 .campaign_subttl {
    width: 12.67rem;
    top: 2.7rem;
    left: 32.9%;
  }
}
@media screen and (min-width: 769px) {
  .campaign03 .campaign_lead > p {
    width: 78rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign03 .campaign_lead > p {
    width: 50.9rem;
  }
}
@media screen and (min-width: 769px) {
  .campaign03 .campaign_lead > hgroup + hgroup {
    margin-top: 3.5rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign03 .campaign_lead > hgroup + hgroup {
    margin-top: 4rem;
  }
}
@media screen and (min-width: 769px) {
  .campaign03 .campaign_lead > hgroup {
    margin-top: 2.7rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign03 .campaign_lead > hgroup {
    margin-top: 4rem;
  }
}
@media screen and (min-width: 769px) {
  .campaign03 .campaign_lead > hgroup .wid01 {
    width: 4.47rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign03 .campaign_lead > hgroup .wid01 {
    width: 7.3rem;
  }
}
@media screen and (min-width: 769px) {
  .campaign03 .campaign_lead > hgroup .wid02 {
    width: 17.7rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign03 .campaign_lead > hgroup .wid02 {
    width: 29rem;
  }
}
@media screen and (max-width: 768px) {
  .campaign03 .campaign_lead > hgroup .txt01 {
    margin-top: 1rem;
  }
}
@media screen and (min-width: 769px) {
  .campaign03 .application h3 {
    width: 10.25rem;
  }
}

.post > a {
  display: grid;
  place-content: center;
  text-decoration: underline;
  font-weight: bold;
  white-space: nowrap;
}
@media screen and (min-width: 769px) {
  .post > a {
    margin-top: 2.5rem;
    font-size: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .post > a {
    margin-top: 4rem;
    font-size: 3rem;
  }
}

.post_btn {
  margin-inline: auto;
  height: auto;
}
@media screen and (min-width: 769px) {
  .post_btn {
    margin-top: 3rem;
    width: 40.5rem;
  }
}
@media screen and (max-width: 768px) {
  .post_btn {
    margin-top: 4rem;
    width: 60.7rem;
  }
}

@keyframes scaleUp {
  0% {
    transform: scale(0.5);
    opacity: 0.5;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}
.block01 .nigiyakashi .pos01 {
  position: absolute;
}
@media screen and (min-width: 769px) {
  .block01 .nigiyakashi .pos01 {
    width: 5.67rem;
    top: 14.5rem;
    left: 22.07rem;
  }
}
@media screen and (max-width: 768px) {
  .block01 .nigiyakashi .pos01 {
    width: 5.8rem;
    top: 9rem;
    left: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .block01 .nigiyakashi .pos02 {
    width: 12rem;
    bottom: 90rem;
    right: 6rem;
  }
}

.block02 .swiper-button.colum01 {
  top: 45%;
  width: 66.3rem;
  margin-left: -1rem;
}

.block02Nigiyakashi__parts01 {
  position: absolute;
  bottom: 16%;
  left: 1%;
  width: 16rem;
  height: auto;
}
@media screen and (min-width: 769px) {
  .block02Nigiyakashi__parts01 {
    bottom: -7rem;
    left: 33%;
    width: 4.7%;
    height: 12.53rem;
  }
}
.block02Nigiyakashi__parts02 {
  position: absolute;
  bottom: 1%;
  right: 20%;
  width: 3.3rem;
  height: auto;
}
.block02Nigiyakashi__parts03 {
  position: absolute;
}
@media screen and (max-width: 768px) {
  .block02Nigiyakashi__parts03 {
    top: 54.4rem;
    left: 0;
    width: 13.2rem;
    height: 11.1rem;
  }
}
@media screen and (min-width: 769px) {
  .block02Nigiyakashi__parts03 {
    top: 40rem;
    left: 22%;
    width: 13.2rem;
    height: 11.1rem;
  }
}

.block02Nigiyakashi2__parts01 {
  position: absolute;
  bottom: 9%;
  left: 9%;
  width: 8.5rem;
  height: auto;
}

.block02Nigiyakashi3 {
  position: relative;
}
.block02Nigiyakashi3__parts01 {
  position: absolute;
  top: -22rem;
  left: 1rem;
  width: 5.1rem;
  height: 7.3rem;
}
@media screen and (min-width: 769px) {
  .block02Nigiyakashi3__parts01 {
    width: 3.87rem;
    height: 7.68rem;
  }
}
@media screen and (min-width: 769px) {
  .block02Nigiyakashi3__parts01-2 {
    position: absolute;
    top: -18rem;
    left: 14%;
    width: 3.87rem;
    height: 7.68rem;
  }
}
.block02Nigiyakashi3__parts02 {
  position: absolute;
  bottom: 18rem;
  right: -11rem;
  width: 9.62rem;
  height: 6.71rem;
}

.p-coursNameB__heading4 {
  position: relative;
  top: -6.5rem;
  width: 64.7rem;
  margin: auto;
}
@media screen and (min-width: 769px) {
  .p-coursNameB__heading4 {
    top: 7.4rem;
    width: 70.13rem;
    margin-left: 13.6rem;
  }
}
.p-coursNameB__txt {
  margin: -4rem auto 0;
  width: 42.5rem;
}

.panels01 .unit__02 {
  width: 100%;
  padding: 0 0 11rem 0;
  background-image: url(../img/campaign01_bg_cloud02_sp.png);
  background-position: -18rem top;
  background-repeat: no-repeat;
  background-size: 103.5rem auto;
}
@media screen and (min-width: 769px) {
  .panels01 .unit__02 {
    left: 21rem;
    padding: 0 0 13rem;
    margin-top: -1rem;
    width: 147.65rem;
    height: 59.1rem;
    background-image: url(../img/campaign01_bg_cloud02_pc.png);
    background-position: 0 0;
    background-size: 147.65rem auto;
  }
}
.panels01 .unit__02 .anim01 {
  top: -6rem;
  left: 86rem;
}
@media screen and (min-width: 769px) {
  .panels01 .unit__02 .chara.wid01 {
    top: 0;
  }
}
@media screen and (min-width: 769px) {
  .panels01 .unit__02 .chara.wid02 {
    width: 100%;
    height: auto;
  }
}

.panels03-swiper {
  position: relative;
  overflow: hidden;
  margin-top: -3rem;
}
@media screen and (min-width: 769px) {
  .panels03-swiper {
    margin-top: -5rem;
  }
}
.panels03-swiper .grd {
  display: grid;
  grid-template-columns: repeat(4, auto);
}
@media screen and (min-width: 769px) {
  .panels03-swiper .grd.colum02 {
    width: 90rem;
    margin-right: auto;
    margin-left: 13.6rem;
  }
}
@media screen and (max-width: 768px) {
  .panels03-swiper .grd.colum02 .panel_ht01 {
    margin: auto;
    width: 38.3rem;
    height: 59.4rem;
  }
}
@media screen and (min-width: 769px) {
  .panels03-swiper .grd.colum02 .panel_ht01 {
    width: 19.1rem;
    height: 29.7rem;
  }
}
.panels03-swiper .swiper-button.colum01.u_colum01 {
  top: 30%;
  margin-left: auto;
}

.cont_wrapper {
  position: relative;
}
.cont_wrapper::before {
  position: absolute;
  content: "";
  z-index: 1;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .cont_wrapper::before {
    width: 83rem;
    height: 174.25rem;
    top: 1.9rem;
    left: 50%;
    transform: translateX(-48%);
    background-image: url(../img/campaign03_nigiyakashi01_sp.png);
    background-size: 83rem auto;
  }
}
@media screen and (min-width: 769px) {
  .cont_wrapper::before {
    width: 182.15rem;
    height: 62.25rem;
    top: 4rem;
    left: 50%;
    z-index: 0;
    transform: translateX(-48%);
    background-image: url(../img/campaign03_nigiyakashi01_pc.png);
    background-size: 182.1rem auto;
  }
}

@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide {
    width: 19.1rem;
    height: 21.25rem;
  }
}
@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide:nth-child(1) {
    top: 0;
    left: 17rem;
  }
}
@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide:nth-child(2) {
    top: 0;
    left: 13rem;
  }
}
@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide:nth-child(3) {
    top: 0;
    left: 9rem;
  }
}
@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide:nth-child(4) {
    top: 24.5rem;
    left: -68rem;
  }
}
@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide:nth-child(5) {
    top: 2.5rem;
    left: 29rem;
  }
}
@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide:nth-child(6) {
    top: 2.5rem;
    left: 12rem;
  }
}
@media screen and (min-width: 769px) {
  .intro-swiper .swiper-slide:nth-child(7) {
    top: 2.5rem;
    left: -4.5rem;
  }
}

.p-notice {
  margin-top: 2.4rem;
  padding: 0 3rem;
}
@media screen and (min-width: 769px) {
  .p-notice {
    padding: 0;
  }
}
.p-noticeTxt {
  font-size: 3rem;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .p-noticeTxt {
    font-size: 1.6rem;
  }
}

@media (min-width: 769px) {
  .swiper-wrapper {
    display: flex;
    flex-wrap: wrap;
    transform: none !important;
  }
  .swiper-slide {
    width: auto !important;
    flex-shrink: 0;
  }
}
.intro_ttl img,
.intro_txt img,
.char figure img,
.panel_ht01 img,
.panel_ht02 img {
  display: block;
  width: 100%;
  height: auto;
}

.deco_bg,
.cont_inner {
  overflow: visible; /* hidden は要注意 */
  position: relative;
}

.swiper-slide {
  overflow: visible; /* デフォルトでは hidden にされることもある */
}

.char figure {
  margin-top: 0;
}

img, svg, video {
  display: block;
  vertical-align: bottom; /* inline-blockの場合に隙間を抑える */
}
