@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700&subset=japanese");
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, input, textarea, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video, :before, :after {
  border: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 100%;
  font: inherit;
  margin: 0;
  padding: 0;
  position: relative;
  vertical-align: baseline
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block
}

body {
  line-height: 1
}

ol, ul {
  list-style: none
}

blockquote, q {
  quotes: none
}

blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

a, button, input, select, textarea {
  outline: none
}

img {
  width: 100%;
  height: auto
}

.bold {
  font-weight: 700 !important
}

.disabled {
  cursor: default;
  opacity: 0.25;
  pointer-events: none
}

.em {
  color: #355da7 !important
}

.pending {
  opacity: 0.5
}

.font10 {
  font-size: 72% !important
}

.font11 {
  font-size: 79% !important
}

.font12 {
  font-size: 86% !important
}

.font13 {
  font-size: 93% !important
}

.font14 {
  font-size: 100% !important
}

.jq-hide {
  display: none !important
}

.note {
  font-size: 86%;
  letter-spacing: 0.05em;
  line-height: 1.5;
  opacity: 0.75
}

.note.is-s {
  font-size: 72%
}

.red {
  color: #e74707 !important
}

.text-left {
  text-align: left !important
}

.text-center {
  text-align: center !important
}

.text-right {
  text-align: right !important
}

.text-table {
  display: table;
  margin-right: auto;
  margin-left: auto
}

.ul {
  text-decoration: underline !important
}

.op0 {
  -ms-filter: "alpha(opacity=0)";
  filter: alpha(opacity=0);
  opacity: 0;
  zoom: 1
}

.op10 {
  -ms-filter: "alpha(opacity=10)";
  filter: alpha(opacity=10);
  opacity: .1;
  zoom: 1
}

.op20 {
  -ms-filter: "alpha(opacity=20)";
  filter: alpha(opacity=20);
  opacity: .2;
  zoom: 1
}

.op30 {
  -ms-filter: "alpha(opacity=30)";
  filter: alpha(opacity=30);
  opacity: .3;
  zoom: 1
}

.op40 {
  -ms-filter: "alpha(opacity=40)";
  filter: alpha(opacity=40);
  opacity: .4;
  zoom: 1
}

.op50 {
  -ms-filter: "alpha(opacity=50)";
  filter: alpha(opacity=50);
  opacity: .5;
  zoom: 1
}

.op60 {
  -ms-filter: "alpha(opacity=60)";
  filter: alpha(opacity=60);
  opacity: .6;
  zoom: 1
}

.op70 {
  -ms-filter: "alpha(opacity=70)";
  filter: alpha(opacity=70);
  opacity: .7;
  zoom: 1
}

.op80 {
  -ms-filter: "alpha(opacity=80)";
  filter: alpha(opacity=80);
  opacity: .8;
  zoom: 1
}

.op90 {
  -ms-filter: "alpha(opacity=90)";
  filter: alpha(opacity=90);
  opacity: .9;
  zoom: 1
}

.op100 {
  -ms-filter: "alpha(opacity=100)";
  filter: alpha(opacity=100);
  opacity: 1;
  zoom: 1
}

.m0 {
  margin: 0px !important
}

.mt0 {
  margin-top: 0px !important
}

.mr0 {
  margin-right: 0px !important
}

.mb0 {
  margin-bottom: 0px !important
}

.ml0 {
  margin-left: 0px !important
}

.p0 {
  padding: 0px !important
}

.pt0 {
  padding-top: 0px !important
}

.pr0 {
  padding-right: 0px !important
}

.pb0 {
  padding-bottom: 0px !important
}

.pl0 {
  padding-left: 0px !important
}

.m5 {
  margin: 5px !important
}

.mt5 {
  margin-top: 5px !important
}

.mr5 {
  margin-right: 5px !important
}

.mb5 {
  margin-bottom: 5px !important
}

.ml5 {
  margin-left: 5px !important
}

.p5 {
  padding: 5px !important
}

.pt5 {
  padding-top: 5px !important
}

.pr5 {
  padding-right: 5px !important
}

.pb5 {
  padding-bottom: 5px !important
}

.pl5 {
  padding-left: 5px !important
}

.m10 {
  margin: 10px !important
}

.mt10 {
  margin-top: 10px !important
}

.mr10 {
  margin-right: 10px !important
}

.mb10 {
  margin-bottom: 10px !important
}

.ml10 {
  margin-left: 10px !important
}

.p10 {
  padding: 10px !important
}

.pt10 {
  padding-top: 10px !important
}

.pr10 {
  padding-right: 10px !important
}

.pb10 {
  padding-bottom: 10px !important
}

.pl10 {
  padding-left: 10px !important
}

.m15 {
  margin: 15px !important
}

.mt15 {
  margin-top: 15px !important
}

.mr15 {
  margin-right: 15px !important
}

.mb15 {
  margin-bottom: 15px !important
}

.ml15 {
  margin-left: 15px !important
}

.p15 {
  padding: 15px !important
}

.pt15 {
  padding-top: 15px !important
}

.pr15 {
  padding-right: 15px !important
}

.pb15 {
  padding-bottom: 15px !important
}

.pl15 {
  padding-left: 15px !important
}

.m20 {
  margin: 20px !important
}

.mt20 {
  margin-top: 20px !important
}

.mr20 {
  margin-right: 20px !important
}

.mb20 {
  margin-bottom: 20px !important
}

.ml20 {
  margin-left: 20px !important
}

.p20 {
  padding: 20px !important
}

.pt20 {
  padding-top: 20px !important
}

.pr20 {
  padding-right: 20px !important
}

.pb20 {
  padding-bottom: 20px !important
}

.pl20 {
  padding-left: 20px !important
}

.m25 {
  margin: 25px !important
}

.mt25 {
  margin-top: 25px !important
}

.mr25 {
  margin-right: 25px !important
}

.mb25 {
  margin-bottom: 25px !important
}

.ml25 {
  margin-left: 25px !important
}

.p25 {
  padding: 25px !important
}

.pt25 {
  padding-top: 25px !important
}

.pr25 {
  padding-right: 25px !important
}

.pb25 {
  padding-bottom: 25px !important
}

.pl25 {
  padding-left: 25px !important
}

.m30 {
  margin: 30px !important
}

.mt30 {
  margin-top: 30px !important
}

.mr30 {
  margin-right: 30px !important
}

.mb30 {
  margin-bottom: 30px !important
}

.ml30 {
  margin-left: 30px !important
}

.p30 {
  padding: 30px !important
}

.pt30 {
  padding-top: 30px !important
}

.pr30 {
  padding-right: 30px !important
}

.pb30 {
  padding-bottom: 30px !important
}

.pl30 {
  padding-left: 30px !important
}

.m35 {
  margin: 35px !important
}

.mt35 {
  margin-top: 35px !important
}

.mr35 {
  margin-right: 35px !important
}

.mb35 {
  margin-bottom: 35px !important
}

.ml35 {
  margin-left: 35px !important
}

.p35 {
  padding: 35px !important
}

.pt35 {
  padding-top: 35px !important
}

.pr35 {
  padding-right: 35px !important
}

.pb35 {
  padding-bottom: 35px !important
}

.pl35 {
  padding-left: 35px !important
}

.m40 {
  margin: 40px !important
}

.mt40 {
  margin-top: 40px !important
}

.mr40 {
  margin-right: 40px !important
}

.mb40 {
  margin-bottom: 40px !important
}

.ml40 {
  margin-left: 40px !important
}

.p40 {
  padding: 40px !important
}

.pt40 {
  padding-top: 40px !important
}

.pr40 {
  padding-right: 40px !important
}

.pb40 {
  padding-bottom: 40px !important
}

.pl40 {
  padding-left: 40px !important
}

.m45 {
  margin: 45px !important
}

.mt45 {
  margin-top: 45px !important
}

.mr45 {
  margin-right: 45px !important
}

.mb45 {
  margin-bottom: 45px !important
}

.ml45 {
  margin-left: 45px !important
}

.p45 {
  padding: 45px !important
}

.pt45 {
  padding-top: 45px !important
}

.pr45 {
  padding-right: 45px !important
}

.pb45 {
  padding-bottom: 45px !important
}

.pl45 {
  padding-left: 45px !important
}

.m50 {
  margin: 50px !important
}

.mt50 {
  margin-top: 50px !important
}

.mr50 {
  margin-right: 50px !important
}

.mb50 {
  margin-bottom: 50px !important
}

.ml50 {
  margin-left: 50px !important
}

.p50 {
  padding: 50px !important
}

.pt50 {
  padding-top: 50px !important
}

.pr50 {
  padding-right: 50px !important
}

.pb50 {
  padding-bottom: 50px !important
}

.pl50 {
  padding-left: 50px !important
}

.block-xlg, .inline-xlg {
  display: none !important
}

@media (max-width: 1399px) {
  .hide-xlg {
    display: none !important
  }
  .block-xlg {
    display: block !important
  }
  .inline-xlg {
    display: inline !important
  }
}

.block-lg, .inline-lg {
  display: none !important
}

@media (max-width: 1199px) {
  .hide-lg {
    display: none !important
  }
  .block-lg {
    display: block !important
  }
  .inline-lg {
    display: inline !important
  }
}

.block-md, .inline-md {
  display: none !important
}

@media (max-width: 991px) {
  .hide-md {
    display: none !important
  }
  .block-md {
    display: block !important
  }
  .inline-md {
    display: inline !important
  }
}

.block-sm, .inline-sm {
  display: none !important
}

@media (max-width: 767px) {
  .hide-sm {
    display: none !important
  }
  .block-sm {
    display: block !important
  }
  .inline-sm {
    display: inline !important
  }
}

.block-s, .inline-s {
  display: none !important
}

@media (max-width: 640px) {
  .hide-s {
    display: none !important
  }
  .block-s {
    display: block !important
  }
  .inline-s {
    display: inline !important
  }
}

