@charset "UTF-8";

/*
GENERAL STYLING
================================================ */
* { box-sizing: border-box; }
html { font-size: 62.5%; }
html * { visibility: hidden; }
html.wf-active * { visibility: visible; }
body {
  overflow-x: hidden;
  font-size: 1.6rem;
  letter-spacing: .1em;
  color: #000;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  font-family: 'Noto Sans JP', sans-serif;
  font-feature-settings: "palt";
}
a { text-decoration: none; }
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

/*
COMMON
================================================ */
@media (820px <= width) {
  #first .pc { display: block !important; }
  .sp { display: none !important; }
}
@media (width < 820px) {
  .pc { display: none !important; }
  .sp { display: block !important; }
}


/*
CONTENTS
================================================ */
main {
  color: #2f2f2f;
  font-family: 'Zen Maru Gothic', serif;
  letter-spacing: -.03em;
  padding-top: 80px;
}
main .inner {
  height: 100%;
  margin: 0 auto;  
  max-width: 100%;
  padding: 0;
  position: relative;
  width: 820px;
}
main section { position: relative; }

/* box common style */
.box {
  align-items: center;
  background-color: #fff;
  border-radius: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 auto 40px;
  padding: 20px;
  position: relative;
  width: 100%;
}
.box:before,
.box:after {
  content: '';
  display: block;
  position: absolute;
}

/* section-first */
.section-first h1 img { width: 100%; }

/* section-outline */
.section-outline {
  background-image: url(../img/bg_img_food.svg), url(../img/bg_pattern_dot.svg);
  background-position: center center, left top;
  background-repeat: no-repeat, repeat;
  background-size: 100%, auto;
  padding: 54px 0 50px;
}

.box.border-frame {
  border: 5px solid #8ad0da;
  padding: 40px 0 23px;
}
.box.border-frame h2 {
  display: block;
  left: 0;
  margin: 0;
  padding: 0;
  position: absolute;
  text-align: center;
  top: -1.7em;
  width: 100%;
}
.box.border-frame h2 span {
  background-color: #8ad0da;
  border-radius: 1.2em;
  color: #fff;
  display: inline-block;
  font-size: 24px;
  font-weight: 700;
  line-height: 2em;
  max-width: 100%;
  text-align: center;
  width: 450px;
}

