@charset "UTF-8";
/* メインカラー */
/* サブカラー */
/* アクセントカラー */
/* breakfast
---------------------------------------------------------------------- */
.breakfast__wrap {
  background: url(../images/bg_breakfast.png) no-repeat;
  background-size: cover;
  position: relative; }

.breakfast__head {
  padding: 90px 0 100px;
  position: relative; }

.breakfast__ttl {
  text-align: center; }
  .breakfast__ttl span {
    display: inline-block;
    color: #1EA264;
    font-size: 42px;
    font-weight: bold;
    letter-spacing: 0.02em;
    line-height: 1.57;
    text-align: center;
    position: relative; }
  .breakfast__ttl span::before,
  .breakfast__ttl span::after {
    content: "";
    display: block;
    position: absolute;
    height: 130px;
    width: 2px;
    background-color: #1EA264; }
  .breakfast__ttl span::before {
    bottom: 0;
    left: -45px;
    transform: rotate(-24deg); }
  .breakfast__ttl span::after {
    bottom: 0;
    right: -45px;
    transform: rotate(24deg); }

.breakfast__deco {
  width: 30%;
  max-width: 530px;
  position: absolute;
  bottom: 0;
  right: 0; }

.breakfast__type {
  display: flex; }
  .breakfast__type li {
    flex: 1; }

.breakfast__type_img {
  width: 100%;
  height: 534px;
  position: relative; }
  .breakfast__type_img img {
    width: 100%;
    height: 100%;
    object-fit: cover; }
  .breakfast__type_img figcaption {
    color: #fff;
    background-color: #754C24;
    position: absolute;
    top: 0;
    right: 0;
    font-size: 34px;
    letter-spacing: 0.1em;
    font-weight: 500;
    writing-mode: vertical-rl;
    padding: 1.15em 0em; }

.breakfast__type li:last-of-type figcaption {
  background-color: #1EA264;
  right: initial;
  left: 0; }

.breakfast__content {
  padding: 45px 0 60px; }

.breakfast__ttl {
  font-size: 34px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #35445C;
  text-align: center; }

p.breakfast__txt {
  color: #35445C;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-align: center; }

.breakfast__dl {
  display: flex;
  color: #1EA264;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.1em;
  justify-content: center; }

.breakfast_info {
  padding: 60px 0 60px;
  background-color: #fff; }

.breakfast_info__ttl {
  text-align: center;
  font-size: 24px;
  letter-spacing: 0.1em;
  line-height: 1.91;
  font-weight: 500;
  color: #35445C; }
  .breakfast_info__ttl::before {
    content: "";
    display: block;
    width: 68px;
    height: 57px;
    margin: 0 auto 30px;
    background: url(../../images/icon_megaphone.svg) no-repeat;
    background-size: contain; }

/*  breakfast_venue
---------------------------------------------------------------------- */
.breakfast_venue {
  display: flex;
  height: 606px; }
  .breakfast_venue li {
    width: 43%; }
  .breakfast_venue li:first-of-type {
    width: 57%; }
  .breakfast_venue img {
    width: 100%;
    height: 100%;
    object-fit: cover; }

.breakfast_venue__img {
  height: 100%; }

.breakfast_venue__body {
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-direction: column;
  height: 100%;
  width: 100%;
  background: url(../images/breakfast_venue02.jpg) no-repeat;
  background-size: cover;
  padding: 15px 30px 45px 68px; }

.breakfast_venue__content {
  text-align: center;
  display: inline-block; }

.breakfast_venue__ttl {
  font-size: 36px;
  font-weight: bold;
  letter-spacing: 0.02em; }

.breakfast_venue__txt {
  font-size: 26px;
  font-weight: bold;
  letter-spacing: 0.02em; }

.breakfast_venue__dl {
  font-size: 18px;
  letter-spacing: 0.1em;
  line-height: 1.9; }
  .breakfast_venue__dl dt, .breakfast_venue__dl dd {
    letter-spacing: 0.1em; }

/*  dinner_group
---------------------------------------------------------------------- */
.dinner_group {
  padding: 95px 0 117px;
  background: url(../images/bg_group.jpg) no-repeat;
  background-size: cover; }

.dinner_group__box {
  padding: 2.188em;
  max-width: 808px;
  margin: 0 auto;
  border-radius: 3.247em;
  text-align: center;
  background-color: rgba(255, 255, 255, 0.5); }

.dinner_group__ttl {
  color: #1EA264;
  font-size: 36px;
  letter-spacing: 0.02em;
  font-weight: bold;
  line-height: 1.5; }

.dinner_group__tel {
  display: inline-block;
  text-align: center;
  font-size: 52px;
  font-weight: 500;
  letter-spacing: 0.02em;
  pointer-events: none; }

.dinner_group__dl {
  display: flex;
  justify-content: center;
  font-size: 24px;
  letter-spacing: 0.02em;
  font-weight: 500;
  gap: 27px;
  margin-left: -14px; }

#inokori {
  scroll-margin-top: 45px; }

/*  restaurant
---------------------------------------------------------------------- */
.restaurant {
  padding: 108px 0 117px;
  width: 100%;
  height: 1175px;
  background: url(../images/bg_restaurant.jpg) no-repeat;
  background-size: cover;
  position: relative;
  overflow: hidden; }

.restaurant__head {
  color: #fff;
  background-color: #000000;
  font-size: 28px;
  font-weight: bold;
  padding: .8em;
  text-align: center; }

.restaurant__inr {
  position: relative; }

.restaurant__content {
  top: 10px;
  right: 5.5%;
  position: absolute;
  color: #fff;
  width: 335px;
  text-align: left; }

.restaurant_ttl {
  font-size: 40px;
  line-height: 1.65;
  font-weight: bold; }
  .restaurant_ttl .restaurant__type {
    display: block;
    font-size: 20px;
    line-height: 1.4;
    font-weight: bold; }
    .restaurant_ttl .restaurant__type span {
      display: block;
      font-size: 24px; }

.restaurant__txt {
  font-size: 18px;
  line-height: 1.77; }

.restaurant__img01 {
  position: absolute;
  left: calc(55.7% - 55.7vw);
  width: calc(55.7vw + 75px);
  height: 100%;
  min-height: 493px;
  max-height: 493px; }

.restaurant__img02 {
  position: absolute;
  top: 415px;
  right: calc(55.7% - 55.7vw);
  width: calc(55.7vw - 55px);
  height: 100%;
  min-height: 540px;
  max-height: 540px; }

.restaurant__img03 {
  position: absolute;
  top: 550px;
  width: calc(27vw + 50px);
  height: 100%;
  min-height: 324px;
  max-height: 324px;
  min-width: 486px;
  right: calc(50% + 4vw); }

.restaurant__img01 img,
.restaurant__img02 img,
.restaurant__img03 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative; }

/*  restaurant_menu
---------------------------------------------------------------------- */
.restaurant_menu {
  background-color: #000000;
  padding-bottom: 170px; }

/*  collabo
---------------------------------------------------------------------- */
.collabo {
  color: #fff;
  padding: 100px 0 80px;
  background: url(../images/bg_collabo.png) no-repeat;
  background-size: cover;
  font-size: 20px;
  line-height: 2.4;
  text-align: center; }
  .collabo p {
    text-align: center;
    position: relative;
    z-index: 2; }

.collabo__inr {
  position: relative; }

.collabo__ttl {
  font-size: 40px;
  font-weight: bold;
  margin-bottom: 25px;
  line-height: 1.8; }
  .collabo__ttl span {
    display: inline-block;
    padding: 0 40px; }

.collabo__logo {
  position: absolute;
  bottom: -53px;
  right: 31px;
  z-index: 1; }

/*  set_menu
---------------------------------------------------------------------- */
.set_menu {
  padding: 110px 0 50px; }

.set_menu__list {
  display: flex;
  justify-content: space-between; }
  .set_menu__list > li {
    width: 48%;
    max-width: 530px; }

.set_menu__content {
  color: #fff;
  padding: 0 30px 0; }

.set_menu__ttl {
  font-size: 32px;
  font-weight: bold;
  text-align: center;
  line-height: 1.4; }

.set_menu__dl {
  display: flex;
  justify-content: center;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  font-size: 24px;
  font-weight: bold;
  padding: 0.2em; }

.set_menu__txt {
  font-size: 18px;
  line-height: 1.61;
  text-indent: -1em;
  padding-left: 1em; }

.set_menu__catch {
  color: #fff;
  font-size: 40px;
  font-weight: bold;
  text-align: center; }
  .set_menu__catch span {
    display: block;
    font-size: 20px; }

/*  restaurant_contact
---------------------------------------------------------------------- */
.restaurant_contact__ttl {
  color: #Fff;
  background-color: #C1272D;
  font-size: 32px;
  font-weight: bold;
  padding: 0.4em;
  text-align: center; }

.restaurant_contact__content {
  padding: 2.3em 2em 3em;
  background-color: #FFFFFF; }
  .restaurant_contact__content p {
    font-size: 20px;
    line-height: 2;
    text-align: center; }

.restaurant_contact__dl {
  text-align: center; }
  .restaurant_contact__dl dt {
    font-size: 32px;
    font-weight: 500; }
  .restaurant_contact__dl dd {
    font-size: 50px;
    font-weight: 500;
    line-height: 1.16; }

/*# sourceMappingURL=meal.css.map */