.block-xs, .inline-xs {
  display: none !important
}

@media (max-width: 480px) {
  .hide-xs {
    display: none !important
  }
  .block-xs {
    display: block !important
  }
  .inline-xs {
    display: inline !important
  }
}

.block-xxs, .inline-xxs {
  display: none !important
}

@media (max-width: 400px) {
  .hide-xxs {
    display: none !important
  }
  .block-xxs {
    display: block !important
  }
  .inline-xxs {
    display: inline !important
  }
}

.block-xxxs, .inline-xxxs {
  display: none !important
}

@media (max-width: 360px) {
  .hide-xxxs {
    display: none !important
  }
  .block-xxxs {
    display: block !important
  }
  .inline-xxxs {
    display: inline !important
  }
}

.btn {
  background-color: #e74707;
  border-bottom: 4px solid #b63806;
  border-radius: 10px;
  color: #fff;
  color: #fff;
  display: block;
  font-size: 129%;
  font-weight: 700;
  margin-right: auto;
  margin-left: auto;
  padding-top: 20px;
  padding-bottom: 20px;
  text-align: center;
  text-decoration: none !important
}

.btn.is-hover {
  color: #fff
}

.btn.is-blue {
  background-color: #355da7;
  border-bottom-color: #294780
}

.btn.is-gray {
  background-color: #2b2b2b;
  border-bottom-color: #121212
}

.btn.is-pink {
  background-color: #e6599f;
  border-bottom-color: #df2d85
}

.btn.is-purple {
  background-color: #c426a5;
  border-bottom-color: #991e81
}

.btn.is-fany, .btn.is-visit {
  background-color: #fff;
  border: 1px solid #646464;
  border-bottom: 4px solid #646464;
  max-width: 500px
}

.btn.is-fany {
  color: #646464;
  color: #646464;
  padding: 30px 20px
}

.btn.is-fany.is-hover {
  color: #646464
}

.btn.is-fany img, .btn.is-fany span {
  vertical-align: middle
}

.btn.is-fany img {
  max-width: 300px
}

.btn.is-fany span {
  display: inline-block;
  margin-left: -11%;
  vertical-align: middle
}

.btn.is-schedule {
  background-color: #314a78;
  border-bottom-color: #0f1c33;
  font-size: 150%;
  max-width: 360px
}

.btn.is-online {
  background-color: #e6599f;
  border-bottom-color: #df2d85;
  font-size: 150%;
  max-width: 380px
}

.btn.is-online00 {
  background-color: #e6599f;
  border-bottom-color: #df2d85;
  font-size: 150%;
  max-width: 380px
}

.btn.is-schedule span {
  display: inline-block;
  padding-left: 32px;
  padding-right: 20px
}

.btn.is-online span {
  display: inline-block;
  padding-left: 32px;
  padding-right: 20px
}

.btn.is-online00 span {
  display: inline-block;
  padding-left: 32px;
  padding-right: 20px
}