.box.border-frame dl {
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 600px;
}
.box.border-frame dl div {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
.box.border-frame dl dt {
  display: block;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.45;
  margin: 0;
  padding: 0;
  position: relative;
  text-align: right;
  width: 40%;
}
.box.border-frame dl dt:after {
  content: '：';
}
.box.border-frame dl dd {
  color: #2f2f2f;
  display: block;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.45;
  margin: 0;
  padding: 0;
  width: 60%;
}
.box.border-frame dl div:last-child {
  border-top: 1px solid #8ad0da;
  margin: .9em 0 0;
  padding: .9em 0 0;
}
.box.border-frame dl div:last-child span {
  display: block;
  font-size: .8em;
  margin: .5em 0 0;
  text-align: center;
  width: 100%;
}
span.adjust-space {
  display: inline-block;
  width: .45em;
}
span.adjust-between {
  display: inline-block;
  letter-spacing: .05em;
}

.box-align-left { justify-content: flex-start; }
.official-application {
  display: flex;
  margin: 0;
  width: 72%;
}
.official-application figure {
  margin-right: 20px;
  width: 22%;
}
.official-application figure img { width: 100%; }
.official-application div { width: 75%; }
.official-application h2 {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.36;
  margin: 0;
  padding: 0;
}
.official-application h2 + p {
  font-size: 16px;
  line-height: 1.75;
  margin: 0;
  padding: 0;
}
.official-application ul {
  display: flex;
  gap: 20px;
  margin: .5em 0 0;
  padding: 0;
  width: 100%;
}
.official-application li { display: block; }
.official-application a {
  display: block;
  width: 100%;
}
.official-application a img {
  display: block;
  height: 55px;
}
.official-application + img {
  display: block;
  position: absolute;
  right: -.7em;
  top: -2em;
  width: 31%;
}

.event-frame {
  margin-bottom: 20px;
  padding: 20px 0 0;
}
.event-information {
  display: block;
  margin: 0;
  padding: 0;
}
.event-information div {
  align-items: center;
  border-bottom: 1px solid #63bbc8;
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  padding: .4em 0;
  width: 88%;
}
.event-information div:last-child { border-bottom: none; }
.event-information dt {
  color: #63bbc8;
  display: block;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding: 0;
  width: 24%;
}
.event-information dt span {
  display: block;
  padding: 0 0 0 1.5em;
  position: relative;
}
.event-information dt span:before {
  background-image: url(../img/icon_anchor.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  height: 1.5em;
  left: 0;
  position: absolute;
  top: 0;
  width: 1em;
}
.event-information dd {
  display: block;
  font-size: 20px;
  line-height: 1.5;
  width: 76%;
}
.event-information dd + p {
  font-size: .65em;
  line-height: 1.46;
  margin: .5em 0;
  padding: 0;
}
.event-attention {
  background-color: #ffe8e9;
  border-radius: 0 0 20px 20px;
  display: flex;
  justify-content: center;
  padding: 1em 0;
  width: 100%;
}
.event-attention span {
  color: #c9161d;
  display: block;
  font-size: 13px;
  line-height: 1.46;
  width: 88%;
}

.outline-link { margin: 0; }
.outline-link ul {
  display: flex;
  gap: 0 10px;
  justify-content: center;
  margin: 0 0 16px;
}
.outline-link li a {
  align-items: center;
  border: 3px solid #63bbc8;
  border-radius: 10px;
  box-shadow: 5px 5px 0 rgba(0, 160, 184, .2);
  display: flex;  
  font-size: 20px;
  font-weight: 700;
  height: 3em;
  padding: 0;
  text-decoration: none;
  transition: all .3s;
  width: 364px;
}
li.reservation a {
  background: #63bbc8;
  color: #fff;
}
li.qa a {
  background-color: #fff;
  color: #63bbc8;
}
.outline-link li a span {
  display: block;
  position: relative;
  text-align: center;
  width: 100%;
}
.outline-link li a span:after {
  border-bottom-style: solid;
  border-bottom-width: 2px;
  border-left: none;
  border-right-style: solid;
  border-right-width: 2px;
  border-top: none;
  content: '';
  display: block;
  height: 5px;
  position: absolute;
  right: 1em;
  top: .4em;
  transform: rotate(-45deg);
  width: 5px;
}
li.reservation a span:after {
  border-bottom-color: #fff;
  border-right-color: #fff;
}
li.qa a span:after {
  border-bottom-color: #63bbc8;
  border-right-color: #63bbc8;
}
.outline-link li a:hover {
  box-shadow: none;
  transform: translateY(5px);
}

/* section-goods */
.section-goods {
  background-image: url("../img/bg_pattern_stripe.svg");
  background-position: left top;
  background-repeat: repeat;
  background-size: auto;
  padding: 70px 0 50px;
}

.goods-frame { margin: 0 0 55px; }
.goods-frame-wrap {
  display: flex;
  justify-content: space-between;
  width: 100%;
}
.goods-frame-inner {
  height: 100%;
  padding-top: 5em;
}
.goods-frame.goods04,
.goods-frame.goods05 {
  margin-bottom: 0;
  width: 48%;
}
.goods-frame:before {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  height: 125px;
  left: -1.2em;
  position: absolute;
  top: -2.2em;
  width: 210px;
}
.goods-frame.goods01:before { background-image: url(../img/item_icon_01.svg); }
.goods-frame.goods02:before { background-image: url(../img/item_icon_02.svg); }
.goods-frame.goods03:before { background-image: url(../img/item_icon_03.svg); }
.goods-frame.goods04:before { background-image: url(../img/item_icon_04.svg); }
.goods-frame.goods05:before { background-image: url(../img/item_icon_05.svg); }

.goods-frame-figure,
.goods-frame-body { width: 49%; }
.goods-frame.goods04 .goods-frame-figure,
.goods-frame.goods05 .goods-frame-figure {
  margin: 0 auto;
  padding: 0 0 4.5em;
  text-align: center;
  width: 80%;
}
.goods-frame.goods04 .goods-frame-body,
.goods-frame.goods05 .goods-frame-body { width: 100%; }
.goods-name {
  color: #63bbc8;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.36;
  margin: 0;
  padding: 0 0 .5em;
}
.goods-spec {
  align-items: flex-start;
  display: flex;
  margin: 0 0 .7em;
}
.goods-spec-title {
  display: block;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
  padding: 0 1em 0 0;
  position: relative;
}
.goods-spec-title:after {
  content: '';
  border-bottom: 3px solid transparent;
  border-left: 3px solid #63bbc8;
  border-right: 0;
  border-style: solid;
  border-top: 3px solid transparent;
  height: 0;
  position: absolute;
  right: .3em;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
}
.goods-spec-title.no-arrow:after { display: none; }
.goods-spec-title + span {
  display: block;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
  padding: 0;
}
.goods-spec dl {
  display: block;
  margin: 0;
  padding: 0;
}
.goods-spec dl div {
  display: flex;
}
.goods-spec dt,
.goods-spec dd {
  display: block;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.4;
  margin: 0;
  padding: 0;
}

.goods-spec dt {
  padding-right: 1em;
  position: relative;
}
.goods-spec dt:after {
  content: '：';
  right: 0;
  position: absolute;
  top: 0;
}

.goods01 dt.blank-space { padding-right: 5.8em; }
.goods02 dt.blank-space,
.goods03 dt.blank-space { padding-right: 1.97em; }

.goods-spec-sentence {
  font-size: 15px;
  line-height: 1.6;
  margin: 0;
  padding: 0;
  width: 85%;
}
.goods-frame.goods04 .goods-spec-sentence,
.goods-frame.goods05 .goods-spec-sentence { width: 100%; }

.goods-spec-supplement {
  font-size: 12px;
  line-height: 2;
  margin: 1em 0 0;
  padding: 0;
  width: 90%;
}
.goods-frame.goods04 .goods-spec-supplement,
.goods-frame.goods05 .goods-spec-supplement { line-height: 1.25; }

.section-supplement {
  font-size: 12px;
  line-height: 1.25;
  margin: 1.6em 0 0;
  padding: 0;
}


/* section-about */
.section-about {
  background-color: #ffe7b1;
  padding: 50px 0;
}

.about-frame-wrap {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 30px 0;
  width: 95%;
}
.about-frame-figure { width: 30%; }
.about-frame-body {
  font-size: 15px;
  line-height: 1.6;
  width: 65%;
}