@charset "utf-8";

@import url(./global/_variable.css);
@import url(./layout/_reset.css);


/* common
  ---- memo ----
  font-feature-settings: 'palt';
  font-size: calc( 16 / var(--r_size) * 1rem );
  font-family: 'Dela Gothic One', sans-serif;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-family: 'Baloo Bhai 2', sans-serif;
============================================ */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 90px;
  @media (width < 896px) {
    scroll-padding-top: 60px;
  }
}

body {
  background: #fff;
  color: var(--font_c);
  font-family: var(--font_normal);
  font-weight: 400;
  min-height: 100vh;
  overflow-wrap: anywhere;
  line-break: strict;
}

body.is-fixed {
  height: 100%;
  overflow: hidden;
}

#wrapper {
  position: relative;
  overflow: hidden;
}

a {
  color: currentColor;
  transition: all .3s ease-out;
}

@media (hover: hover) {
  a:hover {
    opacity: .7;
  }
}

img {
  max-width: 100%;
  height: auto;
}

.pconly {
  @media (width < 896px) {
    display: none;
  }
}
.sponly {
  display: none;
  @media (width < 896px) {
    display: block;
  }
}
.portraitonly {
  display: none;
  @media (width < 480px) {
    display: block;
  }
}
.portraitnone {
  @media (width < 480px) {
    display: none;
  }
}
.tabonly {
  display: none;
  @media (width < 1025px) {
    display: block;
  }
}
.tabnone {
  @media (width < 1025px) {
    display: none;
  }
}

.newline {
  display: inline-block;
}

.width {
  max-width: 1280px;
  width: calc(100% - 30px);
  margin: 0 auto;
}

.outer {
  overflow: hidden;
}




/* header
============================================ */
#header {
  background: #fff;
  border-bottom: 4px solid #1f1f20;
  height: 90px;
  width: 100%;
  position: fixed;
  z-index: 9999;
  @media (width < 1091px) {
    height: 60px;
  }
}

.area__header {
  text-align: center;
  align-content: center;
  height: 100%;
  position: relative;
}

.header__logo {
  line-height: 0;
}

.header__logo-link {
  display: block;
}

.header__logo img {
  width: 550px;
  height: auto;
  @media (width < 1091px) {
    width: min(356px, 74vw);
  }
}

.header-menu{
  cursor: pointer;
  background: #eb5e17;
  border: 4px solid #222;
  box-shadow: 4px 4px 0 #222;
  border-radius: 50px;
  width: 15.3vw;
  min-width: 240px;
  height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: 20px;
  color: #fff;
  text-decoration: none;
  white-space: nowrap;
  position: absolute;
  right: 21px;
  top: 50%;
  transform: translateY(-50%);
  &:hover {
    background-color: #00ccf0;
    opacity: 1;
  }
  @media (width < 1091px) {
    width: 295px;
    position: fixed;
    top: auto;
    right: 50%;
    transform: translateX(50%);
    bottom: 16px;
  }
}
.header-menu__list{
  height: 100%;
  width: 100%;
  position: relative;
}
.header-menu__item{
  opacity: 0;
  visibility: hidden;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  line-height: 1.4;
  position: absolute;
  top: 0;
  left: 0;
}
.header-menu__txt{
  flex-grow: 1;
}
.header-nav {
  width: 320px;
  padding: 16px 20px;
  background-color: rgba(0,0,0,0.7);
  position: fixed;
  top: 80px;
  right: 0;
  translate: 100% 0;
  transition: translate .3s ease-out;
  z-index: 600;
  @media (width < 896px) {
    width: 100%;
    top: 50px;
  }
  &.open{
    translate: 0 0;
  }
}
.header-nav__item{
  border-top: 1px solid rgba(255,255,255,0.4);
  &:first-of-type{
    border-top: none;
  }
}
.nav_kugiri {
  border-top: 2px solid rgba(255,255,255,1);
}
.header-nav__link{
  padding: 10px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  font-weight: 700;
  &::after{
    content: "";
    display: inline-block;
    width: 28px;
    height: 28px;
    background: url("../images/circle_arrow_right_white.svg") center center/ contain no-repeat;
    @media (width < 896px) {
      width: 22px;
      height: 22px;
    }
  }
}

/* #title
============================================ */
#title {
  background: #1abfb9;
  padding-top: 90px;
  @media (width < 1091px) {
    padding-top: 60px;
  }
}

.area__title {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* KV */
.title__kv {
  position: relative;
  overflow: hidden;
  padding-top: clamp(27px, 1.44rem + 1.04vw, 43px);
  padding-bottom: clamp(30px, 3.1vw, 60px);
  text-align: center;
}

.title__card {
  position: relative;
  z-index: 1;
  width: clamp(335px, 6.22rem + 62.8vw, 1305px);
  margin: 0 auto;
  border-radius: 20px;
  overflow: hidden;
  background-color: #FFF;
}

.title__card-visual img {
  width: 100%;
  display: block;
}

.title__card-logo {
  background: #fff;
  border-radius: 0 0 20px 20px;
  padding: clamp(8px, 0.27rem + 0.97vw, 23px) clamp(10px, 0.18rem + 1.88vw, 39px) 24px;
  text-align: center;
}

.title__card-logo img {
  width: 100%;
  max-width: 1227px;
  display: block;
  margin: 0 auto;
}

.title__card-desc {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: clamp(14px, 0.72rem + 0.65vw, 24px);
  color: #1f1f20;
  margin-top: clamp(8px, 0.5rem + 0.52vw, 18px);
  line-height: 1.4;
}

/* Decorative bubbles */
.title__awa {
  position: absolute;
  pointer-events: none;
}

.title__awa--01 {
  width: clamp(98px, 11.56vw, 222px);
  left: 2.66vw;
  top: 9%;
}

.title__awa--02 {
  width: clamp(70px, 8.44vw, 162px);
  right: 3.65vw;
  bottom: 5%;
}

/* Copy */
.title__copy {
  position: relative;
  overflow: hidden;
  padding-top: clamp(40px, 5.7vw + 18.64px, 128px);
  padding-bottom: clamp(90px, 2.59vw + 80.29px, 130px);
}

.title__inner {
  position: relative;
  z-index: 1;
  max-width: 1207px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(24px, 3.13vw, 60px);
}

.title__heading {
  text-align: center;
}

.title__lead {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 0.88rem + 0.52vw, 24px);
  font-variation-settings: 'CTGR' 0, 'wdth' 100;
  color: #1f1f20;
  text-align: center;
  letter-spacing: 0.033em;
  line-height: 1.8;
  word-break: keep-all;
  -webkit-text-stroke: clamp(5px, 0.5vw, 10px) #FFF;
  paint-order: stroke fill;
}