.btn.is-schedule span:before {
  background-image: url(/assets/images/common/icon-schedule-white.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin-top: -15px;
  position: absolute;
  left: 0;
  top: 50%;
  width: 30px;
  height: 30px
}

.btn.is-online span:before {
  background-image: url(/assets/images/common/icon-online-white.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin-top: -15px;
  position: absolute;
  left: 0;
  top: 50%;
  width: 30px;
  height: 30px
}

.btn.is-online00 span:before {
  background-image: url(/assets/images/common/icon-online-white.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin-top: -15px;
  position: absolute;
  left: 0;
  top: 50%;
  width: 30px;
  height: 30px
}

.btn.is-schedule span:after {
  content: '\f054';
  display: inline-block;
  font-family: 'Font Awesome 5 Free';
  font-size: 60%;
  font-weight: 700;
  margin-top: -18px;
  line-height: 40px;
  position: absolute;
  top: 50%;
  right: 0
}

.btn.is-short {
  max-width: 500px
}

.btn.is-sub {
  background-color: #fff;
  border: 2px solid #646464;
  color: #646464;
  color: #646464;
  font-size: 93%;
  padding-top: 8px;
  padding-bottom: 8px;
  max-width: 200px
}

.btn.is-sub.is-hover {
  color: #646464
}

.btn.is-visit {
  color: #646464;
  color: #646464
}

.btn.is-visit.is-hover {
  color: #646464
}

.btn.is-visit i {
  color: #355da7;
  display: block;
  font-size: 200%
}

.btn.is-about, .btn.is-profile {
  background-color: #fff;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 0;
  border-bottom: none;
  font-size: 172%;
  padding: 40% 0 0;
  width: 100%;
  max-width: none;
  height: 0
}

.btn.is-about:before, .btn.is-profile:before {
  background-color: rgba(0, 0, 0, 0.4);
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.btn.is-about p, .btn.is-profile p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.btn.is-about span, .btn.is-profile span {
  border: 1px solid #fff;
  display: inline-block;
  padding-right: 0.5em;
  padding-left: 0.5em
}

.btn.is-about {
  background-image: url(/assets/images/top/btn-img02.jpg)
}

.btn.is-profile {
  background-image: url(/assets/images/top/btn-img01.jpg)
}

.btn.is-s {
  font-size: 100%;
  padding-top: 10px;
  padding-bottom: 10px
}

@media (max-width: 767px) {
  .btn {
    font-size: 150%;
    padding-top: 15px;
    padding-bottom: 15px
  }
  .btn.is-about, .btn.is-profile {
    font-size: 129%
  }
}

@media (max-width: 640px) {
  .btn.is-about, .btn.is-profile {
    font-size: 115%
  }
  .btn.is-fany span {
    display: block;
    margin-top: 5px;
    margin-left: 0;
    font-size: 100%
  }
}

@media (max-width: 480px) {
  .btn {
    font-size: 115%;
    padding-top: 10px;
    padding-bottom: 10px;
    max-width: 280px
  }
  .btn.is-schedule {
    font-size: 129%
  }
	
  .btn.is-online {
    font-size: 115%
  }		
	
  .btn.is-online00 {
    font-size: 129%
  }		
	
  .btn.is-schedule span {
    padding-left: 28px;
    padding-right: 16px
  }
	
  .btn.is-schedule span:before {
    margin-top: -12px;
    width: 24px;
    height: 24px
  }
}

@media (max-width: 400px) {
  .btn {
    font-size: 108%
  }
	
  .btn.is-online {
    font-size: 100%
  }		
	
}

@media (max-width: 360px) {
  .btn {
    font-size: 100%;
    max-width: 240px
  }
}

.event-online {
  background-color: #fff;
  border: 1px solid #355da7;
  color: #355da7;
  display: inline-block;
  font-size: 10px;
  letter-spacing: 0;
  padding: 0 5px
}

.event-online.is-only {
  border-color: #646464;
  color: #646464
}

.sec-title .event-online {
  border: none !important
}

.gototop {
  background-color: #646464;
  border-radius: 50%;
  color: #fff;
  color: #fff;
  display: block;
  position: fixed;
  right: 20px;
  bottom: 20px;
  text-align: center;
  text-decoration: none;
  width: 40px;
  height: 40px;
  z-index: 50
}

.gototop.is-hover {
  color: #fff
}

.gototop:after {
  content: '\f077';
  font-family: 'Font Awesome 5 Free';
  font-size: 150%;
  font-weight: 700;
  line-height: 40px
}

@media (max-width: 767px) {
  .gototop {
    bottom: 70px
  }
}

@media (max-width: 480px) {
  .gototop {
    width: 32px;
    height: 32px;
    right: 10px;
    bottom: 60px
  }
  .gototop:after {
    font-size: 135%;
    line-height: 32px
  }
}

.list-notice li {
  padding-left: 1em;
  text-indent: -1em
}

.owl-next, .owl-prev {
  background-color: #fff;
  border: 1px solid #355da7;
  border-radius: 50%;
  color: #355da7;
  color: #355da7;
  display: block;
  line-height: 30px;
  margin-top: -16px;
  position: absolute;
  top: 50%;
  text-align: center;
  width: 32px;
  height: 32px;
  z-index: 2
}

.owl-next.is-hover, .owl-prev.is-hover {
  color: #355da7
}

.owl-next.is-text, .owl-prev.is-text {
  border-radius: 16px;
  display: inline-block;
  font-size: 86%;
  padding-right: 12px;
  padding-left: 12px;
  width: auto
}

.owl-next {
  right: 4px
}

.owl-next:after {
  content: '\f054';
  display: inline-block;
  font-family: 'Font Awesome 5 Free';
  font-weight: 700
}

.owl-next.is-text:after {
  margin-left: 5px
}

.owl-prev {
  left: 4px
}

.owl-prev:before {
  content: '\f053';
  display: inline-block;
  font-family: 'Font Awesome 5 Free';
  font-weight: 700
}

.owl-prev.is-text:before {
  margin-right: 5px
}

.owl-dots {
  text-align: center
}

.owl-dots .owl-dot {
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  appearance: none;
  background-color: #646464;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  display: inline-block;
  margin: 10px 3px 0;
  -ms-filter: "alpha(opacity=25)";
  filter: alpha(opacity=25);
  opacity: .25;
  zoom: 1;
  padding: 0;
  width: 8px;
  height: 8px
}

.owl-dots .owl-dot.active {
  -ms-filter: "alpha(opacity=100)";
  filter: alpha(opacity=100);
  opacity: 1;
  zoom: 1
}

.owl-dots-container {
  text-align: center
}

.owl-dots-body {
  display: inline-block;
  padding-right: 20px;
  padding-left: 20px
}

.owl-dots-prev, .owl-dots-next {
  display: block;
  line-height: 20px;
  margin-top: -10px;
  position: absolute;
  top: 50%;
  text-decoration: none;
  height: 20px;
  width: 20px
}

.owl-dots-prev:before, .owl-dots-next:before {
  display: block;
  font-family: 'Font Awesome 5 Free';
  font-weight: 700
}

.owl-dots-prev {
  left: 0
}

.owl-dots-prev:before {
  content: '\f053'
}

.owl-dots-next {
  right: 0
}

.owl-dots-next:before {
  content: '\f054'
}

.owl-nav {
  text-align: center
}

.owl-nav:after {
  clear: both;
  content: '';
  display: block
}

.owl-nav .owl-next, .owl-nav .owl-prev {
  display: inline-block;
  margin: 0;
  position: relative;
  top: auto
}

.owl-nav .owl-next {
  float: right;
  right: auto
}

.owl-nav .owl-prev {
  float: left;
  left: auto
}

.preload {
  display: block;
  padding-top: 100%;
  width: 100%;
  height: 0
}

.preload.is-2by1 {
  padding-top: 50%
}

.preload.is-3by1 {
  padding-top: 33.33333333%
}

.preload.is-3by2 {
  padding-top: 66.66666667%
}

.preload.is-4by3 {
  padding-top: 75%
}

.preload.is-5by3 {
  padding-top: 60%
}

.preload.is-5by6 {
  padding-top: 120%
}

.preload.is-16by9 {
  padding-top: 56.25%
}

.preload .thumbnail {
  background-position: center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  background-size: cover;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s all ease-out;
  width: 100%;
  height: 100%
}

.preload.active .thumbnail {
  opacity: 1
}

a[href*="tel:"] {
  color: #646464;
  color: #646464;
  pointer-events: none;
  text-decoration: none !important
}

a[href*="tel:"].is-hover {
  color: #646464
}

.device-mobile a[href*="tel:"] {
  color: #355da7;
  color: #355da7;
  pointer-events: initial;
  text-decoration: underline !important
}

.device-mobile a[href*="tel:"].is-hover {
  color: #355da7
}

.site-header {
  background: #3b4d57;
  background-size: 48px 48px;
  color: #fff;
  font-weight: 700;
  line-height: 36px;
  padding: 10px 20px;
  position: fixed;
  transition: 0.1s all ease-out;
  width: 100%;
  z-index: 100
}

.site-header.is-fixed {
  position: fixed;
  top: 0
}

.site-header-logo {
  line-height: 0;
  width: 100%;
  max-width: 200px
}

.site-header-logo a {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 40px
}

.site-header-toggle {
  color: #fff;
  color: #fff;
  display: none;
  font-size: 50%;
  font-weight: 400;
  margin-top: -48px;
  position: absolute;
  right: 0;
  text-align: center;
  text-decoration: none;
  width: 60px
}

.site-header-toggle.is-hover {
  color: #fff
}

.site-header-toggle:before {
  content: '\f0c9';
  display: block;
  font-family: 'Font Awesome 5 Free';
  font-size: 250%;
  font-weight: 700;
  margin-bottom: -20px
}

.site-header-menu {
  background-color: #fff;
  display: none;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  -moz-overflow-scrolling: touch;
  -ms-overflow-scrolling: touch;
  overflow-scrolling: touch;
  padding-top: 60px;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99
}

.site-header-menu>ul li {
  border-bottom: 1px solid rgba(100, 100, 100, 0.25)
}

.site-header-menu>ul li a {
  display: block;
  padding: 10px 10px 10px 36px;
  text-decoration: none
}

.site-header-menu>ul li a:before {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin-top: -10px;
  opacity: 0.5;
  position: absolute;
  top: 50%;
  left: 10px;
  width: 20px;
  height: 20px
}

.site-header-menu>ul li a.ic-about:before {
  background-image: url(/assets/images/common/icon-about.svg)
}

.site-header-menu>ul li a.ic-event:before {
  background-image: url(/assets/images/common/icon-event.svg)
}

.site-header-menu>ul li a.ic-faq:before {
  background-image: url(/assets/images/common/icon-faq.svg)
}

.site-header-menu>ul li a.ic-news:before {
  background-image: url(/assets/images/common/icon-news.svg)
}

.site-header-menu>ul li a.ic-pick-up-event:before {
  background-image: url(/assets/images/common/icon-pick-up-event.svg)
}

.site-header-menu>ul li a.ic-pick-up01:before {
  background-image: url(/assets/images/common/icon-pick-up01.svg)
}

.site-header-menu>ul li a.ic-pick-up02:before {
  background-image: url(/assets/images/common/icon-pick-up02.svg)
}

.site-header-menu>ul li a.ic-profile:before {
  background-image: url(/assets/images/common/icon-profile.svg)
}

.site-header-menu>ul li a.ic-schedule:before {
  background-image: url(/assets/images/common/icon-schedule.svg)
}

.site-header-menu>ul li a.ic-ticket:before {
  background-image: url(/assets/images/common/icon-ticket.svg)
}

.site-header-menu>ul li a.ic-online:before {
  background-image: url(/assets/images/common/icon-online.svg)
}


.site-header-menu>ul li a.ic-top:before {
  background-image: url(/assets/images/common/icon-top.svg)
}

.site-header-menu .sec-social {
  border-top: none !important;
  margin-top: 0 !important;
  padding-top: 40px
}

.site-header .sec-social {
  margin-top: -16px;
  position: absolute;
  top: 50%;
  right: 10px
}

.site-header .sec-social li {
  padding-right: 5px;
  padding-left: 5px
}


.site-header .sec-social img {
  width: 32px
}

@media (max-width: 767px) {
  .site-header {
    position: absolute;
    padding-top: 12px;
    padding-bottom: 12px
  }
  .site-header-toggle {
    display: block;
    margin-top: -38px
  }
  .site-header .sec-social {
    right: 60px
  }
}

@media (max-width: 640px) {
  .site-header .sec-social {
    display: none
  }
}

.site-nav {
  background-color: #fff;
  border-bottom: 1px solid #2b2b2b;
  font-size: 72%;
  font-weight: 400;
  line-height: 20px;
  padding: 10px 10px 20px;
  position: absolute;
  top: 100%;
  left: 0;
  text-align: center;
  width: 100%;
  z-index: 99
}

.site-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.site-nav li {
  width: 90px
}

.site-nav span {
  display: block;
  letter-spacing: 0;
  margin-left: -50px;
  position: absolute;
  top: 100%;
  left: 50%;
  width: 100px
}

.site-nav a {
  color: #646464;
  color: #646464;
  display: inline-block
}

.site-nav a.is-hover {
  color: #646464
}

.site-nav a:before {
  background-color: #e74707;
  border-radius: 50%;
  content: '';
  display: block;
  margin-right: auto;
  margin-left: auto;
  width: 40px;
  height: 40px
}

.site-nav a:after {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin-left: -12px;
  position: absolute;
  top: 8px;
  left: 50%;
  width: 24px;
  height: 24px
}

.site-nav a.ic-about:after {
  background-image: url(/assets/images/common/icon-about-white.svg)
}

.site-nav a.ic-event:after {
  background-image: url(/assets/images/common/icon-event-white.svg)
}

.site-nav a.ic-faq:after {
  background-image: url(/assets/images/common/icon-faq-white.svg)
}

.site-nav a.ic-news:after {
  background-image: url(/assets/images/common/icon-news-white.svg)
}

.site-nav a.ic-pick-up-event:after {
  background-image: url(/assets/images/common/icon-pick-up-event-white.svg)
}

.site-nav a.ic-pick-up01:after {
  background-image: url(/assets/images/common/icon-pick-up01-white.svg)
}

.site-nav a.ic-pick-up02:after {
  background-image: url(/assets/images/common/icon-pick-up02-white.svg)
}

.site-nav a.ic-profile:after {
  background-image: url(/assets/images/common/icon-profile-white.svg)
}

.site-nav a.ic-schedule:after {
  background-image: url(/assets/images/common/icon-schedule-white.svg)
}

.site-nav a.ic-ticket:after {
  background-image: url(/assets/images/common/icon-ticket-white.svg)
}

.site-nav a.ic-online:after {
  background-image: url(/assets/images/common/icon-online-white.svg)
}

.site-nav a.ic-top:after {
  background-image: url(/assets/images/common/icon-top-white.svg)
}



@media (max-width: 767px) {
  .site-nav {
    display: none
  }
}

@media (max-width: 991px) {
  body.is-site-menu {
    overflow: hidden
  }
  body.is-site-menu .site-header-toggle:before {
    content: '\f00d'
  }
  body.is-site-menu .site-header-menu {
    display: block
  }
}

.common-footer {
  background-color: #3b4d57;
  color: #fff;
  line-height: 1.5;
  padding-top: 3em;
  padding-bottom: 3em;
  text-align: center
}

.common-footer-nav {
  font-size: 93%
}

.common-footer-nav ul+ul {
  margin-top: 1em
}

.common-footer-nav li {
  display: inline-block
}

.common-footer-nav li+li {
  margin-left: 1em;
  padding-left: 1em
}

.common-footer-nav li+li:before {
  background: rgba(255, 255, 255, 0.5);
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 100%
}

.common-footer-nav a {
  color: #fff;
  color: #fff;
  text-decoration: none
}

.common-footer-nav a.is-hover {
  color: #fff
}

.common-footer-copyright {
  font-size: 93%;
  margin-top: 3em
}

@media (max-width: 991px) {
  .common-footer {
    margin-top: 6em
  }
  .common-footer-copyright {
    position: relative;
    right: auto;
    bottom: auto
  }
}

@media (max-width: 767px) {
  .common-footer {
    margin-top: 4em;
    padding-bottom: 80px
  }
  .common-footer-nav {
    font-size: 86%
  }
  .common-footer-nav a {
    display: block
  }
  .common-footer-nav a+a {
    margin-left: 0
  }
}

@media (max-width: 480px) {
  .common-footer {
    margin-top: 3em
  }
  .common-footer-nav {
    font-size: 79%
  }
}

.site-footer {
  background: #fff;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
  display: none;
  position: fixed;
  left: 0;
  bottom: 0;
  text-align: center;
  width: 100%;
  z-index: 99
}

.site-footer-btns {
  display: none;
  padding-top: 10px;
  padding-right: 40px;
  padding-bottom: 10px;
  padding-left: 10px
}

.site-footer-btns-close {
  display: block;
  line-height: 40px;
  margin-top: -20px;
  position: absolute;
  top: 50%;
  right: 0;
  text-align: center;
  width: 40px;
  height: 40px
}

.site-footer-btns-close:after {
  content: '\f00d';
  font-family: 'Font Awesome 5 Free';
  font-weight: 700
}

.site-footer-btns.active {
  display: block
}

.site-footer ul {
  border-top: 1px solid #646464;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.site-footer li {
  width: 20%
}

.site-footer li+li {
  border-left: 1px solid #646464
}

.site-footer li a {
  background-color: #646464;
  color: #fff;
  color: #fff;
  display: block;
  font-size: 65%;
  padding-bottom: 5px;
  padding-top: 10px;
  text-decoration: none
}

.site-footer li a.is-hover {
  color: #fff
}

.site-footer li a:before {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin-right: auto;
  margin-left: auto;
  width: 24px;
  height: 24px
}

.site-footer li a.ic-about:before {
  background-image: url(/assets/images/common/icon-about-white.svg)
}

.site-footer li a.ic-event:before {
  background-image: url(/assets/images/common/icon-event-white.svg)
}

.site-footer li a.ic-faq:before {
  background-image: url(/assets/images/common/icon-faq-white.svg)
}

.site-footer li a.ic-news:before {
  background-image: url(/assets/images/common/icon-news-white.svg)
}

.site-footer li a.ic-profile:before {
  background-image: url(/assets/images/common/icon-profile-white.svg)
}

.site-footer li a.ic-schedule:before {
  background-image: url(/assets/images/common/icon-schedule-white.svg)
}

.site-footer li a.ic-ticket:before {
  background-image: url(/assets/images/common/icon-ticket-white.svg)
}

.site-footer li a.ic-online:before {
  background-image: url(/assets/images/common/icon-online-white.svg)
}

.site-footer li a.ic-top:before {
  background-image: url(/assets/images/common/icon-top-white.svg)
}

.site-footer li a.ic-pick-up:before {
  background-image: url(/assets/images/common/icon-pick-up-event.svg)
}

.site-footer li a.ic-pick-up01:before {
  background-image: url(/assets/images/common/icon-pick-up01.svg)
}

.site-footer li a.ic-pick-up02:before {
  background-image: url(/assets/images/common/icon-pick-up02.svg)
}



@media (max-width: 767px) {
  .site-footer {
    display: block
  }
  .site-footer+.common-footer {
    padding-bottom: 80px
  }
}

html, body {
  height: 100%
}

html {
  -webkit-text-size-adjust: 100%
}

body {
  background: #fff;
  -webkit-background-size: 480px 480px;
  -moz-background-size: 480px 480px;
  -ms-background-size: 480px 480px;
  background-size: 480px 480px;
  color: #646464;
  font-family: "Noto Sans JP", "鬯ｩ蟷｢�ｽ�｢髫ｴ雜｣�ｽ�｢�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�｡鬯ｩ蟷｢�ｽ�｢�ｽ�ｽ�ｽ�ｧ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�､鬯ｩ蟷｢�ｽ�｢髫ｴ雜｣�ｽ�｢�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｪ鬯ｩ蟷｢�ｽ�｢�ｽ�ｽ�ｽ�ｧ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｪ", "Meiryo", "鬯ｩ蟷｢�ｽ�｢髫ｴ蜿門ｾ暦ｿｽ�ｿ�ｽ�ｽ�ｽ�ｽ闕ｳ�ｻ�ｽ�ｸ�ｽ�ｷ�ｽ�ｽ�ｽ�ｹ�ｽ�ｽ�ｽ�ｧ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｮ鬯ｩ蟷｢�ｽ�｢髫ｴ雜｣�ｿ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｧ鬮ｯ蜿･�ｹ�｢�ｽ�ｽ�ｽ�ｵ鬩搾ｽｵ�ｽ�ｺ�ｽ�ｽ�ｽ�ｽ Pro W3", "Hiragino Kaku Gothic Pro", "�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｭ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｳ �ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｰ鬯ｩ蟷｢�ｽ�｢�ｽ�ｽ�ｽ�ｧ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｴ鬯ｩ蟷｢�ｽ�｢�ｽ�ｽ�ｽ�ｧ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｽ�ｷ鬯ｩ蟷｢�ｽ�｢髫ｴ雜｣�ｽ�｢�ｽ�ｽ�ｽ�ｿ�ｽ�ｽ�ｽ�ｽ鬩搾ｽｵ�ｽ�ｺ�ｽ�ｽ�ｽ�ｽ", sans-serif;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.025em;
  line-height: 1.75;
  word-break: break-all;
  word-wrap: break-word
}

a {
  color: #355da7;
  color: #355da7;
  text-decoration: underline;
  transition: 0.3s all ease-out
}

a.is-hover {
  color: #355da7
}

.is-hover {
  -ms-filter: "alpha(opacity=50)";
  filter: alpha(opacity=50);
  opacity: .5;
  zoom: 1
}

img {
  vertical-align: middle;
  -webkit-touch-callout: none
}

ol, ul, li {
  list-style: none
}

span, i {
  display: inline-block
}

input, textarea, button {
  outline: none
}

input:placeholder-shown, textarea:placeholder-shown, button:placeholder-shown {
  color: #9e9e9e
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder, button::-webkit-input-placeholder {
  color: #9e9e9e
}

input:-moz-placeholder, textarea:-moz-placeholder, button:-moz-placeholder {
  color: #9e9e9e;
  -ms-filter: "alpha(opacity=100)";
  filter: alpha(opacity=100);
  opacity: 1;
  zoom: 1
}

input::-moz-placeholder, textarea::-moz-placeholder, button::-moz-placeholder {
  color: #9e9e9e;
  -ms-filter: "alpha(opacity=100)";
  filter: alpha(opacity=100);
  opacity: 1;
  zoom: 1
}

input:-ms-input-placeholder, textarea:-ms-input-placeholder, button:-ms-input-placeholder {
  color: #9e9e9e
}

.site-header+main {
  padding-top: 136px
}

@media (max-width: 767px) {
  .site-header+main {
    padding-top: 63px
  }
}

.container {
  margin-right: auto;
  margin-left: auto;
  padding-right: 20px;
  padding-left: 20px;
  max-width: 1000px
}

.container.is-s {
  max-width: 840px
}

.container .container {
  padding-right: 0 !important;
  padding-left: 0 !important
}

.container .container.is-s {
  max-width: 800px
}

@media (max-width: 767px) {
  .container.is-wide {
    padding-right: 10px;
    padding-left: 10px
  }
}

.sec {
  padding-top: 60px;
  padding-bottom: 60px
}

.sec.is-s {
  padding-top: 30px;
  padding-bottom: 30px
}

.sec.is-t0 {
  padding-top: 0
}

.sec.is-b0 {
  padding-bottom: 0
}

.sec.is-gray {
  background-color: #eee
}

.sec.is-navy {
  background-color: #0b3256
}

.sec.is-navy, .sec.is-navy .sec-title, .sec.is-navy .sec-title-en {
  color: #fff
}

.sec.is-navy .sec-title-en+.sec-title:before {
  background-color: #fff
}

.sec.is-red {
  background-color: #ac9552;
  color: #fff
}

.sec.is-red, .sec.is-red .sec-title, .sec.is-red .sec-title-en {
  color: #fff
}

.sec.is-red .sec-title-en+.sec-title:before {
  background-color: #fff
}

.sec-title {
  color: #e74707;
  font-size: 258%;
  font-weight: 700;
  line-height: 1.5;
  text-align: center
}

.sec-title-en {
  color: #e74707;
  font-size: 258%;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  text-transform: uppercase
}

.sec-title-en+.sec-title {
  font-size: 86%;
  padding-top: 0.5em
}

.sec-title-en+.sec-title:before {
  background-color: #e74707;
  content: '';
  display: block;
  margin-left: -64px;
  position: absolute;
  top: 0;
  left: 50%;
  width: 128px;
  height: 1px
}

.sec-title .ic {
  display: inline-block;
  padding-left: 50px
}

.sec-title .ic:before {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  margin-top: -19px;
  position: absolute;
  left: 0;
  top: 50%;
  width: 40px;
  height: 40px
}

.sec-title .ic.is-schedule:before {
  background-image: url(/assets/images/common/icon-schedule-white.svg)
}

.sec-title+* {
  margin-top: 20px
}

.sec-subtitle {
  background-color: #646464;
  color: #fff;
  font-size: 129%;
  font-weight: 700;
  line-height: 1.5;
  margin-right: auto;
  margin-left: auto;
  padding: 10px 20px;
  max-width: 1180px
}

.sec-subtitle.is-blue {
  background-color: #355da7
}

.sec-subtitle.is-green {
  background-color: #80cd2c
}

.sec-subtitle+* {
  margin-top: 10px
}

.sec-subtitle .year, .sec-subtitle .monthday {
  font-size: 12px;
  font-weight: 400
}

.sec-lead {
  font-size: 115%;
  font-weight: 700;
  text-align: center
}

.sec-content {
  padding-top: 20px;
  padding-bottom: 20px
}

@media (max-width: 767px) {
  .sec {
    padding-top: 45px;
    padding-bottom: 45px
  }
  .sec-title {
    font-size: 200%
  }
  .sec-subtitle {
    font-size: 108%;
    padding: 8px 15px
  }
  .sec-lead {
    font-size: 108%
  }
}

@media (max-width: 480px) {
  .sec-subtitle {
    padding: 5px 10px
  }
}

body.article .entry-body p+p {
  margin-top: 1em
}

body.article .entry-body strong {
  font-weight: 700
}

body.article .entry-body .asset-image {
  margin-top: 1em;
  margin-right: auto;
  margin-bottom: 3em;
  margin-left: auto;
  max-width: 800px
}

body.article .sec-event-detail .entry-body h3 {
  font-size: 129%;
  font-weight: 700
}

body.article .sec-event-detail .entry-body p+p {
  margin-top: 0
}

.entry-youtube {
  display: block;
  margin-right: auto;
  margin-left: auto;
  max-width: 560px
}

.entry-youtube-body {
  display: block;
  padding-top: 56.25%;
  width: 100%;
  height: 0
}

.entry-youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.sec-about-detail .about-access-map {
  padding-top: 75%;
  width: 100%;
  height: 0
}

.sec-about-detail .about-access-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.sec-about-detail .about-anchor {
  letter-spacing: 0;
  margin-right: -10px;
  margin-left: -10px
}

.sec-about-detail .about-anchor ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%
}

.sec-about-detail .about-anchor li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-right: 10px;
  padding-left: 10px;
  width: 25%
}

.sec-about-detail .about-anchor a {
  max-width: none !important;
  width: 100%
}

.sec-about-detail .about-anchor.is-5 {
  margin-top: -20px
}

.sec-about-detail .about-anchor.is-5 li {
  padding-top: 20px;
  width: 33.33333333%
}

.sec-about-detail .about-body {
  padding: 10px 0 60px
}

.sec-about-detail .about-body.is-s {
  padding-bottom: 20px
}

.sec-about-detail .about-body ol {
  margin-left: 1.5em
}

.sec-about-detail .about-body ol li {
  list-style-type: decimal
}

.sec-about-detail .about-body p+*, .sec-about-detail .about-body .about-image+*, .sec-about-detail .about-body .list-notice {
  margin-top: 1em
}

.sec-about-detail .about-body p+.about-system {
  margin-top: 0
}

.sec-about-detail .about-body p+.about-system ul {
  margin-top: 0
}

.sec-about-detail .about-body .preload+p {
  font-size: 86%;
  margin-top: 0.5em
}

.sec-about-detail .about-col {
  margin-right: -20px;
  margin-left: -20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.sec-about-detail .about-contact {
  font-size: 135%;
  line-height: 1.5;
  text-align: center
}

.sec-about-detail .about-contact-hour {
  font-size: 75%;
  font-weight: 400
}

.sec-about-detail .about-contact strong {
  font-size: 140%;
  font-weight: 700
}

.sec-about-detail .about-row {
  padding-right: 20px;
  padding-left: 20px;
  width: 50%
}

.sec-about-detail .about-image {
  margin-right: auto;
  margin-left: auto
}

.sec-about-detail .about-image ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -30px;
  margin-left: -30px
}

.sec-about-detail .about-image li {
  padding-right: 30px;
  padding-left: 30px;
  width: 50%
}

.sec-about-detail .about-image.is-500 {
  max-width: 500px
}

.sec-about-detail .about-image.is-600 {
  max-width: 600px
}

.sec-about-detail .about-image.is-640 {
  max-width: 640px
}

.sec-about-detail .about-lead {
  text-align: center
}

.sec-about-detail .about-lead-title {
  font-size: 150%;
  font-weight: 700;
  margin-bottom: 0.5em;
  text-align: center
}

.sec-about-detail .about-notice {
  background-color: #eee;
  border: 1px solid #646464;
  border-radius: 10px;
  padding: 40px
}

.sec-about-detail .about-notice .btn.is-fany {
  margin: 0;
  max-width: 250px
}

.sec-about-detail .about-notice .btn.is-fany img {
  max-width: 200px
}

.sec-about-detail .about-system .about-image {
  padding-top: 20px;
  padding-bottom: 20px
}

.sec-about-detail .about-system .about-image:after {
  border: 1px solid rgba(100, 100, 100, 0.25);
  content: '';
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0
}

.sec-about-detail .about-system ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -40px;
  margin-right: -30px;
  margin-left: -30px
}

.sec-about-detail .about-system li {
  padding-top: 40px;
  padding-right: 30px;
  padding-left: 30px;
  width: 50%
}

.sec-about-detail .about-system.is-3 ul {
  margin-bottom: -40px;
  margin-right: -25px;
  margin-left: -25px
}

.sec-about-detail .about-system.is-3 li {
  padding-right: 25px;
  padding-left: 25px;
  width: 33.33333333%
}

.sec-about-detail .about-subtitle {
  font-size: 115%;
  font-weight: 700
}

.sec-about-detail .about-subtitle.is-center {
  text-align: center
}

.sec-about-detail .about-subtitle+p {
  margin-top: 10px
}

.sec-about-detail .about-ticket .about-notice {
  margin-top: 1em
}

.sec-about-detail .about-ticket .about-title {
  text-align: center
}

.sec-about-detail .about-title {
  font-size: 150%;
  font-weight: 700;
  line-height: 1.5
}

.sec-about-detail .about-title.is-center {
  text-align: center
}

.sec-about-detail .about-title+* {
  margin-top: 1em
}

.sec-about-detail .about-visit .about-body+.about-body .about-visit-title+.about-col {
  margin-top: -10px
}

.sec-about-detail .about-visit .about-col+.about-col {
  margin-top: 20px
}

.sec-about-detail .about-visit .about-col+.about-col .about-visit-title+.about-col {
  margin-top: -20px
}

.sec-about-detail .about-visit .about-row {
  padding-top: 20px
}

@media (max-width: 991px) {
  .sec-about-detail .about-system ul {
    margin-right: -20px;
    margin-left: -20px
  }
  .sec-about-detail .about-system li {
    padding-right: 20px;
    padding-left: 20px
  }
  .sec-about-detail .about-system.is-3 ul {
    margin-right: -15px;
    margin-left: -15px
  }
  .sec-about-detail .about-system.is-3 li {
    padding-right: 15px;
    padding-left: 15px
  }
}

@media (max-width: 767px) {
  .sec-about-detail .about-anchor {
    margin-top: -20px
  }
  .sec-about-detail .about-anchor li {
    padding-top: 20px;
    width: 50% !important
  }
  .sec-about-detail .about-lead {
    text-align: left
  }
  .sec-about-detail .about-notice {
    padding: 20px
  }
  .sec-about-detail .about-system.is-3 ul {
    margin-right: -20px;
    margin-left: -20px
  }
  .sec-about-detail .about-system.is-3 li {
    padding-right: 20px;
    padding-left: 20px;
    width: 50%
  }
  .sec-about-detail .about-title.is-center, .sec-about-detail .about-subtitle.is-center {
    text-align: left
  }
}

@media (max-width: 640px) {

  .sec-about-detail .about-col {
    margin-right: 0;
    margin-left: 0
  }
  .sec-about-detail .about-row {
    padding-right: 0;
    padding-left: 0;
    width: 100%
  }
  .sec-about-detail .about-row+.about-row {
    padding-top: 20px
  }
  .sec-about-detail .about-ticket .text-center {
    text-align: left !important
  }
}

@media (max-width: 480px) {
  .sec-about-detail .about-image ul {
    margin-right: 0;
    margin-left: 0
  }
  .sec-about-detail .about-image li {
    padding-right: 0;
    padding-left: 0;
    width: 100%
  }
  .sec-about-detail .about-image li+li {
    padding-top: 1em
  }
  .sec-about-detail .about-system ul {
    margin-right: 0 !important;
    margin-left: 0 !important
  }
  .sec-about-detail .about-system li {
    padding-right: 0 !important;
    padding-left: 0 !important;
    width: 100% !important
  }
}

@media (max-width: 400px) {
  .sec-about-detail .about-anchor {
    margin-top: -10px !important;
    margin-right: 0;
    margin-left: 0
  }
  .sec-about-detail .about-anchor li {
    padding-top: 10px !important;
    padding-right: 0;
    padding-left: 0;
    width: 100% !important
  }
}

.sec-access .access-map {
  height: 540px
}

.sec-access .access-map iframe {
  width: 100%;
  height: 100%
}

.sec-access .access-address {
  background-color: #ffe9e1;
  font-weight: 700;
  margin-top: 20px;
  padding: 20px;
  text-align: center
}

@media (max-width: 767px) {
  .sec-access .access-map {
    height: 480px
  }
  .sec-access .access-address {
    font-size: 100%;
    margin-top: 15px;
    padding: 15px
  }
}

@media (max-width: 640px) {
  .sec-access .access-map {
    height: 360px
  }
}

@media (max-width: 480px) {
  .sec-access .access-map {
    height: 240px
  }
  .sec-access .access-address {
    font-size: 93%;
    text-align: left
  }
}

.sec-award li+li {
  padding-top: 60px
}

.sec-banner ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -20px;
  margin-left: -10px;
  margin-right: -10px
}

.sec-banner li {
  padding-top: 20px;
  padding-right: 10px;
  padding-left: 10px;
  width: 25%
}

.sec-banner .btns {
  display: none;
  width: 100%
}

@media (max-width: 991px) {
  .sec-banner li {
    width: 33.33333333%
  }
}

@media (max-width: 767px) {
  .sec-banner .btn+ul {
    display: none
  }
  .sec-banner .btn+ul.active {
    display: block
  }
}

@media (max-width: 640px) {
  .sec-banner .btns {
    display: block
  }
  .sec-banner li {
    width: 50%
  }
  .sec-banner li.more {
    display: none
  }
}

.sec-social+.sec-banner {
  padding-top: 45px
}

.block-editor>*+* {
  margin-top: 2rem
}

.block-editor h1, .block-editor h2, .block-editor h3, .block-editor h4, .block-editor h5, .block-editor h6 {
  font-weight: 700
}

.block-editor h1 {
  font-size: 36px
}

.block-editor h2 {
  font-size: 30px
}

.block-editor h3 {
  font-size: 27px
}

.block-editor h4 {
  font-size: 22px
}

.block-editor em {
  font-style: italic
}

.block-editor strong {
  font-weight: 700
}

.block-editor ul, .block-editor ol {
  margin-left: 2em
}

.block-editor ul li {
  list-style-type: disc
}

.block-editor ol li {
  list-style-type: decimal
}

.block-editor img {
  max-width: 100% !important;
  width: auto !important
}

.sec-btns .btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.sec-btns .btns li {
  width: 50%
}

@media (max-width: 640px) {
  .sec-btns .btns li {
    width: 100%
  }
}

.sec-event ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 0;
  margin-right: -5px;
  margin-left: -5px
}

