@import url(https://fonts.googleapis.com/css?family=Noto+Serif+JP:200,300);
/** VARIABLES
===================================*/
/** RESET AND LAYOUT
===================================*/
.bx-wrapper {
  position: relative;
  margin-bottom: 60px;
  padding: 0;
  *zoom: 1;
  touch-action: pan-y;
}
@media screen and (max-width: 600px) {
  .bx-wrapper {
    margin-bottom: 0;
  }
}

.bx-wrapper img {
  max-width: 100%;
  display: block;
}

.bxslider {
  margin: 0;
  padding: 0;
  /*fix flickering when used background-image instead of <img> (on Chrome)*/
  -webkit-perspective: 1000;
}

ul.bxslider {
  list-style: none;
}

.bx-viewport {
  /* fix other elements on the page moving (in Chrome) */
  -webkit-transform: translateZ(0);
}

/** THEME
===================================*/
.bx-wrapper {
  box-shadow: 0 0 5px #ccc;
  border: 5px solid #fff;
  background: #fff;
}

.bx-wrapper .bx-pager,
.bx-wrapper .bx-controls-auto {
  position: absolute;
  bottom: -30px;
  width: 100%;
}

/* LOADER */
.bx-wrapper .bx-loading {
  min-height: 50px;
  background: url("images/loading.gif") center center no-repeat #ffffff;
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2000;
}

/* PAGER */
.bx-wrapper .bx-pager {
  text-align: center;
  font-size: 0.85em;
  font-family: Arial;
  font-weight: bold;
  color: #666;
  padding-top: 20px;
}

.bx-wrapper .bx-pager.bx-default-pager a {
  background: #666;
  text-indent: -9999px;
  display: block;
  width: 10px;
  height: 10px;
  margin: 0 5px;
  outline: 0;
  border-radius: 5px;
}

.bx-wrapper .bx-pager.bx-default-pager a:hover,
.bx-wrapper .bx-pager.bx-default-pager a.active,
.bx-wrapper .bx-pager.bx-default-pager a:focus {
  background: #000;
}

.bx-wrapper .bx-pager-item,
.bx-wrapper .bx-controls-auto .bx-controls-auto-item {
  display: inline-block;
  vertical-align: bottom;
  *zoom: 1;
  *display: inline;
}

.bx-wrapper .bx-pager-item {
  font-size: 0;
  line-height: 0;
}

/* DIRECTION CONTROLS (NEXT / PREV) */
.bx-wrapper .bx-prev {
  left: 10px;
  background: url("images/controls.png") no-repeat 0 -32px;
}

.bx-wrapper .bx-prev:hover,
.bx-wrapper .bx-prev:focus {
  background-position: 0 0;
}

.bx-wrapper .bx-next {
  right: 10px;
  background: url("images/controls.png") no-repeat -43px -32px;
}

.bx-wrapper .bx-next:hover,
.bx-wrapper .bx-next:focus {
  background-position: -43px 0;
}

.bx-wrapper .bx-controls-direction a {
  position: absolute;
  top: 50%;
  margin-top: -16px;
  outline: 0;
  width: 32px;
  height: 32px;
  text-indent: -9999px;
  z-index: 9999;
}

.bx-wrapper .bx-controls-direction a.disabled {
  display: none;
}

/* AUTO CONTROLS (START / STOP) */
.bx-wrapper .bx-controls-auto {
  text-align: center;
}

.bx-wrapper .bx-controls-auto .bx-start {
  display: block;
  text-indent: -9999px;
  width: 10px;
  height: 11px;
  outline: 0;
  background: url("images/controls.png") -86px -11px no-repeat;
  margin: 0 3px;
}

.bx-wrapper .bx-controls-auto .bx-start:hover,
.bx-wrapper .bx-controls-auto .bx-start.active,
.bx-wrapper .bx-controls-auto .bx-start:focus {
  background-position: -86px 0;
}

.bx-wrapper .bx-controls-auto .bx-stop {
  display: block;
  text-indent: -9999px;
  width: 9px;
  height: 11px;
  outline: 0;
  background: url("images/controls.png") -86px -44px no-repeat;
  margin: 0 3px;
}

.bx-wrapper .bx-controls-auto .bx-stop:hover,
.bx-wrapper .bx-controls-auto .bx-stop.active,
.bx-wrapper .bx-controls-auto .bx-stop:focus {
  background-position: -86px -33px;
}

/* PAGER WITH AUTO-CONTROLS HYBRID LAYOUT */
.bx-wrapper .bx-controls.bx-has-controls-auto.bx-has-pager .bx-pager {
  text-align: left;
  width: 80%;
}

.bx-wrapper .bx-controls.bx-has-controls-auto.bx-has-pager .bx-controls-auto {
  right: 0;
  width: 35px;
}

/* IMAGE CAPTIONS */
.bx-wrapper .bx-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  background: #666;
  background: rgba(80, 80, 80, 0.75);
  width: 100%;
}

