#kaden_fes {
  max-width: 900px;
  margin: 0 auto;
}
#kaden_fes a {
  text-decoration: none;
}
#kaden_fes img {
  width: 100%;
}
#kaden_fes .pc_none {
  display: none !important;
}

/*マトリクス部分*/
#kaden_fes .col_1 {
  margin:30px 0 0 0;
}
#kaden_fes .mtx_inner{
  margin: 0px auto;
}
#kaden_fes .mtx_inner table {
  border-collapse: collapse;
  text-align: center;
  table-layout: fixed;
}
#kaden_fes .mtx_inner th, td {
  padding: 5px;
  border: 4px solid #fff;
  color: #fff;
}
#kaden_fes tr:nth-child(2) td {
  padding: 0;
}
#kaden_fes tr .hangaku {
  background-color: #bf3636;
}
#kaden_fes tr .hangaku a:hover {
  color: #2e2e2e!important;
}
#kaden_fes .mtx_inner th {
  background-color: #060606;
  color: #fff;
  width: 16%;
  font-weight: 300;
}
#kaden_fes .mtx_inner tr th:first-child{
  width: 10%;
}
#kaden_fes tr td.potion1,#kaden_fes tr td.potion2,#kaden_fes tr td.potion3{
  position: relative;
}

#kaden_fes tr td.potion1::after {
  content: "終了しました";
  width: 100%;
  height: 381px;
  position: absolute;
  top: 0;
  left: 0;
  color: #fff;
  font-size: 22px;
  line-height: 410px;
  background-color: #0c1d2de3;
}
#kaden_fes tr td.potion2::after,
#kaden_fes tr td.potion3::after {
  content: "終了しました";
  width: 100%;
  height: 505px;
  position: absolute;
  top: 0;
  left: 0;
  color: #fff;
  font-size: 22px;
  line-height: 530px;
  background-color: #0c1d2de3;
}

#kaden_fes .mtx_inner a{
  transition:.3s;
  display: block;
}
table tr{
  background-color: #2e2e2e
}
#kaden_fes .mtx_inner .btn{
  margin-top:5px;
  display: flex;
  justify-content: flex-end;
  text-align: center;
}
#kaden_fes .mtx_inner .btn a {
  transition: 3s;
  display: block;
  background-color: #f6e786;
  border: 1px solid #fff;
  padding: 10px 0;
  border-radius: 5px;
  margin: 0 2px;
  width: 144px;
  position: relative;
}
#kaden_fes .mtx_inner .btn a:hover {
  top: 5px;
}
#kaden_fes .mtx_inner .btn a::after{
  content: '';
  border: 0;
  border-top: solid 1px #222;
  border-right: solid 1px #222;
  display: inline-block;
  width: 11px;
  height: 11px;
  position: absolute;
  top: 68%;
  right: 40%;
  transform: translateX(-50%) rotate(135deg);
}
#kaden_fes .mtx_inner .btn a::before{
  content: '';
  border: 0;
  border-top: solid 1px #222;
  border-right: solid 1px #222;
  display: inline-block;
  width: 9px;
  height: 9px;
  position: absolute;
  top: 83%;
  right: 41.5%;
  transform: translateX(-50%) rotate(135deg);
}

/*モーダルウィンドウ*/
.modal_p-btn {
  /* width: 100%; */
  text-align: center;
  border-radius: 5px;
  border: 1px solid;
  margin-bottom: 20px;
  padding: 2% 0;
  cursor: pointer;
  position: relative;
  transition: right 0.5s, background 0.5s, border 0.5s;
}

.modal_p-btn::after {
  font-family: "Material Icons";
  font-size: 20px;
  display: inline-block;
  line-height: 1;
  content: "open_in_new";
  position: absolute;
  bottom: calc(50% - 10px);
  right: 3%;
  transition: color 0.5s;
}

.modal_p-btn:hover {
  color: #fff;
  background: #b10e1b;
  border: 1px solid #b10e1b;
}

.modal_p-btn:hover::after {
  color: #fff;
}

/* モーダル全体(背景＋本体) */
.modal_p {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  z-index: 100;
  overscroll-behavior: contain;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  touch-action: none;
}

.modal_p::before,
.modal_p::after {
  position: absolute;
  content: "";
  width: 1px;
  height: calc(100vh + 1px);
  display: flex;
}

.modal_p::-webkit-scrollbar {
  display: none;
}

/* モーダル背景 */
.modal_p-bg {
  position: absolute;
  height: 100vh;
  width: 100%;
  background: rgba(0, 0, 0, 0.8);
  cursor: pointer;
  z-index: 101;
}

/* モーダル本体 */
.modal_p-content {
  position: absolute;
  top: 12%;
  left: 0;
  right: 0;
  bottom: 0;
  will-change: transform;
  display: flex;
  margin: auto;
  padding: 0;
  max-width: 900px;
  width: 100%;
  max-height: 67%;
  background-color: #fff;
  z-index: 102;
  border-radius: 20px;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}