.sec-event li {
  padding-top: 30px;
  padding-right: 5px;
  padding-left: 5px;
  width: 25%
}

.sec-event li a {
  display: block;
  text-align: center
}

.sec-event li .preload {
  margin-bottom: 5px;
  padding-top: 141.25%
}

.sec-event li .preload .thumbnail {
  background-size: contain
}

.sec-event li .entrytitle {
  font-weight: 700;
  overflow: hidden;
  padding-left: 0;
  text-overflow: ellipsis;
  white-space: nowrap
}

.sec-event .news-meta, .sec-event .entry-meta {
  display: block;
  width: auto
}

.sec-event .event-btn {
  border-radius: 5px;
  padding-top: 0.75em;
  padding-bottom: 0.75em;
}

.sec-event .event-missed {
  background-color: #eee;
  border-radius: 5px;
  display: block;
  line-height: 1.2;
  margin-top: 5px;
  padding-top: 0.75em;
  padding-bottom: 0.75em;
  text-align: center;
}

@media (max-width: 767px) {
  .sec-event li {
    width: 33.33333333%
  }
}

@media (max-width: 640px) {
  .sec-event li {
    width: 50%
  }
}

.event-btn {
  background-color: #e74707;
  color: #fff;
  color: #fff;
  display: block;
  line-height: 1.2;
  margin-top: 5px;
  padding-top: 0.4em;
  padding-bottom: 0.4em;
  text-align: center;
  text-decoration: none
}

