@charset "UTF-8";
@font-face {
  font-family: 'hannari';
  src: url("../font/hannari.woff") format("woff"); }

body {
  background: #BE0201; }

.mobile {
  display: none; }

* {
  font-family: "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  -webkit-transition: 0.2s;
  -o-transition: 0.2s;
  transition: 0.2s; }

p,
h2,
h3 {
  color: #BE0201; }

a:hover {
  opacity: 0.7; }

div#loading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
  background: #BE0201;
  position: fixed;
  z-index: 9999;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
  top: 0; }
  div#loading div.ball-pulse {
    margin: auto;
    margin-top: 0; }
  div#loading img {
    width: 100px;
    margin: auto;
    margin-bottom: 20px; }

header {
  width: 100%;
  padding-top: 1%;
  position: fixed;
  z-index: 100;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  top: 0; }
  header h1 {
    width: auto; }
    header h1 img {
      width: auto; }
    header h1.on {
      -webkit-filter: drop-shadow(0px 0px 5px black);
      filter: drop-shadow(0px 0px 5px black); }

section#hero {
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
  width: 100%;
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1; }
  section#hero div {
    width: 100%;
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100); }
    section#hero div video {
      min-width: 100%;
      min-height: 100%;
      z-index: -100;
      position: relative;
      left: 50%;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%); }

section#about {
  height: 110vh;
  background: #BE0201;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #BE0201 url(../img/about_logo.png) no-repeat right 5% bottom 5%;
  margin-top: 100vh;
  -webkit-scroll-snap-type: mandatory;
  -ms-scroll-snap-type: mandatory;
  scroll-snap-type: mandatory; }
  section#about div.area {
    margin: auto;
    width: 60%;
    min-width: 600px;
    max-width: 900px;
    scroll-snap-align: center; }
    section#about div.area p {
      -webkit-filter: drop-shadow(0px 0px 5px #4d0000);
      filter: drop-shadow(0px 0px 5px #4d0000); }

main section {
  padding-top: 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%; }
  main section h2 {
    width: 300px;
    margin: 0 auto 80px; }
    main section h2 img {
      width: 100%; }
  main section#menu {
    background: url(../img/bg.jpg);
    padding: 0 5vw; }
    main section#menu div.content {
      max-width: 900px;
      width: 100%;
      padding: 10vw 0;
      margin: 0 auto; }
      main section#menu div.content div.wrap div.img {
        height: 500px;
        position: relative;
        margin-bottom: 30px; }
        main section#menu div.content div.wrap div.img h3 {
          position: absolute;
          width: 40%;
          max-width: 400px;
          left: 3%;
          top: 2%; }
        main section#menu div.content div.wrap div.img p {
          position: absolute;
          bottom: 0;
          right: 2%; }
      main section#menu div.content div.wrap div.txt {
        margin: auto;
        margin-bottom: 100px;
        background: rgba(255, 255, 255, 0.5);
        padding: 10vmin; }
        main section#menu div.content div.wrap div.txt p {
          font-size: 20px;
          margin: auto;
          font-family: 'hannari';
          line-height: 2;
          max-width: 600px; }
      main section#menu div.content div.wrap.takoyaki div.img {
        background: url(../img/img_takoyaki.jpg) center center/cover no-repeat; }
        main section#menu div.content div.wrap.takoyaki div.img p {
          width: 60%;
          max-width: 708px; }
      main section#menu div.content div.wrap.karaage div.img {
        background: url(../img/img_karaage.jpg) center center/cover no-repeat; }
        main section#menu div.content div.wrap.karaage div.img p {
          width: 40%;
          max-width: 468px; }
  main section#access {
    background: #ffffff;
    padding-bottom: 60px; }
    main section#access div.info {
      width: 70%;
      margin: auto;
      margin-bottom: 60px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex; }
      main section#access div.info div.txt {
        width: 40%;
        padding-right: 50px; }
        main section#access div.info div.txt h3 {
          font-size: 26px;
          margin-bottom: 30px; }
        main section#access div.info div.txt p {
          font-size: 18px;
          margin-bottom: 50px;
          line-height: 1.5; }
        main section#access div.info div.txt a.button {
          background: #BE0201;
          color: #ffffff;
          text-decoration: none;
          display: block;
          border-radius: 30px;
          width: 220px;
          padding: 20px 0;
          text-align: center;
          margin: auto;
          margin-bottom: 30px; }
        main section#access div.info div.txt a.tel {
          display: none; }
      main section#access div.info > p {
        width: 60%;
        padding-left: 50px; }
    main section#access div.map {
      height: 0;
      overflow: hidden;
      padding-bottom: 40%;
      position: relative; }
      main section#access div.map iframe {
        position: absolute;
        left: 0;
        top: 0;
        height: 100%;
        width: 100%; }

footer {
  background: #BE0201;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding: 50px 0 30px; }
  footer a {
    display: block;
    width: 300px;
    margin: auto;
    margin-bottom: 30px; }
  footer small {
    text-align: center;
    color: #ffffff; }