.title__lead p + p {
  margin-top: 1em;
}

/* Characters */
@keyframes caraPowan {
  0%   { scale: 0;    rotate: -15deg; opacity: 0; }
  60%  { scale: 1.18; rotate:   5deg; opacity: 1; }
  80%  { scale: 0.92; rotate:  -2deg; }
  100% { scale: 1;    rotate:   0deg; opacity: 1; }
}

.title__cara {
  position: absolute;
  pointer-events: none;
  scale: 0;
  opacity: 0;
}

.title__cara.is-powan,
.summerparty__cara.is-powan,
.colorfulparty__chars.is-powan,
.shared__char.is-powan,
.goodsfoods__char.is-powan,
.schedule__char.is-powan,
.notice__char.is-powan,
.access__char.is-powan {
  animation: caraPowan 0.7s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.title__cara--01 {
  left: 0;
  top: 0;
  translate: -5% 0;
  width: 13vw;
  animation-delay: 0.1s;
}

.title__cara--02 {
  right: 0;
  top: 0;
  translate: 5% 0;
  width: 13vw;
  animation-delay: 0.25s;
}

.title__cara--03 {
  left: 0;
  top: 45%;
  width: 17vw;
  animation-delay: 0.4s;
}

.title__cara--04 {
  right: 10px;
  top: 50%;
  width: 20vw;
  animation-delay: 0.55s;
  @media (width < 1334px) {
    top: 60%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .title__cara.is-powan,
  .summerparty__cara.is-powan,
  .colorfulparty__chars.is-powan,
  .shared__char.is-powan,
  .goodsfoods__char.is-powan,
  .schedule__char.is-powan,
  .notice__char.is-powan,
  .access__char.is-powan {
    animation: none;
    scale: 1;
    opacity: 1;
  }
}

.title__awa--03 {
  width: clamp(50px, 6.2vw, 119px);
  left: 15.26vw;
  top: 8%;
}

.title__awa--04 {
  width: clamp(50px, 5.94vw, 114px);
  right: 18.6vw;
  top: 7%;
}

.title__awa--05 {
  width: clamp(45px, 6.04vw, 116px);
  left: 1.77vw;
  top: 52%;
  transform: scaleX(-1);
}

.title__awa--06 {
  width: clamp(40px, 5.1vw, 98px);
  right: 13.85vw;
  top: 54%;
}


/* #summerparty
============================================ */
#summerparty {
  background-color: #00ccf0;
  background-image: url(../images/bg_summerparty.png);
  background-repeat: repeat;
  background-size: 254.5px 138.5px;
  @media (width < 896px) {
    background-size: 122.16px 66.48px;
  }
}

.area_summerparty {
  position: relative;
  padding-block: 6vw;
  padding-inline: 11vw;
  @media (width < 896px) {
    padding-block: 100px;
    padding-inline: 20px;
  }
  @media (width < 480px) {
    padding-block: 260px 100px;
  }
}

.summerparty__char--kv {
  position: absolute;
  pointer-events: none;
  right: 0;
  top: 0px;
  width: 44vw;
  z-index: 0;
  @media (width < 480px) {
    width: 94vw;
  }
}

.summerparty__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 0.41rem + 4.66vw, 96px);
}

/* Intro */
.summerparty__intro {
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 1.14rem + 1.55vw, 48px);
  max-width: 904px;
  @media (width < 896px) {
    max-width: none;
  }
}

.summerparty__intro-top {
  display: flex;
  flex-direction: column;
  gap: 1.25vw;
}

.summerparty__ttl-wrap {
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.summerparty__ttl {
  margin: 0;
  line-height: 1.0em;
  width: 42vw;
  min-width: 335px;
}

.summerparty__date {
  margin: 0;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  color: #1f1f20;
  letter-spacing: 0.05em;
  line-height: 1.8;
  -webkit-text-stroke: clamp(5px, 0.5vw, 10px) #FFF;
  paint-order: stroke fill;
}

.summerparty__date--lg {
  font-size: clamp(24px, 1.14rem + 1.55vw, 48px);
}

.summerparty__date--sm {
  font-size: clamp(14px, 0.6rem + 1.17vw, 32px);
}

.summerparty__lead {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 0.88rem + 0.52vw, 24px);
  color: #1f1f20;
  letter-spacing: 0.033em;
  line-height: 1.8;
  word-break: keep-all;
  -webkit-text-stroke: clamp(5px, 0.5vw, 10px) #FFF;
  paint-order: stroke fill;
}

.summerparty__lead p + p {
  margin-top: 0.5em;
}

/* Cards */
.summerparty__cards {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 1.07rem + 0.78vw, 32px);
}

.summerparty__card {
  background: #fff;
  border: 8px solid #ff1d66;
  border-radius: 32px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  @media (width < 896px) {
    border-width: 6px;
  }
}

.summerparty__card-hd {
  background: #ff1d66;
  padding: 16px 20px;
  text-align: center;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: clamp(24px, 1.41rem + 0.39vw, 30px);
  color: #fff;
  line-height: 1.4;
  flex-shrink: 0;
}

/* Wide card */
.summerparty__card--wide .summerparty__card-bd {
  display: flex;
  justify-content: space-between;
  gap: clamp(24px, 2.5vw, 48px);
  padding: clamp(24px, -0.08rem + 6.73vw, 128px);
  @media (width < 896px) {
    flex-direction: column;
    padding: 24px;
  }
}

.summerparty__card--wide .summerparty__card-media {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 1.25vw, 24px);
  width: clamp(200px, 25.26vw, 485px);
  flex-shrink: 0;
  @media (width < 896px) {
    width: 100%;
    align-items: center;
  }
}

