body {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  background-color: #fff;
  color: #000;
}

main {
  overflow: hidden;
}

a {
  transition: 0.3s;
}

img {
  width: 100%;
}

@media (min-width: 768px) {
  .pcnone {
    display: none !important;
  }
}
@media (max-width: 767.98px) {
  .spnone {
    display: none !important;
  }
}
.container {
  position: relative;
}

@media (min-width: 768px) {
  .container {
    width: 1100px;
    margin: 0 auto;
    padding: 0;
    font-size: clamp(9px, 1.2727272727vw, 14px);
  }
  .anchor_link {
    padding-top: 50px;
    margin-top: -50px;
  }
  .anchor_link#event01 {
    padding-top: 300px;
    margin-top: -300px;
  }
  .anchor_link#event02 {
    padding-top: 100px;
    margin-top: -100px;
  }
}
@media (max-width: 767.98px) {
  .container {
    padding-left: 0;
    padding-right: 0;
  }
  .anchor_link {
    padding-top: 30px;
    margin-top: -30px;
  }
  .anchor_link#event01 {
    padding-top: 100px;
    margin-top: -100px;
  }
  .anchor_link#event02 {
    padding-top: 50px;
    margin-top: -50px;
  }
}
.wave {
  position: relative;
}
.wave::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: linear-gradient(0deg, rgba(15, 15, 15, 0.1) 0%, rgba(15, 15, 15, 0) 100%);
}
.wave span {
  width: 100%;
  height: 100%;
  display: block;
  background-attachment: fixed;
  mask-image: url(../images/wave.svg);
  mask-repeat: repeat;
  mask-position: 0 0;
  mask-size: auto 100%;
  -webkit-mask-image: url(../images/wave.svg);
  -webkit-mask-repeat: repeat;
  -webkit-mask-position: 0 0;
  -webkit-mask-size: auto 100%;
}

@media (min-width: 768px) {
  .wave {
    height: 20px;
    margin-top: -20px;
  }
}
@media (max-width: 767.98px) {
  .wave {
    height: 15px;
    margin-top: -15px;
  }
}
.main_kv + .wave {
  z-index: 1;
}
.main_kv + .wave span {
  background-image: repeating-linear-gradient(135deg, #ffffff, #ffffff 10px, #fff8d9 10px, #fff8d9 20px);
  background-attachment: fixed;
}

#event02 + .wave span {
  background-color: #e50012;
}

#event03 + .wave span {
  background-color: #0068b6;
}

#event04 + .wave span {
  background-color: #7fbe26;
}

.event04 + .wave span {
  background-image: repeating-linear-gradient(135deg, #ffffff, #ffffff 10px, #fff8d9 10px, #fff8d9 20px);
  background-attachment: fixed;
}

.pattern_asset {
  position: relative;
}
.pattern_asset::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../images/pattern_asset.webp);
  background-size: 250px;
  background-attachment: fixed;
}

.footer::before {
  background-image: url(../images/event04/pattern_asset.png);
}

.btn_box {
  position: relative;
  z-index: 2;
}

.caution_box {
  background-color: #ffe100;
  font-weight: bold;
}
.caution_box .caution_ttl {
  background-color: #e72410;
  color: #fff;
  text-align: center;
  border-radius: 200px;
}
.caution_box > p > span {
  color: #e72410;
}

@media (min-width: 768px) {
  .caution_box {
    padding: 3.5em 9em;
  }
  .caution_box .caution_ttl {
    font-size: 2.3em;
    padding: 0.3em;
    margin-bottom: 0.5em;
  }
  .caution_box > p {
    font-size: 1.4em;
    line-height: 1.6em;
  }
}
@media (max-width: 767.98px) {
  .caution_box {
    padding: 20px;
  }
  .caution_box .caution_ttl {
    font-size: 15px;
    padding: 5px;
    margin-bottom: 10px;
  }
  .caution_box > p {
    font-size: 11px;
    margin-bottom: 0;
  }
}
.main_lead {
  text-align: center;
  position: relative;
  background-color: #ffe100;
}
.main_lead h2 {
  font-weight: bold;
}
.main_lead .deco span {
  position: absolute;
}

