@charset "utf-8";

/* ----- common ----- */
.ramenterrace {
  margin-top: 10px;
  font-family: "Zen Old Mincho", serif;
  color: #252121;
}
@media screen and (min-width: 768px) {
  .ramenterrace {
    margin-top: 80px;
  }
}

.ramenterrace-anounce {
  margin-bottom: 40px;
  padding: 16px 4%;
  border: 2px solid red;
  text-align: center;
}

.ramenterrace-anounce > p {
  line-height: 1.5;
  color: red;
}

@media screen and (min-width: 768px) {
  .ramenterrace-anounce {
    margin-bottom: 60px;
  }
}

/* ----- mv ----- */
.mv {
  display: block;
}

/* ----- lead ----- */
.lead {
  padding: 75px 4% 60px;
  padding-top: 40px;
  padding-bottom: 100px;
  background: top/contain repeat url(../img/ramenterrace/lead_bg.webp);
  text-align: center;
}
.lead-inner {
  position: relative;
  margin: 0 auto;
  max-width: 1100px;
}
.lead-ttl {
  margin-bottom: 15px;
  line-height: 1.5;
  font-size: 2.4rem;
  font-weight: 700;
}
.lead-txt {
  line-height: 2;
  font-size: 1.4rem;
}
.lead-deco {
  position: absolute;
}
.lead-deco._noren {
  top: -5%;
  top: 23%;
  right: 4%;
  width: calc(171px / 2);
}
.lead-deco._noren img {
  aspect-ratio: 171 / 108;
}
.lead-deco._stamp {
  bottom: -15%;
  left: 4%;
  width: calc(112px / 2);
}
.lead-deco._stamp img {
  aspect-ratio: 112 / 117;
}

@media screen and (min-width: 768px) {
  .lead {
    padding: 100px 30px 140px;
    padding-top: 40px;
    background-size: 750px;
  }
  .lead-ttl {
    font-size: 3.2rem;
  }
  .lead-txt {
    margin-inline: auto;
    max-width: 1080px;
    font-size: 2rem;
  }
  .lead-deco._noren {
    top: -10%;
    top: 27%;
    right: 8%;
    width: 171px;
  }
  .lead-deco._stamp {
    bottom: -33%;
    bottom: -19%;
    left: 5%;
    width: 112px;
  }
}

