#sec1 {
  background: url("../img/lunch/sec1_bg.jpg") no-repeat center 0/cover;
  padding: 25vw 0 15vw; }
  #sec1:before {
    background: url("../img/lunch/sec1_deco.png") no-repeat right 0/90%;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 40vw; }
  #sec1 .map {
    position: relative;
    padding-bottom: 5vw;
    margin: 5vw 0; }
    #sec1 .map dd {
      width: 31%;
      position: absolute;
      right: -3vw;
      bottom: 0;
      z-index: 1; }
  #sec1 .banner {
    padding-top: 10vw;
    gap: 5vw; }
    #sec1 .banner li {
      width: 100%; }
      #sec1 .banner li a {
        padding-bottom: 36px; }
        #sec1 .banner li a:before {
          transform: rotate(90deg);
          height: 20px;
          top: 45px;
          right: calc(50% - 10px); }
        #sec1 .banner li a:hover:before {
          right: calc(50% - 10px) !important;
          top: 70px; }
  @media screen and (min-width: 768px) {
    #sec1 {
      padding: 168px 20px 127px; }
      #sec1:before {
        background-size: auto; } }
    @media screen and (min-width: 768px) and (max-width: 1500px) {
      #sec1:before {
        background-position: calc(50% + 178px) 0; } }
  @media screen and (min-width: 768px) {
      #sec1 .wrap {
        flex-wrap: wrap;
        justify-content: space-between;
        display: flex;
        max-width: 1116px; }
      #sec1 h2 {
        width: 100%;
        padding: 0 0 53px; }
      #sec1 .txt {
        max-width: 404px;
        width: 36%;
        margin: 101px  0 0 0; }
      #sec1 .map {
        position: relative;
        padding-bottom: 0;
        margin: 0 0  104px 9px;
        width: 61%; }
        #sec1 .map dt img {
          height: auto;
          max-width: 100%; }
        #sec1 .map dd {
          width: auto;
          right: 33px;
          bottom: -25px; }
      #sec1 .banner {
        width: 100%;
        justify-content: center;
        padding-top: 0;
        gap: 30px; }
        #sec1 .banner li {
          width: 340px; }
          #sec1 .banner li a {
            padding: 6px 17px 32px 29px;
            font-size: 18px; }
            #sec1 .banner li a:before {
              transform: rotate(90deg);
              height: 20px;
              top: 55px;
              right: calc(50% - 10px); } }

#floor_map {
  padding-bottom: 10vw; }
  #floor_map h2 {
    padding: 0 15% 5vw; }
  #floor_map .map {
    padding-bottom: 10vw; }
  #floor_map .bnr-shared {
    width: 70%; }
  @media screen and (min-width: 768px) {
    #floor_map {
      padding-bottom: 0; }
      #floor_map h2 {
        padding: 0 0 50px; }
      #floor_map .map {
        padding-bottom: 52px; }
      #floor_map .bnr-shared {
        width: 383px; } }

.sec-group {
  position: relative; }
  @media screen and (min-width: 768px) {
    .sec-group {
      background: url("../img/lunch/sec3_deco2.png") no-repeat;
      background-position: calc(50% - 445px) 10px; } }
  @media screen and (min-width: 768px) and (max-width: 1260px) {
    .sec-group {
      background-position: right 290px top 10px; } }

#sec2 {
  color: #fff;
  padding: 15vw 0 30px;
  position: relative;
  z-index: 1; }
  #sec2:before {
    background: url("../img/shared/bg1.jpg") repeat 0 0;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 24px;
    z-index: -1; }
  #sec2 .photo {
    margin: 10vw 0 6vw; }
  @media screen and (min-width: 768px) {
    #sec2 {
      padding: 0 0px; }
      #sec2:before {
        bottom: 0;
        left: 0;
        right: calc(50% + 500px); }
      #sec2 .wrap {
        max-width: 1500px;
        justify-content: flex-end;
        display: flex; }
      #sec2 .photo {
        position: absolute;
        bottom: 0;
        top: 0;
        right: 0;
        width: calc(50% + 5px);
        margin: 0; }
      #sec2 .info {
        width: 539px;
        position: static;
        margin-right: calc(50% + 5px);
        padding: 141px 0 0 0;
        min-height: 630px; }
        #sec2 .info .txt {
          width: 414px;
          margin: 31px 0 0 14px;
          text-shadow: 4px 1px 4px rgba(0, 0, 0, 0.6), 0px -2px 4px rgba(0, 0, 0, 0.6); } }
  @media screen and (min-width: 768px) and (max-width: 1100px) {
    #sec2 .wrap {
      justify-content: flex-start; }
    #sec2 .info {
      margin-left: 20px;
      margin-right: 0; } }