.bx-wrapper .bx-caption span {
  color: #fff;
  font-family: Arial;
  display: block;
  font-size: 0.85em;
  padding: 10px;
}

/*
    Colorbox Core Style:
    The following CSS is consistent between example themes and should not be altered.
*/
#colorbox, #cboxOverlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999;
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
}

#cboxWrapper {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999;
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  max-width: none;
}

#cboxOverlay {
  position: fixed;
  width: 100%;
  height: 100%;
}

#cboxMiddleLeft, #cboxBottomLeft {
  clear: left;
}

#cboxContent {
  position: relative;
}

#cboxLoadedContent {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

#cboxTitle {
  margin: 0;
}

#cboxLoadingOverlay, #cboxLoadingGraphic {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#cboxPrevious, #cboxNext, #cboxClose, #cboxSlideshow {
  cursor: pointer;
}

.cboxPhoto {
  float: left;
  margin: auto;
  border: 0;
  display: block;
  max-width: none;
  -ms-interpolation-mode: bicubic;
}

.cboxIframe {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
  padding: 0;
  margin: 0;
}

#colorbox, #cboxContent, #cboxLoadedContent {
  box-sizing: content-box;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
}

/* 
    User Style:
    Change the following styles to modify the appearance of Colorbox.  They are
    ordered & tabbed in a way that represents the nesting of the generated HTML.
*/
#cboxOverlay {
  background: #fff;
  opacity: 0.9;
  filter: alpha(opacity=90);
}

#colorbox {
  outline: 0;
}

#cboxContent {
  margin-top: 32px;
  overflow: visible;
  background: #000;
}

.cboxIframe {
  background: #fff;
}

#cboxError {
  padding: 50px;
  border: 1px solid #ccc;
}

#cboxLoadedContent {
  background: #000;
  padding: 1px;
}

#cboxLoadingGraphic {
  background: url(images/loading.gif) no-repeat center center;
}

#cboxLoadingOverlay {
  background: #000;
}

#cboxTitle {
  position: absolute;
  top: -22px;
  left: 0;
  color: #000;
}

#cboxCurrent {
  position: absolute;
  top: -22px;
  right: 205px;
  text-indent: -9999px;
}

/* these elements are buttons, and may need to have additional styles reset to avoid unwanted base styles */
#cboxPrevious, #cboxNext, #cboxSlideshow, #cboxClose {
  border: 0;
  padding: 0;
  margin: 0;
  overflow: visible;
  text-indent: -9999px;
  width: 20px;
  height: 20px;
  position: absolute;
  top: -20px;
  background: url(images/controls.png) no-repeat 0 0;
}

/* avoid outlines on :active (mouseclick), but preserve outlines on :focus (tabbed navigating) */
#cboxPrevious:active, #cboxNext:active, #cboxSlideshow:active, #cboxClose:active {
  outline: 0;
}

#cboxPrevious {
  background-position: 0px 0px;
  right: 44px;
}
#cboxPrevious:hover {
  background-position: 0px -25px;
}

#cboxNext {
  background-position: -25px 0px;
  right: 22px;
}
#cboxNext:hover {
  background-position: -25px -25px;
}

#cboxClose {
  background-position: -50px 0px;
  right: 0;
}
#cboxClose:hover {
  background-position: -50px -25px;
}

.cboxSlideshow_on #cboxPrevious, .cboxSlideshow_off #cboxPrevious {
  right: 66px;
}

.cboxSlideshow_on #cboxSlideshow {
  background-position: -75px -25px;
  right: 44px;
}
.cboxSlideshow_on #cboxSlideshow:hover {
  background-position: -100px -25px;
}

.cboxSlideshow_off #cboxSlideshow {
  background-position: -100px 0px;
  right: 44px;
}
.cboxSlideshow_off #cboxSlideshow:hover {
  background-position: -75px -25px;
}