.summerparty__card--wide .summerparty__card-media img {
  width: 100%;
  height: auto;
  @media (width < 896px) {
    max-width: 240px;
  }
}

.summerparty__card-media-txt {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 0.94rem + 0.39vw, 22px);
  color: #222;
  line-height: 1.6;
  margin: 0;
}

.summerparty__card--wide .summerparty__card-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 1.66vw, 32px);
}

/* Info box */
.summerparty__infobox {
  background: #fff8e7;
  border: 4px solid #222;
  border-radius: 20px;
  box-shadow: 6px 6px 0 #222;
  padding: clamp(20px, 2.08vw, 40px) clamp(20px, 2.5vw, 48px);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 1.25vw, 24px);
}

/* Table (dl) */
.summerparty__table {
  background: #fff;
  border: 4px solid #222;
  box-shadow: 4.748px 4.748px 0 #222;
  margin: 0;
  width: 100%;
  overflow: hidden;
}

.summerparty__table-row {
  display: flex;
  @media (width < 896px) {
    flex-direction: column;
  }
}

.summerparty__table-row + .summerparty__table-row {
  border-top: 2px solid #222;
}

.summerparty__table-dt {
  background: #f9c300;
  border-right: 2px solid #222;
  width: 5.5vw;
  flex-shrink: 0;
  padding: 1vw;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: clamp(14px, 0.13vw + 13.51px, 16px);
  color: #222;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  @media (width < 896px) {
    width: 100%;
    min-width: auto;
    border-right: none;
    border-bottom: 2px solid #222;
    padding: 8px;
  }
}

.summerparty__table-dd {
  flex: 1;
  padding: 1vw;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 0.13vw + 13.51px, 16px);
  color: #222;
  text-align: center;
  display: flex;
  flex-direction: column;
  word-break: keep-all;
  line-height: 1.4em;
  gap: 4px;
  margin: 0;
  @media (width < 896px) {
    width: 100%;
    padding: 8px;
  }
}

.summerparty__notes {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.summerparty__notes-item {
  display: flex;
  gap: 4px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 14px;
  color: #222;
  line-height: 1.6;
}

.summerparty__notes-mark {
  flex-shrink: 0;
}

.summerparty__infobox-txt {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: clamp(14px, 0.72rem + 0.13vw, 16px);
  color: #222;
  line-height: 1.71;
  letter-spacing: 0.05em;
  margin: 0;
}

.summerparty__btn {
  background: #18b7ae;
  border: 4px solid #222;
  border-radius: 50px;
  box-shadow: 6px 6px 0 #222;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: clamp(16px, 0.72rem + 0.65vw, 20px);
  color: #fff;
  text-decoration: none;
  text-align: center;
  line-height: 1.4;
  word-break: keep-all;
}

.summerparty__btn--narrow {
  width: 250px;
}

/* Sticker infobox */
.summerparty__sticker {
  display: flex;
  gap: 24px;
  @media (width < 896px) {
    flex-direction: column;
    align-items: center;
  }
}

.summerparty__sticker img {
  width: clamp(120px, 13.28vw, 255px);
  height: auto;
  flex-shrink: 0;
  @media (width < 896px) {
    width: clamp(140px, 63vw, 239px);
  }
}

.summerparty__sticker-body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.summerparty__sticker-ttl {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(18px, 0.94rem + 0.78vw, 24px);
  color: #222;
  text-align: center;
  padding-bottom: 8px;
  border-bottom: 2px dashed #000;
  margin: 0;
}

.summerparty__sticker-txt {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #222;
  line-height: 1.6;
  text-align: center;
  margin: 0;
}

/* 3-column card row */
.summerparty__card-row {
  display: flex;
  gap: clamp(20px, 1.07rem + 0.78vw, 32px);
  @media (width < 896px) {
    flex-direction: column;
  }
}

.summerparty__card-row .summerparty__card {
  flex: 1;
  min-width: 0;
}

@media (width < 896px) {
  .summerparty__card-row .summerparty__card {
    flex: none;
  }
}

.summerparty__card-inner {
  padding: clamp(16px, 2.08vw, 40px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(16px, 1.25vw, 24px);
}

.summerparty__card-img {
  width: 100%;
  aspect-ratio: 960 / 640;
  object-fit: cover;
}

.summerparty__card-txt {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #000;
  line-height: 1.6;
  width: 100%;
  margin: 0;
}

/* Bottom decoration characters */
.summerparty__cara {
  position: absolute;
  pointer-events: none;
  scale: 0;
  opacity: 0;
  z-index: 3;
}

.summerparty__cara--01 {
  left: 0px;
  bottom: 0px;
  width: 12vw;
  @media (width < 896px) {
    width: 95px;
  }
}

.summerparty__cara--02 {
  right: 0px;
  bottom: 0px;
  width: 12vw;
  animation-delay: 0.15s;
  @media (width < 896px) {
    width: 87px;
  }
}


/* #colorfulparty
============================================ */
#colorfulparty {
  background-color: #ffed75;
  background-image: url(../images/bg_colorful.png);
  background-repeat: repeat;
  background-size: 15px 20px;
  @media (width < 896px) {
    background-size: 7px 10px;
  }
}

.area__colorfulparty {
  position: relative;
  padding-block: clamp(64px, 6.67vw, 128px) clamp(96px, 10vw, 192px);
  padding-inline: clamp(20px, 10.42vw, 200px);
  @media (width < 896px) {
    padding-block: 100px;
    padding-inline: 20px;
  }
  @media (width < 480px) {
    padding-block: 260px 90px;
  }
}

.colorfulparty__char--kv {
  position: absolute;
  pointer-events: none;
  right: 0;
  top: 0px;
  width: 44vw;
  z-index: 0;
  @media (width < 480px) {
    width: 94vw;
  }
}

.colorfulparty__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 0.41rem + 4.66vw, 96px);
}

/* Intro */
.colorfulparty__intro {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 0.65vw + 17.57px, 30px);
  max-width: 904px;
  @media (width < 896px) {
    max-width: none;
  }
}

.colorfulparty__ttl {
  margin: 0;
  line-height: 1.0em;
  width: 46vw;
  min-width: 335px;
}

