strong {
  font-weight: bold;
}
button{
  cursor: pointer;
}

footer {
  z-index: 1;
  position: relative;
}
#timeline{
  width: 100%;
  min-height: 100vh;
  position: relative;
  z-index: 0;
}

#timeline .videobox {
  width: 100%;
  aspect-ratio: 16 / 9;
  z-index: 2;
}
#timeline .videobox iframe {
  width: 100%;
  height: 100%;
}

#timeline h2,#timeline h3{
  margin: 0;
  padding: 0;
  text-align: left;
  background-color: transparent;
  color: #333333;
}
#timeline h2::after,#timeline h3::after{
  content: none
}
.flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  box-sizing: border-box;
}
#timeline .wrap{
  width: 100%;
  margin: 0 auto;
  padding: 0 4%;
  box-sizing: border-box;
  max-width: 1300px;
}

#timeline .t-title{
  padding: 20px 0;
}
#timeline .t-title .flex{
  align-items: flex-start;
}
#timeline .t-title .t-title_logo{
  width: 120px;
  height: 0;
  padding-top: 120px;
  box-sizing: border-box;
  position: relative;
  border: solid 1px #c4c4c4;
  border-radius: 10px;
}
#timeline .t-title .t-title_logo img{
  object-fit: contain;
  padding: 5px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}
#timeline .t-title .t-title_box{
  width: calc(100% - 125px);
  text-align: left;
  color: #4E4E4E;
  display: grid;
  flex-wrap: wrap;
  /* min-height: 200px; */
  grid-template-rows: 0.5fr 1fr 1fr 2fr;
}
#timeline .t-title .t-title_box > *{
  width: 100%;
  line-height: 1.2;
}
#timeline .t-title .shop-kana{
  font-size: 15px;
}
#timeline .t-title h2{
  font-size: 30px;
  font-weight: 700;
  margin: 5px 0 0;
}
#timeline .t-title .prfct{
  font-size: 17px;
  margin: 5px 0 0;
}
#timeline .t-title .t-title_desc{
  font-size: 15px;
  justify-self: flex-end;
  align-self: flex-end;
  line-height: 1.4;
}
#timeline h2.c-h2{
  padding: 0;
  margin: 40px 0 0 ;
  position: relative;
  color: #E50012;
  font-size: 18px;
  font-weight: 700;
  text-align: left;
}
#timeline h2.c-h2::after,#timeline h2.c-h2::before{
  content: none;
}
.rwklogo{
  color: transparent;
  display: inline-block;
  width: auto;
  background: url(https://ramen.walkerplus.com/themes/kitchen/img/kitchen_logo_color.png) no-repeat center;
  background-size: contain;
  /* margin: 0 -56px; */
  width: 186px;
  max-width: 100%;
}
.slick01{
  margin-top: 30px;
}
.slick01 li{
  height: auto;
}
.slick01 li .slidimgbox{
  width: calc(100% / 1);
    height: 0;
    position: relative;
    padding-top: calc(100% / 1);
}
.slick01 img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}
.slick01 .slick-list {
  padding: 0 10% 0 0 !important;
}
.slick01 .slick-slide {
  margin-right: 15px;
}
.slick01 .slick-list img {
width: 100%;
}

.t-owner{
  /* display: grid; */
  /* gap: 30px; */
  /* grid-template-rows: 1fr 1fr 0.1fr;
  grid-template-columns: 1fr 3fr; */
  padding: 30px;
  box-sizing: border-box;
  background-color: #f7f4e6;
}
.t-owner{
  align-items: flex-start;
}
.t-owner > div{
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr 3fr;
  gap: 10px;
}
.t-owner > div > *{
  margin-bottom: 20px;
  width: 100%;
}
.t-owner > p{
  width: 100%
}
.t-owner .t-owner-p h3{
  margin: 0;
  background:transparent;
  padding: 0;
  color: #444;
  font-size: 24px;
  line-height: 1.4;
}
.t-owner .t-owner-p h3 rt{
  font-size: 14px;
}
.t-owner .t-owner-p h3 span{
  font-size: 16px;
}
.t-owner .t-owner-p h4{
  font-weight: 700;
  font-size: 17px;
  margin-top: 30px;
  text-align: left;
  display: block;
}
.t-owner .official-link{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}
.t-owner .official-link a.snslinkli{
  display: inline-block;
  width: 100%;
  /* border-bottom: 2px dotted #000; */
  padding: 10px 0;
  text-decoration: none;
  border: none;
  /* border-top: dashed 1px #000; */
  border-bottom: dashed 1px #000;
  /* margin-top: 5px; */
  /* width: 30%; */
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  font-size: 14px;
  color: #0844ab;
}
.t-owner .official-link a.snslinkli .iconbox{
  display: block;
  max-width: 15px;
  display: inline-block;
}
.t-owner .official-link a.snslinkli .iconbox img{
  width: 100%;
  object-fit: contain;
}
.t-owner .official-link a.snslinkli span{
  font-size: 14px;
  color: #0844ab;
}
.t-owner .t-owner-tl{
  font-size: 1.7rem
}