@media (min-width: 768px) {
  .main_lead .container {
    width: 1440px;
  }
  .main_lead .main_lead_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 3em 0;
    gap: 2em;
  }
  .main_lead h1 {
    width: 15%;
  }
  .main_lead .here_we_go {
    width: 85%;
  }
  .main_lead .deco span:nth-child(1) {
    width: 165px;
    top: 0;
    right: calc(50% + 460px);
  }
  .main_lead .deco span:nth-child(2) {
    width: 234px;
    top: 0;
    left: calc(50% + 460px);
  }
}
@media (max-width: 767.98px) {
  .main_lead .container {
    padding: 25px 0;
  }
  .main_lead .main_lead_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 3%;
  }
  .main_lead h1 {
    width: 20%;
  }
  .main_lead .here_we_go {
    width: 70%;
  }
  .main_lead .deco span:nth-child(1) {
    width: 695px;
    top: 0;
    right: calc(50% + 270px);
  }
  .main_lead .deco span:nth-child(2) {
    width: 1008px;
    top: 0;
    left: calc(50% + 240px);
  }
}
.main_kv {
  position: relative;
  z-index: 1;
}
.main_kv > .kv_layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

@media (max-width: 767.98px) {
  .main_kv {
    padding-bottom: 20px;
    background-color: #ffe100;
  }
}
.campaign {
  background-image: repeating-linear-gradient(135deg, #ffffff, #ffffff 10px, #fff8d9 10px, #fff8d9 20px);
  background-attachment: fixed;
}

@media (min-width: 768px) {
  .campaign {
    padding: 5em 0 20em;
  }
  .campaign .campaign_ttl {
    width: 22%;
    margin: 0 auto 1.5em;
  }
  .campaign .btn_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 75%;
    margin: 0 auto;
    gap: 1em 0;
  }
  .campaign .btn_box > a {
    width: calc(50% - 0.5em);
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
}
@media (max-width: 767.98px) {
  .campaign {
    padding: 30px 0 120px;
  }
  .campaign .campaign_ttl {
    width: 30%;
    margin: 0 auto 10px;
  }
  .campaign .btn_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto;
    gap: 0.5em 0;
    padding: 0 1em;
  }
  .campaign .btn_box > a {
    width: calc(50% - 0.2em);
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
}
.event01_back {
  background-color: #ffe100;
  position: relative;
}

@media (min-width: 768px) {
  .event01 {
    margin-top: -15em;
  }
  .event01 .event01_back {
    padding-bottom: 10em;
  }
  .event01 .event_ttl_wrap {
    position: relative;
  }
  .event01 .event_ttl {
    background-color: #fff;
    position: relative;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
    background-color: #ffe100;
    padding-top: 5em;
    overflow: hidden;
    border-radius: 260px 260px 0 0;
  }
  .event01 .event_ttl > div {
    background-color: #fff;
  }
  .event01 .event_ttl .txt {
    width: 55%;
    margin: 0 auto;
    z-index: 1;
    padding: 1.5em 0 2em;
    position: relative;
  }
  .event01 .event_ttl_inner {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 1;
  }
  .event01 .event_ttl_inner .icon {
    position: absolute;
    width: 30%;
    left: -7%;
    bottom: 6em;
  }
  .event01 .event_ttl_inner .img {
    position: absolute;
    bottom: 0;
    width: 57%;
    right: -24%;
  }
  .event01 .event01_txt {
    width: 98%;
    margin: 0 auto;
    padding: 4.5em 0;
  }
  .event01 .box {
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
    position: relative;
  }
  .event01 .box > .img {
    padding: 3em;
    background-color: #fff;
    border-radius: 25px 25px 0 0;
    margin-bottom: 0;
  }
  .event01 .box > .img > figcaption {
    text-align: right;
    font-weight: bold;
    margin: 0.5em 0 0 0;
  }
  .event01 .box > .img > .icon {
    position: absolute;
    width: 29%;
    top: -3em;
    right: -4em;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event01 .box > .blue {
    background-color: #009bd9;
    border-radius: 0 0 25px 25px;
    padding: 4em 0;
    margin-bottom: 4em;
  }
  .event01 .box > .blue > img {
    display: block;
    margin: 0 auto 1em;
    width: 56%;
  }
  .event01 .box > .blue > a {
    display: block;
    margin: 0 auto;
    width: 50%;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
    cursor: pointer;
  }
  .event01 .box .box_deco span {
    position: absolute;
  }
  .event01 .box .box_deco span:nth-child(1) {
    width: 37%;
    top: -12%;
    right: -8%;
  }
  .event01 .box .box_deco span:nth-child(2) {
    width: 30%;
    top: 16%;
    left: -11%;
  }
  .event01 .deco span {
    position: absolute;
  }
  .event01 .deco span:nth-child(1) {
    width: 40%;
    top: -26%;
    left: -17%;
  }
  .event01 .deco span:nth-child(2) {
    width: 30%;
    bottom: -5%;
    right: -18%;
  }
}
@media (max-width: 767.98px) {
  .event01_back {
    padding-bottom: 100px;
  }
  .event01 {
    margin-top: -100px;
  }
  .event01 .event01_txt {
    width: 55%;
    padding: 25px 0;
    margin: 0 auto;
  }
  .event01 .box {
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
    margin: 0 1em;
    position: relative;
  }
  .event01 .box > .img {
    padding: 15px 15px 5px 15px;
    margin-bottom: 0;
    border-radius: 15px 15px 0 0;
    background-color: #fff;
  }
  .event01 .box > .img > figcaption {
    text-align: right;
    font-weight: bold;
    font-size: 0.6em;
    margin-top: 0.5em;
  }
  .event01 .box > .img > .icon {
    position: absolute;
    width: 32%;
    top: -25px;
    right: -1em;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event01 .box > .blue {
    background-color: #009bd9;
    border-radius: 0 0 15px 15px;
    padding: 20px 0 20px;
    margin-bottom: 25px;
  }
  .event01 .box > .blue > img {
    display: block;
    margin: 0 auto 0.5em;
    width: 75%;
  }
  .event01 .box > .blue > a {
    display: block;
    margin: 0 auto;
    width: 65%;
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
    cursor: pointer;
  }
  .event01 .box .box_deco span {
    position: absolute;
  }
  .event01 .box .box_deco span:nth-child(1) {
    width: 37%;
    top: -33px;
    right: -8%;
  }
  .event01 .box .box_deco span:nth-child(2) {
    width: 30%;
    top: 70px;
    left: -11%;
  }
  .event01 .deco span {
    position: absolute;
  }
  .event01 .deco span:nth-child(1) {
    width: 40%;
    top: -13%;
    left: -13%;
  }
  .event01 .deco span:nth-child(2) {
    width: 30%;
    bottom: -5%;
    right: 0;
  }
}
.event02 {
  background-color: #e50012;
}
.event02 .container {
  z-index: 1;
}

@media (min-width: 768px) {
  .event02 {
    padding: 6em 0 10em;
    position: relative;
  }
  .event02 .event_ttl {
    position: relative;
    background-color: #fff;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
  }
  .event02 .event_ttl .txt {
    width: 56.5%;
    margin: 0 auto;
    padding: 1.5em 0 2em;
    z-index: 1;
    position: relative;
  }
  .event02 .event_ttl .icon {
    position: absolute;
    width: 30%;
    left: -7%;
    top: -11em;
  }
  .event02 .event_ttl .img {
    position: absolute;
    width: 60%;
    bottom: -1px;
    right: -21%;
  }
  .event02 .event_ttl02 {
    width: 64%;
    margin: 2em auto 1em;
  }
  .event02 .box {
    background-color: #fff;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
    padding-bottom: 5em;
    border-radius: 0 0 25px 25px;
    margin-bottom: 7em;
    z-index: 1;
    position: relative;
  }
  .event02 .box .box_ttl {
    width: calc(100% + 3em);
    margin-left: -1.5em;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
  }
  .event02 .box .days {
    width: 90%;
    margin: 3em auto 1em;
  }
  .event02 .box .days figcaption {
    text-align: center;
    font-weight: bold;
    margin: 1em 0 0 0;
  }
  .event02 .box .content01 {
    width: 106%;
    margin-left: -7.5%;
    margin-bottom: -3.5em;
    z-index: 1;
    position: relative;
  }
  .event02 .box .content03 {
    width: 111.4%;
    margin: -8em 0 5em -12.8%;
    z-index: 1;
    position: relative;
  }
  .event02 .box .content02 {
    width: 103.5%;
    margin: 3em 0 -2em 1.7%;
    z-index: 1;
    position: relative;
  }
  .event02 .box .line {
    overflow: hidden;
  }
  .event02 .box .line > img {
    width: 101%;
  }
  .event02 .box2 {
    background-color: #fff;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
    border-radius: 25px;
    position: relative;
    padding: 3em 0 5em;
  }
  .event02 .box2 .box_ttl2 {
    position: absolute;
    width: 75%;
    left: 0;
    right: 0;
    margin: auto;
    top: -2%;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
  }
  .event02 .box2 .box2_txt {
    width: 75%;
    margin: 3.5em auto 1em;
  }
  .event02 .box2 .btn_box {
    display: flex;
    justify-content: space-between;
    width: 75%;
    margin: 0 auto;
  }
  .event02 .box2 .btn_box > a {
    width: calc(50% - 0.5em);
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event02 .box2 .box_deco span {
    position: absolute;
    width: 22%;
    top: 7%;
    right: -10%;
  }
  .event02 .deco span {
    position: absolute;
  }
  .event02 .deco span:nth-child(1) {
    width: 45%;
    top: -4.7%;
    left: -20%;
  }
  .event02 .deco span:nth-child(2) {
    width: 53%;
    bottom: -3.5%;
    right: -20%;
    z-index: -1;
  }
  .event02 .deco span:nth-child(3) {
    width: 37%;
    top: -1.5%;
    right: -14%;
    z-index: 1;
  }
}
@media (max-width: 767.98px) {
  .event02 {
    padding-bottom: 80px;
  }
  .event02 .event_ttl {
    position: relative;
  }
  .event02 .event_ttl > img {
    margin-top: -60px;
  }
  .event02 .event_ttl02 {
    width: 60%;
    margin: 15px auto;
  }
  .event02 .box {
    background-color: #fff;
    padding-bottom: 20px;
    margin: 0 1em 30px;
    border-radius: 0 0 15px 15px;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
    position: relative;
  }
  .event02 .box .box_ttl {
    width: calc(100% + 1em);
    margin: 0 -0.5em;
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
  .event02 .box .days > img {
    width: 80%;
    margin: 20px auto 0;
    display: block;
  }
  .event02 .box .days > figcaption {
    text-align: center;
    font-weight: bold;
    font-size: 0.6em;
    margin-top: 0.5em;
  }
  .event02 .box .content01 {
    padding: 0 3%;
  }
  .event02 .box .content02 {
    margin-left: 3%;
    padding-right: 2%;
  }
  .event02 .box .content03 {
    padding: 0 3%;
    margin-bottom: 30px;
  }
  .event02 .box2 {
    margin: 0 1em;
    background-color: #fff;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
    padding-bottom: 30px;
    border-radius: 0 0 15px 15px;
    position: relative;
  }
  .event02 .box2 .box_ttl2 {
    width: calc(100% + 1em);
    margin: 0 -0.5em;
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
  .event02 .box2 .box2_txt {
    width: 80%;
    margin: 30px auto 10px;
  }
  .event02 .box2 .btn_box {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 0 10px;
  }
  .event02 .box2 .btn_box > a {
    width: calc(50% - 0.2em);
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
  .event02 .deco span {
    position: absolute;
  }
  .event02 .deco span:nth-child(1) {
    width: 45%;
    top: -3.9%;
    left: -10%;
  }
  .event02 .deco span:nth-child(2) {
    width: 53%;
    bottom: -2%;
    right: -10%;
    z-index: -1;
  }
  .event02 .deco span:nth-child(3) {
    width: 37%;
    top: -0.5%;
    right: -7%;
    z-index: 1;
  }
}
.event03 {
  background-color: #0068b6;
}
.event03 .container {
  z-index: 1;
}

@media (min-width: 768px) {
  .event03 {
    padding: 6em 0 10em;
  }
  .event03 .event_ttl {
    position: relative;
    background-color: #fff;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
  }
  .event03 .event_ttl .txt {
    width: 65.2%;
    margin-left: 19.5%;
    padding: 1.5em 0 2em;
    z-index: 1;
    position: relative;
  }
  .event03 .event_ttl .icon {
    position: absolute;
    width: 30%;
    left: -7%;
    top: -12em;
  }
  .event03 .event_ttl .img {
    position: absolute;
    width: 52%;
    bottom: -1px;
    right: -25.5%;
  }
  .event03 .box {
    background-color: #fff;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
    border-radius: 0 0 25px 25px;
    margin: 5em 0 0 0;
    z-index: 0;
    position: relative;
  }
  .event03 .box .box_ttl {
    width: calc(100% + 3em);
    margin-left: -1.5em;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
  }
  .event03 .box .content01 {
    width: calc(100% + 3em);
    margin-left: -1.5em;
    margin-top: -6em;
  }
  .event03 .box .caution_box {
    margin: 2em 0 5em;
  }
  .event03 .box .caution_box .btn_list {
    display: block;
    width: 40%;
    margin: 0 auto;
  }
  .event03 .shopper_img {
    margin: -6.5em -4.5em 0;
  }
  .event03 .shopper_img > figcaption {
    text-align: right;
    font-weight: bold;
    margin: 0 4em;
    color: #fff;
  }
  .event03 .event03_content {
    width: calc(100% + 3em);
    margin-left: -1.5em;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
  }
  .event03 .deco span {
    position: absolute;
  }
  .event03 .deco span:nth-child(1) {
    width: 28%;
    top: -4.7%;
    left: -13%;
  }
  .event03 .deco span:nth-child(2) {
    width: 52%;
    bottom: -16.3%;
    right: -14%;
  }
}
@media (max-width: 767.98px) {
  .event03 {
    padding-bottom: 80px;
  }
  .event03 .event_ttl {
    position: relative;
  }
  .event03 .event_ttl > img {
    margin-top: -20px;
  }
  .event03 .shopper_img {
    margin-top: -25px;
  }
  .event03 .shopper_img > figcaption {
    text-align: right;
    font-weight: bold;
    font-size: 0.6em;
    margin: 0 1em;
    color: #fff;
  }
  .event03 .box {
    background-color: #fff;
    margin: 10px 1em;
    border-radius: 0 0 15px 15px;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event03 .box .box_ttl {
    width: calc(100% + 1em);
    margin: 0 -0.5em;
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
  .event03 .box .content01 {
    width: calc(100% + 1em);
    margin: -20px -0.5em 0;
  }
  .event03 .box .caution_box {
    margin: 20px 0;
  }
  .event03 .box .caution_box .btn_list {
    display: block;
    width: 55%;
    margin: 10px auto 0;
  }
  .event03 .event03_content {
    margin: 0 0.5em;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event03 .deco span {
    position: absolute;
  }
  .event03 .deco span:nth-child(1) {
    width: 20%;
    top: -4.7%;
    left: -1%;
  }
  .event03 .deco span:nth-child(2) {
    width: 52%;
    bottom: -13.2%;
    right: -8%;
  }
}
.event04 {
  background-color: #7fbe26;
}
.event04 .caution {
  font-weight: bold;
  text-align: right;
  color: #fff;
}
.event04 .container {
  z-index: 1;
}

@media (min-width: 768px) {
  .event04 {
    padding: 6em 0 1em;
  }
  .event04 .event_ttl {
    position: relative;
    background-color: #fff;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
    z-index: 1;
  }
  .event04 .event_ttl .txt {
    width: 100%;
    padding: 1.5em 0 2em;
    z-index: 1;
    position: relative;
    filter: drop-shadow(0px 0px 15px rgb(255, 252, 252));
  }
  .event04 .event_ttl .icon {
    position: absolute;
    width: 30%;
    left: -7%;
    top: -11em;
  }
  .event04 .event_ttl .img {
    position: absolute;
    width: 55%;
    bottom: -1px;
    right: -23%;
  }
  .event04 .event04_txt {
    width: 82%;
    margin: 3em auto 0;
  }
  .event04 .event04_img {
    width: 85%;
    margin: 3em auto -2em;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 1;
    position: relative;
  }
  .event04 .event04_img > figure {
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event04 .event04_img > figure:nth-child(1) {
    width: 50%;
    background-color: #fff;
    border-radius: 50%;
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3em;
    font-size: 1.5em;
    font-weight: bold;
  }
  .event04 .event04_img > figure:nth-child(2) {
    width: 43%;
  }
  .event04 .event04_img > figure:nth-child(2) figcaption {
    text-align: right;
    font-weight: bold;
    margin-top: 0.5em;
    color: #fff;
  }
  .event04 .event04_content {
    width: calc(100% + 3em);
    margin-left: -1.5em;
    filter: drop-shadow(0px 0px 15px rgba(0, 0, 0, 0.3));
    z-index: 1;
    position: relative;
  }
  .event04 .caution {
    margin-top: 10em;
  }
  .event04 .deco span {
    position: absolute;
  }
  .event04 .deco span:nth-child(1) {
    width: 39%;
    top: 6.3%;
    right: -20%;
    transform: rotate(215deg);
  }
  .event04 .deco span:nth-child(2) {
    width: 37%;
    top: 2%;
    left: -19%;
    transform: rotate(90deg);
  }
  .event04 .deco span:nth-child(3) {
    width: 39%;
    bottom: -3.3%;
    right: -14%;
    z-index: 1;
  }
}
@media (max-width: 767.98px) {
  .event04 {
    padding-bottom: 50px;
  }
  .event04 .event_ttl {
    position: relative;
    z-index: 1;
  }
  .event04 .event_ttl > img {
    margin-top: -30px;
  }
  .event04 .event04_txt {
    width: 72%;
    margin: 25px auto 10px;
  }
  .event04 .event04_img {
    margin: 25px 1em -10px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 1;
    position: relative;
  }
  .event04 .event04_img > figure {
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event04 .event04_img > figure:nth-child(1) {
    font-size: 0.8em;
    width: 50%;
    background-color: #fff;
    border-radius: 50%;
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 15px;
    font-weight: bold;
  }
  .event04 .event04_img > figure:nth-child(2) {
    width: 45%;
  }
  .event04 .event04_img > figure:nth-child(2) figcaption {
    text-align: right;
    font-weight: bold;
    font-size: 0.6em;
    margin-top: 0.5em;
    color: #fff;
  }
  .event04 .event04_content {
    margin: 0 0.5em 0;
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .event04 .caution {
    font-size: 0.6em;
    margin: 50px 1em 0 0;
  }
  .event04 .deco span {
    position: absolute;
  }
  .event04 .deco span:nth-child(1) {
    width: 30%;
    top: -7.3%;
    left: -8%;
  }
  .event04 .deco span:nth-child(2) {
    width: 37%;
    top: 35%;
    right: -14%;
  }
  .event04 .deco span:nth-child(3) {
    width: 39%;
    bottom: -3%;
    right: -14%;
  }
}
.footer {
  background-image: repeating-linear-gradient(135deg, #ffffff, #ffffff 10px, #fff8d9 10px, #fff8d9 20px);
  background-attachment: fixed;
}
.footer .container {
  z-index: 1;
}
.footer .hakata_city {
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .footer {
    padding: 9em 0 0 0;
  }
  .footer .btn_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 75%;
    margin: 0 auto 5em;
    gap: 1em 0;
    z-index: 1;
    position: relative;
  }
  .footer .btn_box > a {
    width: calc(50% - 0.5em);
    filter: drop-shadow(0px 0px 5px rgba(0, 0, 0, 0.3));
  }
  .footer .mario_bro {
    position: absolute;
    top: -24em;
    left: -18%;
    width: 61%;
  }
}
@media (max-width: 767.98px) {
  .footer {
    position: relative;
    padding: 80px 0 0 0;
  }
  .footer .btn_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto 30px;
    gap: 0.5em 0;
    padding: 0 1em;
  }
  .footer .btn_box > a {
    width: calc(50% - 0.2em);
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
  .footer .mario_bro {
    position: absolute;
    top: -10px;
    left: -10px;
    width: 260px;
    top: -150px;
    left: -60px;
    z-index: -1;
  }
}
@media (min-width: 768px) {
  .topics {
    padding: 5em 0;
  }
  .topics .topics_ttl {
    width: 15%;
    margin-bottom: 2em;
  }
  .topics .bnr_box {
    display: flex;
    flex-wrap: wrap;
    gap: 2em;
  }
  .topics .bnr_box > a {
    width: calc(50% - 1em);
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
}
@media (max-width: 767.98px) {
  .topics {
    padding: 50px 1em;
  }
  .topics .topics_ttl {
    width: 25%;
    margin-bottom: 20px;
  }
  .topics .bnr_box {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0 1em;
  }
  .topics .bnr_box > a {
    filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.3));
  }
}
.copyright {
  background-color: #000;
  color: #fff;
  text-align: center;
  padding: 2px;
}

@media (min-width: 768px) {
  .copyright {
    font-size: 10px;
  }
}
@media (max-width: 767.98px) {
  .copyright {
    font-size: 8px;
  }
}
.map_modal .modal-content {
  border: none;
  border-radius: 15px;
  overflow: hidden;
}
.map_modal .modal-body {
  background-color: #009bd9;
}
.map_modal .modal-body .map_inner {
  background-color: #fff;
}
.map_modal .modal-body .map_inner > img:nth-child(1) {
  border-bottom: 1px solid #E6E6E6;
  padding-bottom: 20px;
}
.map_modal .modal-body .map_inner > img:nth-child(2) {
  padding-top: 20px;
}
.map_modal .modal-body .close_btn {
  font-weight: bold;
  border: none;
  display: block;
  background-color: #ffe100;
  border-radius: 200px;
}

@media (min-width: 768px) {
  .map_modal .modal-dialog {
    width: 600px;
    max-width: none;
    border-radius: 25px;
  }
  .map_modal .modal-body {
    padding: 20px;
  }
  .map_modal .map_ttl {
    width: 80%;
    margin: 0 auto;
    padding: 20px 0;
  }
  .map_modal .map_inner {
    padding: 15px;
  }
  .map_modal .close_btn {
    font-size: 20px;
    padding: 5px 50px;
    margin: 20px auto 0;
  }
}
@media (max-width: 767.98px) {
  .map_modal .modal-dialog {
    border-radius: 25px;
  }
  .map_modal .modal-body {
    padding: 10px;
  }
  .map_modal .map_ttl {
    width: 90%;
    margin: 0 auto;
    padding: 20px 0;
  }
  .map_modal .map_inner {
    padding: 15px;
  }
  .map_modal .close_btn {
    font-size: 18px;
    padding: 5px 50px;
    margin: 10px auto 0;
  }
}
.inview-fade-up {
  transition: opacity 1s, transform 1s;
  opacity: 0;
  transform: translateY(20px);
}
.inview-fade-up.inview-once {
  opacity: 1;
  transform: translateY(0);
}/*# sourceMappingURL=style.css.map */