.event_period {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(18px, 0.65vw + 15.57px, 28px);
  color: #1f1f20;
  letter-spacing: 0.033em;
  line-height: 1.8;
  word-break: keep-all;
  -webkit-text-stroke: clamp(5px, 0.5vw, 10px) #FFF;
  paint-order: stroke fill;
}

.colorfulparty__lead {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 0.88rem + 0.52vw, 24px);
  color: #1f1f20;
  letter-spacing: 0.033em;
  line-height: 1.8;
  word-break: keep-all;
  -webkit-text-stroke: clamp(5px, 0.5vw, 10px) #FFF;
  paint-order: stroke fill;
}

.colorfulparty__lead p + p {
  margin-top: 0.5em;
}

/* Cards */
.colorfulparty__cards {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 1.07rem + 0.78vw, 32px);
}

.colorfulparty__card {
  background: #fff;
  border: 8px solid #ff1d66;
  border-radius: 32px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  @media (width < 896px) {
    border-width: 6px;
  }
}

.colorfulparty__card-hd {
  background: #ff1d66;
  padding: 16px 20px;
  text-align: center;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: clamp(22px, 0.52vw + 20.06px, 30px);
  color: #fff;
  line-height: 1.4;
  flex-shrink: 0;
  word-break: keep-all;
}

/* Wide card */
.colorfulparty__card--wide .colorfulparty__card-bd {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(32px, 3.33vw, 64px);
}

/* 3-column card row */
.colorfulparty__card-row {
  display: flex;
  gap: clamp(20px, 1.07rem + 0.78vw, 32px);
  @media (width < 896px) {
    flex-direction: column;
  }
}

.colorfulparty__card-row .colorfulparty__card {
  flex: 1;
  min-width: 0;
}

@media (width < 896px) {
  .colorfulparty__card-row .colorfulparty__card {
    flex: none;
  }
}

.colorfulparty__card-inner {
  padding: clamp(16px, 2.08vw, 40px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(16px, 1.25vw, 24px);
  flex: 1;
}

.colorfulparty__coming {
  display: block;
  max-width: clamp(200px, 20.83vw, 400px);
  width: 100%;
  height: auto;
}

/* Bottom characters */
.colorfulparty__chars {
  position: absolute;
  bottom: 0px;
  left: 50%;
  translate: -50% 0;
  pointer-events: none;
  width: clamp(300px, 37.14vw, 713px);
  scale: 0;
  opacity: 0;
  @media (width < 896px) {
    width: min(80vw, 350px);
    bottom: 0px;
  }
}


/* #shared
============================================ */
#shared {
  background-color: #ffd54f;
}

.area__shared {
  position: relative;
  padding-block: clamp(64px, 6.67vw, 128px) clamp(96px, 10vw, 192px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(24px, 2.5vw, 48px);
  overflow: hidden;
}

.shared__ttl-wrap {
  text-align: center;
  padding-bottom: 2vw;
  padding-inline: 20px;
}

.shared__ttl {
  margin: 0;
  line-height: 1.0em;
}

.shared__band {
  width: 100%;
  background: #007bff;
  border-top: 8px solid #222;
  border-bottom: 8px solid #222;
  padding-inline: clamp(20px, 10.42vw, 200px);
  position: relative;
  isolation: isolate;
  @media (width < 896px) {
    padding-inline: 20px;
  }
}

.shared__awa {
  position: absolute;
}

.shared__awa--03 {
  left: 6vw;
  bottom: 4vw;
  @media (width < 896px) {
    left: 5px;
    bottom: 5px;
  }
}

.shared__awa--06 {
  right: 6vw;
  top: 4vw;
  @media (width < 896px) {
    right: 5px;
    top: 5px;
  }
}

.shared__frame {
  background: #fff;
  border: 8px solid #222;
  border-radius: 20px;
  padding: clamp(32px, 3.65vw, 70px) clamp(24px, 4.69vw, 90px);
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 2.5vw, 48px);
  margin-block: -20px;
  position: relative;
  @media (width < 896px) {
    border-width: 6px;
    padding: 24px;
  }
}

.shared__lead {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 0.88rem + 0.52vw, 24px);
  color: #1f1f20;
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 1.8;
}

.shared__lead p + p {
  margin-top: 0.5em;
}

.shared__content {
  display: flex;
  gap: clamp(24px, 2.5vw, 48px);
  align-items: center;
  @media (width < 896px) {
    flex-direction: column;
  }
}

.shared__media {
  width: clamp(240px, 33.75vw, 648px);
  flex-shrink: 0;
  border: 10px solid #ffd54f;
  overflow: hidden;
  @media (width < 896px) {
    width: 100%;
    border-width: 6px;
  }
}

.shared__media img {
  width: 100%;
  height: auto;
  display: block;
}

.shared__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 1.25vw, 24px);
}

.shared__content-hd {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(22px, 1.14rem + 0.78vw, 32px);
  color: #222;
  padding-bottom: 16px;
  border-bottom: 6px solid #ff1d66;
}

.shared__content-txt {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #222;
  line-height: 1.6;
  margin: 0;
}

.shared__char {
  position: absolute;
  pointer-events: none;
  right: 10px;
  bottom: clamp(-150px, -7.8vw, -40px);
  width: clamp(120px, 16.15vw, 310px);
  scale: 0;
  opacity: 0;
  @media (width < 896px) {
    width: clamp(80px, 20vw, 120px);
  }
}


/* goodsfoods
============================================ */
#goodsfoods {
  background-color: #fdd2d3;
  background-image: url(../images/bg_goods.png);
  background-repeat: repeat;
}

.area__goodsfoods {
  position: relative;
  padding-block: clamp(64px, 6.67vw, 128px) clamp(96px, 10vw, 192px);
  padding-inline: clamp(20px, 10.42vw, 200px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(48px, 5vw, 96px);
  overflow: hidden;
  @media (width < 896px) {
    padding-block: 64px clamp(96px, 10vw, 192px);
    padding-inline: 20px;
    gap: clamp(32px, 4vw, 48px);
  }
}

.goodsfoods__intro {
  display: flex;
  align-items: center;
  gap: clamp(24px, 8.39vw, 161px);
  width: 100%;
  @media (width < 896px) {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
  }
}

.goodsfoods__ttl-wrap {
  flex-shrink: 0;
}

.goodsfoods__ttl {
  margin: 0;
}

.goodsfoods__ttl img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
}