.horizontal-list {
  list-style: none; /* リストのスタイルをなしに */
  padding: 0; /* パディングをリセット */
  display: flex; /* Flexboxを使用 */
  flex-wrap: wrap; /* 複数行にまたがる場合に折り返し */
  gap: 20px; /* アイテム間の隙間 */
}


.map {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 75%; /* 比率を4:3に固定 */
}
 
/* Google Mapのiframe */
.map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.t-access{
  display: grid;
  gap:30px;
  grid-template-columns: 1fr 1fr;
  margin-top: 0;
  border-top: 1px solid #dfdfdf;
    padding-top: 10px;
}

.t-access h3{
  font-size: 22px;
  line-height: 1.4;
}
.t-access h3 span{
  font-size: 80%;
}
.t-access p{
  font-size: 18px;
  line-height: 1.6;
  margin-top: 5px;
}
.t-access a{
  text-align: center;
  display: inline-block;
  width: 100%;
  max-width: 305px;
  color: #B00000;
  border: solid 1px #B00000;
  border-radius:5px;
  padding: 10px;
  box-sizing: border-box;
  margin-top: 20px;
  font-size: 16px;
}

#timeline .timeline-list{
  margin-top: 30px;
  background: #ffffff;
  border: solid 1px #ef6408;
  border-radius: 5px 5px 0 0;
}
#timeline .timeline-list h3{
  font-size: 24px;
  font-weight: 700;
  width: 100%;
  display: block;
  color: #fff;
  padding: 12px;
  text-align: center;
  background: #ef6408;
  border-radius: 5px 5px 0 0;
}

#timeline .t-li-box{
  margin-top: 30px;
}
#timeline .t-li-box .t-li-day{
  font-size: 20px;
  margin: 0 0 10px;
}
#timeline .t-li-box .t-li-day small{
  font-size: 85%;
}
#timeline .t-li-box .t-li-day::before{
  content: '○';
}
#timeline .t-li-box .t-li-inner{
  margin: 10px 20px;
  padding: 20px;
  box-sizing: border-box;
  background-color: rgba(229, 0, 18, .05);
  text-align: left;
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}
#timeline .t-li-box .t-li-inner > div{
  flex: 0 1 48%;
  max-width: 48%;
}
#timeline .t-li-box .t-li-inner > div:first-of-type{
  flex: 1 1 48%;
}

#timeline .t-li-box .t-li-inner > div a{
  height: 100%;
    display: block;
    text-align: right;
    z-index: 1;
}
#timeline .t-li-box .t-li-inner > div img{
  display: inline-block;
  height: auto;
  margin: 0 auto;
  max-height: 350px;
  object-fit: contain;
}
#timeline .t-li-box .t-li-inner > div.t-imgcont{
  display: flex;
  /* background: #fff; */
  /* padding: 5px; */
  box-sizing: border-box;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}


/* Twiiterを右にする修正 */
#timeline .t-li-box.txt-right .t-li-inner{
  display: flex;
  justify-content: space-between;
  max-width: none;
}
#timeline .t-li-box.txt-right .t-li-inner > div:first-of-type{
  display: contents;
}
#timeline .t-li-box.txt-right .t-li-inner > div.t-imgcont{
  display: none;
}
#timeline .t-li-box.txt-right .t-li-inner .t-li-box-main{
  width: 48%;
}
#timeline .t-li-box.txt-right .t-li-inner .t-li-box-txt{
  font-size: 16px;
  width: 48%;
}
@media screen and (max-width:750px){
  #timeline .t-li-box.txt-right .t-li-inner{
    display: block
  }
  #timeline .t-li-box.txt-right .t-li-inner .t-li-box-main,
  #timeline .t-li-box.txt-right .t-li-inner .t-li-box-txt{
    width: 100%;
  }
}