.visual_box {
  margin-bottom: 50px;
  min-height: 460px;
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}
.visual_box iframe {
  height: 100% !important;
  width: 100% !important;
  position: absolute;
  top: 0;
  right: 0;
}
.visual_box .row {
  display: flex;
  justify-content: flex-end;
  position: absolute;
  right: 225px;
  bottom: 5%;
  z-index: 2;
}
.visual_box .ranking {
  width: 160px;
}
.visual_box .icon {
  position: absolute;
  bottom: 5%;
  right: 40px;
  z-index: 2;
}

.fv_icon {
  display: flex;
  position: absolute;
  bottom: 20px;
  right: 20px;
  z-index: 2;
}
@media screen and (max-width: 1200px) {
  .fv_icon img {
    width: 14vw;
  }
}
.fv_icon .ranking {
  margin-right: 20px;
}
@media screen and (max-width: 1200px) {
  .fv_icon .ranking img {
    width: 16vw;
  }
}

@-webkit-keyframes Zoom1 {
  100% {
    transform: scale(1.2) translate(-10%, 10%);
  }
}

@keyframes Zoom1 {
  100% {
    transform: scale(1.2) translate(-10%, 10%);
  }
}
@-webkit-keyframes Zoom2 {
  100% {
    transform: scale(1.2) translate(-10%, -10%);
  }
}
@keyframes Zoom2 {
  100% {
    transform: scale(1.2) translate(-10%, -10%);
  }
}
@-webkit-keyframes Zoom3 {
  100% {
    transform: scale(1.2) translate(10%, -10%);
  }
}
@keyframes Zoom3 {
  100% {
    transform: scale(1.2) translate(10%, -10%);
  }
}
@-webkit-keyframes Zoom4 {
  100% {
    transform: scale(1.2) translate(10%, 10%);
  }
}
@keyframes Zoom4 {
  100% {
    transform: scale(1.2) translate(10%, 10%);
  }
}
.main {
  margin: 0 auto 80px;
  width: 100%;
}
.main .slide_box {
  margin-bottom: 25px;
  position: relative;
}
.main .slide_box .bx-wrapper {
  box-shadow: none;
  border: none;
  margin-bottom: 30px;
  z-index: 1;
}
.main .slide_box .bx-wrapper .img {
  width: 100% !important;
  position: relative;
  overflow: hidden;
}
.main .slide_box .bx-wrapper .img img {
  width: 100%;
}
.main .slide_box .bx-wrapper .slide0 img {
  -webkit-animation: Zoom1 20s linear infinite;
          animation: Zoom1 20s linear infinite;
}
.main .slide_box .bx-wrapper .slide1 img {
  -webkit-animation: Zoom2 20s linear infinite;
          animation: Zoom2 20s linear infinite;
}
.main .slide_box .bx-wrapper .slide2 img {
  -webkit-animation: Zoom3 20s linear infinite;
          animation: Zoom3 20s linear infinite;
}
.main .slide_box .bx-wrapper .slide3 img {
  -webkit-animation: Zoom4 20s linear infinite;
          animation: Zoom4 20s linear infinite;
}
.main .slide_box .bx-wrapper .slide4 img {
  -webkit-animation: Zoom1 20s linear infinite;
          animation: Zoom1 20s linear infinite;
}
.main .icon {
  position: absolute;
  bottom: 20%;
  right: 70px;
  z-index: 2;
}
.main .banner_box {
  margin: 0 auto;
  overflow: hidden;
  max-width: 1000px;
  padding: 0 20px;
}
.main .banner_box ul li a {
  display: block;
  margin: 0 10px;
}
.main .banner_box_noneslide {
  margin: 0 auto;
  overflow: hidden;
  width: 1000px;
}
.main .banner_box_noneslide li {
  text-align: center;
}
.main .banner_box_noneslide_1 ul {
  display: flex;
  justify-content: center;
}
.main .banner_box_noneslide_1 li {
  width: 49%;
}
.main .banner_box_noneslide_2 ul {
  display: flex;
  justify-content: space-between;
}
.main .banner_box_noneslide_2 li {
  width: 48%;
}