.goodsfoods__lead {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 0.83rem + 0.63vw, 24px);
  color: #1f1f20;
  line-height: 1.8;
  letter-spacing: 0.8px;
  max-width: 744px;
  margin: 0;
  -webkit-text-stroke: clamp(5px, 0.5vw, 10px) #FFF;
  paint-order: stroke fill;
}

.goodsfoods__group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(24px, 2.5vw, 48px);
  width: 100%;
}

.goodsfoods__group-hd {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: clamp(32px, 0.52vw + 30.06px, 40px);
  color: #222;
  line-height: 1.3em;
  display: inline-block;
  padding-inline: 0.5em;
}

.goodsfoods__group-hd--goods {
  border-bottom: #00aaff solid 8px;
}

.goodsfoods__group-hd--food {
  border-bottom: #ff6a00 solid 8px;
}

.goodsfoods__cards {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: clamp(24px,1.6vw,32px);
  width: 100%;
  @media (width < 896px) {
    grid-template-columns: repeat(2,1fr);
  }
  @media (width < 480px) {
    grid-template-columns: repeat(1,1fr);
  }
}

.goodsfoods__card {
  background: #fff;
  border: 4px solid #222;
  border-radius: 15px;
  box-shadow: 6px 6px 0 #222;
  padding: 24px;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 5;
  gap: 12px;
  text-align: center;
}

.goodsfoods__card-media {
  border: 2px solid #222;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 3 / 2;
  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
}

.goodsfoods__card-name {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: clamp(18px, 0.26vw + 17.03px, 22px);
  color: #222;
  line-height: 1.3;
  width: 100%;
  word-break: keep-all;
  align-content: center;
}

.goodsfoods__card-place {
  background: #1f1f20;
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 14px;
  padding: 4px 24px;
  border-radius: 1000px;
}

.goodsfoods__card-price {
  color: #e60012;
  text-align: center;
  margin: 0;
  width: 100%;
}

.goodsfoods__card-price-num {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 900;
  font-size: 24px;
  line-height: 1;
}

.goodsfoods__card-price-unit {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 900;
  font-size: 16px;
  line-height: 1;
}

.goodsfoods__card-note {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 14px;
  color: #666;
  text-align: center;
  margin: 0;
  width: 100%;
  line-height: 1;
}

.goodsfoods__char {
  position: absolute;
  pointer-events: none;
  bottom: clamp(-80px, -4vw, -20px);
  scale: 0;
  opacity: 0;
}

.goodsfoods__char--l {
  left: clamp(0px, 3.13vw, 60px);
  width: clamp(100px, 10.21vw, 196px);
  @media (width < 896px) {
    width: clamp(60px, 12vw, 100px);
  }
}

.goodsfoods__char--r {
  right: clamp(0px, 3.13vw, 60px);
  width: clamp(95px, 9.53vw, 183px);
  animation-delay: 0.15s;
  @media (width < 896px) {
    width: clamp(60px, 12vw, 100px);
  }
}

/* ticket
============================================ */
#ticket {
  background-color: #e3f2fd;
  background-image: url(../images/bg_ticket.png);
  background-repeat: repeat;
  background-size: 15px 20px;
}

.area__ticket {
  padding-block: clamp(64px, 6.67vw, 128px);
  padding-inline: clamp(20px, 10.42vw, 200px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(48px, 5vw, 96px);
  @media (width < 896px) {
    padding-inline: 20px;
  }
}

.ticket__intro {
  display: flex;
  align-items: center;
  gap: clamp(24px, 8.39vw, 161px);
  width: 100%;
  @media (width < 896px) {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
  }
}

.ticket__ttl {
  margin: 0;
  flex-shrink: 0;
}

.ticket__ttl img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
}

.ticket__lead {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 0.83rem + 0.63vw, 24px);
  color: #1f1f20;
  line-height: 1.8;
  letter-spacing: 0.8px;
  max-width: 744px;
  margin: 0;
}

.ticket__panel {
  background: white;
  border-radius: 20px;
  width: 100%;
}

.ticket__panel--summer {
  border: 10px solid #ff1d66;
}

.ticket__panel--colorful {
  border: 10px solid #1abfb9;
}

.ticket__panel--annual {
  border: 10px solid #f9c300;
}

.ticket__panel-hd {
  margin: -10px -10px 0;
  border-radius: 20px 20px 0 0;
  padding: 16px;
  text-align: center;
}

.ticket__panel-hd-txt {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: clamp(20px, 1.67vw, 32px);
  color: white;
  line-height: 1.4;
  margin: 0;
  word-break: keep-all;
}

.ticket__panel-hd--summer {
  background: #ff1d66;
}

.ticket__panel-hd--colorful {
  background: #1abfb9;
}

.ticket__panel-hd--annual {
  background: #f9c300;
}