.event-btn.is-hover {
  color: #fff
}

.event-btn.is-online {
  background-color: #e6599f
}

.event-date {
  font-size: 86%;
  text-align: center
}

.event-modal-bg, .event-modal-wrap {
  align-items: center;
  cursor: pointer;
  display: none;
  justify-content: center;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  transition: 0.3s all ease-out;
  width: 100%;
  height: 100%
}

.event-modal-bg.active, .event-modal-wrap.active {
  display: flex
}

.event-modal-bg {
  background-color: rgba(0, 0, 0, 0.75);
  z-index: 100
}

.event-modal-bg.fade {
  opacity: 1
}

.event-modal-body {
  margin: auto;
  width: 100%;
  max-width: 400px
}

.event-modal-body.is-4 {
  max-width: 600px
}

.event-modal-close {
  background-color: #e74707;
  border-radius: 50%;
  display: block;
  position: fixed;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px
}

.event-modal-close:before, .event-modal-close:after {
  background-color: #fff;
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 50%;
  height: 2px
}

.event-modal-close:before {
  transform: translateX(-50%) translateY(-50%) rotate(45deg)
}

.event-modal-close:after {
  transform: translateX(-50%) translateY(-50%) rotate(-45deg)
}

.event-modal-content {
  cursor: default;
  text-align: center
}