#timeline .more {
  display: none;
}

#timeline button {
  display: block;
}

#timeline .t-li-box .t-li-inner h4{
  font-size: 22px;
  color: #E50012;
  text-align: left;
}
#timeline .t-li-box .t-li-inner h5{
  font-size: 20px;
  color: #FF6600;
  text-align: left;
  margin-top: 10px;
}
#timeline .t-li-box .t-li-inner strong{
  font-size: 20px;
  color: #E50012;
  text-align: left;
  margin-top: 10px;
}
#timeline .t-li-box .t-li-inner p{
  margin-top: 10px;
  font-size: 16px;
}

#timeline .t-link-li{
  margin: 50px 0;
  padding-bottom: 80px;
}
#timeline .t-link-li ul{
  display: grid; 
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 30px; 
  align-items: start;
}
#timeline .t-link-li ul li{
  /* display: grid; 
  grid-template-columns: 1fr 1fr; */
  gap: 20px; 
  padding: 15px 0;
  border-top: 1px solid #cecece;
  /* border-bottom: 1px solid #4E4E4E; */
}
#timeline .t-link-li ul li p{
  font-size: 14px;
}
#timeline .t-link-li ul li a{
  font-size: 16px;
  color: #285EB5;
  margin-top: 5px;
  text-align: left;
  display: inline-block;
  display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    gap: 5px;
}
#timeline .t-link-li ul li .iconbox{
  width: 20px;
  display: inline-block;
  /* height: 0; */
  /* padding-top: 100%; */
  position: relative;
}
#timeline .t-link-li ul li .iconbox img{
  /* position: absolute;
  transform: translate(-50%,-50%);
  left: 50%;
  top: 50%; */
  object-fit: contain;
}

#timeline .awards{
  margin-top: 50px;
}

#timeline .awards h2{
  margin: 0 auto;
  display: block;
  text-align: center;
  padding: 20px;
  position: relative;
  color: #ef6408;
  max-width: fit-content;
  margin-bottom: 20px;
}

#timeline .awards h2::before,#timeline .awards h2::after{
  content: '';
  height: calc(100% + 10px);
  width: 5px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  background: none;
}
#timeline .awards h2::before{
  left: 0;
  border: solid 2px #ef6408;
  border-right: none;
}
#timeline .awards h2::after{
  right: 0;
  border: solid 2px #ef6408;
  border-left: none;
  left: auto;
}
#timeline .awards .awrad-li{
  display: block;
  margin-top: 10px;
  font-size: 17px;
  padding: 10px;
  border-bottom: 1px solid #fcdfcc;
  font-weight: 700;
  position: relative;
}
#timeline .awards .awrad-li::before{
  content: '・';
}
#timeline .awards .awrad-li .awardtitle{
  display: inline;
  font-size: 20px;
  font-weight: 700;
  
  box-sizing: border-box;
}
#timeline .awards .awrad-li .rank{
  font-size: 22px;
  font-weight: 700;
  color: #B00000;
}

#timeline button.btnds{
  background: none;
  border: solid 1px #000;
  padding: 10px;
  width: 100%;
  max-width: 200px;
  margin-top: 10px;
  box-sizing: border-box;
}


.blurbg {
  filter: blur(5px);
  display: block;
  width: 300%;
  height: 300%;
  object-fit: cover;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  z-index: 0;
  opacity: .7;
  background-position: center;

}

/*タブ*/

.shoptabarea{
  margin-top: 30px;
}