#sec3 {
  position: relative;
  background: url("../img/lunch/sec3_deco1.png") no-repeat right 0/210%;
  padding-bottom: 15vw; }
  #sec3:before {
    background: url("../img/lunch/sec3_deco2.png") no-repeat -34vw 0/120%;
    content: '';
    position: absolute;
    top: -20vw;
    left: 0;
    right: 0;
    height: 96vw; }
  #sec3 h2 {
    width: 31%;
    position: absolute;
    top: 5vw;
    right: 2vw;
    z-index: 1; }
  #sec3 .photo {
    width: 109%;
    margin: 0 0 10vw -33vw; }
  @media screen and (min-width: 768px) {
    #sec3 {
      background: none;
      padding: 0 20px 20px; }
      #sec3:before {
        background: url("../img/lunch/sec3_deco1.png") no-repeat center 0;
        top: -215px;
        left: 0;
        right: 0;
        height: 1210px; }
      #sec3 .wrap {
        max-width: 1300px;
        justify-content: flex-end;
        display: flex; }
      #sec3 h2 {
        width: auto;
        position: static;
        top: auto;
        right: auto;
        margin: 0 0 29px 75px; }
      #sec3 .photo {
        width: auto;
        margin: 0 0;
        position: absolute;
        top: -36px;
        right: calc(50% - 240px); } }
    @media screen and (min-width: 768px) and (max-width: 1180px) {
      #sec3 .photo {
        right: 320px;
        width: 141%;
        top: auto;
        bottom: -19px;
        text-align: right; }
        #sec3 .photo img {
          max-width: 100%;
          height: auto; } }
  @media screen and (min-width: 768px) {
      #sec3 .info {
        width: 400px;
        position: static;
        padding: 92px 0px 60px 0;
        min-height: 973px; } }

#sec4 {
  color: #fff;
  position: relative;
  z-index: 1;
  padding: 15vw 0 20vw;
  text-shadow: 4px 4px 10px rgba(0, 0, 0, 0.6), -4px 2px 10px rgba(0, 0, 0, 0.6); }
  #sec4:before {
    content: '';
    position: absolute;
    top: 0;
    left: -17vw;
    right: 0;
    bottom: 0;
    z-index: -1;
    background: url("../img/lunch/sec4_bg.jpg") no-repeat center/cover; }
  #sec4 h2 {
    padding: 0 28% 5vw 0; }
  @media screen and (min-width: 768px) {
    #sec4 {
      padding: 100px 20px 106px; }
      #sec4:before {
        left: -0; }
      #sec4 h2 {
        padding: 0 0 12px 0;
        position: relative; }
        #sec4 h2:before {
          content: '';
          border-top: 2px solid #7c4f24;
          position: absolute;
          bottom: 34px;
          left: -250px;
          width: 300px;
          z-index: 2; }
      #sec4 .txt {
        width: 393px;
        margin: 0 0 0 10px; } }