.event-modal-content .event-btn {
  border-radius: 5px;
  padding-top: 1em;
  padding-bottom: 1em;
}

.event-modal-wrap {
  overflow: auto;
  padding: 20px;
  z-index: 200
}

.event-modal-wrap.fade {
  opacity: 1
}

@media (max-width: 480px) {
  .event-btn {
    font-size: 93%
  }

  .event-date {
    font-size: 79%
  }
}

.faq {
  border: 1px solid #646464;
  margin-top: 20px
}

.faq-body img {
  width: auto;
  max-width: 100%
}

.faq-body+.faq-body {
  margin-top: 60px
}

.faq-body p+*, .faq-body .faq-image+*, .faq-body .btns+* {
  margin-top: 1em
}

.faq-body strong {
  font-weight: 700
}

.faq-body a {
  text-decoration: underline
}

.faq-body a.btn {
  color: #fff;
  text-decoration: none
}

.faq-body .btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -5px;
  margin-left: -5px;
  text-align: center
}

.faq-body .btns li {
  padding-right: 5px;
  padding-left: 5px;
  width: 50%
}

@media (max-width: 480px) {
  .faq-body .btns {
    margin-right: 0;
    margin-left: 0
  }
  .faq-body .btns li {
    padding-right: 0;
    padding-left: 0;
    width: 100%

  }
  .faq-body .btns li+li {
    padding-top: 10px
  }
}

.faq-q, .faq-title {
  background-color: #e0e0e0;
  color: #000;
  font-weight: 700;
  padding: 10px
}

.faq-q {
  padding-left: 35px
}

.faq-q:before {
  background-color: #646464;
  border-radius: 10px;
  color: #fff;
  content: 'Q';
  display: block;
  font-family: sans-serif;
  font-size: 80%;
  line-height: 20px;
  position: absolute;
  top: 12px;
  left: 10px;
  text-align: center;
  width: 20px;
  height: 20px
}

.faq-a {
  padding: 15px
}

.faq-a-title {
  margin-left: -5px;
  padding-left: 25px
}

.faq-a-title:before {
  background-color: #355da7;
  border-radius: 10px;
  color: #fff;
  content: 'A';
  display: block;
  font-family: sans-serif;
  font-size: 80%;
  line-height: 20px;
  position: absolute;
  top: 2px;
  left: 0px;
  text-align: center;
  width: 20px;
  height: 20px
}

.faq-image {
  text-align: center
}

.sec-flyer a {
  display: block
}

.sec-flyer p {
  margin-top: 0.5em;
  text-align: center
}

.sec-flyer .btns {
  margin-top: 20px
}

.sec-flyer .owl-stage {
  align-items: center;
  display: flex
}

.sec-flyer .event-btn {
  display: none
}

.sec-flyer .event-thumbnail .preload {
  padding-top: 141.25%
}

.sec-flyer .event-thumbnail .preload .thumbnail {
  -webkit-background-size: 100% auto;
  -moz-background-size: 100% auto;
  -ms-background-size: 100% auto;
  background-size: 100% auto
}

@media (max-width: 991px) {
  .sec-flyer .btns {
    margin-top: 15px
  }
}

.movie {
  max-width: 800px;
  margin-right: auto;
  margin-left: auto
}

.movie:before {
  content: '';
  display: block;
  padding-top: 56.25%;
  width: 100%;
  height: 0
}

.movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.sec-mv .mv-image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  overflow: hidden;
  padding-top: 50%;
  width: 100%;
  height: 0
}

@media (max-width: 767px) {
  .sec-mv .mv-image {
    padding-top: 66.66666667%
  }
}

.sec-news ul {
  margin-top: 0
}

.sec-news li {
  border-bottom: 1px solid rgba(100, 100, 100, 0.25)
}

.sec-news li a {
  align-items: center;
  color: #646464;
  color: #646464;
  display: flex;
  font-weight: 700;
  padding-top: 10px;
  padding-right: 30px;
  padding-bottom: 10px;
  text-decoration: none
}

.sec-news li a.is-hover {
  color: #646464
}

.sec-news li:after {
  content: '\f054';
  font-family: 'Font Awesome 5 Free';
  font-weight: 700;
  line-height: 30px;
  margin-top: -15px;
  position: absolute;
  top: 50%;
  right: 10px
}

.sec-news .page-navigation {
  border-bottom: none !important;
  padding-top: 40px;
  text-align: center;
  width: 100% !important
}

.sec-news .page-navigation:after {
  display: none
}

.sec-news .page-navigation a {
  display: inline-block;
  font-weight: 700;
  margin: 0 10px;
  padding: 0 !important
}

.sec-news .page-navigation-next:after, .sec-news .page-navigation-prev:before {
  display: inline-block;
  font-family: 'Font Awesome 5 Free';
  font-weight: 700
}

.sec-news .page-navigation-next:after {
  content: '\f054';
  margin-left: 5px
}

.sec-news .page-navigation-prev:before {
  content: '\f053';
  margin-right: 5px
}

.sec-news .btns {
  margin-top: 20px
}

.sec-news .btns .btn {
  margin-right: auto;
  margin-left: auto;
  width: calc(50% - 20px)
}

.sec-news.is-short ul {
  overflow: auto;
  max-height: 240px
}

@media (max-width: 991px) {
  .sec-news .btns {
    margin-top: 15px
  }
  .sec-news .btns .btn {
    width: calc(50% - 15px)
  }
}

@media (max-width: 767px) {
  .sec-news ul {
    margin-top: 0
  }
  .sec-news li a {
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 0
  }
  .sec-news .btns {
    margin-top: 15px
  }
  .sec-news .btns .btn {
    width: calc(50% - 10px)
  }
}

@media (max-width: 480px) {

  .sec-news li a {
    display: block
  }
  .sec-news li .news-title, .sec-news li .entrytitle {
    font-size: 93%;
    padding-top: 5px;
    padding-left: 0
  }
  .sec-news .btns .btn {
    width: auto
  }
}

.sec-news-detail .container {
  margin-right: auto;
  margin-left: auto;
  max-width: 800px
}

.news-meta, .entry-meta {
  width: 120px
}

.news-title, .entrytitle {
  flex: 1;
  padding-left: 15px
}

.news-date, .news-category, .entry-date, .entry-category {
  display: block;
  font-size: 79%;
  font-weight: 400
}

.news-date {
  opacity: 0.75
}