.tab_content {
  display: none;
}
.tab_item{
  cursor: pointer;
  padding: 20px;
  box-sizing: border-box;
  margin: 20px 0 0 0;
  font-size: 15px;
  border-radius: 20px 20px 0 0;
  background-color: #d5d5d5;
  /* width: calc(100%/4); */
}
input[name="tab_item"] {
  display: none;
}
label {
  cursor: pointer;
  position: relative;
  padding: 10px;
  display: inline-block;
  border-radius: 5px;
  border: solid 1px #fff;
  border-bottom: none;
  display: table-cell;
  font-size: 14px;
 }
 #tabshop1:checked ~ .tablabelshop1,
 #tabshop2:checked ~ .tablabelshop2,
 #tabshop3:checked ~ .tablabelshop3, 
 #tabshop4:checked ~ .tablabelshop4, 
 #tabshop5:checked ~ .tablabelshop5{
  background-color: #e44f4f;
  color: #fff;
  font-weight: bold;
 }

/*選択されているタブのコンテンツのみを表示*/
#tabshop1:checked ~ #shop1,
#tabshop2:checked ~ #shop2,
#tabshop3:checked ~ #shop3, 
#tabshop4:checked ~ #shop4, 
#tabshop5:checked ~ #shop5{
  display: block;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item {
  background-color: #5ab4bd;
  color: #fff;
}



@media screen and (max-width:750px) {
  #timeline .t-title {
    padding: 20px 0 ;
  }
  #timeline .t-title .flex{
    display: block;
  }
  #timeline .t-title .t-title_logo{
    width: 150px;
    padding-top: 150px;
    margin: 0 auto;
    display: block;
  }
  #timeline .t-title .t-title_box{
    width: 100%;
    display: block;
  }
  #timeline .t-title h2{
    font-size: 20px;
  }
  #timeline .t-title .shop-kana{
    font-size: 12px;
  }
  #timeline .t-title .prfct{
    font-size: 14px;
  }
  #timeline .t-title .t-title_desc{
    /* width: calc(100% + 120px); */
    /* margin-left: -120px; */
    display: block;
    /* margin-top: 45px; */
  }
  #timeline h2.c-h2 {
    line-height: 1.2;
  }
  .rwklogo{
    display: block;
  }

  .t-owner .official-link{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
  }
  .t-owner > div {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 13px;
    grid-template-rows: 0.3fr 0.5fr;

  }
  .t-owner .t-owner-p{
    grid-column: 1/3;
  }
  .t-owner > p {
      width: 100%;
  }
  .t-owner .t-owner-p h3{
    font-size: 18px;
  }
  .t-owner .t-owner-p h3 span {
    font-size: 13px;
  }
  .t-owner .t-owner-p h3 rt{
    font-size: 11px;
  }
  .t-access{
    grid-template-columns: 1fr;
  }
  .t-access > div:first-of-type{
    order: 2;
  }
  .t-access > div:nth-of-type(2){
    order: 1;
  }
  .t-access p {
    font-size: 14px;
  }
  #timeline .t-li-box{
    margin-top: 20px;
  }
  #timeline .t-li-box .t-li-inner{
    grid-template-columns: 1fr;
  }
  #timeline .t-li-box .t-li-inner p {
    font-size: 14px;
  }
  #timeline .t-link-li ul {
    grid-template-columns: 1fr 1fr;
    gap: 15px;
  }
  #timeline .t-link-li ul li {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 10px 0;
  }
  #timeline .t-link-li ul li p{
    font-size: 13px;
  }
  #timeline .t-link-li ul li a{
    font-size: 13px;
  }

  #timeline .t-li-box .t-li-inner{
    display: block;
  }
  #timeline .t-li-box .t-li-inner > div{
    flex: 0 1 100%;
    max-width: 100%;
    margin-bottom:10px;
  }
  #timeline .t-li-box .t-li-inner > div:first-of-type{
    flex: 1 1 100%;

  }
  #timeline .t-li-box .t-li-inner > div a{
    text-align: center;
  }
  #timeline .t-li-box .t-li-inner > div img{
    display: block;
  }
  .tab_item {
    display: inline-block;
    margin: 10px 0 5px;
    font-size: 15px;
    border-radius: 6px;
    background-color: #d5d5d5;
  }

}