.ticket__panel-body {
  padding: clamp(32px, 3vw, 56px) clamp(24px, 5.73vw, 88px) clamp(40px, 4vw, 80px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(24px, 2.5vw, 48px);
  @media (width < 896px) {
    padding: 24px 20px 40px;
  }
}

.ticket__panel-body--coming {
  min-height: 200px;
  justify-content: center;
  @media (width < 896px) {
    min-height: 140px;
  }
}

.ticket__coming-soon {
  font-family: 'Baloo Bhai 2', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 3.13vw, 60px);
  background: linear-gradient(to bottom, #21ccf2 5.469%, #93ebff 99.219%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: 1.6388px;
  margin: 0;
  text-align: center;
}

.ticket__contents {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  width: 100%;
}

.ticket__contents-ttl {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(24px, 1.67vw, 32px);
  color: #222;
  padding-bottom: 8px;
  line-height: 1;
  margin: 0;
  padding-inline: 0.5em;
}

.ticket__contents-ttl--pink {
  border-bottom: 6px solid #ff1d66;
}

.ticket__contents-ttl--yellow {
  border-bottom: 6px solid #f9c300;
}

.ticket__contents-items {
  display: flex;
  gap: 32px;
  align-items: stretch;
  width: 100%;
  justify-content: center;
  @media (width < 896px) {
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }
}

.ticket__contents-item {
  flex: 1;
  background: #FFF;
  border: 4px solid #00aaff;
  border-radius: 10px;
  text-align: center;
  align-content: center;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: clamp(20px, 1.67vw, 32px);
  color: #00aaff;
  text-align: center;
  line-height: 1.2;
  padding: 16px 8px;
  @media (width < 896px) {
    width: 100%;
    flex: none;
    min-height: 80px;
    font-size: 22px;
  }
}

.ticket__contents-item-sub {
  font-size: clamp(16px, 1.25vw, 24px);
}

.ticket__contents-note {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: clamp(14px, 0.13vw + 13.51px, 16px);
  color: #222;
  line-height: 1.4;
  text-align: left;
  margin: 0;
  display: inline-block;
}

.txt_emphasis {
  color: #ff1d66;
}

.ticket__contents-note_item {
  text-indent: -1em;
  padding-inline: 1em 0;
  padding-block: 2px;
  display: inline-block;
}

.ticket__cards-wrap {
  display: flex;
  gap: 32px;
  align-items: stretch;
  width: 100%;
  @media (width < 896px) {
    flex-direction: column;
    gap: 24px;
  }
}

.ticket__card {
  flex: 1;
  background: #fff8e7;
  border: 4px solid #222;
  border-radius: 20px;
  box-shadow: 6px 6px 0 #222;
  padding: 2vw;
  display: flex;
  flex-direction: column;
  gap: 25px;
  text-align: center;
  @media (width < 896px) {
    padding: 16px;
  }
}

.ticket__card--full {
  flex: none;
  width: 100%;
  padding: 40px 80px;
  @media (width < 896px) {
    padding: 24px;
  }
}

.ticket__card-ttl {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(18px, 1.25vw, 24px);
  color: #222;
  letter-spacing: 0.8px;
  padding-bottom: 16px;
  border-bottom: 2px dashed #222;
  line-height: 1.4;
  word-break: keep-all;
}

.ticket__card-desc {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: clamp(14px, 0.26vw + 13.03px, 18px);
  color: #222;
  line-height: 1.4;
  margin: 0;
  display: inline-block;
  text-align: left;
}

.ticket__price-table {
  width: 100%;
  border-collapse: collapse;
  border: 4px solid #222;
  box-shadow: 4.748px 4.748px 0 #222;
}

.ticket__price-th {
  background: #00aaff;
  border: 2px solid #222;
  color: white;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: clamp(14px, 0.13vw + 13.51px, 16px);
  letter-spacing: 0.633px;
  text-align: center;
  padding: 1vw;
  @media (width < 896px) {
    padding: 10px;
  }
}

.ticket__price-th:first-child {
  width: 70%;
  @media (width < 896px) {
    width: 50%;
  }
}

.ticket__price-td {
  background: white;
  border: 2px solid #222;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: clamp(14px, 0.13vw + 13.51px, 16px);
  color: #222;
  letter-spacing: 0.633px;
  word-break: keep-all;
  text-align: center;
  padding: 1vw;
  @media (width < 896px) {
    padding: 10px;
  }
}

.ticket__info-table {
  width: 100%;
  border-collapse: collapse;
  border: 4px solid #222;
  box-shadow: 4.748px 4.748px 0 #222;
}

.ticket__info-th {
  background: #f9c300;
  border: 2px solid #222;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: clamp(14px, 0.13vw + 13.51px, 16px);
  color: #222;
  letter-spacing: 0.633px;
  text-align: center;
  white-space: nowrap;
  width: 1%;
  padding: 1vw;
  vertical-align: middle;
  @media (width < 896px) {
    padding: 10px;
  }
}

.ticket__info-td {
  background: white;
  border: 2px solid #222;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 0.13vw + 13.51px, 16px);
  color: #222;
  letter-spacing: 0.633px;
  text-align: center;
  padding: 1vw;
  line-height: 1.4em;
  @media (width < 896px) {
    padding: 10px;
  }
}

.ticket__btn {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: 20px;
  color: white;
  text-align: center;
  border: 4px solid #222;
  border-radius: 50px;
  box-shadow: 6px 6px 0 #222;
  max-width: 334px;
  width: 100%;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.4;
  text-decoration: none;
  align-self: center;
  @media (width < 480px) {
    width: 100%;
    height: 60px;
  }
}

.ticket__btn--active {
  background: #18b7ae;
}

.ticket__btn--disabled {
  background: #8e8e8e;
  cursor: default;
  pointer-events: none;
}

.ticket__btn-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-top: auto;
}

.ticket__btn-note {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: #222;
  letter-spacing: 0.8px;
  margin: 0;
  text-indent: -1em;
  padding-left: 1em;
}

.ticket__annual-body {
  display: flex;
  gap: 44px;
  align-items: flex-start;
  width: 100%;
  @media (width < 896px) {
    flex-direction: column;
    gap: 24px;
  }
}

.ticket__annual-body .ticket__price-table {
  flex: 1;
}

.ticket__annual-side {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
}

.ticket__annual-side img {
  width: 100%;
  max-width: 470px;
  height: auto;
  display: block;
}

.ticket__novelty {
  background: #fff8e7;
  border: 4px solid #222;
  border-radius: 20px;
  box-shadow: 6px 6px 0 #222;
  padding: 40px 48px;
  display: flex;
  gap: 24px;
  align-items: flex-start;
  width: min(649px, 100%);
  @media (width < 896px) {
    padding: 24px;
  }
  @media (width < 480px) {
    flex-direction: column;
    align-items: center;
  }
}

.ticket__novelty_body {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 12px;
  align-items: center;
  padding: clamp(16px,2.5vw,48px);
  @media (width < 480px) {
    grid-template-columns: repeat(1,1fr);
  }
}

.ticket__novelty-txt {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 600;
  font-size: clamp(18px, 1.25vw, 24px);
  color: #222;
  letter-spacing: 0.8px;
  line-height: 1.6em;
}

/* schedule
============================================ */

#schedule {
  background-color: #f9c300;
  background-image: url(../images/bg_schedule.png);
  background-repeat: repeat;
}

