#panel {
  display: none; }
  @media all and (max-width: 896px) {
    #panel {
      display: block; } }

body {
  background: #e4e4e4;
  color: #595959; }
  body::after {
    position: absolute;
    content: "";
    z-index: -3;
    background: #e4e4e4;
    width: 30vw;
    height: 2200px;
    top: -100px;
    right: 0; }
    @media all and (max-width: 1367px) {
      body::after {
        height: 1600px; } }
  body #wrapper {
    overflow: visible !important; }
    @media all and (max-width: 1025px) {
      body #wrapper {
        overflow: hidden !important; } }
  body.fixed {
    overflow: visible !important; }
    @media all and (max-width: 1025px) {
      body.fixed {
        overflow: hidden !important; } }

.copy {
  font-size: 22px;
  font-size: 2.2em;
  letter-spacing: 3px;
  line-height: 2;
  margin-left: 10%;
  margin-bottom: 20px; }
  @media all and (max-width: 1367px) {
    .copy {
      font-size: 20px;
      font-size: 2em;
      margin-left: 5%; } }
  @media all and (max-width: 1025px) {
    .copy {
      margin-left: 0; } }
  @media all and (max-width: 896px) {
    .copy {
      font-size: 18px;
      font-size: 1.8em; } }

.normal {
  font-size: 15px;
  font-size: 1.5em;
  line-height: 2.5;
  margin-left: 10%;
  letter-spacing: 2px; }
  @media all and (max-width: 896px) {
    .normal {
      font-size: 14px;
      font-size: 1.4em; } }
  @media all and (max-width: 1367px) {
    .normal {
      margin-left: 5%; } }
  @media all and (max-width: 1025px) {
    .normal {
      margin-left: 0; } }

.thumbnail {
  display: none; }
  @media all and (max-width: 1025px) {
    .thumbnail {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      margin-top: 40px;
      margin-left: 25px; } }
  @media all and (max-width: 1025px) and (max-width: 896px) {
    .thumbnail {
      display: block; } }

  @media all and (max-width: 480px) {
    .thumbnail {
      margin-left: auto; } }
  @media all and (max-width: 480px) {
    .thumbnail li {
      text-align: center; } }
  @media all and (max-width: 1025px) {
    .thumbnail li img {
      max-width: 80%; } }

.time {
  margin-bottom: 20px;
  font-size: 15px;
  font-size: 1.5em;
  line-height: 2.5;
  letter-spacing: 3px;
  line-height: 2.2; }
  @media all and (max-width: 896px) {
    .time {
      font-size: 14px;
      font-size: 1.4em; } }
  .time li {
    padding-left: 1.2em;
    text-indent: -1.2em;
    margin-bottom: 20px; }
    .time li::first-letter {
      font-size: 90%; }
    .time li:last-child {
      margin-bottom: 0; }

hr {
  width: 100px;
  border-top: 1px solid #1b1414;
  height: 1px;
  margin: 150px auto; }
  @media all and (max-width: 1367px) {
    hr {
      width: 60px;
      margin: 100px auto; } }

.maintitle_u {
  margin-top: 40px; }
  .maintitle_u h1 {
    text-align: center;
    font-size: 20px;
    font-size: 2em;
    letter-spacing: 0.2em; }
    @media all and (max-width: 896px) {
      .maintitle_u h1 {
        font-size: 16px;
        font-size: 1.6em; } }
    .maintitle_u h1 img {
      margin: 0 auto 30px;
      max-width: 190px; }
    .maintitle_u h1 span.flex span {
      display: block; }
      .maintitle_u h1 span.flex span.large {
        font-size: 28px;
        font-size: 2.8em;
        font-family: 'Shippori Mincho', serif;
        font-weight: 400; }
      .maintitle_u h1 span.flex span.ruby {
        font-size: 8px;
        font-size: 0.8em;
        letter-spacing: 2px;
        margin-top: -10px; }
        @media all and (max-width: 480px) {
          .maintitle_u h1 span.flex span.ruby {
            margin-top: -5px; } }