.modal_p-content02 {
  position: relative;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 20px;
  padding-top: 70px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.modal_p-content::-webkit-scrollbar,
.modal_p-content02::-webkit-scrollbar {
  display: none;
}

.modal_p_title {
  align-items: center;
  background: #fe6600;
  /* border-bottom: 1px solid #ebebeb; */
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  display: flex;
  flex: 0 0 auto;
  height: 70px;
  justify-content: center;
  left: 0;
  margin: auto;
  position: fixed;
  right: 0;
  top: 0;
  width: 100%;
  z-index: 104;
  font-size: 25px;
  color: #fff;
}

.modal_p_title_2{
  width: 80%;
  margin: 0 auto;
  font-size: 25px;
  position: relative;
  border-left: solid #393939 5px;
  padding-left: 18px;
}
.modal_p_title_2::before{
  content: "";
  position: absolute;
  top: 0;
  left: -10px;
  border-left: solid #d1d1d1 5px;
}
.modal_p-content02 .explanation{
  font-size: 16px;
  padding: 15px 0;
  width: 80%;
  margin: 0 auto;
}
.modal_p-content02 .s_btn {
  width: 70%;
  margin: 0 auto;
  background-color: #222;
  border: solid 2px  #222;
  border-radius: 50px;
  text-align: center;
}
.modal_p-content02 .s_btn:hover {
  background-color: #fff;
  transition: 0.3s;
}
.modal_p-content02 .s_btn a {
  font-size: 20px;
  color: #fff;
  display: block;
}
.modal_p-content02 .s_btn:hover a {
  color: #222 !important;
  transition: 0.3s;
}

.modal_p-closebtn {
  -webkit-appearance: none;
  appearance: none;
  background: #0000;
  border: none;
  border-radius: 0;
  padding: 0;
  position: absolute;
  right: 0;
  top: 0;
  cursor: pointer;
  position: fixed;
  right: 2%;
  top: 2.5%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 202;
}

.modal_p-closebtn::after {
  font-family: "Material Icons";
  font-size: 40px;
  content: "cancel";
  position: absolute;
}

.modal_p-closebtn2_bg {
  width: 100%;
  background-color: #2e2e2e;
  padding: 2% 0;
  text-align: center;
}

.modal_p-closebtn2 {
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin: 0 auto;
  background-color: #fff;
  padding: 1% 5%;
  border: 1px solid #d1d1d1;
}

.modal_p-closebtn2::before {
  font-family: "Material Icons";
  content: "close";
  line-height: 1;
}

.lineup_box {
  width: 100%;
  margin: 0 auto;
  padding: 1% 3%;
  background-size:  cover;   
  /* background-color: #ffffff; */
  flex-grow: 1;
  box-sizing: border-box;
}

/*slide*/
/*======= ▼ ここからslide ▼ =======*/

.slide {
  padding: 1% 0 2% 0;
}

.slick-slide > dl {
  padding: 2% 2% 4% 2%;
  background-color: #fff;
  border-radius: 5px;
  position: relative;
}

.slick-prev{
  background-image: none;
  width: auto;
  height: auto;
  top: 50%;
  z-index: 20;
  left: -1% !important;
}
.slick-next {
  background-image: none;
  width: auto;
  height: auto;
  top: 50%;
  z-index: 20;
  right: -1% !important;
}

.slick-prev::after,
.slick-next::after {
  font-family: "Material Icons Outlined";
  content: "chevron_left";
  background-color: rgb(0, 0, 0, 0.2);
  border: 1px solid #fff;
  color: #fff;
  border-radius: 50%;
  height: 50px;
  width: 50px;
  font-size: 30px;
  font-weight: 200;
  margin: auto;
  z-index: 20;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
  -webkit-justify-content: center;
  justify-content: center;
  cursor: pointer;
}

.slick-next::after {
  transform: rotate(180deg);
}

.slick-dots li {
  display: inline-block;
  margin: 0 !important;
  width: unset !important;
}

.slick-track {
  display: flex !important;
}

.slick-slide {
  height: auto !important;
  display: flex;
  margin: 0 8px;
  position: relative;
  flex-direction: column;
}

.slick-prev:before,
.slick-next:before {
  display: none;
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

.slick-dots li button:before {
  content: "";
  border-radius: unset;
  width: 15px;
  height: 3px;
  margin: 0 6px;
  background-color: #222;
  opacity: 0.2;
}

.slick-dots li.slick-active button:before {
  opacity: 0.75;
  background-color: #222;
}

.slide-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 10px;
  background: #fff;
  border-radius: 10px;
  height: 100%;
}

.slide-name {
  display: flex;
  justify-content: center;
  flex-grow: 1;
  text-align: center;
}

.slide-btn {
  width: 80%;
  text-align: center;
  margin: 0 auto;
  padding: 2% 0;
  background-color: #383838;
  border: 2px solid #383838;
  color: #fff;
  border-radius: 5px;
  position: relative;
  transition: background 0.5s;
}

.slide-btn::after {
  font-family: "Material Icons";
  color: inherit;
  font-size: inherit;
  position: absolute;
  content: "chevron_right";
  right: 5%;
  top: 50%;
  margin: auto;
  transform: translate(-50%, -50%);
  transition: right 0.5s;
}

.slide-link:hover .slide-btn {
  background: transparent;
  color: #383838;
}

.slide-link:hover .slide-btn::after {
  right: 2%;
  color: #383838;
}

.slick-dots li {
  display: inline-block;
  margin: 0 !important;
  width: unset !important;
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

.slick-dots li button:before {
  content: "";
  border-radius: unset;
  width: 15px;
  height: 3px;
  margin: 0 6px;
  background-color: #222;
  opacity: 0.2;
}

/*カードデザイン*/
.item {
  padding: 2% 5%;
 /*  background-color: #fbe9e5 !important; */
}
.item h2{
  font-size: 33px;
  text-align: center;
  margin-bottom: 15px;
  border-bottom: solid #333 2px;
}

.item .col_2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.item .col_3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.item .item-list {
  background: #fff;
  border-radius: 10px;
  margin-bottom: 20px;
  position: relative;
  padding-bottom: 30px;
}

.item .item-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  text-align: center;
  padding: 10px 10px 15px 10px;
  height: 100%;
}

.item .item-img {
  display: block;
  width: 100%;
}

.item .item-name {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-grow: 1;
  font-weight: 600;
  font-size: 20px;
  line-height: 24px;
}

.item .size {
  content: "";
  position: absolute;
  top: 50%;
  left: 5px;
  background-color: #fe6600;
  color: #fff;
  border-radius: 50%;
}

.item .item-text {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-grow: 1;
  font-weight: 300;
}

.item .price {
  font-size: 24px !important;
  color: #e64f7a;
}

.item .price .spesicalprice{
  display: none !important;
}

.item .intax {
  font-size: 15px !important;
  color: #e64f7a !important;
}

.item .button {
  width: 200px;
  margin: 0 auto;
  background-color: #e64f7a;
  color: #fff;
  font-size: 16px;
  border: solid 2px #e64f7a;
  border-radius: 50px;
  position: relative;
  transition: all 0.3s;
}

.item .button::before {
  content: '';
  display: inline-block;
  border-style: solid;
  border-width: 8px 0 8px 10px;
  border-color: transparent transparent transparent #fff;
  display: inline-block;
  width: 0;
  height: 0;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
}

.item li:hover .button {
  background-color: #fff;
  color: #e64f7a;
}

.item li:hover .button::before {
  border-color: transparent transparent transparent #e64f7a;
}


@keyframes shine {
  100% {
    left: 100%;
  }
}

.item-button::after {
  font-family: "Material Icons";
  color: inherit;
  font-size: 20px;
  position: absolute;
  content: "expand_more";
  transform: rotate(270deg);
  right: 4%;
  bottom: -3%;
  top: 0;
  margin: auto;
}

/* ==================================================

   固定メニュー

================================================== */

#kaden_fes .cate_nav_fixed {
  position: fixed;
  right: 1vw;
  bottom: 3vw;
  z-index: 100;
}