/**
  メニュー
*/
.menu-list{
  width: 100%;
  margin-top: 20px;
  padding:20px;
  box-sizing: border-box;
  background-color: white;
}
.menu-list__head{
  display: flex;
  align-items: center;
  margin-bottom:20px;
  font-size: 16px !important;
  font-weight: bold;
}
.menu-list__head::before{
  content:"";
  width: 30px;
  height: 31px;
  margin-right: 5px;
  background-image: url(/themes/kitchen/img/logo_small.png);
  background-repeat: no-repeat;
  background-size: 100%;
}
.menu-list__body{
  position: relative;
  z-index: 999;
}
.menu-list-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateY(-40%);
  width: 40px;
  height: 40px;
  padding: 0;
  transition: all .3s;
  opacity: 1;
  background: none;
  border: none;
}
.menu-list-arrow._arrow-left {
  left: 0;
  transform: translateY(-50%) translateY(-40%) translateX(-100%);
  opacity: 0;
}
.menu-list-arrow._arrow-right {
  right: 0;
  transform: translateY(-50%) translateY(-40%) translateX(100%);
}
.menu-list-arrow svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.menu-list-arrow svg path{
  fill: #E50012;
}

.menu-list__list{
  position: relative;
  z-index: 4;
  width: auto;
  overflow-x: scroll;
  overflow-y: hidden;
  white-space: nowrap;
  padding-bottom: 2.4rem;
  font-size: 0;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
}
.menu-list__list::-webkit-scrollbar {
  height: .4rem
}
.menu-list__list::-webkit-scrollbar-track {
  background-color: #f5f5f5
}
.menu-list__list::-webkit-scrollbar-thumb {
  background-color: #ccc
}
.menu-list__item{
  display: inline-block;
  vertical-align: top;
  white-space: normal;
  width: 22.5%;
  padding-right: 20px;
  box-sizing: border-box;
  font-size: 10px;
}
.menu-list__item:last-child {
  padding-right: 0;
  width: calc(22.5% - 20px);
}
.menu-list__item--body{
  display: block;
  cursor: pointer;
}
.menu-list__item--img{
  border-radius: 20px;
  overflow: hidden;
}
.menu-list__item--img img{
  display: block;
  width: 100%;
}
.menu-list__item--caption{
  font-size: 14px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: initial;
} 
.menu-body{
  position: relative;
  z-index: 99999;
  display: none;
}


@media screen and (max-width:750px){

  .menu-list__head::before{
    flex-shrink: 0;
  }
  .menu-list__item{
    width: 30%;
  }
  .menu-list__item:last-child {
    width: calc(30% - 20px);
  }
  .blurbg{
    display: none;
  }
}

@media screen and (max-width:480px){
  .menu-list{
    padding:10px;
  }
  .menu-list__head{
    margin-bottom:10px;
  }
  .menu-list__item{
    width: 45%;
    padding-right: 10px;
  }
  .menu-list__item:last-child {
    width: calc(45% - 10px);
  }

}


/**
  キッチンカード
*/
.card-list{
  display: flex;
}
.card-list__item{
  flex:1;
  width: calc(100% - 10px);
}
.card-list__item:first-child{
  margin-right: 20px;
}
.card-list__item img{
  display: block;
  box-shadow: 3px 3px 6px #9E9E9E;
}

@media screen and (max-width:750px){
  .card-list{
    display: block;
  }
  .card-list__item{
    width: 100%;
  }
  .card-list__item:first-child{
    margin-bottom: 20px;
    margin-right: 0;
  }
}


/**************************\
  Basic Modal Styles
\**************************/
.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  cursor:pointer;
  width: 100%;
  padding:10px;
  box-sizing: border-box;
}
.modal__container {
  max-width: 100%;
  position: relative;
  background-color: #fff;
  border-radius: 8px;
}
.modal__body{
  padding: 30px;
  width: 500px;
  max-width: 100%;
  max-height: 80vh;
  box-sizing: border-box;
  overflow-y: auto;
}
.modal__body img{
  display: block !important;
  width: 220px;
  max-width: 100%;
  margin: auto !important;
  border-radius: 20px;
  overflow: hidden;
}
.modal__container h4{
  margin-top: 10px;
  font-size: 18px !important;
  font-weight: bold;
}
.modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal__close {
  position: absolute;
  top: 0;
  right: 0;
  transform:translateY(-110%);
  padding: 0;
  background: transparent;
  border: 0;
  font-size: 20px;
  color: #E50012;
}
.modal__content {
  margin-top: 2rem;
  margin-bottom: 2rem;
  line-height: 1.5;
  color: rgba(0,0,0,.8);
}