#sec5 {
  background: url("../img/lunch/sec5_deco1.png") no-repeat right 0/100%, url("../img/lunch/sec5_deco2.png") no-repeat 0 143vw/190%, url("../img/lunch/sec5_deco3.png") no-repeat 0 bottom/55%;
  position: relative;
  padding: 20vw 0 15vw; }
  #sec5 .deco {
    width: 24%;
    position: absolute;
    top: -22vw;
    right: 0;
    z-index: 1; }
  #sec5 .lead {
    padding-bottom: 10vw; }
    #sec5 .lead h2 {
      width: 35%;
      margin: 0 auto 5vw; }
    #sec5 .lead .photo1 {
      padding-bottom: 5vw; }
  #sec5 .group .slick-dots {
    left: auto;
    width: 20px;
    flex-wrap: wrap;
    right: 10vw; }
  #sec5 .group .menu {
    margin-bottom: 10vw; }
    #sec5 .group .menu dl {
      position: relative;
      padding: 0 5%; }
      #sec5 .group .menu dl dt {
        position: absolute;
        bottom: 5vw;
        left: 0;
        z-index: 1; }
        #sec5 .group .menu dl dt.ext {
          bottom: 40vw; }
        #sec5 .group .menu dl dt img {
          height: 8.5vw;
          width: auto; }
  #sec5 .banner {
    padding-top: 5vw; }
    #sec5 .banner li {
      text-align: center;
      position: relative; }
      #sec5 .banner li:nth-child(1) {
        width: 100%; }
      #sec5 .banner li img {
        width: auto;
        height: 49vw; }
      #sec5 .banner li:nth-child(2):before {
        content: '';
        background: url("../img/lunch/smoke.png") no-repeat 0 0/100%;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1;
        mix-blend-mode: screen; }
  @media screen and (min-width: 768px) {
    #sec5 {
      background-size: auto,auto,auto;
      background-position: right 0, 0 398px,0 bottom;
      padding: 166px 20px 91px; }
      #sec5 .wrap {
        max-width: 1126px; }
      #sec5 .deco {
        width: auto;
        top: -566px;
        right: 0; } }
    @media screen and (min-width: 768px) and (max-width: 1300px) {
      #sec5 .deco {
        right: -50px; } }
  @media screen and (min-width: 768px) {
      #sec5 .lead {
        padding-bottom: 88px;
        max-width: 1014px;
        margin: 0 auto;
        position: relative;
        z-index: 2; }
        #sec5 .lead h2 {
          width: auto;
          position: absolute;
          top: 0;
          right: -18px; }
        #sec5 .lead .photo1 {
          padding-bottom: 53px;
          margin-left: -52px; }
        #sec5 .lead .txt {
          max-width: 542px;
          width: 54%; }
      #sec5 .group {
        position: relative;
        padding-bottom: 65px; }
        #sec5 .group .slick-dots {
          width: 20px;
          right: 23px;
          bottom: 30px; }
        #sec5 .group .menu {
          margin-bottom: 0; }
          #sec5 .group .menu dl {
            padding: 0 0 0 19px; }
            #sec5 .group .menu dl dt {
              bottom: 28px;
              left: 0; }
              #sec5 .group .menu dl dt.ext {
                bottom: 266px; }
              #sec5 .group .menu dl dt img {
                height: auto; }
          #sec5 .group .menu.menu1 {
            position: absolute;
            width: 488px;
            top: -198px;
            right: 0; }
          #sec5 .group .menu.menu2 dl {
            padding-left: 54px; } }
      @media screen and (min-width: 768px) and (max-width: 1160px) {
        #sec5 .group .menu.menu1 {
          width: 45%; }
        #sec5 .group .menu dl dt img {
          height: 45px; }
        #sec5 .group .menu dl dd img {
          max-width: 100%;
          height: auto; }
        #sec5 .group .menu.menu2 dl {
          padding-left: 10px;
          width: 52%; } }
  @media screen and (min-width: 768px) {
      #sec5 .banner {
        padding-top: 0;
        margin: 0 -40px;
        justify-content: center; }
        #sec5 .banner li:nth-child(1) {
          width: auto; }
        #sec5 .banner li img {
          height: auto; } }