/* ----- shop ----- */
.shop {
  position: relative;
  padding: 40px 4% 60px;
  overflow: hidden;
}
.shopTtl {
  margin-bottom: 30px;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
}
.shopTtl span {
  position: relative;
  margin: 0 auto 5px;
  display: block;
  width: fit-content;
  font-size: 0.8em;
  font-weight: 400;
}
.shopTtl span::before,
.shopTtl span::after {
  content: "";
  position: absolute;
  top: 50%;
  display: block;
  width: 20px;
  height: 2px;
  border-top: 1px solid #252121;
  border-bottom: 1px solid #252121;
}
.shopTtl span::before {
  right: calc(100% + 5px);
}
.shopTtl span::after {
  left: calc(100% + 5px);
}
.shop-ttl {
  margin-inline: auto;
  width: calc(687px / 2);
}
.shop-ttl img {
  aspect-ratio: 687 / 210;
}
.shop-deco {
  position: absolute;
  z-index: 0;
  opacity: 0.8;
}
.shop-flex {
  position: relative;
  z-index: 1;
}
.shop-ramen {
  position: relative;
  margin: auto;
  display: block;
}
.shop-ramenName {
  text-align: center;
  font-size: 1.3rem;
  font-weight: 700;
  text-shadow:
    1px 1px 0 #fff,
    -1px 1px 0 #fff,
    1px -1px 0 #fff,
    -1px -1px 0 #fff;
}
.shop-steam {
  position: absolute;
  z-index: 1;
  width: 150px;
  height: 358px;
  pointer-events: none;
  opacity: 0;
}
.shop-steam img {
  aspect-ratio: 150 / 358;
}
.shop-steam._1 {
  right: 0;
  animation: steam01 10s infinite linear;
}
.shop-steam._2 {
  left: 0;
  animation: steam02 14s infinite linear;
}
.shop-steam._3 {
  margin: auto;
  right: 0;
  left: 0;
  animation: steam02 12s infinite linear;
  animation-delay: 6s;
}
@keyframes steam01 {
  0% {
    bottom: 0px;
    filter: blur(16px);
    transform: rotateY(0deg);
    transform: scale(0.6, 1);
    opacity: 0;
  }
  11% {
    opacity: 0.6;
  }
  33% {
    transform: rotateY(40deg);
    transform: scale(1, 1.4);
    opacity: 1;
  }
  66% {
    transform: rotateY(10deg);
    transform: scaleY(1.8, 1);
    opacity: 0.8;
  }
  100% {
    bottom: 200px;
    filter: blur(20px);
    transform: rotateY(60deg);
    transform: scaleY(2, 1.8);
    opacity: 0;
  }
}
@keyframes steam02 {
  0% {
    bottom: 0px;
    filter: blur(16px);
    transform: rotateY(0deg);
    transform: scale(0.6, 0.6);
    opacity: 0;
  }
  11% {
    opacity: 0.6;
  }
  33% {
    transform: rotateY(40deg);
    transform: scale(0.8, 1);
    opacity: 1;
  }
  66% {
    transform: rotateY(2deg);
    transform: scaleY(1, 1.2);
  }
  100% {
    bottom: 200px;
    filter: blur(20px);
    transform: rotateY(50deg);
    transform: scaleY(1.2, 1.4);
    opacity: 0;
  }
}
.shop-logo {
  margin: auto;
  display: block;
}
.shop-closed {
  margin-block: 0.5em;
  font-size: 1.4rem;
  font-weight: 700;
  color: #ff0000;
}
.shop-strong {
  margin-bottom: 10px;
  font-size: 2rem;
  font-weight: 700;
  text-shadow:
    1px 1px 0 #fff,
    -1px 1px 0 #fff,
    1px -1px 0 #fff,
    -1px -1px 0 #fff;
}
.shop-txt {
  line-height: 1.75;
  font-size: 1.4rem;
  text-shadow:
    1px 1px 0 #fff,
    -1px 1px 0 #fff,
    1px -1px 0 #fff,
    -1px -1px 0 #fff;
}
.shop-award {
  margin-top: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.shop-awardMark {
  width: 15%;
  aspect-ratio: 1 / 1;
}
.shop-awardList {
  width: calc(85% - 10px);
}
.shop-awardList > li {
  line-height: 1.5;
  font-size: 1.2rem;
  font-weight: 700;
}
.shop-awardList > li + li {
  margin-top: 0.5em;
}

@media screen and (min-width: 768px) {
  .shop {
    padding: 70px 30px 80px;
  }
  .shopTtl {
    margin-bottom: 60px;
    font-size: 3.2rem;
  }
  .shopTtl span {
    margin-bottom: 10px;
  }
  .shopTtl span::before,
  .shopTtl span::after {
    top: 45%;
    width: 40px;
    height: 4px;
    border-width: 2px;
  }
  .shop-ttl {
    width: 588px;
  }
  .shop-flex {
    margin-inline: auto;
    max-width: 1152px;
    display: flex;
    align-items: center;
    gap: 6%;
  }
  .shop-leftBox {
    width: 45%;
    display: flex;
    flex-direction: column-reverse;
  }
  .shop-rightBox {
    width: 49%;
  }
  .shop-steam {
    width: 250px;
    height: 600px;
  }
  .shop-ramenName {
    font-size: 1.6rem;
  }
  .shop-closed {
    font-size: 1.8rem;
  }
  .shop-strong {
    font-size: 3rem;
  }
  .shop-txt {
    font-size: 1.8rem;
  }
  .shop-award {
    gap: 20px;
  }
  .shop-awardList li {
    font-size: 1.8rem;
  }
}

.shopMenu {
  margin-top: 20px;
  position: relative;
  padding: 20px 20px 30px;
  background-position:
    0 0,
    0 0,
    100% 0,
    0 100%;
  background-size:
    3px 100%,
    100% 3px,
    3px 100%,
    100% 3px;
  background-repeat: no-repeat;
  background-image:
    linear-gradient(0deg, transparent 12%, #d6b47a 12%, #d6b47a 88%, transparent 88%),
    linear-gradient(90deg, transparent 5%, #d6b47a 5%, #d6b47a 95%, transparent 95%),
    linear-gradient(180deg, transparent 12%, #d6b47a 12%, #d6b47a 88%, transparent 88%),
    linear-gradient(270deg, transparent 5%, #d6b47a 5%, #d6b47a 95%, transparent 95%);
}
.shopMenu-pattern {
  position: absolute;
  display: block;
  width: 21px;
  height: auto;
  aspect-ratio: 1 / 1;
  background: center/contain no-repeat url(../img/ramenterrace/shop_menu_pattern.webp);
}
.shopMenu-pattern._tl {
  top: 0;
  left: 0;
  rotate: -90deg;
}
.shopMenu-pattern._tr {
  top: 0;
  right: 0;
}
.shopMenu-pattern._bl {
  bottom: 0;
  left: 0;
  rotate: -180deg;
}
.shopMenu-pattern._br {
  bottom: 0;
  right: 0;
  rotate: 90deg;
}
.shopMenu-ttl {
  margin-bottom: 10px;
  text-align: center;
  font-size: 1.8rem;
  font-weight: 700;
}
.shopMenu-item {
  padding-bottom: 5px;
  border-bottom: 1px solid #d6b47a;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  line-height: 1.25;
  font-size: 1.4rem;
}
.shopMenu-item + .shopMenu-item {
  margin-top: 10px;
}
.shopMenu-itemPrice::after {
  content: "(税込)";
  font-size: 0.8em;
}
@media screen and (min-width: 768px) {
  .shopMenu {
    padding: 30px 30px 50px;
    background-size:
      4px 100%,
      100% 4px,
      4px 100%,
      100% 4px;
    background-image:
      linear-gradient(0deg, transparent 12%, #d6b47a 12%, #d6b47a 88%, transparent 88%),
      linear-gradient(90deg, transparent 4%, #d6b47a 4%, #d6b47a 96%, transparent 96%),
      linear-gradient(180deg, transparent 12%, #d6b47a 12%, #d6b47a 88%, transparent 88%),
      linear-gradient(270deg, transparent 4%, #d6b47a 4%, #d6b47a 96%, transparent 96%);
  }
  .shopMenu-pattern {
    width: 30px;
  }
  .shopMenu-ttl {
    font-size: 2.4rem;
  }
  .shopMenu-item {
    border-width: 2px;
    font-size: 1.8rem;
  }
  .shopMenu-item + .shopMenu-item {
    margin-top: 15px;
  }
}

.shop-allergy {
  margin: 20px auto 0;
  padding-inline-end: 20px;
  font-size: 1.6rem;
}
@media screen and (min-width: 768px) {
  .shop-allergy {
    margin: 20px auto 0;
    padding-inline-end: 20px;
    font-size: 2rem;
  }
}

/* 01 */
._01 {
  padding-top: 60px;
  background: top/cover url(../img/ramenterrace/shop_bg01.webp);
}
._01 .shop-deco {
  top: 21%;
  right: -3px;
  width: calc(134px / 2);
}
._01 .shop-deco img {
  aspect-ratio: 134 / 893;
}
._01 .shop-ramen {
  width: calc(608px / 2);
}
._01 .shop-ramen > img {
  aspect-ratio: 608 / 494;
}
._01 .shop-steam {
  width: 230px;
  height: 550px;
}
._01 .shop-logo {
  margin: 20px auto 30px;
  width: calc(550px / 2);
}
._01 .shop-logo img {
  aspect-ratio: 550 / 175;
}
@media screen and (min-width: 768px) {
  ._01 {
    padding-top: 100px;
    padding-bottom: 170px;
  }
  ._01 .shop-deco {
    top: 33%;
    width: calc(134px / 1.3);
  }
  ._01 .shop-ramen {
    width: 100%;
  }
  ._01 .shop-logo {
    margin-block: 0 10px;
    width: 80%;
  }
}

/* 02 */
._02 {
  background: top/cover url(../img/ramenterrace/shop_bg02.webp);
}
._02 .shop-deco {
  top: 14%;
  left: -3px;
  width: calc(133px / 2);
}
._02 .shop-deco img {
  aspect-ratio: 133 / 553;
}
._02 .shop-ramen {
  width: calc(616px / 2);
}
._02 .shop-logo {
  margin-block: 30px;
  width: calc(550px / 2);
}
@media screen and (min-width: 768px) {
  ._02 .shop-deco {
    top: 26%;
    width: calc(133px / 1.3);
  }
  ._02 .shop-ramen {
    width: 100%;
  }
  ._02 .shop-logo {
    margin-block: 0 10px;
    width: 80%;
  }
}

/* 03 */
._03 {
  background: top/cover url(../img/ramenterrace/shop_bg03.webp);
}
._03 .shop-deco {
  top: 16%;
  left: -3px;
  width: calc(133px / 2);
}
._03 .shop-deco img {
  aspect-ratio: 133 / 420;
}
._03 .shop-ramen {
  width: calc(565px / 2);
}
._03 .shop-steam {
  width: 250px;
  height: 600px;
}
._03 .shop-logo {
  margin-block: 20px 30px;
  width: calc(550px / 2);
}
._03 .shop-txt {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  ._03 .shop-deco {
    top: 24%;
    width: calc(133px / 1.3);
  }
  ._03 .shop-ramen {
    width: 100%;
  }
  ._03 .shop-logo {
    margin: 0 auto 40px;
    width: 80%;
  }
  ._03 .shop-txt {
    margin-bottom: 20px;
  }
}

/* 04 */
._04 {
  background: top/cover url(../img/ramenterrace/shop_bg04.webp);
}
._04 .shop-deco:nth-of-type(1) {
  top: 13%;
  right: -3px;
  width: calc(134px / 2);
}
._04 .shop-deco:nth-of-type(1) img {
  aspect-ratio: 134 / 667;
}
._04 .shop-deco:nth-of-type(2) {
  top: 18%;
  left: -3px;
  width: calc(134px / 2);
}
._04 .shop-deco:nth-of-type(2) img {
  aspect-ratio: 134 / 787;
}
._04 .shop-ramen {
  width: calc(671px / 2);
}
._04 .shop-logo {
  margin: 20px auto 30px;
  width: calc(554px / 2);
}

@media screen and (min-width: 768px) {
  ._04 .shop-deco:nth-of-type(1) {
    top: 20%;
    width: calc(134px / 1.3);
  }
  ._04 .shop-deco:nth-of-type(2) {
    top: 30%;
    width: calc(134px / 1.3);
  }
  ._04 .shop-ramen {
    width: 100%;
  }
  ._04 .shop-logo {
    margin-block: 0 10px;
    width: 80%;
  }
}

/* 05 */
._05 {
  background: top/cover url(../img/ramenterrace/shop_bg05.webp);
}
._05 .shop-deco {
  top: 13%;
  right: -3px;
  width: calc(125px / 2);
}
._05 .shop-deco img {
  aspect-ratio: 125 / 377;
}
._05 .shop-ramen {
  width: calc(622px / 2);
}
._05 .shop-ramen > img {
  aspect-ratio: 622 / 493;
}
._05 .shop-steam {
  width: 200px;
  height: 477px;
}
._05 .shop-logo {
  margin: 20px auto 30px;
  width: calc(550px / 2);
}
._05 .shop-logo img {
  aspect-ratio: 550 / 175;
}
@media screen and (min-width: 768px) {
  ._05 .shop-deco {
    top: 24%;
    width: calc(125px / 1.3);
  }
  ._05 .shop-ramen {
    width: 100%;
  }
  ._05 .shop-logo {
    margin: 0 auto 30px;
    width: 80%;
  }
}

/* 06 */
._06 {
  background: top/cover url(../img/ramenterrace/shop_bg06.webp);
}
._06 .shop-deco {
  top: 15%;
  left: -3px;
  width: calc(129px / 2);
}
._06 .shop-deco img {
  aspect-ratio: 129 / 815;
}
._06 .shop-ramen {
  width: calc(637px / 2);
}
._06 .shop-ramen > img {
  aspect-ratio: 637 / 404;
}
._06 .shop-logo {
  margin-bottom: 30px;
  width: calc(550px / 2);
}
._06 .shop-logo img {
  aspect-ratio: 550 / 286;
}
@media screen and (min-width: 768px) {
  ._06 .shop-deco {
    top: 19%;
    width: calc(129px / 1.3);
  }
  ._06 .shop-ramen {
    width: 100%;
  }
  ._06 .shop-steam {
    width: 200px;
    height: 477px;
  }
  ._06 .shop-logo {
    margin-block: 0 20px;
    width: 80%;
  }
}

/* ----- map ----- */
.map {
  padding: 60px 4% 110px;
  background: top/cover url(../img/ramenterrace/map_bg.webp);
}

.map-ttl {
  margin-bottom: 15px;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
}
.map-ttl span {
  position: relative;
  margin: 0 auto 5px;
  display: block;
  width: fit-content;
  font-size: 0.8em;
  font-weight: 400;
}
.map-ttl span::before,
.map-ttl span::after {
  content: "";
  position: absolute;
  top: 50%;
  display: block;
  width: 20px;
  height: 2px;
  border-top: 1px solid #252121;
  border-bottom: 1px solid #252121;
}
.map-ttl span::before {
  right: calc(100% + 5px);
}
.map-ttl span::after {
  left: calc(100% + 5px);
}

.map-img {
  margin: 0 auto;
  display: block;
}

@media screen and (min-width: 768px) {
  .map {
    padding: 100px 30px 100px;
    background-size: 750px;
  }
  .map-ttl {
    margin-bottom: 30px;
    font-size: 3.2rem;
  }
  .map-ttl span {
    margin-bottom: 10px;
  }
  .map-ttl span::before,
  .map-ttl span::after {
    top: 45%;
    width: 40px;
    height: 4px;
    border-width: 2px;
  }
  .map-img {
    max-width: 800px;
  }
}

.map-subttl {
  margin-top: 45px;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
}

.map-hours {
  margin: 15px auto 0;
  width: 100%;
  max-width: 800px;
  background-color: #fff;
}
.map-hours thead {
  background-color: #eee;
}
.map-hours thead td {
  padding: 0.5em;
  border: 1px solid #ccc;
  text-align: center;
  font-weight: bold;
}
.map-hours tbody th {
  text-align: center;
  vertical-align: middle;
  font-weight: normal;
}
.map-hours tbody th,
.map-hours tbody td {
  padding: 0.5em;
  border: 1px solid #ccc;
  line-height: 1.5;
}

/* ----- preparation ----- */
.preparation {
  padding: 75px 4% 60px;
  background: top/cover url(../img/ramenterrace/shop_bg01.webp);
  text-align: center;
}

.preparation-txt {
  font-size: 2.4rem;
}

@media screen and (min-width: 768px) {
  .preparation-txt {
    font-size: 4.8rem;
  }
}