.news-category, .entry-category {
  background-color: #eee;
  color: #e74707;
  margin-top: 0.5em;
  text-align: center
}

@media (max-width: 767px) {
  .news-date, .entry-meta {
    font-size: 86%;
    position: relative
  }
}

@media (max-width: 480px) {
  .news-meta, .entry-meta {
    width: auto
  }
  .news-date, .news-category, .entry-date, .entry-category {
    display: inline-block
  }
  .news-category, .entry-category {
    width: 90px
  }
}

.sec-news-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -30px;
  margin-right: -30px;
  margin-left: -30px
}

.sec-news-list li {
  padding-top: 60px;
  padding-right: 30px;
  padding-left: 30px;
  width: 50%
}

.sec-news-list li a {
  display: block
}

.sec-news-list .entry-meta {
  margin-top: 0.5em
}

.sec-news-list .entrytitle {
  font-size: 115%;
  font-weight: 700;
  margin-top: 0.25em
}

.sec-news-list .entry-excerpt {
  margin-top: 0.25em
}

.sec-news-list .entry-thumbnail {
  padding-top: 56.25%
}

.sec-news-list .pagemore .btn {
  margin-top: 1em
}

.sec-news-list .page-navigation {
  width: 100% !important
}

.sec-news-list .page-navigation:after {
  clear: both;
  content: '';
  display: block
}

.sec-news-list .page-navigation a {
  border: 2px solid #e74707;
  color: #e74707;
  color: #e74707;
  font-size: 86%;
  font-weight: 700;
  padding: 10px 10px
}

.sec-news-list .page-navigation a.is-hover {
  color: #e74707
}

.sec-news-list .page-navigation-prev {
  float: left
}

.sec-news-list .page-navigation-next {
  float: right
}

@media (max-width: 991px) {
  .sec-news-list ul {
    margin-top: -10px;
    margin-right: -20px;
    margin-left: -20px
  }
  .sec-news-list li {
    padding-top: 40px;
    padding-right: 20px;
    padding-left: 20px
  }
}

@media (max-width: 767px) {
  .sec-news-list ul {
    margin-right: 0;
    margin-left: 0
  }
  .sec-news-list li {
    padding-right: 0;
    padding-left: 0;
    width: 100%
  }
}

.sec-notice .notice-body {
  border: 2px solid #e74707
}

.sec-notice .notice-title {
  color: #e74707;
  font-size: 115%;
  font-weight: 700;
  padding: 5px 10px;
  text-align: center
}

.sec-notice ul {
  padding: 0 1em 1em
}

.sec-notice li {
  border-bottom: 1px dashed rgba(100, 100, 100, 0.5);
  font-size: 93%;
  line-height: 1.5
}

.sec-notice li+li {
  margin-top: 0.25em
}

.sec-notice li a {
  display: block;
  padding-top: 10px;
  padding-bottom: 10px
}

.sec-notice.is-toggle {
  display: none
}

.sec-notice.is-toggle.active {
  display: block
}

.sec-notice.is-toggle .notice-title {
  cursor: pointer
}

.sec-notice.is-toggle .notice-title:after {
  content: '\f067';
  font-family: 'Font Awesome 5 Free';
  font-weight: 700;
  line-height: 40px;
  margin-top: -20px;
  position: absolute;
  right: 0;
  top: 50%;
  text-align: center;
  width: 30px
}

.sec-notice.is-toggle .notice-title.is-open:after {
  content: '\f068'
}

.sec-notice.is-toggle ul {
  display: none
}

@media (max-width: 767px) {
  .sec-notice .notice-title {
    font-size: 100%
  }
  .sec-notice li {
    font-size: 93%
  }
}

.sec-profile ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 0;
  margin-right: -20px;
  margin-left: -20px
}

.sec-profile .sec-subtitle+ul {
  margin-top: -40px
}

.sec-profile li {
  padding-top: 60px;
  padding-right: 20px;
  padding-left: 20px;
  width: 33.33333333%
}
li.th-li {
    padding-top: 60px;
    padding-right: 20px;
    padding-left: 20px;
    width: 49.666666%;
}
.sec-profile .profile+.profile {
  margin-top: 60px
}

.sec-profile .profile-title {
  font-size: 129%;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 0.5em
}

.sec-profile .profile p {
  border-top: 1px solid rgba(100, 100, 100, 0.25);
  border-bottom: 1px solid rgba(100, 100, 100, 0.25);
  margin-top: 1em;
  padding-top: 1em;
  padding-bottom: 1em
}

.sec-profile .profile p+p {
  border-top: none;
  margin-top: 0
}

.sec-profile .profile-official {
  background-color: #355da7;
  border-radius: 14px;
  color: #fff;
  color: #fff;
  display: inline-block;
  font-size: 86%;
  line-height: 26px;
  padding-right: 10px;
  padding-left: 10px;
  text-decoration: none
}

.sec-profile .profile-official.is-hover {
  color: #fff
}

.sec-profile .profile-anchor {
  letter-spacing: 0;
  margin-right: -10px;
  margin-left: -10px
}

.sec-profile .profile-anchor ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 40px !important;
  margin-right: 0;
  margin-left: 0;
  width: 100%
}

.sec-profile .profile-anchor li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-top: 0 !important;
  padding-right: 10px;
  padding-left: 10px;
  width: 25%
}

.sec-profile .profile-anchor a {
  max-width: none !important;
  width: 100%
}

@media (max-width: 991px) {
  .sec-profile ul {
    margin-right: -15px;
    margin-left: -15px
  }
  .sec-profile .sec-subtitle+ul {
    margin-top: -20px
  }
  .sec-profile li {
    padding-top: 40px;
    padding-right: 15px;
    padding-left: 15px
  }
}

@media (max-width: 767px) {
  .sec-profile ul {
    margin-right: -10px;
    margin-left: -10px
  }
  .sec-profile li {
    padding-right: 10px;
    padding-left: 10px;
    width: 50%
  }
	
li.th-li {
    padding-right: 10px;
    padding-left: 10px;
    width: 100%;
}
  .sec-profile .profile-anchor li {
    width: 50%
  }
}

@media (max-width: 480px) {
  .sec-profile .profile-title {
    font-size: 100%
  }
}

@media (max-width: 400px) {
  .sec-profile .profile-anchor {
    margin-right: 0;
    margin-left: 0
  }
  .sec-profile .profile-anchor li {
    padding-top: 10px !important;
    padding-right: 0;
    padding-left: 0;
    width: 100%
  }
}

@-webkit-keyframes calendarActive {
  0% {
    background-color: #355da7
  }
  50% {
    background-color: rgba(53, 93, 167, 0)
  }
  100% {
    background-color: #355da7
  }
}

@-moz-keyframes calendarActive {
  0% {
    background-color: #355da7
  }
  50% {
    background-color: rgba(53, 93, 167, 0)
  }
  100% {
    background-color: #355da7
  }
}

@-ms-keyframes calendarActive {
  0% {
    background-color: #355da7
  }
  50% {
    background-color: rgba(53, 93, 167, 0)
  }
  100% {
    background-color: #355da7
  }
}

@keyframes calendarActive {
  0% {
    background-color: #355da7
  }
  50% {
    background-color: rgba(53, 93, 167, 0)
  }
  100% {
    background-color: #355da7
  }
}

@-webkit-keyframes calendarPastActive {
  0% {
    background-color: #9e9e9e
  }
  50% {
    background-color: rgba(158, 158, 158, 0)
  }
  100% {
    background-color: #9e9e9e
  }
}

@-moz-keyframes calendarPastActive {
  0% {
    background-color: #9e9e9e
  }
  50% {
    background-color: rgba(158, 158, 158, 0)
  }
  100% {
    background-color: #9e9e9e
  }
}

@-ms-keyframes calendarPastActive {
  0% {
    background-color: #9e9e9e
  }
  50% {
    background-color: rgba(158, 158, 158, 0)
  }
  100% {
    background-color: #9e9e9e
  }
}

@keyframes calendarPastActive {
  0% {
    background-color: #9e9e9e
  }
  50% {
    background-color: rgba(158, 158, 158, 0)
  }
  100% {
    background-color: #9e9e9e
  }
}

@-webkit-keyframes calendarTodayActive {
  0% {
    background-color: #e74707
  }
  50% {
    background-color: rgba(231, 71, 7, 0)
  }
  100% {
    background-color: #e74707
  }
}

@-moz-keyframes calendarTodayActive {
  0% {
    background-color: #e74707
  }
  50% {
    background-color: rgba(231, 71, 7, 0)
  }
  100% {
    background-color: #e74707
  }
}

@-ms-keyframes calendarTodayActive {
  0% {
    background-color: #e74707
  }
  50% {
    background-color: rgba(231, 71, 7, 0)
  }
  100% {
    background-color: #e74707
  }
}

@keyframes calendarTodayActive {
  0% {
    background-color: #e74707
  }
  50% {
    background-color: rgba(231, 71, 7, 0)
  }
  100% {
    background-color: #e74707
  }
}

.sec-schedule .calendar .sat {
  color: #06c
}

.sec-schedule .calendar .sun {
  color: #c00
}

.sec-schedule .calendar-month {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}

.sec-schedule .calendar-month li {
  width: 33.33333333%
}

.sec-schedule .calendar-month li+li a {
  border-left: none
}

.sec-schedule .calendar-month a {
  border: 1px solid #355da7;
  color: #355da7;
  color: #355da7;
  display: block;
  font-weight: 700;
  padding-top: 5px;
  padding-bottom: 5px;
  text-align: center
}

.sec-schedule .calendar-month a.is-hover {
  color: #355da7
}

.sec-schedule .calendar-month a.active {
  background-color: #355da7;
  color: #fff;
  color: #fff
}

.sec-schedule .calendar-month a.active.is-hover {
  color: #fff
}

.sec-schedule .calendar dl {
  border: 1px solid rgba(0, 0, 0, 0.25);
  display: table;
  font-size: 90%;
  table-layout: fixed;
  text-align: center;
  width: 100%
}