.fair {
  position: relative;
  margin-bottom: 70px;
  padding: 0 20px;
}
.fair .bgbox {
  top: 40%;
}
.fair .bgbox.zexy {
  height: 30%;
  background: #fff;
}
.fair_link {
  max-width: 1000px;
  border-bottom: 1px solid #95928a;
  margin: 0 auto 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.fair_link .list {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 245px;
  margin-bottom: -1px;
}
.fair_link .list.active {
  padding: 10px 0 5px;
  border-top: 1px solid #95928a;
  border-left: 1px solid #95928a;
  border-right: 1px solid #95928a;
  border-bottom: 2px solid #fff;
}
.fair_link .list.active .img {
  width: 15px;
  margin-right: 5px;
  display: inline-block;
}
.fair_link .list.active .img img {
  width: 100%;
}
.fair_link .list.bg {
  background: #eee;
}
.fair_link .list.bg a {
  display: block;
  padding: 10px 0 5px;
  width: 100%;
  text-align: center;
}
.fair_link .list.bg a .img {
  width: 18px;
  display: inline-block;
  margin-right: 5px;
}
.fair_link .list.bg a .img img {
  width: 100%;
}
.fair_zexy {
  text-align: center;
  margin-bottom: 20px;
}
.fair_zexy iframe {
  height: 360px !important;
}
.fair_list {
  max-width: 1000px;
  margin: 0 auto 30px;
}
.fair_list ul {
  display: flex;
  justify-content: center;
}
.fair_list ul li {
  width: 30%;
  margin-right: 5%;
  background: #fff;
}
.fair_list ul li:last-child {
  margin-right: 0;
}
.fair_list ul li .ttl {
  padding: 15px 0;
  margin: 0 10px;
  text-align: left;
  font-size: 1.6rem;
  font-family: "Noto Serif JP", serif;
  border-bottom: 1px dotted #a89d99;
}
.fair_list ul li dl {
  padding: 10px;
  font-size: 1.2rem;
}
.fair_list ul li dl dd {
  margin-bottom: 10px;
}

@media all and (-ms-high-contrast: none) {
  .fair_link {
    align-items: flex-end;
  }
  .fair_link .list.bg {
    border-bottom: 1px solid #95928a;
  }
  .fair_link .list .txt {
    vertical-align: bottom;
  }
}
.faircal {
  max-width: 1000px;
  margin: 0 auto 60px;
}
.faircal .calbox {
  width: 700px;
  margin: 0 auto;
  font-family: "Noto Serif JP", serif;
}
.faircal .calbox_pager {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 5px;
  border-bottom: 1px solid #2f2c2c;
  margin-bottom: 15px;
}
.faircal .calbox_pager .prev,
.faircal .calbox_pager .next {
  font-size: 1.6rem;
}
.faircal .calbox_pager .prev .month,
.faircal .calbox_pager .next .month {
  font-size: 2.4rem;
}
.faircal .calbox_pager .prev_inner {
  position: relative;
  padding-left: 10px;
}
.faircal .calbox_pager .prev_inner:before {
  background: url(../img/com/cal_left.png) no-repeat center center;
  content: "";
  display: inline-block;
  width: 9px;
  height: 16px;
  margin-right: 10px;
}
.faircal .calbox_pager .next_inner {
  position: relative;
  display: block;
  padding-right: 10px;
}
.faircal .calbox_pager .next_inner:after {
  background: url(../img/com/cal_right.png) no-repeat center center;
  content: "";
  display: inline-block;
  width: 9px;
  height: 16px;
  margin-left: 10px;
}
.faircal .calbox_pager .calbox_ttl .calmonth {
  font-size: 2.4rem;
  display: inline-block;
}
.faircal .calbox_pager .calbox_ttl .calmonth .month {
  font-size: 3.4rem;
}
.faircal .calbox_pager .calbox_ttl .calyear {
  font-size: 2.4rem;
  padding-right: 30px;
}
.faircal .calbox_list {
  padding: 0 15px;
}
.faircal .calbox_list table {
  width: 100%;
}
.faircal .calbox_list table th {
  font-size: 1.6rem;
  font-weight: 100;
  text-align: center;
}
.faircal .calbox_list table th.sat {
  color: #00658a;
}
.faircal .calbox_list table th.sun {
  color: #d34848;
}
.faircal .calbox_list table td {
  font-size: 2.4rem;
  text-align: center;
  color: #95928a;
}
.faircal .calbox_list table td .daybox {
  margin: 5px 10px;
}
.faircal .calbox_list table td a {
  text-decoration: underline;
  display: block;
  padding: 5px;
}
.faircal .calbox_list table td a:hover {
  text-decoration: none;
}
.faircal .calbox_list table td.sat {
  color: #00658a;
}
.faircal .calbox_list table td.sat a {
  color: #00658a;
}
.faircal .calbox_list table td.sun {
  color: #d34848;
}
.faircal .calbox_list table td.sun a {
  color: #d34848;
}

.topics {
  background: #f2f0ea;
  position: relative;
  margin-bottom: 80px;
}
.topics_inner {
  max-width: 880px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  padding: 30px 0 50px;
}
.topics_ttl {
  width: 180px;
  margin-bottom: 0;
}
.topics_list {
  width: 600px;
}
.topics_list .list li {
  border-bottom: 1px dotted #2f2c2c;
  margin-bottom: 10px;
}
.topics_list .list li .day {
  font-size: 1.4rem;
  display: block;
  margin-bottom: 5px;
  font-family: "Noto Serif JP", serif;
}
.topics_list .list li .list-ttl {
  font-size: 1.4rem;
  padding-bottom: 10px;
}
.topics .line_img {
  width: 42px;
  margin: 0 auto;
}
.topics .button {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  margin-top: -25px;
}

.banner {
  max-width: 630px;
  margin: 0 auto 90px;
}
.banner li {
  margin-bottom: 30px;
  text-align: center;
}
.banner li:last-child {
  margin-bottom: 0;
}

.plan {
  max-width: 1000px;
  margin: 0 auto 100px;
}
.plan.fuwel {
  max-width: initial;
  margin: 0 auto 70px;
  position: relative;
}
.plan_list {
  margin-bottom: 40px;
}
.plan_list iframe {
  height: 360px !important;
}
.plan_list ul {
  display: flex;
  justify-content: center;
}
.plan_list ul li {
  width: 30%;
  margin-right: 5%;
}
.plan_list ul li:last-child {
  margin-right: 0;
}
.plan_list ul li .img {
  height: 200px;
  overflow: hidden;
  display: block;
  position: relative;
  margin-bottom: 15px;
}
.plan_list ul li .img img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
}
.plan_list ul li .ttl {
  font-size: 1.6rem;
  margin-bottom: 0;
}
.plan_list iframe {
  height: 360px !important;
}