.area__schedule {
  position: relative;
  padding-block: clamp(64px, 6.67vw, 128px);
  padding-inline: clamp(20px, 10.42vw, 200px);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  overflow: hidden;
  @media (width < 896px) {
    flex-direction: column;
    gap: 24px;
    align-items: flex-start;
    padding-inline: 20px;
  }
}


.schedule__ttl-wrap {
  position: relative;
  z-index: 1;
}

.schedule__ttl img {
  width: clamp(180px, 25vw, 495px);
  height: auto;
  display: block;
}

.schedule__list {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
}

.schedule__list img {
  width: clamp(300px, 45.47vw, 873px);
  height: auto;
  display: block;
  @media (width < 896px) {
    width: 100%;
  }
}

.schedule__char {
  position: absolute;
  left: clamp(100px, 13.44vw, 200px);
  bottom: -160px;
  width: clamp(200px, 24vw, 470px);
  pointer-events: none;
  z-index: 1;
  scale: 0;
  opacity: 0;
  @media (width < 896px) {
    top: 24px;
    left: auto;
    bottom: auto;
    right: 0;
    width: clamp(100px, 35.2vw, 132px);
  }
}

/* notice
============================================ */

#notice {
  background-color: #ff1d66;
  background-image: url(../images/bg_notice.png);
  background-repeat: repeat;
}

.area__notice {
  position: relative;
  padding-block: clamp(64px, 6.67vw, 128px);
  padding-inline: clamp(20px, 26.04vw, 500px);
  overflow: hidden;
  @media (width < 896px) {
    padding-inline: 20px;
  }
}

.notice__card {
  background: #fff8e7;
  border: 4px solid #222;
  border-radius: 20px;
  box-shadow: 6px 6px 0 #222;
  padding: clamp(24px, 2.08vw, 40px) clamp(20px, 5vw, 96px);
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: relative;
  z-index: 1;
}

.notice__card-ttl {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: 24px;
  color: #222;
  text-align: center;
  padding-bottom: 12px;
  border-bottom: 2px dashed #222;
  line-height: 1.2;
  margin: 0;
}

.notice__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.notice__list-item {
  display: flex;
  align-items: flex-start;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 14px;
  color: #222;
  line-height: 1.4;
  letter-spacing: 0.633px;
}

.notice__list-mark {
  flex-shrink: 0;
}

.notice__char {
  position: absolute;
  pointer-events: none;
  z-index: 3;
  scale: 0;
  opacity: 0;
}

.notice__char--r {
  top: clamp(20px, 2.29vw, 44px);
  right: clamp(5px, 19.58vw, 376px);
  width: clamp(136px, 14.17vw, 272px);
  @media (width < 896px) {
    right: -5px;
  }
}

.notice__char--l {
  left: clamp(5px, 21.04vw, 404px);
  bottom: clamp(10px, 3.4vw, 67px);
  width: clamp(77px, 8.02vw, 154px);
  animation-delay: 0.15s;
  @media (width < 896px) {
    left: -5px;
  }
}

/* access
============================================ */

#access {
  background-color: #00a6ff;
  background-image: url(../images/bg_access.png);
  background-repeat: repeat;
}

.area__access {
  position: relative;
  padding-block: clamp(64px, 6.67vw, 128px);
  padding-inline: clamp(20px, 10.42vw, 200px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(24px, 2.5vw, 48px);
  overflow: hidden;
  isolation: isolate;
  @media (width < 896px) {
    padding-inline: 20px;
  }
}

.access__inner {
  background: white;
  border: 14px solid #f9c300;
  border-radius: 20px;
  padding: clamp(32px, 3.65vw, 70px) clamp(20px, 4.69vw, 90px);
  display: flex;
  flex-direction: column;
  gap: clamp(24px, 2.5vw, 48px);
  align-items: center;
  width: 100%;
  position: relative;
  z-index: 1;
}

.access__ttl img {
  width: clamp(200px, 40vw, 760px);
  height: auto;
  display: block;
  margin: 0 auto;
}

.access__content {
  display: flex;
  gap: clamp(24px, 2.5vw, 48px);
  align-items: flex-start;
  width: 100%;
  @media (width < 896px) {
    flex-direction: column;
  }
}

.access__map {
  width: clamp(300px, 39.79vw, 764px);
  height: clamp(220px, 22.45vw, 431px);
  flex-shrink: 0;
  @media (width < 896px) {
    width: 100%;
    height: 250px;
  }
}

.access__map iframe {
  display: block;
  width: 100%;
  height: 100%;
}

.access__table {
  flex: 1;
  border-collapse: collapse;
  border: 4px solid #222;
  box-shadow: 4.748px 4.748px 0 #222;
  align-self: stretch;
  @media (width < 480px) {
    display: block;
  }
}

.access__table tr {
  @media (width < 480px) {
    display: block;
  }
}

.access__table-th {
  background: #f9c300;
  border: 2px solid #222;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: #222;
  text-align: center;
  padding: 20px;
  white-space: nowrap;
  width: 130px;
  vertical-align: middle;
  align-content: center;
  @media (width < 480px) {
    display: block;
    width: 100%;
    height: 46px;
    padding: 0;
    box-sizing: border-box;
  }
}

.access__table-td {
  background: white;
  border: 2px solid #222;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #222;
  padding: 20px 24px;
  line-height: 1.4;
  vertical-align: middle;
  @media (width < 480px) {
    display: block;
    width: 100%;
    padding: 20px 16px;
    box-sizing: border-box;
  }
}

.access__table-td p {
  margin: 0;
}

.access__notes {
  list-style: none;
  padding: 0;
  margin: 10px 0 0;
  display: flex;
  flex-direction: column;
}

.access__notes-item {
  display: flex;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.4;
  letter-spacing: 0.633px;
}

.access__notes-mark {
  flex-shrink: 0;
}

.access__awa {
  position: absolute;
  pointer-events: none;
  @media (width < 896px) {
    display: none;
  }
}

.access__awa--01 {
  left: clamp(10px, 1.04vw, 20px);
  top: clamp(260px, 27.03vw, 519px);
  width: clamp(111px, 11.59vw, 223px);
}

.access__awa--02 {
  left: clamp(96px, 10.05vw, 193px);
  top: clamp(412px, 42.92vw, 824px);
  width: clamp(91px, 9.52vw, 183px);
  transform: scaleX(-1);
}

.access__awa--03 {
  right: 0;
  top: clamp(151px, 15.68vw, 301px);
  width: clamp(81px, 8.44vw, 162px);
}

.access__awa--04 {
  right: clamp(75px, 7.76vw, 149px);
  top: clamp(2px, 0.26vw, 5px);
  width: clamp(110px, 11.45vw, 220px);
}

.access__char {
  position: absolute;
  right: clamp(10px, 1.93vw, 37px);
  bottom: 0;
  width: clamp(130px, 13.39vw, 257px);
  pointer-events: none;
  z-index: 2;
  scale: 0;
  opacity: 0;
  @media (width < 896px) {
    display: none;
  }
}

/* program
============================================ */

#program {
  background-color: #1abfb9;
}