.sec-schedule .calendar dl+dl {
  border-top: none
}

.sec-schedule .calendar dl dt, .sec-schedule .calendar dl dd {
  border-left: 1px solid rgba(0, 0, 0, 0.25);
  display: table-cell
}

.sec-schedule .calendar dl dt:first-child, .sec-schedule .calendar dl dd:first-child {
  border-left: none
}

.sec-schedule .calendar dl dt {
  background-color: rgba(0, 0, 0, 0.05);
  padding: 5px
}

.sec-schedule .calendar dl dd.is-6 {
  color: #06c
}

.sec-schedule .calendar dl dd.is-6 a {
  color: #06c;
  color: #06c
}

.sec-schedule .calendar dl dd.is-6 a.is-hover {
  color: #06c
}

.sec-schedule .calendar dl dd.is-0 {
  color: #c00
}

.sec-schedule .calendar dl dd.is-0 a {
  color: #c00;
  color: #c00
}

.sec-schedule .calendar dl dd.is-0 a.is-hover {
  color: #c00
}

.sec-schedule .calendar dl dd.is-past a:after {
  background-color: #9e9e9e
}

.sec-schedule .calendar dl dd.is-today {
  color: #fff
}

.sec-schedule .calendar dl dd.is-today:before {
  background: #e74707;
  border-radius: 50%;
  content: '';
  display: block;
  margin-top: -12px;
  margin-left: -12px;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 24px;
  height: 24px;
  z-index: -1
}

.sec-schedule .calendar dl dd.is-today a {
  color: #fff;
  color: #fff
}

.sec-schedule .calendar dl dd.is-today a.is-hover {
  color: #fff
}

.sec-schedule .calendar dl dd.is-today a:after {
  display: none
}

.sec-schedule .calendar dl dd.is-gray {
  color: #9e9e9e !important
}

.sec-schedule .calendar dl dd.is-gray p, .sec-schedule .calendar dl dd.is-gray a, .sec-schedule .calendar dl dd.is-gray:before {
  display: none
}

.sec-schedule .calendar dl dd.is-gray a {
  color: #9e9e9e;
  color: #9e9e9e
}

.sec-schedule .calendar dl dd.is-gray a.is-hover {
  color: #9e9e9e
}

.sec-schedule .calendar dl dd.is-gray a:after {
  background-color: rgba(0, 0, 0, 0.15)

}

.sec-schedule .calendar dl p, .sec-schedule .calendar dl a {
  display: block;
  padding: 5px
}

.sec-schedule .calendar dl a {
  background-color: rgba(231, 71, 7, 0.05);
  color: #355da7;
  color: #355da7;
  font-weight: 700;
  text-decoration: underline
}

.sec-schedule .calendar dl a.is-hover {
  color: #355da7
}

.sec-schedule .calendar-day dl {
  border-top: none
}

.sec-schedule .schedule {
  margin-top: 20px
}

.sec-schedule .schedule-block {
  border-top: 1px dashed #646464;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-top: 2em;
  padding-bottom: 2em
}

.sec-schedule .schedule-block-l {
  text-align: center;
  width: 40px
}

.sec-schedule .schedule-block-l.is-6 {
  color: #06c
}

.sec-schedule .schedule-block-l.is-0 {
  color: #c00
}

.sec-schedule .schedule-block-r {
  padding-left: 10px;
  width: 100%
}

.sec-schedule .schedule-time {
  border: 1px solid #646464;
  border-radius: 5px;
  cursor: pointer;
  display: block;
  font-size: 93%;
  line-height: 1.5;
  margin-top: 1em;
  padding: 10px;
  padding-right: 30px
}

.sec-schedule .schedule-time:first-child {
  margin-top: 0
}

.sec-schedule .schedule-time:after {
  color: #355da7;
  content: '\f055';
  font-family: 'Font Awesome 5 Free';
  font-size: 150%;
  font-weight: 700;
  line-height: 40px;
  margin-top: -20px;
  position: absolute;
  right: 2px;
  top: 50%;
  text-align: center;
  width: 30px
}

.sec-schedule .schedule-time strong {
  font-weight: 700
}

.sec-schedule .schedule-time.is-open:after {
  content: '\f056'
}

.sec-schedule .schedule-day {
  display: block;
  font-size: 60%;
  margin-top: -5px
}

.sec-schedule .schedule-date {
  display: block;
  font-size: 150%;
  font-weight: 700
}

.sec-schedule .schedule-detail {
  background-color: rgba(0, 0, 0, 0.05);
  border-radius: 5px;
  display: none;
  padding: 15px
}

.sec-schedule .schedule-detail dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}

.sec-schedule .schedule-detail dl+dl {
  margin-top: 1em
}

.sec-schedule .schedule-detail dt {
  text-align: center;
  width: 80px
}

.sec-schedule .schedule-detail dt label {
  background-color: #355da7;
  border-radius: 15px;
  color: #fff;
  display: block;
  font-weight: 700;
  font-size: 93%;
  line-height: 30px;
  width: 100%
}

.sec-schedule .schedule-detail dd {
  flex: 1;
  padding-left: 10px
}

.sec-schedule .schedule-detail dd a {
  text-decoration: underline
}

.sec-schedule .schedule-detail .btns {
  margin-right: -5px;
  margin-left: -5px
}

.sec-schedule .schedule-detail .btns ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.sec-schedule .schedule-detail .btns li {
  padding-right: 5px;
  padding-left: 5px;
  width: 50%
}

@media (max-width: 640px) {
  .sec-schedule .schedule-detail .btns li {
    width: 100%
  }
}

@media (max-width: 480px) {
  .sec-schedule .schedule-detail dl {
    display: block
  }
  .sec-schedule .schedule-detail dd {
    padding-left: 0
  }
}

.sec-schedule .schedule-none {
  background-color: rgba(0, 0, 0, 0.05);
  display: none;
  padding: 10px;
  text-align: center
}

.sec-schedule .btn {
  margin-top: 15px
}

.sec-schedule-dl a {
  background: url(/assets/images/schedule/banner-program.jpg) no-repeat center;
  background-size: contain;
  display: block;
  overflow: hidden;
  padding-top: 10%;
  text-indent: 100%;
  white-space: nowrap;
  width: 100%;
  height: 0
}

.sec-schedule-top {
  text-align: center
}

.sec-schedule-top .sec-lead {
  margin-bottom: 1em
}

.sec-social ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

.sec-social li {
  padding-right: 10px;
  padding-left: 10px
}

.sec-social img {
  border-radius: 10px;
  max-width: 60px;
  vertical-align: top
}

.ticket-list {
  margin-top: 1em;
  margin-right: -5px;
  margin-left: -5px
}

.ticket-list ul {
  display: flex;
  flex-wrap: wrap
}

.ticket-list li {
  padding-right: 5px;
  padding-left: 5px;
  width: 25%
}

.ticket-list a {
  display: block;
  letter-spacing: 0;
  font-size: 150%;
  padding: 20px 0;
  text-decoration: underline
}

.ticket-list a.is-online:before {
  content: '\f35d';
  font-family: 'Font Awesome 5 Free';
  font-weight: 700;
  position: absolute;
  top: 5px;
  right: 10px
}

.ticket-list img {
  max-width: 72px
}

.ticket-fany {
  margin-top: 4em
}

.ticket-fany dl {
  align-items: center;
  display: flex;
  flex-wrap: wrap
}

.ticket-fany dt {
  flex: 1;
  font-size: 150%;
  font-weight: 700;

  text-align: center;
  text-indent: 16px
}

.ticket-fany dt img {
  max-width: 270px;
  margin-bottom: 0.5em
}

.ticket-fany ul {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0.5em;
  margin-right: -5px;
  margin-left: -5px
}

.ticket-fany li {
  padding-right: 5px;
  padding-left: 5px;
  width: 50%
}

@media (max-width: 991px) {
  .ticket-list a {
    font-size: 129%
  }
  .btn.is-online {
    font-size: 129%
  }			
  .ticket-fany dl {
    display: block
  }

  .ticket-fany dd {
    padding-top: 1em
  }
}

@media (max-width: 767px) {
  .ticket-list ul {
    margin-top: -10px
  }
  .ticket-list li {
    padding-top: 10px;
    width: 50%
  }

  .ticket-list img {
    max-width: 60px
  }
}

@media (max-width: 480px) {
  .ticket-list a {
    font-size: 115%
  }
  .ticket-list img {
    max-width: 48px
  }
}

@media (max-width: 400px) {
  .ticket-list a {
    font-size: 100%
  }
  .btn.is-online {
    font-size: 100%
  }			
}

.sec-topics ul {
  display: flex;
  flex-wrap: wrap;
  margin-top: -40px;
  margin-right: -10px;
  margin-left: -10px;
  padding-top: 3em;
  justify-content: center
}

.sec-topics li {
  display: flex;
  padding-right: 10px;
  padding-left: 10px;
  padding-top: 40px;
  width: 25%
}

.sec-topics a {
  background-color: #fff;
  color: #646464;
  color: #646464;
  display: block;
  text-decoration: none;
  width: 100%
}

.sec-topics a.is-hover {
  color: #646464
}

.sec-topics .news-meta, .sec-topics .entry-meta {
  display: block;
  width: auto
}

.sec-topics .news-date, .sec-topics .entry-date {
  text-align: right
}

.sec-topics .news-date {
  padding: 0 10px
}

.sec-topics .news-category, .sec-topics .entry-category {
  width: 90px
}

.sec-topics .news-title {
  display: block;
  font-weight: 700;
  line-height: 1.2;
  padding: 10px
}

.sec-topics .entrytitle {
  padding: 10px 0 0
}

.sec-topics .btns {
  margin-top: 20px
}

@media (max-width: 767px) {
  .sec-topics li {
    width: 50%
  }
}