#sec7 {
  background: url("../img/lunch/sec7_bg.png") no-repeat center 0/100%, url("../img/concept/bg5.jpg") repeat center 0;
  padding: 15vw 0 5vw;
  position: relative;
  z-index: 1; }
  #sec7:after {
    background: url("../img/lunch/sec7_deco.png") no-repeat right 0/210%;
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 150vw;
    height: 120vw;
    z-index: -1; }
  #sec7 .lead {
    padding-bottom: 10vw; }
    #sec7 .lead .txt {
      padding: 5vw 0; }
  #sec7 .group .menu {
    padding-bottom: 10vw; }
    #sec7 .group .menu .photo {
      position: relative; }
      #sec7 .group .menu .photo .catch {
        width: 30%;
        position: absolute;
        right: -3vw;
        top: -10vw;
        z-index: 1; }
    #sec7 .group .menu .tag dt {
      text-align: center;
      font-size: 22px;
      border-bottom: 1px solid #7c4f24;
      padding: 15px 0;
      margin-bottom: 15px; }
      #sec7 .group .menu .tag dt span {
        font-size: 18px; }
  @media screen and (min-width: 768px) {
    #sec7 {
      background: url("../img/lunch/sec7_bg.png") no-repeat center 0/100%, url("../img/concept/bg5.jpg") repeat center 0;
      background-size: auto,auto;
      padding: 120px 20px 0px;
      text-align: center; }
      #sec7:after {
        top: 750px;
        height: 1107px;
        background-size: auto; }
      #sec7 .wrap {
        max-width: 1036px; }
      #sec7 .lead {
        padding-bottom: 112px; }
        #sec7 .lead .txt {
          padding: 0 0; }
        #sec7 .lead h2 {
          padding-bottom: 30px; }
      #sec7 .group {
        justify-content: space-between;
        display: flex;
        flex-wrap: wrap; }
        #sec7 .group .menu {
          padding-bottom: 66px;
          width: calc(50% - 25px);
          text-align: left; }
          #sec7 .group .menu .photo {
            margin-bottom: 20px; }
            #sec7 .group .menu .photo img {
              width: 100%;
              height: auto; }
            #sec7 .group .menu .photo .catch {
              width: 214px;
              right: 12px;
              top: -68px;
              z-index: 1; }
          #sec7 .group .menu .tag dt {
            font-size: 30px;
            padding: 15px 0 29px;
            max-width: 515px;
            margin: 0 auto 22px; }
            #sec7 .group .menu .tag dt span {
              font-size: 25px; }
          #sec7 .group .menu:nth-child(1) {
            width: 100%;
            text-align: center; }
            #sec7 .group .menu:nth-child(1) .photo {
              width: 930px;
              margin: 0 auto 32px; } }

#sec8 {
  background: url("../img/concept/bg5.jpg") repeat center 0;
  padding: 5vw 5% 10vw;
  position: relative; }
  #sec8:before {
    content: '';
    background: url("../img/lunch/sec8_deco1.png") no-repeat 0 bottom/80%;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 30vw;
    z-index: 1; }
  #sec8 .wrap {
    background: url("../img/shared/bd_bg.jpg") repeat center 0;
    padding: 15vw 5%; }
  #sec8 h2 {
    border-top: 1px solid #7c4f24;
    border-bottom: 1px solid #7c4f24;
    padding: 0 10%; }
  #sec8 .note {
    padding: 7vw 0 10vw; }
  #sec8 .menu-list h3 {
    text-align: center;
    background: url("../img/shared/bg1.jpg") repeat center 0;
    font-size: 18px;
    margin-bottom: 10px;
    color: #fff; }
  #sec8 .menu-list dl {
    display: block; }
    #sec8 .menu-list dl dt {
      width: auto; }
    #sec8 .menu-list dl dd {
      margin-top: -30px; }
  #sec8 .col {
    width: 100%; }
  @media screen and (min-width: 768px) {
    #sec8 {
      padding: 24px 20px 132px; }
      #sec8:before {
        content: '';
        background-size: auto;
        height: 288px; } }
    @media screen and (min-width: 768px) and (max-width: 1500px) {
      #sec8:before {
        background-position: calc(50% - 167px) bottom; } }
  @media screen and (min-width: 768px) {
      #sec8 .wrap {
        padding: 83px 0 90px;
        max-width: 1034px; }
      #sec8 .box {
        max-width: 870px;
        margin: 0 auto; }
      #sec8 h2 {
        padding: 0 0; }
      #sec8 .note {
        padding: 32px 0 34px;
        text-align: center; }
      #sec8 .menu-list h3 {
        font-size: 16px;
        line-height: 41px;
        margin-bottom: 10px; }
      #sec8 .col {
        width: 412px; } }
