@charset "UTF-8";

/* ========================================
   common
   ======================================== */

body {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
}

#main p {
  font-size: 16px;
  text-align: center;
}

/* ========================================
   mainVisual
   ======================================== */

.mainVisual {
  position: relative;
  margin: 0 auto;
  max-width: 1440px;
  overflow: hidden;
}

.mainVisual h1 {
  margin: 0;
}

.mainVisual h1 img {
  display: block;
  width: 100%;
}

.copy {
  position: absolute;
  width: 11%;
  top: 60px;
  right: 33%;
  animation: fadeIn 1.5s ease-out 1 both;
  animation-delay: 0.3s;
}

.fair {
  position: absolute;
  width: 14%;
  top: 38px;
  left: 24%;
  animation: fadeIn 1.5s ease-out 1 both;
  animation-delay: 1s;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* ========================================
   menuArea
   ======================================== */

.menuArea {
  position: relative;
  background: url(../img/bg_pattern_04.png) no-repeat bottom;
  padding-bottom: 130px;
}

.menuInner ul img {
  max-width: 64%;
  margin: 0 auto;
  display: block;
}

.menuInner ul li {
  padding: 40px 0;
}

.menuInner ul li#negishio_maguro {
  background: url(../img/bg_pattern_01.png);
}

.menuInner ul li#maguro_tataki {
  background: url(../img/bg_pattern_02.png);
}

.menuInner ul li#maguro_yukke {
  background: url(../img/bg_pattern_03.png);
}

.linkBtn {
  display: block;
  width: 318px;
  margin: 20px auto 0;
  padding: 16px 0;
  border-radius: 60px;
  background-image: url(../img/bg_btn.png);
  color: #fff;
  font-size: 20px;
  text-align: center;
}

.menuArea .linkBtn {
  margin-top: 130px;
}

.animeWrapper {
  position: absolute;
  bottom: 0;
  left: 10%;
  display: flex;
  align-items: flex-end;
}

.animeWrapper #oyako {
  width: 86px;
}

/* ========================================
   linksArea
   ======================================== */

.linksArea h2 {
  margin: 0 0 16px;
  font-size: 24px;
  text-align: center;
}

.linksArea .online {
  margin: 32px auto;
  max-width: 980px;
}

.linksArea .online ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.linksArea .online li {
  width: 24.5%;
}

.linksArea .online li img {
  border-radius: 5px;
}

.linksArea .variousLinks {
  margin-bottom: 40px;
}

.linksArea .mobileOrder {
  display: flex;
  justify-content: center;
  margin-bottom: 16px;
}

.linksArea .shop {
  padding: 50px 0;
  background-color: #fff;
  text-align: center;
}

.linksArea .shop img {
  margin-top: 16px;
}

/* ========================================
   たまごの割れるアニメーション
   ======================================== */

.stage {
  position: relative;
  width: 155px;
  height: 900px;
  overflow: hidden;
}

/* 丼 */
.donburi {
  position: absolute;
  bottom: 0;
  z-index: 1;
  width: 155px;
}

/* 卵共通 */
.egg {
  position: absolute;
  left: 50%;
  width: 100px;
  transform: translateX(-50%);
}

/* 通常卵 */
.whole-egg {
  top: 80px;
  z-index: 5;
  width: 75px;
}

/* ヒビ */
.cracked-egg {
  top: 80px;
  z-index: 6;
  width: 75px;
  opacity: 0;
}

/* 殻 */
.shell {
  top: 80px;
  z-index: 5;
  opacity: 0;
}

/* 黄身 */
.yolk {
  position: absolute;
  left: 50%;
  z-index: 3;
  width: 70px;
  opacity: 0;
  transform: translate(-50%, 0);
}

/* 揺れ */
@keyframes shake {
  0% {
    transform: translateX(-50%) rotate(0deg);
  }
  25% {
    transform: translateX(-50%) rotate(5deg);
  }
  50% {
    transform: translateX(-50%) rotate(-5deg);
  }
  75% {
    transform: translateX(-50%) rotate(3deg);
  }
  100% {
    transform: translateX(-50%) rotate(0deg);
  }
}

.shake {
  animation: shake 0.5s ease;
}

/* 落下（topは触らない） */
@keyframes fall {
  from {
    transform: translate(-50%, 0);
  }
  to {
    transform: translate(-50%, 580px);
  }
}

.fall {
  animation: fall 0.8s ease forwards;
}

/* フェード */
@keyframes fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

.fade-out {
  animation: fadeOut 0.4s forwards;
}

/* ========================================
   footer
   ======================================== */

#footer {
  padding-top: 40px;
}

/* ========================================
   p-gotop（ページトップへ）
   ======================================== */

.p-gotop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition:
    opacity 0.4s ease,
    transform 0.4s ease,
    visibility 0.4s ease;
}

.p-gotop.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.p-gotop.is-hide {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* ========================================
   レスポンシブ
   ======================================== */

@media screen and (max-width: 700px) {
  .pc_view {
    display: none !important;
  }

  .copy {
    width: 28%;
    top: 40px;
    right: 10%;
  }

  .fair {
    width: 34%;
    top: 38px;
    left: 10%;
  }

  .menuInner ul img {
    max-width: 309px;
  }

  .animeWrapper {
    left: 0;
    bottom: 0;
  }

  .stage {
    width: 155px;
  }

  .whole-egg,
  .cracked-egg {
    width: 70px;
  }

  .yolk {
    width: 67px;
  }

  .menuArea {
    padding-bottom: 240px;
  }

  .menuInner ul {
    flex-wrap: wrap;
  }

  .linksArea .online ul {
    margin: 32px 6px;
  }

  .linksArea .online li.w100 {
    margin: 0 6px 6px;
    width: 100%;
    text-align: center;
  }

  .linksArea .online li.w100 img {
    width: 100%;
  }

  .linksArea .online li.w50 {
    width: 49%;
  }

  .linksArea .shop {
    padding: 50px 20px;
  }
}

@media screen and (min-width: 701px) {
  .sp_view {
    display: none !important;
  }
}