.area__program {
  padding-block: clamp(64px, 6.67vw, 128px) clamp(90px, 6.67vw, 128px);
  padding-inline: clamp(20px, 10.42vw, 200px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(24px, 2.5vw, 48px);
  @media (width < 896px) {
    padding-inline: 20px;
  }
}

.program__card {
  background: #fff8e7;
  border: 4px solid #222;
  border-radius: 20px;
  box-shadow: 6px 6px 0 #222;
  padding: clamp(24px, 2.08vw, 40px) clamp(20px, 5vw, 96px);
  width: 100%;
}

.program__main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(16px, 2.5vw, 48px);
  @media (width < 896px) {
    flex-direction: column;
    align-items: flex-start;
  }
}

.program__info {
  display: flex;
  align-items: center;
  gap: clamp(16px, 1.67vw, 32px);
  @media (width < 896px) {
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
  }
}

.program__img-logo {
  width: clamp(120px, 12.5vw, 240px);
  flex-shrink: 0;
  overflow: hidden;
  @media (width < 896px) {
    width: 100%;
  }
}

.program__img-logo img {
  width: 100%;
  height: auto;
  display: block;
}

.program__desc {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 800;
  font-size: clamp(16px, 1.25vw, 22px);
  color: #1f1f20;
  line-height: 1.8;
  letter-spacing: 0.8px;
  width: clamp(200px, 24.58vw, 472px);
  margin: 0;
  @media (width < 896px) {
    width: 100%;
  }
}

.program__img-cast {
  width: clamp(130px, 13.18vw, 253px);
  flex-shrink: 0;
  border-radius: 16px;
  overflow: hidden;
  @media (width < 896px) {
    width: 100%;
  }
}

.program__img-cast img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.program__broadcast {
  background: white;
  border: 1px solid #e0e0e0;
  border-radius: 24px;
  padding: 16px 24px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex-shrink: 0;
  @media (width < 896px) {
    width: 100%;
  }
}

.program__broadcast-channel {
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: 32px;
  color: #1abfb9;
  line-height: 1;
  margin: 0;
}

.program__broadcast-times {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.program__broadcast-slot {
  display: flex;
  flex-direction: column;
}

.program__broadcast-day {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #222;
  line-height: 1.8em;
  margin: 0;
}

.program__broadcast-time {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  color: #222;
  line-height: 1.8em;
  margin: 0;
}

.program__broadcast-time-label {
  font-size: 18px;
}

.program__broadcast-time-num {
  font-size: 36px;
}

.program__links {
  display: flex;
  gap: clamp(16px, 2.5vw, 48px);
  align-items: center;
  @media (width < 896px) {
    flex-direction: column;
    gap: 16px;
    width: 100%;
  }
}

.program__link-btn {
  background: #f9c300;
  border: 4px solid #222;
  border-radius: 50px;
  box-shadow: 6px 6px 0 #222;
  height: 70px;
  width: 334px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  font-weight: 900;
  font-size: 20px;
  color: #1f1f20;
  text-decoration: none;
  @media (width < 896px) {
    width: 100%;
    max-width: 334px;
  }
}

.program__copyright {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.4em;
  color: white;
  white-space: nowrap;
  margin: 0;
  @media (width < 896px) {
    white-space: normal;
  }
}

/* ============================================
  telop
============================================ */
.area__telop {
  background: #fff;
  border-top: 4px solid #1f1f20;
  border-bottom: 4px solid #1f1f20;
  height: 70px;
  box-sizing: border-box;
  overflow: hidden;
}
.area__telop .splide,
.area__telop .splide__track,
.area__telop .splide__list,
.area__telop .splide__slide {
  height: 100%;
}
.area__telop .splide__slide {
  display: flex;
  align-items: center;
  width: auto;
}
.area__telop .splide__slide img {
  height: 62px;
  width: auto;
  display: block;
}

/* ============================================
  bubble
============================================ */
@keyframes bubbleRise {
  0%   { transform: translateY(0);        opacity: 0;   }
  8%   { opacity: 0.75; }
  88%  { opacity: 0.5;  }
  100% { transform: translateY(-2500px);  opacity: 0;   }
}

@keyframes bubbleShake {
  0%   { transform: translateX(0);    }
  20%  { transform: translateX(7px);  }
  40%  { transform: translateX(-5px); }
  60%  { transform: translateX(9px);  }
  80%  { transform: translateX(-3px); }
  100% { transform: translateX(0);    }
}

.bubble-layer {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: -1;
}

.bubble {
  position: absolute;
  bottom: -10px;
  will-change: transform, opacity;
}

.bubble__inner {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: radial-gradient(
    circle at 38% 30%,
    rgba(255, 255, 255, 0.85) 0%,
    rgba(255, 255, 255, 0.05) 52%,
    transparent 68%
  );
  border: 1.5px solid rgba(255, 255, 255, 0.7);
  box-shadow:
    inset 2px 4px 8px rgba(255, 255, 255, 0.55),
    0 0 5px rgba(255, 255, 255, 0.12);
}

/* ============================================
  SNS icons
============================================ */
.global-menu__sns-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 16px;
}

.global-menu__sns-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  transition: background 0.2s ease-out;
}

.global-menu__sns-link img {
  width: 22px;
  height: 22px;
  display: block;
}

@media (hover: hover) {
  .global-menu__sns-link:hover {
    background: rgba(255, 255, 255, 0.35);
    opacity: 1;
  }
}

/* elements
============================================ */
