@charset "UTF-8";
@font-face {
  font-family: seaweed-script-pro;

  src: url(../font/SeaweedScript-Regular.ttf);
}

@font-face {
  font-family: source-han-sans-cjk-ja;

  src: url(../font/SourceHanSansJP-Regular.otf);
}

@font-face {
  font-family: "petersburg-web";

  src: url(../font/Petersburg-Regular.woff);
}

@font-face {
  font-family: Raleway;

  src: url(../font/Raleway-VariableFont_wght.ttf);
}

@font-face {
  font-family: Monsieur La Doulaise;

  src: url(../font/MonsieurLaDoulaise-Regular.ttf);
}

@font-face {
  font-family: Notera;

  src: url(../font/Notera_PersonalUseOnly.ttf);
}

/* ----------------------------------------------------------

Base Style

---------------------------------------------------------- */
@font-face {
  font-family: "icomoon";
  font-weight: normal;
  font-style: normal; 

  src: url("../font/icomoon.eot?i8fcpd");
  src: url("../font/icomoon.eot?i8fcpd#iefix") format("embedded-opentype"), url("../font/icomoon.ttf?i8fcpd") format("truetype"), url("../font/icomoon.woff?i8fcpd") format("woff"), url("../font/icomoon.svg?i8fcpd#icomoon") format("svg");
}