.photo {
  position: relative;
  margin-top: -20px; }
  .photo .mainimage {
    background: url(../images/main.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    height: calc(100vh - 300px); }
    @media all and (max-width: 896px) {
      .photo .mainimage {
        height: 500px; } }
    @media all and (max-width: 480px) {
      .photo .mainimage {
        height: 250px; } }
  .photo .scrolldown {
    position: absolute;
    z-index: 1;
    top: 50%;
    transform: translateY(-50%);
    right: 0; }
    @media all and (max-width: 1367px) {
      .photo .scrolldown {
        top: 45%; } }
    @media all and (max-width: 896px) {
      .photo .scrolldown {
        top: 50%;
        left: -35px; } }
    .photo .scrolldown span {
      right: 50px; }
      @media all and (max-width: 896px) {
        .photo .scrolldown span {
          right: 15px; } }
      @media all and (max-width: 896px) {
        .photo .scrolldown span::after {
          width: 0.8px;
          right: 7px; } }

.lead {
  text-align: center;
  margin: 100px 40px; }
  @media all and (max-width: 896px) {
    .lead {
      text-align: left;
      width: calc(100% - 40px);
      margin: 50px auto; } }
  .lead .copy, .lead .normal {
    margin-left: 0; }

.style {
  position: relative;
  padding-bottom: 600px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }
  @media all and (max-width: 896px) {
    .style {
      display: block; } }
  @media all and (max-width: 1367px) {
    .style {
      padding-bottom: 400px;
      margin-top: 80px; } }
  @media all and (max-width: 1025px) {
    .style {
      padding-bottom: 200px; } }
  @media all and (max-width: 896px) {
    .style {
      padding-bottom: 0; } }
  .style .image {
    z-index: 2;
    position: absolute;
    width: 100%;
    height: 100%; }
    @media all and (max-width: 1025px) {
      .style .image {
        position: static; } }
    .style .image img {
      position: sticky;
      top: 0; }
      @media all and (max-width: 1367px) {
        .style .image img {
          top: -10px; } }
      @media all and (max-width: 1025px) {
        .style .image img {
          max-width: 90%; } }
    @media all and (max-width: 1025px) {
      .style .image::after {
        position: absolute;
        content: "";
        z-index: -2;
        background: #cbc6bd;
        top: 50px;
        width: 100%;
        height: 1700px; } }
    @media all and (max-width: 480px) {
      .style .image::after {
        height: 1060px; } }
  .style .text {
    position: relative;
    z-index: 2;
    width: calc(100% - 53%);
    margin-top: 400px;
    margin-left: 53%;
    padding-bottom: 5%;
    background: #cbc6bd; }
    @media all and (max-width: 1500px) {
      .style .text {
        width: calc(100% - 57%);
        margin-top: 100px;
        margin-left: 50%; } }
    @media all and (max-width: 1025px) {
      .style .text {
        width: calc(100% - 40px);
        margin-left: 40px;
        background: transparent; } }
    @media all and (max-width: 896px) {
      .style .text {
        margin: 40px auto 0; } }
    .style .text h2 {
      color: #fff;
      margin-bottom: 40px; }
      @media all and (max-width: 896px) {
        .style .text h2 {
          margin-bottom: 20px; } }
    .style .text .scrolldown {
      position: absolute;
      top: 46%;
      transform: translateY(-50%);
      right: 3vw; }
      @media all and (max-width: 1500px) {
        .style .text .scrolldown {
          right: -1vw; } }
      @media all and (max-width: 1025px) {
        .style .text .scrolldown {
          display: none; } }

.localfood {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding-bottom: 500px; }
  @media all and (max-width: 896px) {
    .localfood {
      display: block; } }
  @media all and (max-width: 1367px) {
    .localfood {
      padding-bottom: 400px; } }
  @media all and (max-width: 1025px) {
    .localfood {
      padding-bottom: 0;
      display: flex; } }
  .localfood .text {
    position: relative;
    width: calc(100% - 57%);
    margin-left: 5%;
    margin-top: 500px;
    z-index: 1;
    padding-bottom: 5%;
    background: linear-gradient(to left, transparent 0%, transparent 20%, #e4e4e4 20%, #e4e4e4 100%); }
    @media all and (max-width: 1500px) {
      .localfood .text {
        margin-left: 0;
        background: linear-gradient(to left, transparent 0%, transparent 10%, #e4e4e4 10%, #e4e4e4 100%);
        margin-top: 100px; } }
    @media all and (max-width: 1367px) {
      .localfood .text {
        width: calc(100% - 55%); } }
    @media all and (max-width: 1025px) {
      .localfood .text {
        order: 2;
        width: calc(100% - 40px);
        margin: auto;
        background: transparent; } }
    .localfood .text h2 {
      margin: 75px 0 25px;
      text-align: center; }
      @media all and (max-width: 1025px) {
        .localfood .text h2 {
          margin: 40px 0 25px;
          text-align: left; } }
    .localfood .text .copy, .localfood .text .normal {
      margin-left: 18%; }
      @media all and (max-width: 1500px) {
        .localfood .text .copy, .localfood .text .normal {
          margin-left: 15%; } }
      @media all and (max-width: 1025px) {
        .localfood .text .copy, .localfood .text .normal {
          margin-left: 0; } }
    .localfood .text .thumbnail {
      margin-left: 18%; }
      @media all and (max-width: 1500px) {
        .localfood .text .thumbnail {
          margin-left: 15%; } }
      @media all and (max-width: 1025px) {
        .localfood .text .thumbnail {
          margin-left: 25px; } }
      @media all and (max-width: 480px) {
        .localfood .text .thumbnail {
          margin-left: auto; } }
    .localfood .text .scrolldown {
      position: absolute;
      top: 53%;
      transform: translateY(-50%);
      right: 10%; }
      @media all and (max-width: 1500px) {
        .localfood .text .scrolldown {
          right: 0; } }
      @media all and (max-width: 1025px) {
        .localfood .text .scrolldown {
          display: none; } }
  .localfood .image {
    position: absolute;
    right: 0;
    height: 100%;
    text-align: right; }
    @media all and (max-width: 1025px) {
      .localfood .image {
        position: static;
        order: 1;
        width: 100%; } }
    @media all and (max-width: 1025px) {
      .localfood .image::after {
        position: absolute;
        content: "";
        background: #dcd9d3;
        width: 100%;
        height: 1500px;
        top: 80px;
        right: 0;
        z-index: -1; } }
    @media all and (max-width: 480px) {
      .localfood .image::after {
        height: 880px; } }
    .localfood .image img {
      position: sticky;
      top: 60px; }
      @media all and (max-width: 1025px) {
        .localfood .image img {
          max-width: 90%; } }

.restaurant_detail {
  position: relative;
  width: 490px;
  margin: auto;
  font-size: 1.8em;
  border-top: 1px solid #595959;
  border-bottom: 1px solid #595959;
  margin-top: 150px; }
  @media all and (max-width: 1025px) {
    .restaurant_detail {
      width: 300px;
      font-size: 1.4em; } }
  .restaurant_detail a {
    display: block;
    padding: 25px 0;
    background: #efefef; }
    @media all and (max-width: 1025px) {
      .restaurant_detail a {
        padding: 12px 0; } }
    .restaurant_detail a div.base.top {
      position: relative; }
      .restaurant_detail a div.base.top .line_left {
        top: -26px;
        left: 0; }
        @media all and (max-width: 1025px) {
          .restaurant_detail a div.base.top .line_left {
            top: -13px; } }
      .restaurant_detail a div.base.top .line_right {
        top: -26px;
        right: 0; }
        @media all and (max-width: 1025px) {
          .restaurant_detail a div.base.top .line_right {
            top: -13px; } }
    .restaurant_detail a div.base.bottom {
      position: relative; }
      .restaurant_detail a div.base.bottom .line_left {
        bottom: -26px;
        left: 0; }
        @media all and (max-width: 1025px) {
          .restaurant_detail a div.base.bottom .line_left {
            bottom: -13px; } }
      .restaurant_detail a div.base.bottom .line_right {
        bottom: -26px;
        right: 0; }
        @media all and (max-width: 1025px) {
          .restaurant_detail a div.base.bottom .line_right {
            bottom: -13px; } }
    .restaurant_detail a div.base span.line_left {
      position: absolute;
      height: 35px;
      border-left: 1px solid #595959; }
      @media all and (max-width: 480px) {
        .restaurant_detail a div.base span.line_left {
          height: 20px; } }
    .restaurant_detail a div.base span.line_right {
      position: absolute;
      height: 35px;
      border-right: 1px solid #595959;
      z-index: 1; }
      @media all and (max-width: 480px) {
        .restaurant_detail a div.base span.line_right {
          height: 20px; } }
    .restaurant_detail a div.arrow {
      position: absolute;
      background: #dcd9d3;
      width: 106px;
      right: 0;
      height: 99%;
      top: 50%;
      transform: translateY(-50%); }
      @media all and (max-width: 1025px) {
        .restaurant_detail a div.arrow {
          width: 50px; } }
      .restaurant_detail a div.arrow span::before {
        position: absolute;
        content: "";
        width: 30px;
        height: 1px;
        background: #595959;
        top: 50%;
        left: 50%;
        transform: translateY(-50%) translateX(-50%); }
        @media all and (max-width: 1025px) {
          .restaurant_detail a div.arrow span::before {
            width: 15px; } }
      .restaurant_detail a div.arrow span::after {
        position: absolute;
        content: "";
        top: 44%;
        left: 54%;
        width: 9px;
        height: 8px;
        border-top: 1px solid #595959;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg); }
        @media all and (max-width: 480px) {
          .restaurant_detail a div.arrow span::after {
            left: 50%;
            width: 5px; } }
    .restaurant_detail a p {
      padding-left: 60px; }
      @media all and (max-width: 1025px) {
        .restaurant_detail a p {
          padding-left: 20px; } }

.dinner {
  position: relative;
  padding-bottom: 400px;
  margin-top: 150px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }
  @media all and (max-width: 896px) {
    .dinner {
      display: block; } }
  @media all and (max-width: 1367px) {
    .dinner {
      margin-top: 80px; } }
  @media all and (max-width: 1025px) {
    .dinner {
      padding-bottom: 200px; } }
  @media all and (max-width: 896px) {
    .dinner {
      padding-bottom: 0; } }
  .dinner .image {
    z-index: 2;
    position: absolute;
    width: 100%;
    height: 100%; }
    @media all and (max-width: 1025px) {
      .dinner .image {
        position: static; } }
    .dinner .image img {
      position: sticky;
      top: 0; }
      @media all and (max-width: 1500px) {
        .dinner .image img {
          top: -5px; } }
      @media all and (max-width: 1025px) {
        .dinner .image img {
          max-width: 90%; } }
    @media all and (max-width: 1025px) {
      .dinner .image::after {
        position: absolute;
        content: "";
        z-index: -2;
        background: #cbc6bd;
        top: 50px;
        width: 100%;
        height: 1700px; } }
    @media all and (max-width: 480px) {
      .dinner .image::after {
        height: 940px; } }
  .dinner .text {
    position: relative;
    z-index: 2;
    width: calc(100% - 53%);
    margin-top: 500px;
    margin-left: 53%;
    padding-bottom: 5%;
    background: #cbc6bd; }
    @media all and (max-width: 1500px) {
      .dinner .text {
        width: calc(100% - 57%);
        margin-top: 200px; } }
    @media all and (max-width: 1025px) {
      .dinner .text {
        width: calc(100% - 40px);
        margin-left: 40px;
        background: transparent; } }
    @media all and (max-width: 896px) {
      .dinner .text {
        margin: 40px auto 0; } }
    .dinner .text h2 {
      color: #fff;
      margin-bottom: 20px; }
    .dinner .text .normal {
      margin-left: 0; }
    .dinner .text .scrolldown {
      position: absolute;
      top: 46%;
      transform: translateY(-50%);
      right: 3vw; }
      @media all and (max-width: 1500px) {
        .dinner .text .scrolldown {
          right: -1vw; } }
      @media all and (max-width: 1025px) {
        .dinner .text .scrolldown {
          display: none; } }

.breakfast {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 200px;
  padding-bottom: 500px; }
  @media all and (max-width: 896px) {
    .breakfast {
      display: block; } }
  @media all and (max-width: 1367px) {
    .breakfast {
      display: flex;
      margin-top: 0; } }
  @media all and (max-width: 1025px) {
    .breakfast {
      padding-bottom: 100px; } }
  @media all and (max-width: 896px) {
    .breakfast {
      padding-bottom: 0; } }
  @media all and (max-width: 1025px) {
    .breakfast::after {
      position: absolute;
      content: "";
      z-index: -2;
      background: #dcd9d3;
      width: 100%;
      max-width: 1600px;
      height: 1700px;
      top: 50px;
      left: 0; } }
  @media all and (max-width: 480px) {
    .breakfast::after {
      height: 930px; } }
  .breakfast .text {
    position: relative;
    width: calc(100% - 60%);
    margin-top: 500px;
    margin-left: 6%;
    z-index: 1;
    padding-bottom: 5%;
    background: #dcd9d3; }
    @media all and (max-width: 1500px) {
      .breakfast .text {
        margin-left: 2%;
        margin-top: 180px; } }
    @media all and (max-width: 1025px) {
      .breakfast .text {
        order: 2;
        width: calc(100% - 40px);
        margin: 40px auto 0;
        background: transparent; } }
    .breakfast .text h2 {
      text-align: center;
      margin-bottom: 20px; }
      @media all and (max-width: 1025px) {
        .breakfast .text h2 {
          text-align: left; } }
    .breakfast .text .time, .breakfast .text .normal {
      margin-left: 24%; }
      @media all and (max-width: 1500px) {
        .breakfast .text .time, .breakfast .text .normal {
          margin-left: 15%; } }
      @media all and (max-width: 1025px) {
        .breakfast .text .time, .breakfast .text .normal {
          margin-left: 0; } }
    .breakfast .text .thumbnail {
      margin-left: 24%; }
      @media all and (max-width: 1500px) {
        .breakfast .text .thumbnail {
          margin-left: 15%; } }
      @media all and (max-width: 1025px) {
        .breakfast .text .thumbnail {
          margin-left: 25px; } }
      @media all and (max-width: 480px) {
        .breakfast .text .thumbnail {
          margin-left: auto; } }
    .breakfast .text .scrolldown {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 0; }
      @media all and (max-width: 1500px) {
        .breakfast .text .scrolldown {
          right: -3vw; } }
      @media all and (max-width: 1025px) {
        .breakfast .text .scrolldown {
          display: none; } }
  .breakfast .image {
    position: absolute;
    right: 0;
    height: 100%;
    width: 100%;
    text-align: right; }
    @media all and (max-width: 1025px) {
      .breakfast .image {
        position: static;
        order: 1; } }
    .breakfast .image img {
      position: sticky;
      top: 50px; }
      @media all and (max-width: 1367px) {
        .breakfast .image img {
          top: -10px; } }
      @media all and (max-width: 1025px) {
        .breakfast .image img {
          top: 100px;
          max-width: 90%; } }

.slidebox {
  width: 100%;
  margin: 150px auto;
  padding: 30px;
  border: 1px solid #aaa;
  display: flex;
  justify-content: space-between;
  align-items: center; }
  @media all and (max-width: 896px) {
    .slidebox {
      width: 93%;
      margin: 75px 0 0 auto;
      padding: 20px;
      display: block; } }
  .slidebox .image {
    width: 50%; }
    @media all and (max-width: 896px) {
      .slidebox .image {
        width: 100%; } }
    .slidebox .image .slider {
      margin: 0 auto 0;
      max-width: 100%; }
      .slidebox .image .slider img {
        height: auto;
        width: 100%; }
  .slidebox .info {
    width: 50%;
    padding: 50px; }
    @media all and (max-width: 896px) {
      .slidebox .info {
        width: 100%;
        padding: 0;
        margin-top: 20px; } }
    .slidebox .info p {
      margin-top: 10px;
      margin-bottom: 30px;
      padding-bottom: 30px;
      font-size: 14px;
      font-size: 1.4em;
      line-height: 1.6;
      letter-spacing: 3px;
      position: relative; }
      @media all and (max-width: 896px) {
        .slidebox .info p {
          font-size: 12px;
          font-size: 1.2em; } }
      .slidebox .info p::after {
        content: "";
        display: inline-block;
        width: 100%;
        height: 1px;
        background: #aaa;
        position: absolute;
        left: 0;
        bottom: 0; }
      .slidebox .info p.last {
        letter-spacing: 1px;
        padding-bottom: 0;
        margin-bottom: 0; }
        .slidebox .info p.last::after {
          content: none; }
    .slidebox .info dl {
      display: flex;
      flex-wrap: wrap;
      font-size: 14px;
      font-size: 1.4em;
      line-height: 1.6;
      margin-top: 10px; }
      @media all and (max-width: 896px) {
        .slidebox .info dl {
          font-size: 12px;
          font-size: 1.2em; } }
    .slidebox .info .ttl_slide {
      text-align: center;
      font-size: 28px;
      font-size: 2.8em;
      font-weight: 500;
      letter-spacing: 0.3em; }
      @media all and (max-width: 896px) {
        .slidebox .info .ttl_slide {
          font-size: 22px;
          font-size: 2.2em; } }
      .slidebox .info .ttl_slide img {
        margin: 0 auto 10px;
        max-width: 120px; }

.instagram {
  background: #cbc6bd;
  padding: 130px 0; }
  @media all and (max-width: 1025px) {
    .instagram {
      margin-top: 100px; } }
  @media all and (max-width: 1367px) {
    .instagram {
      padding: 65px 0; } }
  .instagram h2 {
    color: #fff; }

@media all and (max-width: 1025px) {
  img.pconly, br.pconly {
    display: none; } }

@media all and (max-width: 1025px) {
  img.sponly, br.sponly {
    display: block; } }

footer {
  margin-top: 100px; }