.ceremony {
  position: relative;
}
.ceremony_bg {
  width: 63%;
  height: 70%;
  left: auto;
  right: 0;
}

.banquet {
  position: relative;
}
.banquet .imgbox {
  margin-bottom: 100px;
}
.banquet_bg {
  width: 63%;
  height: 70%;
  left: 0;
  right: auto;
}

.memory {
  position: relative;
}
.memory_bg {
  width: 63%;
  height: 70%;
  left: auto;
  right: 0;
}
.memory .bx-wrapper {
  background: inherit;
}
.memory .button {
  width: 370px;
}

.linkbox {
  max-width: 900px;
  margin: 0 auto 100px;
}
.linkbox ul {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 600px) {
  .linkbox ul {
    flex-wrap: wrap;
  }
}
.linkbox ul li {
  width: 28.888%;
}
@media screen and (max-width: 600px) {
  .linkbox ul li {
    width: 60%;
  }
}
.linkbox ul li:not(:first-child) {
  margin-left: 20px;
}
@media screen and (max-width: 600px) {
  .linkbox ul li:not(:first-child) {
    margin-top: 20px;
    margin-left: 0;
  }
}
.linkbox ul li .img {
  display: block;
  margin-bottom: 15px;
}
.linkbox ul li .ttl {
  padding-bottom: 10px;
  margin-bottom: 0;
  border-bottom: 1px solid #2f2c2c;
  position: relative;
}
.linkbox ul li .ttl_main {
  margin-bottom: 5px;
}
.linkbox ul li .ttl:after {
  content: "";
  background: url(../img/com/cal_right.png) no-repeat center center;
  width: 9px;
  height: 16px;
  position: absolute;
  top: 30%;
  right: 5%;
}

.movie {
  position: relative;
  margin-bottom: 100px;
}
.movie_bg {
  background: #eee;
  height: 70%;
}
.movie .imgbox {
  max-width: 500px;
}
.movie .imgbox_imglink {
  height: 335px;
  position: relative;
  overflow: hidden;
}
.movie .imgbox_imglink .thumbnail {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 100%;
}
.movie .imgbox_imglink .mark {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  background: rgba(0, 0, 0, 0.6);
}
.movie .imgbox_imglink .mark img {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.insta {
  max-width: 1000px;
  margin: 0 auto 30px;
}
.insta_ttl {
  margin-bottom: 25px;
  text-align: center;
}
.insta #instafeed {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.insta #instafeed pre {
  display: none;
}
.insta #instafeed li {
  width: 15%;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
  height: 150px !important;
}
.insta #instafeed li img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
}

.snsbox_ttl {
  text-align: center;
  margin-bottom: 15px;
}
/*# sourceMappingURL=top.css.map */