[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change font */
  font-family: "icomoon" !important;
  font-weight: normal;
  font-style: normal;
  font-variant: normal;
  line-height: 1;

  text-transform: none;

  speak: none;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-list:before {
  content: "\e906";
}

.icon-access:before {
  content: "\e900";
}

.icon-facebook:before {
  content: "\e901";
}

.icon-heart:before {
  content: "\e902";

  color: #dea398;
}

.icon-instagram:before {
  content: "\e903";
}

.icon-tel:before {
  content: "\e904";
}

.icon-time:before {
  content: "\e905";
}

@font-face {
  font-family: "icomoon";
  font-weight: normal;
  font-style: normal; 

  src: url("../font/icomoon.eot?phylq9");
  src: url("../font/icomoon.eot?phylq9#iefix") format("embedded-opentype"), url("../font/icomoon.ttf?phylq9") format("truetype"), url("../font/icomoon.woff?phylq9") format("woff"), url("../font/icomoon.svg?phylq9#icomoon") format("svg");
}

[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change font */
  font-family: "icomoon" !important;
  font-weight: normal;
  font-style: normal;
  font-variant: normal;
  line-height: 1;

  text-transform: none;

  speak: none;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-tel:before {
  content: "\e904";
}

.icon-access:before {
  content: "\e900";
}

.icon-service01:before {
  content: "\e912";

  color: #dea398;
}

.icon-service02:before {
  content: "\e913";

  color: #dea398;
}

.icon-service03:before {
  content: "\e914";

  color: #dea398;
}

body {
  font-family: source-han-sans-cjk-ja, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;

  overflow-x: hidden;

  text-align: justify;

  color: #333;

  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
      -ms-text-size-adjust: none;
          text-size-adjust: none;
}

a {
  text-decoration: none; 

  color: inherit;
}

table,
ul ul,
ol ol {
  font-size: 100%;
}

td ul,
td p,
td dt,
td dd {
  font-size: 100%;
}

select,
input,
textarea,
button {
  font-size: 99%;
}

strong,
em {
  font-weight: inherit;
}

.en {
  font-family: "Raleway", sans-serif;
  font-weight: 400;
  line-height: 1.0;

  letter-spacing: 1px;
}

.tit {
  font-family: "petersburg-web", serif;
  font-weight: 300;
}

.sub {
  font-family: source-han-serif-japanese, serif;
  font-weight: 300;
}

a {
  -webkit-transition: opacity .3s;
       -o-transition: opacity .3s;
          transition: opacity .3s; 
  text-decoration: none;

  color: inherit;
}

a:hover,
a:active,
a:hover img {
  opacity: .8;
}

::-moz-selection,
::-moz-selection {
  background: #f7a6b3;
}

::selection,
::-moz-selection {
  background: #f7a6b3;
}

*:focus {
  outline: none;
}

#topcontrol {
  z-index: 1000;
}

#MenuNavi {
  display: none;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/*  中面おすすめフェア
---------------------------------------------------*/
.section_recfair {
  width: 100%;
  margin: 0 auto;
  padding: 60px 0 70px;

  text-align: center;

  background: #f5f5f5;
}
.section_recfair .list .box .ph {
  position: relative;

  overflow: hidden;

  height: 306px;
  margin: 0 0 16px; 

  border-radius: 10px;
}
@media screen and (max-width: 760px) {
  .section_recfair .list .box .ph {
    height: 74vw;
  }
}
.section_recfair .list .box .iconbox {
  margin: 5px 0;
}
.section_recfair .list .box .iconbox li {
  font-size: 11px;

  display: inline-block;
  overflow: hidden;

  min-width: auto;
  max-width: 100%;
  padding: 1px 10px 1px; 

  white-space: nowrap;
     text-overflow: ellipsis;

  -o-text-overflow: ellipsis;
  -webkit-box-flex: 0;
  -ms-flex: none;
      flex: none;
}
@media screen and (min-width: 0\0) {
  .section_recfair .list .box .iconbox li {
    padding: 1px 10px 2px;
  }
}
.section_recfair .list .box .ph img {
  position: absolute;
  top: 50%;
  left: 50%;

  width: auto;
  height: 100%;

  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 760px) {
  .section_recfair .list .box .ph img {
    width: 100%;

    border-radius: 10px; 

    -o-object-fit: cover;
       object-fit: cover;
  }
}
.section_recfair h3.font01 {
  font-family: "petersburg-web", serif;
  font-size: 34px;
  font-weight: inherit; 
  line-height: 1;

  margin-bottom: 5px;
}
.section_recfair .catch {
  font-family: "petersburg-web", serif;
  font-size: 20px;

  margin-bottom: 30px;
}

.section_partyReport {
  margin: 0;
  padding: 70px 0;

  color: #fff; 
  background: #002b89;
}

.prev-arrow,
.next-arrow {
  display: block;

  width: 70px;
  height: 70px;

  border-style: solid;
  border-color: #000; 
  background: transparent;
}

.slick-arrow {
  cursor: pointer;
}

.prev-arrow {
  left: calc(50% - 33vw); 

  -webkit-transform: rotate(-45deg) skew(-5deg, -5deg);
      -ms-transform: rotate(-45deg) skew(-5deg, -5deg);
          transform: rotate(-45deg) skew(-5deg, -5deg);

  border-width: 2px 0px 0px 2px;
}
@media (min-width: 320px) and (max-width: 374px) {
  .prev-arrow {
    left: 10px;
  }
}
@media (min-width: 375px) and (max-width: 424px) {
  .prev-arrow {
    left: 15px;
  }
}
@media (min-width: 425px) and (max-width: 767px) {
  .prev-arrow {
    left: 20px;
  }
}

.next-arrow {
  right: calc(50% - 33vw); 

  -webkit-transform: rotate(-45deg) skew(-5deg, -5deg);
      -ms-transform: rotate(-45deg) skew(-5deg, -5deg);
          transform: rotate(-45deg) skew(-5deg, -5deg);

  border-width: 0px 2px 2px 0px;
}
@media (min-width: 320px) and (max-width: 374px) {
  .next-arrow {
    right: 10px;
  }
}
@media (min-width: 375px) and (max-width: 424px) {
  .next-arrow {
    right: 15px;
  }
}
@media (min-width: 425px) and (max-width: 767px) {
  .next-arrow {
    right: 20px;
  }
}

@media print, screen and (min-width: 741px) {
  /* for Desktop Device */
  .section_recfair .list {
    width: 980px;
    margin: 0 auto;
  }
  .section_recfair .list .box {
    display: inline-block;
    float: left; 
    overflow: hidden;

    width: 306px;
    margin-right: 31px;

    text-align: left;
    vertical-align: top;
  }
  .section_recfair .list .box:last-child {
    margin-right: 0;
  }
  .section_recfair .list .box ul.icon li {
    font-size: 11px;
    line-height: 1.1em;

    display: inline-block;

    width: auto;
    margin-right: 3px;
    padding: 3px 10px 4px;

    text-align: center;

    color: #fff;
    background: #ccc;
  }
  .section_recfair .list .box .tit {
    font-size: 15px;
    font-weight: 400; 
    line-height: 1.6;
    line-height: 1.6;

    overflow: hidden;
    overflow: hidden;

    width: auto;
    max-height: 48px;
    padding: 0;

    border: none;
  }
  .section_recfair .date {
    font-size: 12px;
  }
}

@media screen and (max-width: 740px) {
  /* for Mobile Device */
  .section_recfair {
    width: 100%;
    padding: 10% 0;
  }
  .section_recfair h3.font01 {
    font-size: 7vw;
    font-weight: inherit;
  }
  .section_recfair .catch {
    font-size: 14px;

    margin-bottom: 4%;
  }
  .section_recfair .list {
    width: 80%;
    margin: 0 auto;
  }
  .section_recfair .list .box {
    display: block;
    float: left;

    width: 100%;
    margin-right: 0;
  }
  .section_recfair .list .box:last-child {
    margin-right: 0;
  }
  .section_recfair .list .box .ph {
    margin-bottom: 10px;
  }
  .section_recfair .list .box .tit {
    font-size: 15px;
    line-height: 1.5;

    max-height: 43px;
    margin-top: 8px; 
    margin-bottom: 6px;
  }
  .section_recfair .slick-slide {
    height: auto;
  }
  .section_partyReport {
    margin: 0;
    padding: 10% 0;
  }
}

.section_recfair.section_partyReport .list .box .ph {
  height: 203px;
}
@media screen and (max-width: 760px) {
  .section_recfair.section_partyReport .list .box .ph {
    height: 53vw;
  }
}

/* 中面レポート
--------------------------------------------------*/
.section_report {
  width: 1100px;
  margin: 0 auto;

  text-align: center;
}
.section_report h3.font01 {
  font-family: "petersburg-web", serif;
  font-size: 34px;
  font-weight: inherit;
  line-height: 1;

  margin-bottom: 5px;
}
.section_report .catch {
  font-family: "petersburg-web", serif;
  font-size: 20px;

  margin-bottom: 30px;
}
.section_report .list {
  width: 100%;
  margin: 0 auto;
}
.section_report .list .box .iconbox {
  margin: 5px 0;
}
.section_report .list .box .iconbox li {
  font-size: 11px;

  display: inline-block;
  overflow: hidden;

  min-width: auto;
  max-width: 100%;
  padding: 1px 10px 1px; 

  white-space: nowrap;
     text-overflow: ellipsis;

  -o-text-overflow: ellipsis;
  -webkit-box-flex: 0;
  -ms-flex: none;
      flex: none;
}
.section_report .list .box {
  display: inline-block;
  float: left; 
  overflow: hidden;

  width: 346px;
  margin-right: 31px;

  text-align: left;
  vertical-align: top;
}
.section_report .list .box:last-child {
  margin-right: 0;
}
.section_report .list .box .ph {
  position: relative;

  overflow: hidden;

  height: 346px;
  margin: 0 0 16px; 

  border-radius: 10px;
}
@media (max-width: 760px) {
  .section_report .list .box .ph {
    height: 74vw;
  }
}
.section_report .list .box .ph img {
  position: absolute;
  top: 50%;
  left: 50%;

  width: auto;
  height: 100%;

  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 760px) {
  .section_report .list .box .ph img {
    width: 100%;

    border-radius: 10px; 

    -o-object-fit: cover;
       object-fit: cover;
  }
}
.section_report .list .box ul.icon li {
  font-size: 11px;
  line-height: 1.1em;

  display: inline-block;

  width: auto;
  margin-right: 3px;
  padding: 1px 10px 1px;

  text-align: center;

  color: #fff;
  background: #ccc;
}
.section_report .list .box .tit {
  font-size: 16px;
  line-height: 1.6;
  line-height: 1.6; 

  overflow: hidden;
  overflow: hidden;

  width: auto;
  max-height: 60px;
  margin-bottom: 8px;
  padding: 0;

  border: none;
}

@media screen and (max-width: 760px) {
  .section_report {
    width: 90%;
    margin: 0 5% 10%;
  }
  .section_report a {
    text-align: center;
  }
  .section_report h3.font01 {
    font-size: 30px;
    font-weight: inherit;

    margin-bottom: 0;
  }
  .section_report .catch {
    font-size: 15px;

    margin-bottom: 20px;
  }
  .section_report .list {
    width: 100%;
    margin: 0 auto;
  }
  .section_report .list .box {
    display: block;

    width: 100%;
    margin-right: 0;
  }
  .section_report .list .box .ph {
    margin-bottom: 10px;
  }
  .section_report .list .box .tit {
    font-size: 16px;
    line-height: 1.6;
    line-height: 1.6; 

    overflow: hidden;
    overflow: hidden;

    width: auto;
    max-height: 60px;
    margin-bottom: 8px;
    padding: 0;

    border: none;
  }
}

/* 他のコンテンツ
--------------------------------------------------*/
.other_contents {
  width: 100%;
  height: 307px;
}
.other_contents li {
  position: relative;

  float: left;
  overflow: hidden; 

  width: 33.333333%;
  height: 307px;
}
.other_contents li a {
  position: relative; 

  display: block;

  width: 100%;
  height: 100%;
}
.other_contents li a::after {
  display: block;

  width: 100%;
  height: 100%;

  content: "";

  background-color: rgba(0, 0, 0, .3);
}
.other_contents li .tit_box {
  position: absolute;
  top: 50%;
  left: 50%;

  width: 90%; 

  -webkit-transform: translateY(-50%) translateX(-50%);
      -ms-transform: translateY(-50%) translateX(-50%);
          transform: translateY(-50%) translateX(-50%);
  text-align: center;

  color: #fff;
}
.other_contents li .tit_box h3 {
  font-family: "petersburg-web", serif;
  font-size: 32px;
  font-weight: inherit; 
  line-height: 1;

  margin-bottom: 5px;
}
.other_contents li .tit_box .sub {
  font-family: "petersburg-web", serif; 
  font-size: 14px;
}
.other_contents li .unit_inner {
  height: 307px;
}
.other_contents li.dress .unit_inner {
  background: url(../img/cmn/other_dress.jpg) no-repeat center center;
  background-size: cover;
}
.other_contents li.cuisine .unit_inner {
  background: url(../img/cmn/other_cuisine.jpg) no-repeat center center;
  background-size: cover;
}
.other_contents li.gallery .unit_inner {
  background: url(../img/cmn/other_gallery.jpg) no-repeat center center;
  background-size: cover;
}
.other_contents li.guide .unit_inner {
  background: url(../img/cmn/other_guide.jpg) no-repeat center center;
  background-size: cover;
}

@media screen and (max-width: 760px) {
  .other_contents {
    height: auto;
  }
  .other_contents li {
    float: none;

    width: 100%;
    height: auto;
    height: 150px;
  }
  .other_contents li a {
    display: block;

    width: 100%;
    height: 100%;
    padding: 0;
  }
  .other_contents li .tit_box {
    position: absolute;
    top: 50%;
    left: 50%;

    -webkit-transform: translateY(-50%) translateX(-50%);
        -ms-transform: translateY(-50%) translateX(-50%);
            transform: translateY(-50%) translateX(-50%);
    text-align: center; 

    color: #fff;
  }
  .other_contents li .tit_box h3 {
    font-size: 30px;
    font-weight: inherit;
  }
  .other_contents li .unit_inner {
    height: 150px;
  }
}