#kaden_fes .btn_pagetop { display: none; }

#kaden_fes .navigation {
  position: relative;
  width: 200px;
}
#kaden_fes .navigation .toggle { display: none; }
#kaden_fes .navigation .nav_wrap,
#kaden_fes .navigation .nav_inner {
  position: relative;
  width: 100%;
}
#kaden_fes .navigation .nav_inner ul {
  position: relative;
  width: 100%;
 background-color: rgba(255,255,255,0.5);
}

#kaden_fes .navigation .nav_inner ul li {
  border-top: 1px solid #d1986dc7;
}

#kaden_fes .navigation .nav_inner ul li:last-child  {
  border-bottom: 1px solid #d1986dc7;
}


#kaden_fes .navigation .nav_inner ul li a {
  display: flex;
  align-items: center;
  width: 100%;
  justify-content: center;
  padding:0 ;
  letter-spacing: 1px;
  height: 70px;
  transition: all 0.3s;
}
/*
#kaden_fes .navigation .nav_inner ul li:last-child a{
  justify-content: center;
  
}*/

#kaden_fes .navigation .nav_inner ul li a:hover {
  background-color:#fcfaf9;

}

#kaden_fes .navigation .nav_inner ul li a:hover img {
  transform: translateY(-4px);

}

#kaden_fes .navigation .nav_inner ul li img {
  width: 40px;
  margin: 0 10px;
}
#kaden_fes .navigation .nav_inner ul li span {
  font-size: 14px;
  color:#d1986dc7;
  line-height: 1.3em;
}

/* 画像切り替え */
.title01,
.title02 {
  display:none;
}
.title01.mornig,
.title02.night {
  display: block;
}
.lineup_box.mornig {
  background-image: url(https://www.irisplaza.co.jp//IMAGE/kaden_fes/noon.jpg);  /* モーダル背景画像指定 */
  background-size:  cover;   
}
.lineup_box.night {
  background-image: url(https://www.irisplaza.co.jp//IMAGE/kaden_fes/night.jpg);  /* モーダル背景画像指定 */
  background-size:  cover;   
}