@charset "utf-8";

@import url("https://fonts.googleapis.com/css?family=Noto+Sans");

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
1.0 Normalize
2.0 Layouts
--------------------------------------------------------------*/
/*--------------------------------------------------------------
1.0 Normalize
Styles based on Normalize v5.0.0 @link https://github.com/necolas/normalize.css
--------------------------------------------------------------*/
* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.hbg_menu,
.slider_front_box img.slider_sp,
.sp_appear {
  display: none;
}
figcaption,
figure,
main,
article,
aside,
footer,
header,
nav,
section,
figcaption,
figure,
main,
.hbg_menu_show,
.headline01 .headline01_sub span {
  display: block;
}
audio,
video,
.sp_hide,
.location_information a,
.menu-trigger,
.menu-trigger span,
.sns_link li {
  display: inline-block;
}
img {
  border: none;
}
svg:not(:root) {
  overflow: hidden;
}
ul {
  list-style: none;
}
/*--------------------------------------------------------------
2.0 Layouts
--------------------------------------------------------------*/

/* Misc.
---------------------------------------------------------- */
/* Clearfix */
.clearfix:before,
.clearfix:after,
.cf:before,
.cf:after {
  content: "";
  display: block;
  overflow: hidden;
}
.clearfix:after,
.cf:after {
  clear: both;
}
.clearfix,
.cf {
  zoom: 1;
}
.flex {
  display: -webkit-flex;
  display: flex;
}
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,
font,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial, "游ゴシック",
    YuGothic, Futura, "ヒラギノ角ゴ Pro W3", Osaka, "Hiragino Kaku Gothic Pro",
    メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.6;
}
html {
  width: 100%;
  height: 100%;
  color: #333;
  font-size: 87.5%;
  line-height: 1.6;
  overflow-y: scroll;
}
html.font_s {
  font-size: 75%;
}
html.font_l {
  font-size: 112.5%;
}
body {
  position: relative;
  height: 100%;
  z-index: 0;
  margin: 0;
  background: #fff;
  color: #000;
  /*font-feature-settings: 'pkna' 1;*/
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -ms-text-size-adjust: 100%;
  font-size: 1rem;
}
a {
  color: #e6378d;
  outline: none;
  overflow: hidden;
  text-decoration: none;
}
a:hover {
  color: #000;
  text-decoration: underline;
}
a[href^="tel:"] {
  cursor: default;
}
.show-mobile-inline,
.show-mobile {
  display: none;
}

.hide-mobile {
  display: block;
}

.hide-mobile-inline {
  display: inline-block;
}

@media only screen and (max-width: 767px) {
  .show-mobile {
    display: block;
  }

  .show-mobile-inline {
    display: inline-block;
  }

  .hide-mobile {
    display: none;
  }

  .hide-mobile-inline {
    display: none;
  }
}

.t-alpha {
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
  font-weight: normal;
}

/* Header
---------------------------------------------------------- */
header {
  border-bottom: 3px solid #e6378d;
  width: 100%;
  background: #fff;
  font-size: 14px;
}
.header {
  width: 980px;
  margin: 0px auto 4px auto;
  display: -webkit-flex;
  display: flex;
  padding-top: 10px;
}
.header a {
  text-decoration: none;
  display: block;
}
.header .logo a {
  width: 224px;
}
.header .logo img {
  width: 224px;
  height: auto;
}
.header .logo {
  width: 300px;
}
.header_right {
  -webkit-flex: 1;
  flex: 1;
}
.header_right_top {
  margin: 14px 0 28px 0;
}
.header_right_top .header_misc {
  justify-content: space-between;
}
.header_misc form input[type="text"] {
  padding: 10px 40px 10px 16px;
  border-radius: 20px;
  border: 1px solid #e6e6e6;
  background: #fff url(../images/common/search_gy.svg) no-repeat right 12px top
    9px;
  background-size: 20px auto;
  width: 180px;
  height: 38px;
}
.header_misc form input[type="text"]:focus {
  outline: 0;
}
.header_misc form input[type="text"]:focus::placeholder {
  color: transparent;
}
.header_right_bottom nav {
  -webkit-flex: 1;
  flex: 1;
}
.lang_switch {
  width: 40px;
  margin-top: -7px;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
}
/* ドロップダウン */
.header_right_bottom nav li {
  position: relative;
}
.header_right_bottom > nav > ul > li > span,
.header_right_bottom nav li a {
  display: block;
  width: 100%;
  font-size: 16px;
  font-weight: bold;
  padding: 3px 25px 4px 4px;
  color: #e6378d;
  cursor: pointer;
}
.header_right_bottom nav li a .t-alpha {
  font-weight: normal;
}
.header_right_bottom nav li:last-of-type a {
  padding-right: 0;
}
.header_right_bottom nav li div {
  width: 100%;
  top: 30px;
  left: 0px;
  position: absolute;
  z-index: 9999;
}
.header_right_bottom nav li ul li a {
  display: block;
  padding: 6px 12px 6px 12px;
  background: #fff;
  width: 100%;
  border: 1px dotted #e6378d;
}
.nav_level1,
.nav_level2 {
  width: 220px;
  display: none;
}
.header_right_bottom nav .nav_level1 a:hover,
.header_right_bottom nav .nav_level2 a:hover {
  background: #e6378d;
  color: #fff;
}
.header_right_bottom nav .nav_level1.has_child > li > a {
  position: relative;
  padding-left: 26px;
  transition: all 0s;
}
.header_right_bottom nav .nav_level1.has_child > li > a:before {
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  left: 9px;
  top: 13px;
  background: url(../images/common/bg_gnav_level1.svg) no-repeat center;
  background-size: 10px auto;
}
.header_right_bottom nav .nav_level1.has_child > li > a:hover:before {
  background: #e6378d url(../images/common/bg_gnav_level1_w.svg) no-repeat
    center;
  background-size: 10px auto;
}
.header_right_bottom nav .nav_level1.has_child > li > a.is-open:before {
  transform: rotate(45deg);
}
.header_right_bottom nav li .nav_level2 a {
  font-size: 13px;
  font-weight: normal;
}
.header_sub_menu {
  background: #e6378d;
  height: 36px;
  border-radius: 20px;
  margin: 0 0 0 10px;
  font-weight: bold;
  font-size: 12px;
  line-height: 1;
}
.font_size_switch {
  width: 137px;
  height: 36px;
  float: left;
  color: #fff;
  padding: 7px 5px 8px 12px;
}
.font_size_switch span {
  font-weight: bold;
  font-size: 10px;
}
.font_size_switch select {
  cursor: pointer;
  outline: none;
  text-indent: 0.01px;
  text-overflow: "";
  font-size: inherit;
  color: inherit;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  color: #fff;
  border-color: #e6378d;
  font-weight: bold;
  vertical-align: baseline;
  width: 50px;
}
.font_size_switch select option {
  background: #828c9a;
}
.font_size_switch select:hover {
  text-decoration: underline;
}
.font_size_switch select:hover {
  color: #000;
}
.font_size_switch select::-ms-expand {
  display: none;
}
.font_size_switch select:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #828c9a;
}
.header_sub_menu a {
  display: block;
  padding: 8px 13px;
  height: 36px;
  float: left;
  color: #fff;
  font-weight: bold;
  border-left: 1px solid #fff;
}
.header_sub_menu a:hover {
  text-decoration: underline;
}
.header_event_button {
  margin-left: 8px;
}
.header_event_button a {
  display: block;
  background: #000 url(../images/top/mail_icon.svg) no-repeat left 10px center;
  background-size: 14px auto;
  color: #fff;
  padding: 12px 15px 11px 36px;
  height: 36px;
  border-radius: 18px;
  font-weight: bold;
  font-size: 12px;
  line-height: 1;
  white-space: nowrap;
}
.header_event_button a:hover {
  text-decoration: underline;
}
.lang_switch li {
  padding: 0 10px 0 0;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
  letter-spacing: 0.07em;
  text-align: center;
}
.lang_switch li:first-of-type {
  border-bottom: 1px solid #b3b3b3;
}
.lang_switch a {
  color: #b3b3b3;
}
.lang_switch a:hover {
  color: #e6378d;
}
.lang_switch span {
  color: #000;
}
/* 固定ヘッダー */
header.fixed {
  position: fixed;
  z-index: 1001;
}
header .logo img,
header .header_right_top,
header .header_right_bottom {
  transition: all 0.4s;
}
header.fixed .header .logo {
  width: 300px;
}
header.fixed .header .logo img {
  width: 150px;
}
header.fixed .header_right_top {
  margin: 0 0 12px 0;
}

/* Main
---------------------------------------------------------- */

/* Footer
---------------------------------------------------------- */
.footer {
  margin: 50px 0 0;
  background: #000;
  color: #fff;
  line-height: 1;
}
footer .inner {
  width: 980px;
  margin: 0 auto;
}
footer .footer .inner {
  padding: 40px 0;
}
footer a {
  color: #fff;
}
footer a:hover,
footer a:active {
  color: #e6378d;
}
.footer_left {
  width: 400px;
}
.footer_right {
  -webkit-flex: 1;
  flex: 1;
}
footer .logo {
  margin-bottom: 45px;
}
footer .logo img {
  width: 224px;
  height: auto;
}
footer address {
  font-style: normal;
  font-size: 12px;
}
footer address span {
  display: block;
  margin-bottom: 2px;
  letter-spacing: 0.04em;
}
.copyright {
  width: 100%;
  padding: 10px;
  margin: 0;
  font-size: 11px;
  background: #fff;
  color: #000;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
}
.footer_right {
  -webkit-flex: 1;
  flex: 1;
  font-size: 12px;
}
.footer_right .footer_nav_1,
.footer_right .footer_nav_2 {
  margin-right: 40px;
}
.footer_right .footer_nav_1 {
  width: calc(35.3333% - 40px);
}
.footer_right .footer_nav_2 {
  width: calc(38.3333% - 40px);
}
.footer_right .footer_nav_1 dt:nth-of-type(2) {
  margin-top: 65px;
}
.footer_right .footer_nav_2 dt:nth-of-type(2) {
  margin-top: 40px;
  /* margin-top: 15px; 　本番環境のfooterに「アーティスト紹介」を追加した時に反映 */
}
.footer_right .footer_nav_2 .fooer_nav_parent dl {
  margin-right: 40px;
}
.footer_right .footer_nav_1 dt,
.footer_right .footer_nav_2 dt,
.footer_right .footer_nav_3 > dt {
  font-size: 16px;
  margin-bottom: 12px;
  border-left: 4px solid #e6378d;
  padding: 0 0 0 10px;
  letter-spacing: 0.05em;
}
.footer_right .footer_nav_2 dd.fooer_nav_parent dt {
  margin: 0 0 8px 16px;
  letter-spacing: 0.1em;
  font-size: 0.9rem;
}
.footer_right dd:not(.fooer_nav_parent) {
  margin: 0 0 1px 10px;
}
.footer_right .footer_nav_1 a,
.footer_right .footer_nav_2 a,
.footer_right .footer_nav_3 a {
  display: block;
  text-decoration: none;
  line-height: 2;
}
.footer_right .footer_nav_1 a:hover,
.footer_right .footer_nav_2 a:hover,
.footer_right .footer_nav_3 a:hover {
  color: #e6378d;
}
.footer_right .footer_nav_1 a::before,
.footer_right .footer_nav_2 a::before,
.footer_right .footer_nav_3 a::before {
  content: "・";
  color: #e6378d;
}

/* トップページ
---------------------------------------------------------- */
.page_top section {
  margin-top: 30px;
}
/* メインイメージ
----------------------------------------------------------- */
.swiper-slide {
  text-align: center;
  position: relative;
  line-height: 0;
  font-size: 0;
  max-width: 980px;
  opacity: 0.4;
}
.swiper-slide img {
  width: 100%;
  height: auto;
}
.swiper-slide.swiper-slide-active {
  opacity: 1;
}
.main-slide-title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  color: #e6378d;
  font-weight: bold;
  width: 80%;
  line-height: 1.6;
}
.main-slide-title p {
  margin-bottom: 12px;
}
.slide-copy {
  font-size: 1.14rem;
  background: #fff;
  padding: 6px 18px;
  font-weight: bold;
}
.slide-title {
  font-size: 2rem;
  background: #fff;
  padding: 6px 20px;
  font-weight: bold;
}
.slide-date {
  font-size: 1rem;
  background: #fff;
  padding: 6px 12px;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
  font-weight: normal;
}
.main-slide-title span {
  transition: all 0.4s linear;
  opacity: 0;
}
.main-slide-title .slide-title {
  transition-delay: 0.1s;
}
.main-slide-title .slide-date {
  transition-delay: 0.2s;
}
.main-slide-title.is-active .slide-copy,
.main-slide-title.is-active .slide-title,
.main-slide-title.is-active .slide-date {
  opacity: 1;
}
.swiper-button-next,
.swiper-button-prev {
  width: 54px;
  height: 54px;
}
.swiper-button-next {
  background: url(../images/common/slider1_allow_right.svg) no-repeat center;
  background-size: 54px auto;
  right: 10px;
  left: auto;
  margin-top: -5px;
}
.swiper-button-prev {
  background: url(../images/common/slider1_allow_left.svg) no-repeat center;
  background-size: 54px auto;
  left: 10px;
  right: auto;
  margin-top: -5px;
  transform: rotate(0);
}
.swiper-pagination-bullet {
  display: inline-block;
  height: 6px;
  width: 80px;
  background: #fff;
  border: 0;
  border-radius: 0;
  opacity: 1;
}
.swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #e6378d;
}
section {
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
}
/* 黒枠ボタン
----------------------------------------------------------- */
.link_page_button {
  float: right;
  position: relative;
  padding: 4px 30px 4px 40px;
  font-weight: bold;
  border: 2px solid #000;
  border-radius: 50px;
}
a.link_page_button {
  display: block;
  color: #000;
}
a.link_page_button:hover {
  background: #000;
  color: #fff;
  text-decoration: none;
}
a.link_page_button:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  right: 11px;
  width: 6px;
  height: 6px;
  border-bottom: solid 2px #000;
  border-right: solid 2px #000;
  transform: translate(0, -50%) rotate(-45deg);
}
a.link_page_button:hover:after {
  border-bottom: solid 2px #fff;
  border-right: solid 2px #fff;
}
/* 最新のお知らせ
----------------------------------------------------------- */
.page_top section.hot_news {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  background-color: #f5f5f5;
}
.hot_news_box {
  position: relative;
  max-width: 980px;
  margin: 0 auto;
}
.hot_news_title {
  width: 167px;
  height: 100%;
  position: absolute;
  background-color: #e6378d;
  font-weight: bold;
}
.hot_news_title:before {
  content: "";
  position: absolute;
  width: 167px;
  height: 40px;
  top: -40px;
  background-color: #e6378d;
  opacity: 0.7;
  z-index: 100;
}
.hot_news_title span {
  margin: 15px auto;
  display: block;
  text-align: center;
  color: #fff;
  font-size: 1.14rem;
  letter-spacing: 0.07em;
  font-weight: bold;
}
.news_list {
  float: right;
  width: 790px;
}
.hot_news_box li {
  padding: 20px 6px;
  border-bottom: 1px dotted #000;
}
.news_date_label {
  width: 230px;
  padding: 0 10px 0 0;
}
.news_list a {
  width: calc(100% - 210px);
}
.news_date_label,
.news_list a {
  display: table-cell;
}
.news_list a:last-child {
  width: auto;
}
.type_box {
  background: #fff;
  border: 1px solid #e62686;
  display: table-cell;
  color: #e62686;
  padding: 2px 8px;
  margin: 0 12px;
  font-size: 0.79rem;
  font-weight: bold;
}
.font_l .type_box {
  font-size: 0.69rem;
}
.type_box_date {
  width: 84px;
  display: table-cell;
  color: #666;
  font-size: 0.84rem;
  letter-spacing: 0.07em;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
}
.font_l .type_box_date {
  font-size: 0.74rem;
}
.hot_news_box a {
  color: #000;
}
.news_list a.hot_news_more {
  width: auto;
  position: relative;
  float: right;
  margin-right: 10px;
  padding: 16px 15px 16px 0;
  line-height: 1;
}
.hot_news_more span:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  right: 3px;
  width: 5px;
  height: 5px;
  margin: 0;
  border-bottom: solid 2px #000;
  border-right: solid 2px #000;
  transform: translate(0, -50%) rotate(-45deg);
}
/* 新着イベント
----------------------------------------------------------- */
.event_title_right {
  float: right;
}
section h1 {
  display: inline-block;
  margin: 12px 20px 12px 0;
  color: #e6378d;
  font-size: 1.72rem;
  letter-spacing: 0.05em;
  font-weight: bold;
  float: none;
}
section h1 .t-alpha {
  font-weight: normal;
}
.event .description {
  display: inline-block;
  position: relative;
  color: #000;
  padding: 0 0 0 16px;
  margin: 18px 25px;
  transform: translateY(8px);
}
.event .description::before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 5px;
  height: 5px;
  border-bottom: solid 2px #000;
  border-right: solid 2px #000;
  transform: translate(0, -50%) rotate(-45deg);
}
.event a.link_page_button {
  margin: 20px 0 0 0;
  background: url(../images/top/event_01.svg) no-repeat left 10px center;
  background-size: 26px auto;
  color: #000;
}
.event a.link_page_button:hover {
  background: #000 url(../images/top/event_01_w.svg) no-repeat left 10px center;
  background-size: 26px auto;
  text-decoration: none;
  color: #fff;
}
.event_menu,
.week_event_menu {
  display: flex;
  justify-content: space-around;
  align-content: center;
  width: 100%;
  position: relative;
}
.event_menu::after {
  content: "";
  background-color: #e6e6e6;
  width: 98%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0);
}
.event_menu li {
  cursor: pointer;
  padding: 20px 0;
  font-weight: bold;
  vertical-align: middle;
  position: relative;
}
.event_menu li:nth-of-type(1) {
  flex-grow: 2;
  padding: 24px 0;
}
.event_menu li:nth-of-type(2),
.event_menu li:nth-of-type(3),
.event_menu li:nth-of-type(4),
.event_menu li:nth-of-type(5),
.event_menu li:nth-of-type(6) {
  flex-grow: 1;
}
.event_menu li::after {
  content: "";
  width: 90%;
  border-bottom: solid 4px #e6378d;
  position: absolute;
  left: 5%;
  right: 5%;
  bottom: 0;
  transform: scale(0, 1);
  transform-origin: center top;
  transition: all 0.4s;
  z-index: 1;
}
.event_menu li.is-active::after,
.event_menu li:hover::after {
  transform: scale(1, 1);
}
.event_menu span {
  text-align: center;
  color: #666;
  letter-spacing: 0.07em;
  font-weight: bold;
  border-left: 1px dotted #000;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.event_menu li:first-of-type span {
  border: none !important;
}
.event_menu span:hover {
  text-decoration: none;
}
.event_menu img {
  width: 30px;
  margin-right: 10px;
  vertical-align: middle;
}
/*イベントの表*/
.event_wrap {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.event_wrap.art,
.event_wrap.traditional,
.event_wrap.music,
.event_wrap.other,
.event_wrap.committee {
  display: none;
}
.event_box {
  display: block;
  float: left;
  padding: 14px 10px 10px 10px;
  width: 25%;
  border-right: solid 1px #e6e6e6;
  border-top: solid 1px #e6e6e6;
  cursor: pointer;
}
.event_box:nth-of-type(-n + 4) {
  border-top: none;
}
.event_box:nth-of-type(4n) {
  border-right: none;
}
.event_box p {
  float: left;
  line-height: 1.4;
}
.event_box p.event_title {
  display: block;
  font-size: 1.07rem;
  margin: 10px 0 20px;
  width: 100%;
  color: #000;
  line-height: 1.4;
  font-weight: bold;
  text-align: justify;
  transition: all 0.4s;
}
.event_box.event_link:hover p.event_title {
  color: #e6378d;
}
.event_box.event_link:hover p.event_title {
  color: #e6378d;
}
.event_header {
  line-height: 1;
  display: flex;
}
.font_l .event_header p {
  font-size: 0.83rem;
}
.event_header_right {
  float: right;
  width: 59px;
}
.event_header .date {
  display: block;
  color: #808080;
  float: right;
  font-weight: normal;
  vertical-align: top;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  margin-bottom: 2px;
  padding-right: 0;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
  line-height: 1;
}
.font_l .event_header .date {
  font-size: 0.65rem;
}
.event_new {
  display: inline-block;
  padding: 4px 0;
  width: 50px;
  text-align: center;
  background-color: #e6378d;
  border-radius: 3px;
  color: #fff;
  font-size: 10px;
  line-height: 0.9;
  letter-spacing: 0.1em;
  margin-left: 8px;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
}
.event_date {
  width: 100%;
  color: #808080;
  font-size: 0.82rem;
  letter-spacing: 0.05em;
}
.event_img {
  display: flex;
  height: auto;
  width: 100%;
  justify-content: center;
  align-items: center;
  padding: 0;
}
.event_img img {
  max-width: 100%;
  max-height: 100%;
}
.event_img .post-image img {
  height: auto !important;
}
/*イベントボタン*/
.event_button {
  display: block;
  width: 340px;
  max-width: 340px;
  padding: 15px 20px;
  margin: 0 auto 12px auto;
  border-radius: 50px;
  background-color: #e6378d;
  text-align: center;
}
.font_l .event_button {
  width: 430px;
  max-width: 430px;
}
.event_button img {
  width: 19px;
  margin: 0 23px 0 0;
  vertical-align: -2px;
}
.event_button__artist img {
  width: 24px;
  margin-bottom: -3px;
}
.event_button__flag img {
  width: 27px;
  margin-bottom: -7px;
  margin-left: -20px;
  margin-right: 10px;
}
.event_button span {
  color: #fff;
  font-size: 1.2rem;
  font-weight: bold;
}
a.event_button:hover {
  text-decoration: none;
  background: #000;
}
a.event_button:hover span {
  color: #fff;
}
.event_attention {
  color: #e6378d;
  text-align: center;
  font-weight: bold;
  padding: 0 0 12px 0;
  font-size: 1.1rem;
}
.post-image.home {
  width: auto;
  height: auto;
  line-height: 1;
}
/* 週間イベント情報
----------------------------------------------------------- */
.week_event h1 {
  display: inline-block;
}
.week_event .link_page_button {
  float: right;
  margin: 10px 0 0 0;
  background: url(../images/top/event_02.svg) no-repeat left 10px center;
  background-size: 26px auto;
}
.week_event .link_page_button:hover {
  background: #000 url(../images/top/event_02_w.svg) no-repeat left 10px center;
  background-size: 26px auto;
}
.week_event_menu {
  display: flex;
}
.week_event_menu li {
  cursor: pointer;
  position: relative;
  width: 33%;
  padding: 20px 0;
  text-align: center;
  font-weight: bold;
}
.week_event_menu li::after {
  content: "";
  width: 90%;
  border-bottom: solid 4px #e6378d;
  position: absolute;
  left: 5%;
  right: 5%;
  bottom: 0;
  transform: scale(0, 1);
  transform-origin: center top;
  transition: all 0.4s;
}
.week_event_menu li.is-active::after,
.week_event_menu li:hover::after {
  transform: scale(1, 1);
}
.week_event_menu span {
  display: block;
  color: #666;
  letter-spacing: 0.1em;
  font-weight: bold;
  border-left: 1px dotted #000;
}
.week_event_menu span:hover {
  text-decoration: none;
}
.week_event_menu li:first-child span {
  border: none;
}
/*週間イベントリスト*/
.week_event_list_wrap {
  width: 100%;
  margin: 20px 0;
  border-collapse: collapse;
}
.week_event_list_wrap.next_week,
.week_event_list_wrap.after_next_week {
  display: none;
}
.week_event_list_wrap tr {
  border-top: solid 1px #e6e6e6;
}
.week_event_list_wrap {
  border-bottom: solid 1px #e6e6e6;
}
.border_dotted {
  border-top: 1px dotted #e6e6e6;
}
.week_event_day {
  position: relative;
  width: 139px;
  text-align: center;
  vertical-align: middle;
}
.week_event_list_wrap tbody tr td.week_event_day:nth-of-type(even) {
  background: #f6f6f6;
}
.week_event_list_wrap tbody tr td.week_event_day {
  border-top: 5px solid #fff;
  border-bottom: 6px solid #fff;
  background: #efefef;
}
.week_event_list_wrap tbody tr td.week_event_day.event_saturday {
  background: #dbf0ff;
}
.week_event_list_wrap tbody tr td.week_event_day.event_sunday {
  background: #fef4f8;
}
.week_event_day .month {
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: 0.7rem;
  font-weight: bold;
}
.week_event_day .month .t-bold {
  font-weight: bold;
  font-size: 1.26rem;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
}
.week_event_day .date {
  font-size: 2.1rem;
  font-weight: bold;
  display: block;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
  color: #000;
  padding-right: 0;
}
.week_event_day .week {
  font-weight: bold;
}
.week_event_day.event_sunday {
  background-color: #fef4f8;
}
.week_event_day.event_saturday {
  background-color: #dbf0ff;
  border-bottom: solid 1px #e6e6e6;
}
.month_first_day {
  padding: 40px 0 20px 0;
}
.week_event_list {
  padding: 10px;
  vertical-align: middle;
}
.week_event_img {
  float: left;
  margin-right: 15px;
  width: 90px;
  height: 90px;
  object-fit: cover;
  overflow: hidden;
}
.week_event_list div {
  display: table-cell;
}
.week_event_label {
  color: #e6378d;
  font-weight: bold;
}
.week_event_list .week_event_title {
  display: block;
  color: #000;
  font-weight: bold;
  font-size: 1.07rem;
  padding: 4px 0;
  line-height: 1.4;
  cursor: pointer;
}
.week_event_list .week_event_title:hover {
  color: #e6378d;
  text-decoration: none;
}
.week_event_icon {
  width: 40px;
  margin: 0 10px 0 0;
  vertical-align: -15px;
}
.week_event_list p.week_event_period {
  display: block;
  color: #808080;
  font-size: 0.82rem;
  letter-spacing: 0.05em;
}
.no_event {
  padding: 30px 12px;
  font-size: 1.07rem;
  text-align: center;
  color: #999999 !important;
  font-weight: normal !important;
}
.week_event_list_icon {
  color: #e6378d;
  font-weight: bold;
  font-size: 0.9rem;
}
/* 実行委員会事業の紹介
----------------------------------------------------------- */
.committee_title {
  display: inline-block;
}
.committee h1 {
  display: inline-block;
  margin-right: 20px;
}
.committee_span {
  display: inline-block;
  color: #e6378d;
  font-weight: bold;
  border-bottom: 1px solid #e6378d;
  vertical-align: 4px;
}
.committee .link_page_button {
  float: right;
  margin: 20px 0;
  background: url(../images/top/event_03.svg) no-repeat left 10px center;
  background-size: 26px auto;
}
.committee .link_page_button:hover {
  background: #000 url(../images/top/event_03_w.svg) no-repeat left 10px center;
  background-size: 26px auto;
}
.pink_box {
  padding: 30px 30px 22px 30px;
  background-color: #fef4f8;
}
.pink_content {
  display: inline-block;
  width: 73%;
  margin-right: 4%;
  vertical-align: top;
  text-align: justify;
}
.pink_content div {
  margin: 0 0 13px 0;
}
.pink_content h2 {
  float: left;
  font-size: 1.4rem;
  font-weight: bold;
}
.pink_content a {
  position: relative;
  padding-right: 20px;
  text-decoration: underline;
  color: #000;
  margin-top: 10px;
}
.pink_content a:hover {
  text-decoration: none;
}
.pink_content a span:after {
  display: block;
  content: "";
  position: absolute;
  top: 15px;
  right: 7px;
  width: 5px;
  height: 5px;
  margin: -8px 0 0 0;
  border-bottom: solid 2px #000;
  border-right: solid 2px #000;
  transform: rotate(-45deg);
  transform-origin: 50% 50% 0;
}
.pink_content .date {
  color: #808080;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
  letter-spacing: 0.07em;
  padding-right: 0;
  font-size: 1rem;
}
.pink_content .date,
.pink_content a {
  float: right;
}
.pink_box .post-image-link {
  float: right;
  width: 23%;
}
.pink_box .post-image {
  margin: 0;
}
.pink_box img {
  display: inline-block;
  max-height: 200px;
  max-width: 100%;
  width: auto;
  border: 6px solid #fff;
}
/* KCICについて
----------------------------------------------------------- */
.page-about .sub_page_head #title {
  margin: 0 auto;
  float: none;
  position: relative;
  text-align: center;
  font-size: 2.2rem;
}
.page-about .sub_content_wrapper {
  margin: 10px auto;
  width: auto;
}
.page-about .sub_page_head #title::after {
  content: "";
  position: absolute;
  bottom: -28px;
  left: 50%;
  margin-left: -50px;
  width: 100px;
  border-bottom: 4px solid #e6378d;
}
.about_introduction {
  width: 60%;
  margin: 0 auto;
}
.about {
  border-top: 1px solid #e6e6e6;
  border-bottom: 1px solid #e6e6e6;
  padding: 60px 0px;
  margin: 30px auto;
}
.page-about-content .about_introduction section {
  padding-top: 0;
}

/* インスタスライド
---------------------------------------------------------- */
section.sec_insta_feed {
  width: 100% !important;
  max-width: 100%;
  display: none;
}
#scroller {
  width: 100%;
  height: 300px;
  margin: 0 auto;
}
.simply-scroll {
  width: 100%;
  margin-bottom: 0;
}
.simply-scroll .simply-scroll-clip {
  width: 100%;
  height: 190px;
}
.simply-scroll .simply-scroll-list {
  width: 100%;
}
.simply-scroll .simply-scroll-list li {
  width: 210px;
  height: 190px;
  overflow: hidden;
  margin-right: 20px;
  border-radius: 8px;
}
.simply-scroll .simply-scroll-list li img {
  width: auto;
  height: 190px;
}

/* 外部バナースライド
---------------------------------------------------------- */
.other_banner_slider {
  width: 980px;
  margin: 0px auto 0 auto;
}
.other_banner_slider .slick-list {
  width: 900px;
  margin: 0 auto;
}
.other_banner_slider .slick-list li {
  width: 25%;
}
.other_banner_slider .slick-list li a {
  display: block;
  width: 210px;
  margin: 0 auto;
}
.other_banner_slider .slick-list li a:hover {
  opacity: 0.8;
}
.other_banner_slider .slick-list li img {
  width: 210px;
  height: auto;
}
.other_banner_slider .slick-prev,
.other_banner_slider .slick-next {
  z-index: 1000;
  width: 22px;
  height: 22px;
}
.other_banner_slider .slick-next {
  content: "";
  background-image: url(../images/common/slider2_allow_right.svg);
  right: 0;
  left: auto;
  margin-top: -5px;
}
.other_banner_slider .slick-prev {
  background-image: url(../images/common/slider2_allow_left.svg);
  left: 0;
  right: auto;
  margin-top: -5px;
}
.page-about-content .sub_page_head #title {
  font-weight: normal;
}
.sub_content_wrapper.page-about-content {
  width: auto;
}
.page-about-content section {
  margin: 0 auto;
  padding: 10px 0 60px;
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
}
.page-about-content p {
  color: #333;
}
.page-about-content h1 {
  width: 100%;
  margin: 30px 0;
  font-weight: normal;
}
/*パンくず*/
#breadcrumb {
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  padding: 10px 0;
  text-align: right;
}
#breadcrumb li {
  display: inline;
  position: relative;
  padding: 0 20px 0 0;
}
#breadcrumb li:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 11px;
  width: 6px;
  height: 6px;
  border-bottom: solid 1px #666;
  border-right: solid 1px #666;
  transform: translate(0, -50%) rotate(-45deg);
}
#breadcrumb li:last-of-type:after {
  display: none;
}
#breadcrumb li:last-of-type {
  padding-right: 10px;
}
#breadcrumb li a {
  text-decoration: none;
  color: #666;
}
#breadcrumb li a:hover {
  color: #e6378d;
}
/*トップ*/
.sub_page_top {
  height: 210px;
}
.sub_page_top p {
  margin: 40px 0;
  font-size: 2.2rem;
  letter-spacing: 0.08em;
  color: #e6378d;
}
/*kagoshima cultural information center*/
.information_center {
  background-color: #f5f5f5;
}
.information_center p:last-child {
  margin-top: 20px;
}
.information_center .img_wrap {
  float: right;
  width: 50%;
  vertical-align: top;
}
.information_center img {
  width: 90%;
  margin: 0 0 0 10%;
}
/*access to kagoshima*/
.access_01 {
  background-color: #f5f5f5;
}
.access_01 section {
  padding: 30px 0 60px;
}
.access_01 .img_wrap {
  width: 50%;
  vertical-align: top;
}
.access_01 img {
  width: 90%;
  float: left;
  margin: 0 10% 0 0;
}
.access_01 p {
  float: right;
  width: 50%;
  line-height: 1.2;
}
/*access to kagoshima cultural information center (KCIC)*/
.access_02 .img_wrap {
  width: 68%;
  float: left;
  vertical-align: top;
}
.access_02 img {
  width: auto;
  margin: 0 3% 0 0;
}
.access_02 p {
  float: right;
  width: 30%;
}
/*access to kagoshima*/
.access_03 section {
  padding: 30px 0 60px;
}
.access_03 .img_wrap {
  float: left;
  width: 50%;
  vertical-align: top;
}
.access_03 img {
  width: 94%;
  margin: 0 6% 0 0;
}
.access_03 p {
  float: right;
  width: 50%;
}
.access_04 h2 {
  font-size: 15px;
  margin-bottom: 6px;
}
.access_04 ul {
  margin: 0 0 12px 14px;
}
/* かごしま文化情報センターについて
--------------------------------------------------------*/
#access_kagoshima,
#access_kcic {
  float: left;
}
#access_kcic {
  width: 29%;
  margin-left: 3%;
}
#access_kagoshima {
  width: 50%;
  margin-bottom: 10px;
}
#access_kagoshima li {
  margin-bottom: 10px;
}
#access_kcic li {
  margin-bottom: 12px;
}
.access_04 h2 {
  font-size: 15px;
}
.access_04 ul {
  margin-left: 14px;
}
/* サブページ共通
---------------------------------------------------------- */
.sub_page {
  margin-bottom: 40px;
}
.sub_page_head {
  width: 980px;
  margin: 0 auto;
}
.sub_page_head #title-box {
  padding: 40px 0 50px 4px;
  display: -webkit-flex;
  display: flex;
}
.sub_page_head #title {
  padding: 0;
  margin: 0 34px 0 0;
  border-right: none;
  line-height: 1.4;
  height: auto;
  color: #e6378d;
  font-size: 1.92rem;
  font-weight: bold;
  letter-spacing: 0.14em;
}
#title-text {
  -webkit-flex: 1;
  flex: 1;
}
#title-text p {
  display: inline-block;
  color: #e6378d;
  font-weight: bold;
  letter-spacing: 0.08em;
  border-bottom: 1px solid #e6378d;
  padding: 6px 0 3px 0;
  line-height: 1.4;
}

#right-banner-box .banner img {
  border: 1px solid #999999;
  width: 98% !important;
  height: auto;
  border: 1px solid #acacac;
}
.sub_content_wrapper {
  width: 980px;
  margin: 20px auto 10px auto;
}
#art-box-index {
  float: none;
  width: 100%;
}
#art-box {
  padding: 20px 30px 30px 30px;
}
#art-box h1 {
  color: #000;
  font-weight: bold;
  font-size: 1.5rem;
  letter-spacing: inherit;
}
#art-box h2 {
  color: #000;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: inherit;
}
#art-box h3 {
  color: #000;
  font-weight: bold;
  font-size: 16px;
  letter-spacing: inherit;
}
#art-box h4 {
  letter-spacing: inherit;
}
.single-contents-text {
  word-break: break-all;
}
.single-contents-text .type-box {
  margin: 0;
  padding: 3px 8px;
  width: auto;
}
.type-box-date {
  margin: 0 9px;
  color: #666;
  font-size: 0.84rem;
  width: 6em;
}
.single-contents-text .type-box-date {
  float: right;
  text-align: right;
  color: #999999;
}
#art-box .single img {
  width: auto;
  height: auto !important;
}
#art-box .list_label {
  font-weight: bold;
}
#art-box .list_date {
  color: #999;
  letter-spacing: 0.05em;
}
.single-contents-text .post-attr-box {
  margin: 12px 0;
  padding: 14px 12px 6px 12px;
  background: #efefef;
}
.font_l .single-contents-text .post-attr-box {
  font-size: 0.9rem;
}
.single-contents-text .post-attr-box .post-attr-title {
  letter-spacing: 0.2em;
}
.single-contents-text .post-attr-box.two .post-attr-title {
  width: 100px;
  letter-spacing: 0.2em;
  border: none;
}
.single-contents-text .post-attr-box.two .post-attr-content {
  margin-left: 110px;
  padding-left: 14px;
  border-left: 1px solid #6b6c6e;
}
.title-none {
  margin-left: 110px;
  padding-left: 14px;
  display: block;
  margin: 0 0 0.4em 9.1em;
  line-height: 1.8;
  vertical-align: middle;
  letter-spacing: 0.2em;
}
.title-none + .post-attr-content {
  border-left: transparent !important;
}
.single-contents-text .post-attr-box.three .post-attr-title {
  width: 9.3em;
  letter-spacing: 0.2em;
  padding-right: 0.8em;
}
.single-contents-text .post-attr-box.three .post-attr-content {
  margin-left: 10.3em;
}
.single-contents-text table {
  word-break: break-all;
}
#breadcrumb {
  padding: 8px 0;
}
#pagination {
  text-align: center;
}
#pagination span#pagination-page-title {
  display: none;
}
#pagination span,
#pagination a {
  display: inline;
  float: none;
}
/* 蔵書一覧
---------------------------------------------------------- */
.library-box {
  padding: 0;
  width: auto;
  float: none;
  margin: 0 0 15px 0;
}
/* お知らせ一覧
---------------------------------------------------------- */
#news-index {
  margin-bottom: 30px;
  border-top: 1px dashed #525252;
}
#news-index .type-box {
  width: 11em;
  padding: 4px 0;
  background: #fff;
  color: #e62686;
  font-weight: bold;
}
#news-index li a {
  color: #000;
}
#art-box-wrapper {
  float: none;
  width: 100%;
}
#art-box-wrapper strong {
  font-weight: bold;
}
#art-box-wrapper em{
  font-style: italic;
}
#art-box-wrapper strong span{
  font-weight: bold;
}
#art-box-wrapper strong em{
  font-weight: bold;
  font-style: italic;
}
#right-banner-box {
  float: right;
  width: 22%;
  margin-bottom: 30px;
}
#art-box {
  background-color: #fff;
  border: 1px solid #acacac;
}
#art-box-wrapper.map #art-box {
  border: none;
}
#art-box .list_label {
  float: left;
  color: #e6378d;
}
#art-box .list_date {
  float: right;
}
.social-action.facebook {
  margin-top: 7px;
}
.font_l .social-action.facebook {
  margin-top: 1px;
}
#art-box .gm-style .gm-style-iw-c {
  padding: 17px 12px 12px 28px !important;
}
#art-box .gm-style .gm-style-iw-d {
  padding-right: 0 !important;
  padding-bottom: 0 !important;
}
.p-shop-map {
  margin-top: 7px;
}
/* かごしまアートナビ
---------------------------------------------------------- */
#art-box-wrapper.map {
  float: left;
  width: 100%;
}
#art-box .gm-ui-hover-effect {
  right: 0 !important;
  top: 2px !important;
}
/* 伝統芸能マップ
---------------------------------------------------------- */
.tam-title-link {
  top: 6px;
}
.font_l .map-title {
  letter-spacing: 0.3em;
}
#art-box ul li::marker {
  content: none;
}
.map.tam #art-box ul li {
  margin-left: 0;
}
.event-box-wrapper-title {
  font-size: 1.125rem;
}
.event-box-wrapper-note {
  font-size: 0.9rem;
}
/* 伝統芸能団体
---------------------------------------------------------- */
.map-category {
  background: #fff;
}
/* イベント情報詳細
---------------------------------------------------------- */
#art-box .event_detail_head {
  position: relative;
}
.event_detail_icon {
  color: #e6378d;
  font-size: 14px;
}
.event_detail_icon img {
  width: 40px;
  margin: 0 10px 0 0;
  vertical-align: -15px;
}
#art-box .event_detail_head h1 {
  margin: 12px 0;
}
.event_detail_limit {
  color: #999;
  margin-bottom: 40px;
}
.event_detail_date {
  position: absolute;
  top: 0;
  right: 0;
  color: #acacac;
}
.event_detail_info p {
  margin-bottom: 0.6rem;
}
.event_detail_footer {
  text-align: center;
  padding: 6px 0;
}
.event_detail_footer .link_page_button {
  float: none;
  display: inline-block;
}
.link_page_button.event {
  background: url(../img/top/event_01.svg) no-repeat left 10px center;
  background-size: 26px auto;
  color: #000;
}
.information_center_wrap {
  display: flex;
}
.information_center_wrap div {
  width: 50%;
}
.information_center_wrap div.img {
  order: 2;
}
.information_center_wrap div.text {
  order: 1;
}
.link_page_button.about_access_link {
  float: inherit;
  margin-top: 24px;
  background: url(../images/common/map-bk.svg) no-repeat left 12px center;
  background-size: 19px auto;
  color: #000;
  width: 198px;
}
.link_page_button.about_access_link:hover {
  background: #000 url(../images/common/map-wh.svg) no-repeat left 12px center;
  background-size: 19px auto;
  color: #fff;
}
.link_page_button.event:hover {
  background: #000 url(../img/top/event_01_w.svg) no-repeat left 10px center;
  background-size: 26px auto;
  color: #fff;
}
.link_page_button.week_event {
  background: url(../img/top/event_02.svg) no-repeat left 10px center;
  background-size: 26px auto;
  margin-right: 6px;
}
.link_page_button.week_event:hover {
  background: #000 url(../img/top/event_02_w.svg) no-repeat left 10px center;
  background-size: 26px auto;
}
/* イベント投稿
---------------------------------------------------------- */
.page_contribute {
  width: 100%;
}
.page_contribute section:first-child {
  margin-top: 0;
  background-color: #f5f5f5;
  width: 100%;
  max-width: 100%;
}
.sub_page_top p span {
  font-size: 13px;
  padding-left: 50px;
  vertical-align: middle;
}
.event_form_description {
  width: 100%;
  max-width: 980px;
  margin: 16px auto 0 auto;
  padding: 16px 0 22px 0;
}
.event_form_description h1 {
  float: none;
  font-size: 1.42rem;
  margin: 12px 0;
}
.event_form_description p {
  margin: 0 0 10px 0;
}
/*メールフォーム*/
.event_mail_form_wrap h1 {
  margin: 40px 0 20px 0;
}
.event_mail_form_wrap h2 {
  font-size: 20px;
  font-weight: bold;
  color: #000;
  padding: 0px 0 12px 3px;
  margin-top: 10px;
}
.event_mail_form_wrap h2:nth-of-type(2) {
  margin-top: 50px;
}
.event_mail_form {
  border-top: solid 1px #e6e6e6;
  border-bottom: solid 1px #e6e6e6;
  font-size: 1.1rem;
}
.event_mail_form li {
  padding: 30px 30px 15px 30px;
  border-top: dashed 1px #e6e6e6;
}
.event_mail_form li:first-child {
  border: none;
}
.event_mail_form div {
  float: left;
  width: 30%;
  padding-right: 30px;
}
.event_mail_form div p {
  line-height: 1.2;
}
.event_mail_form div span.t-small {
  font-size: 0.82rem;
  line-height: 1.2;
}
.event_mail_form div span.t-century-gothic {
  font-family: "Century Gothic" !important;
}
.event_mail_form .event_date-right-text {
  color: #888;
}
.event_mail_form div span.required {
  font-size: 0.76rem;
  color: #ff0000;
  padding-left: 6px;
}
.event_mail_form .form_right {
  float: left;
  width: 70%;
}
.event_mail_form input,
.event_mail_form textarea {
  width: 100%;
  border: solid 1px #e6e6e6;
  border-radius: 3px;
  padding: 6px;
  box-shadow: 0 0 2px #e6e6e6 inset;
  color: #000;
}
.event_mail_form .textarea-small {
  height: 36px;
}
.event_mail_form input[type="radio"] {
  width: auto;
  -webkit-appearance: radio;
}
.event_date_start,
.event_date_end,
.expire_date_start,
.expire_date_end {
  display: inline-block;
  margin: 0 20px 0 0;
}
.event_date_end,
.expire_date_end {
  margin: 0 20px;
}
.wpcf7-custom-item-error.event_date_end,
.wpcf7-custom-item-error.expire_date_end {
  margin: 0 0 14px 0;
  width: 100%;
}
.event_mail_form textarea {
  height: 130px;
}
.form_last {
  text-align: center;
  padding: 35px 30px;
}
.form_last p {
  width: 100%;
  float: none;
}
.form_last a {
  text-decoration: underline;
}
.form_last input {
  width: auto;
  margin: 0 10px 0 0;
  -webkit-appearance: checkbox;
}
.check {
  margin: 20px 0 0 0;
  font-weight: bold;
  font-size: 1.1rem;
}
.confirmation_button {
  margin: 20px 0;
  text-align: center;
}
.confirmation_button input {
  width: 230px;
  border: none;
  border-radius: 50px;
  padding: 18px;
  background-color: #e6378d;
  color: #fff;
  font-weight: bold;
  margin: 0 10px;
}
.font_l .confirmation_button input {
  width: 270px;
  margin: 0;
}
.confirmation_button input.wpcf7c-btn-back {
  background-color: #666;
  font-size: 1rem;
}
input[type="date"].wpcf7c-conf,
input[type="text"].wpcf7c-conf,
input[type="password"].wpcf7c-conf,
input[type="email"].wpcf7c-conf,
input[type="tel"].wpcf7c-conf,
input[type="url"].wpcf7c-conf,
input[type="number"].wpcf7c-conf,
textarea.wpcf7c-conf {
  background-color: #999999;
  color: black;
  border: 1px solid #333333;
  box-shadow: none;
}
input[type="submit"]:hover {
  background-color: #000;
  padding: 18px;
}
select.wpcf7-select {
  -moz-appearance: pop-up-menu;
  -webkit-appearance: pop-up-menu;
  appearance: pop-up-menu;
  padding: 0.7em 0.4em;
}
.wpcf7-form-control-wrap.your-contact-category {
  display: inline-block;
}
.wpcf7-form-control-wrap.your-contact-category::after {
  position: absolute;
  top: 35%;
  right: 10px;
  width: 9px;
  height: 9px;
  content: "";
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
  pointer-events: none;
  border-top: 1px solid #444;
  border-right: 1px solid #444;
}
.confirmation_button input:disabled:hover,
.confirmation_button input:disabled {
  background-color: #acacac;
}
.wpcf7c-elm-step2 {
  color: #009fe8;
  padding: 20px 0 30px 2px;
  font-size: 1.2rem;
  text-align: center;
}
.wpcf7c-elm-step2.attention {
  padding-top: 0;
}
.wpcf7c-elm-step3 {
  border: 1px solid #009fe8;
  color: #009fe8;
  padding: 20px;
  font-size: 1.2rem;
  text-align: center;
}

/* イベント情報
---------------------------------------------------------- */
/*イベントカレンダーリンク*/
.week_event.event-list_event-calender {
  margin: 0 0 0 auto;
}
.week_event.event-list_event-calender .link_page_button {
  margin: 0;
}
/*メニュー*/
.event_when {
  width: 100%;
  max-width: 980px;
  margin: 0 auto 20px;
  border-bottom: solid 1px #e6e6e6;
}
.event_when li {
  position: relative;
  width: 20%;
  float: left;
  text-align: center;
}
.event_when span {
  border-right: solid 1px #e6e6e6;
  display: block;
}
.event_when li:last-child span {
  border: none;
}
.event_when a {
  display: block;
  color: #333;
  font-weight: bold;
  padding: 20px 0;
}
.event_when a:hover {
  text-decoration: none;
}
.event_when li.on a:after,
.event_when a:hover:after {
  content: "";
  width: 100%;
  border-bottom: solid 6px #e6378d;
  position: absolute;
  right: 0;
  left: 0;
  top: 36px;
  bottom: 0;
}
/*検索、絞り込み*/
.event_search_wrap {
  background-color: #f5f5f5;
}
.event_search_wrap section {
  padding: 30px 0;
}
.event_search_wrap form {
  float: left;
  width: 37%;
}
.event_search_wrap div {
  float: left;
  width: 63%;
}
.event_search_wrap p {
  font-weight: bold;
  margin-bottom: 10px;
}
.event_search_wrap .search {
  height: 45px;
  width: 85%;
  padding: 10px;
}
.search_check li {
  position: relative;
  float: left;
  padding: 5px 12px 5px 30px;
  margin: 0 10px 5px 0;
  color: #fff;
  font-weight: bold;
  background-color: #666;
  border-radius: 5px;
  cursor: pointer;
}
.search_check span:before {
  content: "";
  height: 13px;
  width: 13px;
  top: 9px;
  left: 12px;
  position: absolute;
  border: solid 1px #fff;
}
.font_l .search_check span:before {
  top: 12px;
}
.search_check .check_pink {
  background-color: #e6378d;
}
.search_check .check_pink:before {
  content: "";
  position: absolute;
  top: 13px;
  left: 18px;
  width: 5px;
  height: 13px;
  margin: -8px 0 0 0;
  border-bottom: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
  transform-origin: 50% 50% 0;
  transform-origin: 50% 50% 0;
}
.font_l .search_check .check_pink:before {
  top: 17px;
}
/*リスト*/
.event_list_left {
  width: 22%;
  float: left;
}
.event_list li {
  padding: 20px 0;
  border-bottom: 1px dotted #666;
}
.event_list .event_img {
  float: left;
  width: 23%;
  height: 170px;
}
.event_list .post-image img {
  width: auto;
  max-width: 100% !important;
  max-height: 300px !important;
}
.event_list .post-image.home {
  margin: 0;
}
.event_list_right {
  width: 77%;
  float: left;
  padding-left: 20px;
}
.event_list_right .list_label {
  float: left;
  color: #e6378d;
  font-weight: bold;
}
.event_list_right .list_title {
  font-size: 17px;
  font-weight: bold;
  margin: 5px 0;
}
.event_list_right .list_title a {
  color: #000;
  font-weight: bold;
}
.event_list_right .list_text {
  margin: 5px 0;
  color: #666;
  text-align: justify;
}
.event_list_right .list_date {
  float: right;
  color: #999;
}
.event_list_right .list_period {
  font-size: 0.9rem;
  color: #666;
  font-weight: bold;
}
/*ページネーション*/
.event_list_pagination {
  text-align: center;
  margin: 0 auto 60px;
}
.event_list_pagination li {
  display: inline-block;
  font-size: 17px;
  font-weight: bold;
  color: #e6378d;
  border: 1px solid #e6378d;
}
.event_list_pagination a {
  display: block;
  padding: 5px 8px;
}
.event_list_pagination a:hover {
  background-color: #e6378d;
  color: #fff;
}
.contribute_button_layer {
  padding-top: 30px;
}
.page_contribute .event_date_start input,
.page_contribute .event_date_end input,
.page_contribute .expire_date_start input,
.page_contribute .expire_date_end input {
  width: 150px;
}
/* イベントカレンダー
---------------------------------------------------------- */
.week_event.event-calender_event-list-search {
  margin: 0 0 0 auto;
}
.week_event.event-calender_event-list-search .link_page_button {
  margin: 0;
  background-image: url(../images/event/search-calender-icon-bk.svg);
  background-size: 18px auto;
}
.week_event.event-calender_event-list-search .link_page_button:hover {
  background-image: url(../images/event/search-calender-icon-wh.svg);
  background-size: 18px auto;
}
.calender_search_layer {
  background: #f6f6f6;
  padding: 20px 0;
  margin-top: 20px;
}
.font_l .calender_search_layer {
  font-size: 0.78rem;
}
.calender_search_layer .inner {
  display: -webkit-flex;
  display: flex;
  width: 980px;
  margin: 0 auto;
}
.calender_search_layer .slick-next,
.calender_search_layer .slick-prev {
  top: 13px;
  background: #e6378d;
  color: #fff;
  width: 26px;
  height: 26px;
}
.calender_search_layer .slick-prev {
  left: 10px;
  background: #e6378d url(../images/event/calendar_allow_left.svg) no-repeat
    left 5px center;
  background-size: 14px;
}
.calender_search_layer .slick-next {
  right: 10px;
  background: #e6378d url(../images/event/calendar_allow_right.svg) no-repeat
    left 6px center;
  background-size: 14px;
}
.calender_list {
  width: 740px;
  padding: 0 40px;
  margin-right: 30px;
  height: 210px;
  opacity: 0;
}
.calender_list.slick-slider {
  opacity: 1;
  height: auto;
}
.calendar_search_input {
  -webkit-flex: 1;
  flex: 1;
}
.calendar_box {
  float: left;
  min-height: 210px;
}
.calendar_box h3 {
  width: 100%;
  text-align: center;
  color: #e6378d;
  background: #fff;
  padding: 10px 0;
}
.calendar_box table {
  font-size: 11px;
  width: 100%;
  height: 155px;
  background: #fff;
  border-collapse: collapse;
}
.calendar_box table thead {
  border-bottom: 1px solid #ccc;
}
.calendar_box table th,
.calendar_box table td {
  padding: 3px;
  text-align: center;
  vertical-align: middle;
}
.calendar_box table td.on {
  background: #fef4f8;
}
.calendar_box table td.on.today,
.calendar_box table td.today {
  background: #e6378d;
  color: #fff;
}
.calendar_box table th.sat,
.calendar_box table th.sun {
  color: #e6378d;
}
.calendar_search_input input[type="date"],
.calendar_search_input input[type="text"] {
  border: 1px solid #b3b3b3;
  padding: 10px;
  width: 100%;
  color: #000;
}
.calendar_search_input input.focus {
  border: 1px solid #e6378d;
}
.calendar_search_box {
  padding-right: 20px;
  width: 210px;
}
.calendar_search_box input[type="submit"] {
  background: #e6378d;
  color: #fff;
  margin-top: 12px;
  padding: 12px 0;
  width: 100%;
  border: 0;
  font-weight: bold;
  cursor: pointer;
}
.week_event_list_title {
  font-size: 1.4rem;
  text-align: center;
  padding: 20px 0;
  letter-spacing: 0.1em;
}
.week_event_list_title .t-alpha {
  font-size: 2rem;
}
#pagination {
  padding: 25px 0;
}
/*イベントカレンダー・新着イベント情報共通のリンクボタン*/
@media only screen and (max-width: 767px) {
  .week_event.event-calender_event-list-search .link_page_button {
    background-size: 12px auto;
    width: 160px;
    font-size: 11px;
    padding: 5px 18px 5px 23px;
  }
  .week_event.event-calender_event-list-search .link_page_button:hover {
    background-size: 12px auto;
  }
  .week_event.event-list_event-calender .link_page_button {
    background-size: 22px auto;
    width: 160px;
    font-size: 11px;
    padding: 5px 18px 5px 26px;
  }
  .week_event.event-list_event-calender .link_page_button:hover {
    background-size: 22px auto;
  }
}

/* お問い合わせ
---------------------------------------------------------- */
#contact_agreement input {
  width: auto;
  margin: 0 10px 0 0;
  -webkit-appearance: checkbox;
  border: solid 1px #e6e6e6;
  border-radius: 3px;
  padding: 6px;
  box-shadow: 0 0 2px #e6e6e6 inset;
  color: #000;
}
#contact_attention,
#contact_agreement {
  text-align: center;
}
/* contact form7
---------------------------------------------------------- */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="number"],
textarea {
  font-family: "游ゴシック", YuGothic, Futura, "ヒラギノ角ゴ Pro W3", Osaka,
    "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, "ＭＳ Ｐゴシック",
    "MS PGothic", sans-serif;
}
input[type="submit"].wysija-submit,
.wpcf7-form input[type="submit"] {
  padding: 18px;
  background: #e62686;
  border: 1px solid #e62686;
  color: #fff;
  font-weight: bold;
  font-size: 1.1rem;
}
input[type="submit"].wysija-submit:hover,
.wpcf7-form input[type="submit"]:hover {
  background: #000;
  border: 1px solid #000;
}
.wpcf7-form-control-wrap.refusal span.wpcf7-list-item,
.wpcf7-form-control-wrap.agreement span.wpcf7-list-item {
  margin: 0;
}

/* 実行委員会について
---------------------------------------------------------- */
table.responsive_table {
  width: 100%;
  border-right: #333 solid 1px;
  border-collapse: collapse;
}
table.responsive_table thead th {
  background: #333;
  color: #fff;
  padding: 10px 15px;
  border-right: #fff solid 1px;
  border-bottom: #fff solid 1px;
}
table.responsive_table thead th:last-child {
  border-right: #333 solid 1px;
}
table.responsive_table tbody th {
  background: #333;
  color: #fff;
  padding: 10px 15px;
  border-bottom: #fff solid 1px;
  border-right: #fff solid 1px;
  vertical-align: top;
}
table.responsive_table tbody tr:last-child th {
  border-bottom: #333 solid 1px;
}
table.responsive_table tbody td {
  background: #fff;
  padding: 10px 15px;
  border-left: #333 solid 1px;
  border-bottom: #333 solid 1px;
  vertical-align: top;
}

@media only screen and (max-width: 767px) {
  table.responsive_table tbody th {
    text-align: center;
    font-size: 13px;
    padding: 5px;
  }
  table.responsive_table tbody td {
    font-size: 11px;
    padding: 5px;
  }
}

@media only screen and (max-width: 979px) {
  /* Header
	---------------------------------------------------------- */
  .header {
    display: none;
  }
  #header-sp {
    display: block;
  }
  #logo-sp {
    width: 130px;
    height: 80px;
    padding: 10px 0 0 12px;
  }
  #logo-sp img {
    width: auto;
    height: 64px;
  }
  .lang_switch {
    width: auto;
    height: auto;
    margin: 0;
    padding: 10px 6px;
    position: absolute;
    top: 20px;
    right: 70px;
    z-index: 100;
    border: 1px solid #b3b3b3;
    border-radius: 22px;
  }
  .lang_switch li:first-of-type {
    border-bottom: none;
    border-right: 1px solid #b3b3b3;
  }
  .lang_switch li {
    display: table-cell;
    padding: 0 10px;
  }
  #header-sp-nav-btn {
    width: 60px;
    height: 60px;
    margin: 0;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 101;
  }
  #menu {
    display: block;
    position: absolute;
    top: 21px;
    right: 16px;
    width: 35px;
    height: 24px;
    cursor: pointer;
  }
  #menu span.l1,
  #menu span.l2,
  #menu span.l3 {
    position: absolute;
    width: 100%;
    height: 3px;
    background: #000;
    border-radius: 1.5px;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: 0.25s ease-in-out;
    -moz-transition: 0.25s ease-in-out;
    -o-transition: 0.25s ease-in-out;
    transition: 0.25s ease-in-out;
  }
  #menu span.l1 {
    top: 0px;
  }
  #menu span.l2 {
    top: 10px;
  }
  #menu span.l3 {
    top: 20px;
  }
  #menu.open span.l1 {
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
    top: 6px;
    left: 0;
  }
  #menu.open span.l2 {
    width: 0%;
    opacity: 0;
  }
  #menu.open span.l3 {
    top: 6px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }
  #menu #header-sp-nav-btn-text {
    position: absolute;
    width: auto;
    top: 26px;
    left: -1px;
    font-size: 12px;
    color: #000;
    font-family: Futura, "Century Gothic", "Helvetica Neue", Arial;
    letter-spacing: 0.03em;
  }
  /* 検索メニュー */
  .search_menu {
    width: 44px;
    height: 44px;
    margin: 0;
    padding: 4px;
    position: absolute;
    top: 18px;
    right: 70px;
    z-index: 100;
    border: 1px solid #b3b3b3;
    border-radius: 22px;
    text-indent: -9999px;
    background: #fff url(../images/common/search_gy.svg) no-repeat center;
    background-size: 20px auto;
  }
  /* 検索ボックス */
  #header-search-nav {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 80px;
    bottom: 0;
    left: 0;
    z-index: 100;
    display: none;
    background: #e6378d;
    overflow-y: scroll !important;
  }
  /* メニュー */
  #header-sp-nav {
    width: 100%;
    height: auto;
    position: absolute;
    top: 80px;
    bottom: 0;
    left: 0;
    z-index: 100;
    display: none;
    background: #e6378d;
    overflow-y: scroll !important;
    -webkit-overflow-scrolling: touch;
  }
  #header-sp-nav ul {
    border-top: 1px solid #fff;
  }
  #header-sp-nav > ul > li {
    margin: 0;
    border-bottom: 1px solid #fff;
    font-size: 16px;
    font-weight: bold;
  }
  #header-sp-nav li span,
  #header-sp-nav li a {
    display: block;
    padding: 14px 10px;
    color: #fff;
    position: relative;
  }
  #header-sp-nav li span:after,
  #header-sp-nav li a:after {
    display: block;
    content: "";
    position: absolute;
    top: 31px;
    right: 20px;
    width: 6px;
    height: 6px;
    margin: -8px 0 0 0;
    border-bottom: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(-45deg);
    transition: all 0.4s;
  }
  #header-sp-nav li.is-open > span:after,
  #header-sp-nav li.is-open > a:after {
    transform: rotate(45deg);
  }
  #header-sp-nav li a:hover {
    display: block;
  }
  .nav_level1 {
    background: #fff;
  }
  #header-sp-nav .nav_level1 li span,
  #header-sp-nav .nav_level1 li a {
    color: #e6378d;
    border-bottom: 1px dotted #e6378d;
  }
  #header-sp-nav .nav_level1 li span:after,
  #header-sp-nav .nav_level1 li a:after {
    display: block;
    content: "";
    position: absolute;
    top: 31px;
    right: 20px;
    width: 6px;
    height: 6px;
    border-bottom: solid 2px #e6378d;
    border-right: solid 2px #e6378d;
    transform: translate(0, -50%) rotate(-45deg);
  }
  #header-sp-nav .nav_level1 > li.is-open > span:after,
  #header-sp-nav .nav_level1 > li.is-open > a:after {
    transform: translate(0, -50%) rotate(45deg);
  }
  #header-sp-nav .nav_level2 li span,
  #header-sp-nav .nav_level2 li a {
    font-size: 13px;
    padding-left: 30px;
  }
  .nav_level1,
  .nav_level2 {
    width: auto;
    display: none;
  }
  #header-sp-nav li.font_switch_sp span:after {
    display: none;
  }
  #header-sp-nav li.font_switch_sp span {
    display: table-cell;
    width: 130px;
    vertical-align: middle;
  }
  .font_switch_sp div.font_options_sp {
    display: table-cell;
    width: auto;
    padding: 10px 0;
  }
  .font_options_sp p {
    float: left;
    background: #000;
    color: #fff;
    border-radius: 50%;
    line-height: 1;
    padding: 10px;
    margin-right: 12px;
  }
  .font_options_sp p.on {
    background: #fff;
    color: #000;
  }
  .search_form_sp {
    padding: 20px;
  }
  .search_form_sp form input[type="text"] {
    padding: 10px 40px 10px 16px;
    border-radius: 20px;
    background: #fff url(../images/common/search_gy.svg) no-repeat right 12px
      top 11px;
    background-size: 20px auto;
    width: calc(100% - 100px);
    border: none;
    font-size: 16px;
  }
  .search_form_sp form input[type="submit"] {
    padding: 10px 20px;
    border-radius: 20px;
    background: #000;
    border: none;
    color: #fff;
    width: 80px;
    margin-left: 10px;
    font-weight: bold;
    font-size: 16px;
  }
  /* Footer
    ---------------------------------------------------------- */
  footer .inner {
    width: auto;
  }
  .footer_left {
    width: auto;
  }
  footer .flex {
    display: block;
  }
  footer .logo {
    margin-bottom: 20px;
  }
  footer .logo img {
    width: 200px;
  }
  .footer_right {
    display: none;
  }
  footer .footer .inner {
    padding: 30px 20px;
  }
  .copyright {
    text-align: center;
    line-height: 1.6;
    font-size: 10px;
  }
  /* サブページ共通
    ---------------------------------------------------------- */
  .sub_page_head {
    margin: 0 20px;
    width: auto;
  }
  .sub_content_wrapper {
    width: auto;
    margin: 20px 20px 10px 20px;
  }
  section {
    max-width: 100%;
    padding: 0 0 35px 0;
    width: 100%;
  }
  .page_top section {
    max-width: 100%;
    padding: 0 10px 10px 10px;
    width: 100%;
  }
  .page_top section.other_banner {
    padding: 0 10px;
  }
  section#category {
    padding: 0;
  }
  section h1 {
    font-size: 1.56rem;
  }
  .page-about-content section {
    max-width: 100%;
    padding: 0 10px 35px 10px;
    width: 100%;
  }
  .page-about-content h1 {
    font-size: 1.2rem;
    line-height: 1.4;
  }
  .sub_content_wrapper.page-about-content {
    width: auto;
    margin: 20px auto 0 auto;
  }
  /* 最新のお知らせ
	-------------------------------- */
  .hot_news_box {
    max-width: 100%;
  }
  .hot_news_box a {
    display: block;
    margin: 4px 0 0 0;
  }
  .hot_news_box li {
    padding: 10px 4px;
    display: block;
  }
  .hot_news_title {
    width: 147px;
  }
  .hot_news_title:before {
    width: 147px;
  }
  .news_list {
    width: calc(100% - 167px);
  }
  .news_date_label {
    width: auto;
    padding: 0;
  }
  /* 新着イベント
	-------------------------------- */
  .event .description {
    margin: 15px 25px;
  }
  .event a.link_page_button {
    margin: 15px 0 0 0;
  }
  .event_menu {
    background-color: #fff;
    border: 1px solid #e6e6e6;
    border-radius: 5px;
  }
  .event_menu::after {
    display: none;
  }
  .event_menu a {
    padding: 5px 10px;
  }
  .event_header_right {
    float: none;
    width: 100%;
    margin: 0;
  }
  .event_header img {
    width: 35px;
    vertical-align: -13px;
  }
  .event_box .event_header p {
    margin: 0 0 4px 0;
    float: none;
  }
  .event_header .date {
    display: inline-block;
    float: right;
    line-height: 1.6;
  }
  .event_new {
    margin: 0;
  }
  .event_button span {
    transition: all 0.4s;
  }
  .event_date {
    font-size: 0.6rem;
  }
  .event_title a {
    font-size: 1rem;
  }
  /* 週間イベント情報
	-------------------------------- */
  .week_event .link_page_button {
    margin: 14px 0;
  }
  .week_event_day {
    width: 119px;
  }
  /* 実行委員会事業の紹介
	-------------------------------- */
  .committee .link_page_button {
    margin: 15px 0;
  }
  .font_l .committee .hide-mobile {
    display: none;
  }
  .font_l .committee .show-mobile {
    display: block;
  }
  .committee .show-mobile .link_page_button {
    width: 90%;
    max-width: 340px;
    padding: 12px 20px;
    text-align: center;
    margin: 12px auto 0 auto;
    float: none;
  }
  .committee h1 {
    margin-right: 15px;
  }
  /* KCICについて
	-------------------------------- */
  .about_introduction {
    width: 80%;
  }
  .about_box {
    padding: 0 10px 0 0;
  }
  .about_box h1 {
    margin: 15px 0;
  }
  .sns_icon_box {
    margin: 15px 0;
  }
  .about .link_page_button {
    margin: 15px auto 0;
  }
  .about_img {
    margin: 20px 0;
  }
  .kan-input {
    display: none;
  }
  /* コンテンツバナースライド
    ---------------------------------------------------------- */
  .content_banner_slider,
  .other_banner_slider,
  .content_banner_slider .slick-list,
  .other_banner_slider .slick-list {
    width: 100%;
  }
  /* イベント情報
    -----------------------------------*/
  .event_search_wrap section {
    padding: 30px 10px;
  }
  /* パンくず
	------------------------------------*/
  #breadcrumb {
    padding: 6px 10px 0 10px;
  }
  /* イベント投稿
	------------------------------------*/
  .event_form_description {
    padding: 16px 20px;
  }
  .page_contribute section:first-child {
    padding-bottom: 0;
  }
  .page_contribute .event_date_start input,
  .page_contribute .event_date_end input,
  .page_contribute .expire_date_start input,
  .page_contribute .expire_date_end input {
    width: 120px;
    min-height: 2.2rem;
  }
  /* 伝統芸能マップ
	------------------------------------*/
  .font_l .map-title {
    text-align: left;
    padding-left: 10px;
    letter-spacing: 0.1em;
  }
  .font_l .tam-title-link {
    right: 0.5em;
  }
}
@media only screen and (min-width: 768px) and (max-width: 980px) {
  /* トップページ
    ---------------------------------------------------------- */
  .week_event_icon {
    width: 35px;
  }
  .page_top section.about {
    padding: 0 10px 30px 10px;
  }
  .simply-scroll {
    height: 160px;
  }
  .simply-scroll .simply-scroll-list li {
    width: 170px;
    height: 160px;
  }
  #scroller {
    height: 160px;
  }
  /* サブページ共通
    ---------------------------------------------------------- */
  .sub_page_head #title-box {
    padding: 40px 0 40px 4px;
  }
  /* KCICについて
    ---------------------------------------------------------- */
  .page-about .sub_page_head #title::after {
    bottom: -22px;
  }
  /* イベントカレンダー
    ---------------------------------------------------------- */
  .calender_list {
    width: 500px;
    padding: 0 40px;
    margin-right: 30px;
  }
  .calendar_search_box {
    width: calc(100% - 530px);
  }
  .calender_search_layer .inner {
    display: -webkit-flex;
    display: flex;
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  section {
    margin: 0 auto;
    padding: 0;
  }
  .footer {
    margin: 20px 0 0;
  }
  /* トップページ
    ---------------------------------------------------------- */
  /* メインイメージ
    ----------------------------------------------------------- */
  .swiper-button-next,
  .swiper-button-prev {
    width: 30px;
    height: 30px;
  }
  .swiper-button-next {
    background-size: 30px auto;
    margin-top: -14px;
  }
  .swiper-button-prev {
    background-size: 30px auto;
    margin-top: -14px;
  }
  .swiper-container-horizontal > .swiper-pagination-bullets,
  .swiper-pagination-custom,
  .swiper-pagination-fraction {
    bottom: 0;
  }
  .swiper-pagination-bullet {
    height: 3px;
    width: 30px;
  }
  .main-slide-title P {
    margin-bottom: 4px;
  }
  .slide-copy {
    font-size: 10px;
    padding: 4px 8px;
  }
  .slide-title {
    font-size: 14px;
    padding: 4px 8px;
  }
  .slide-date {
    font-size: 10px;
    padding: 2px 6px;
  }
  section {
    width: auto;
  }
  section h1 {
    margin: 0 0 10px 4px;
    font-size: 1.4rem;
  }
  .page_top section {
    padding: 0 10px 25px 10px;
  }
  .link_page_button.hide-mobile {
    display: none;
  }
  .link_page_button.sp_appear {
    display: block;
    float: none !important;
    width: 90%;
    padding: 10px 15px;
    margin: 15px auto 0 auto !important;
    text-align: center;
  }
  .link_page_button a:after {
    top: 27px;
    right: 15px;
  }
  .link_page_button img {
    margin-right: 10px;
  }
  /* 最新のお知らせ
	-------------------------------- */
  .hot_news {
    padding: 0;
  }
  .hot_news ul {
    padding: 0 5px;
  }
  .hot_news_title span {
    margin: 0;
    text-align: left;
    line-height: 1;
    padding: 19px 16px;
  }
  .event .description span:before {
    top: 14px;
  }
  .hot_news_title {
    width: 100%;
    height: 55px;
    margin: 0 auto;
    position: relative;
  }
  .hot_news_title:before {
    content: none;
  }
  .news_list {
    float: none;
    width: 98%;
    margin: 0 auto;
  }
  .hot_news_more {
    margin: 0 10px 0 0 !important;
    font-size: 0.9rem;
  }
  /* 新着イベント
	-------------------------------- */
  .event_menu li:nth-of-type(1),
  .event_menu li {
    width: 50%;
    display: block;
    padding: 0;
    margin: 0;
  }
  .event_menu li span {
    padding: 14px 6px 12px 6px;
    text-align: center;
    font-size: 1rem;
    letter-spacing: 0;
    min-height: 30px;
    border: none;
    height: inherit;
  }
  .event_menu li:first-of-type span {
    padding: 20px 6px 12px 6px;
  }
  .event_menu li:nth-of-type(2n) span {
    border-left: dotted 1px #acacac;
  }
  .event_menu li:nth-of-type(3) span,
  .event_menu li:nth-of-type(4) span {
    border-top: dotted 1px #acacac;
    border-bottom: dotted 1px #acacac;
  }
  .event_menu li:nth-of-type(3) span,
  .event_menu li:nth-of-type(4) span,
  .event_menu li:nth-of-type(5) span {
    padding: 14px 16px 12px 6px;
  }
  .event_menu img {
    width: 26px;
    margin-right: 10px;
    vertical-align: middle;
  }
  .event_wrap {
    margin: 10px 0 14px 0;
    background-color: #fff;
    border: 1px solid #e6e6e6;
    border-radius: 5px;
  }
  .event_box {
    width: 50%;
  }
  .event_box:nth-of-type(-n + 4) {
    border-top: inherit;
  }
  .event_box:nth-of-type(4n + 1) {
    border-left: none;
  }
  .event_box:nth-of-type(-n + 2) {
    border-top: none;
  }
  .event_box:nth-of-type(2n) {
    border-right: none;
  }
  .event_header img {
    width: 30px;
    margin: 0 7px 0 0;
    vertical-align: -11px;
  }
  .event_title_right {
    float: none;
  }
  .event h1 {
    float: left;
    margin: 0 0 0 4px;
  }
  .event .description {
    margin: 0 0 10px 0;
    float: right;
    font-size: 0.86rem;
  }
  .event_menu {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
  }
  .event_button {
    width: 90%;
    padding: 12px 20px;
    text-align: center;
    margin: 0 auto;
  }
  .font_l .event_button {
    width: 90%;
    max-width: 340px;
  }
  .event_button img {
    margin: 0 12px 0 0;
  }
  .event_button__artist img {
    margin-bottom: -3px;
  }
  .event_button__flag img {
    margin-bottom: -7px;
    margin-left: -20px;
    margin-right: 10px;
  }
  .event_button span {
    font-size: 1rem;
  }
  .event_attention {
    font-size: 1rem;
  }
  .event_box {
    padding: 8px;
  }
  .event_box p.event_title {
    line-height: 1.4;
    font-size: 1.03rem;
  }
  .event_box p.event_date {
    margin: 0 0 12px 0;
    line-height: 1.4;
  }
  .event_date {
    font-size: 0.76rem;
  }
  .event_img {
    height: auto;
    padding: 0;
    vertical-align: middle;
  }
  .event_img .post-image {
    margin: 0;
  }
  .week_event a.link_page_button,
  .event a.link_page_button {
    width: 90%;
    max-width: 340px;
    padding: 12px 20px;
    text-align: center;
    margin: 12px auto 0 auto;
    float: none;
  }
  .week_event a.link_page_button {
    margin: 20px auto 0 auto;
  }
  .committee a.link_page_button {
    margin: 18px auto 10px auto;
  }
  /* 週間イベント情報
	-------------------------------- */
  .week_event_menu a:hover:after {
    top: 36px;
  }
  .week_event_day {
    width: 55px;
  }
  .week_event_day .month {
    top: 4px;
    left: 4px;
  }
  .week_event_day .month .t-bold {
    font-weight: bold;
    font-size: 1rem;
  }
  .week_event_day .date {
    font-size: 1.5rem;
  }
  .week_event_img {
    width: 80px;
    height: 80px;
    margin-right: 10px;
  }
  .week_event_list_icon {
    font-size: 0.8rem;
  }
  .week_event_icon {
    width: 30px;
    margin: 0 8px 0 0px;
    vertical-align: -11px;
  }
  .week_event_list .week_event_title {
    font-size: 1rem;
  }
  .week_event_list p.week_event_period {
    font-size: 0.7rem;
    letter-spacing: normal;
  }
  .week_event_list_wrap {
    margin: 10px 0 0 0;
  }
  .week_event_list {
    padding: 6px 0 6px 6px;
  }
  .week_event_list .week_event_img img {
    width: auto;
    height: auto;
  }
  .page_top section.content_banner {
    padding: 0 10px 20px 10px;
  }
  /* 実行委員会事業の紹介
	-------------------------------- */
  .committee_title {
    padding: 0 0 0 6px;
  }
  .committee h1 {
    display: block;
    margin: 0 0 6px 0;
  }
  .committee_span {
    margin: 0 0 12px 0;
    font-size: 0.82rem;
  }
  .pink_content {
    width: 100%;
  }
  .pink_content h2 {
    font-size: 1.07rem;
  }
  .pink_content .date {
    font-size: 0.8rem;
  }
  .pink_box {
    padding: 14px 14px 10px 14px;
  }
  .pink_box .post-image-link {
    float: none;
    width: 100%;
  }
  .pink_box img {
    height: auto !important;
    margin: 30px 0 0;
  }
  /* KCICについて
	-------------------------------- */
  .about_introduction {
    max-width: 100%;
    padding: 0 10px;
    width: 100%;
  }
  .page-about .sub_page_head #title {
    font-size: 2rem;
  }
  .page-about .sub_page_head #title::after {
    bottom: -19px;
  }
  .page_top section.about {
    padding: 0;
  }
  .about_box {
    width: 100%;
    padding: 0;
  }
  .about_box h1,
  .about_box p {
    padding: 0 10px;
  }
  .about .link_page_button {
    display: block;
    width: 90%;
    max-width: 340px;
    text-align: center;
    padding: 14px 20px 14px 12px;
  }
  .about_img {
    display: block;
    width: 100%;
    margin: 20px auto;
    padding: 0 10px;
  }
  .about_box h1 {
    margin: 20px 0 10px 0;
  }
  .sns_icon_box {
    margin: 20px 0 0 0;
  }
  .about_link_layer {
    margin: 15px 0;
  }
  .information_center_wrap {
    display: block;
  }
  .information_center_wrap div {
    width: 100%;
  }
  /* インスタスライド
    ---------------------------------------------------------- */
  section.sec_insta_feed {
    width: 100% !important;
    max-width: 100%;
    margin-top: 10px;
    padding: 0;
    display: none;
  }
  .simply-scroll .simply-scroll-list li {
    width: 100px;
    height: 100px;
    overflow: hidden;
    margin-right: 14px;
  }
  .simply-scroll {
    width: auto;
    height: 100px;
    margin-bottom: 0;
  }
  /* コンテンツスライド
    ---------------------------------------------------------- */
  .content_banner_slider {
    width: auto;
  }
  .content_banner_slider .slick-list {
    width: auto;
  }
  .other_banner_slider .slick-prev,
  .content_banner_slider .slick-prev {
    left: -6px;
  }
  .other_banner_slider .slick-next,
  .content_banner_slider .slick-next {
    right: -6px;
  }

  /* 外部バナースライド
    ---------------------------------------------------------- */
  .other_banner_slider {
    width: auto;
    margin: 0px auto 0 auto;
  }
  .other_banner_slider .slick-list {
    width: auto;
  }
  .other_banner_slider .slick-list li a {
    width: auto;
    margin: 0 10px;
  }
  .other_banner_slider .slick-list li img {
    width: 100%;
    height: auto;
  }
  /* サブページ（英語）
	-------------------------------- */
  #breadcrumb {
    padding: 10px;
    text-align: right;
    font-size: 0.82rem;
    display: none;
  }
  .sub_page_top {
    height: 140px;
  }
  .sub_page_top p {
    margin: 12px 0 0 0;
    font-size: 1.68rem;
  }
  /*kagoshima cultural information center*/
  .information_center .img_wrap {
    float: none;
    width: 100%;
  }
  .information_center img {
    width: 100%;
    margin: 0;
  }
  .information_center p {
    width: 100%;
    margin: 5px 0 20px 0;
  }
  /*access to kagoshima*/
  .access_01 .img_wrap {
    width: 100%;
  }
  .access_01 img {
    width: 100%;
    float: none;
    margin: 0;
  }
  .access_01 p,
  #access_kagoshima {
    float: none;
    width: 100%;
    margin: 5px 0 20px 0;
  }
  /*access to kagoshima cultural information center (KCIC)*/
  .access_02 .img_wrap {
    float: none;
    width: 100%;
  }
  .access_02 img {
    width: auto;
    margin: 0;
  }
  .access_02 p,
  #access_kcic {
    float: none;
    width: 100%;
    margin: 5px 0 20px 0;
  }
  /*access to kagoshima*/
  .access_03 .img_wrap {
    float: none;
    width: 100%;
  }
  .access_03 img {
    width: 100%;
    margin: 0;
  }
  .access_03 p {
    float: none;
    width: 100%;
    margin: 5px 0 20px 0;
  }

  /* サブページ共通
    ---------------------------------------------------------- */
  #title-text p {
    border-bottom: 0;
  }
  .sub_content_wrapper {
    width: auto;
    margin: 0 10px;
  }
  .sub_page {
    margin-bottom: 40px;
  }
  .sub_page_head {
    width: auto;
    margin: 0 10px;
  }
  .sub_page_head #title-box {
    padding: 40px 6px 26px 6px;
  }
  .sub_page_head #title {
    margin: 0;
    font-size: 1.3rem;
    letter-spacing: 0.05em;
  }
  .sub_page_head #title-box {
    display: block;
  }
  .sub_page_head.sub_page_head--link #title-box {
    display: flex;
  }
  #title-text {
    line-height: 1.6;
    padding: 0;
    font-size: 0.82rem;
  }
  .type-box-date {
    margin: 0;
    width: auto;
  }
  #art-box-wrapper {
    float: none;
    width: 100%;
  }
  #art-box {
    width: auto;
    padding: 14px;
  }
  #art-box h1 {
    font-size: 1.2rem;
  }
  #art-box h2 {
    font-size: 15px;
  }
  #art-box h3 {
    font-size: 14px;
  }
  #art-box h4 {
    font-size: 13px;
  }
  #right-banner-box {
    display: none;
  }
  #art-box table td {
    height: auto;
    padding: 0 0.5rem;
  }
  /* お知らせ
	--------------------------------------------------------- */
  #art-box-wrapper #back-archive {
    margin: 0 10px;
  }
  /* アートナビ
    ---------------------------------------------------------- */
  .map.kan .kan-input {
    display: block;
  }
  /* イベントカレンダー
    ---------------------------------------------------------- */
  .calender_search_layer {
    padding: 20px 10px;
    margin-top: 0;
  }
  .calendar_search_box {
    padding-right: 0;
    width: 100%;
  }
  .calender_search_layer .inner {
    display: block;
    width: auto;
    margin: 0 10px;
  }
  .week_event_list_title {
    padding: 24px 0 16px 0;
    font-size: 1rem;
  }
  .week_event_list_title .t-alpha {
    font-size: 1.2rem;
  }
  .contribute_button_layer {
    padding: 30px 0 20px 0;
  }
  /* イベントリスト
    ---------------------------------------------------------- */
  .event_list li {
    padding: 20px 10px;
  }
  .event_list .week_event_icon {
    width: 40px;
    margin: 0 10px 0 0;
    vertical-align: -15px;
  }
  /* イベント投稿
	----------------------------------------------------------*/
  .event_form_description {
    padding: 10px 14px;
  }
  .event_mail_form input,
  .event_mail_form textarea {
    font-size: 1rem;
  }
  .event_mail_form div,
  .event_mail_form .form_right {
    width: auto;
    float: none;
    padding-right: 0;
  }
  .event_mail_form .form_left {
    margin-bottom: 6px;
  }
  .event_mail_form li {
    padding: 14px 4px 0 4px;
  }
  .event_mail_form li.form_last {
    font-size: 1rem;
  }
  .form_last p {
    text-align: left;
  }
  #contact_attention,
  #contact_agreement {
    text-align: left;
  }
  #contact_agreement,
  .form_last p:nth-of-type(2) {
    margin-top: 12px;
  }
  .event_mail_form_wrap h1 {
    margin: 40px 0 10px 0;
  }
  .event_mail_form_wrap h2 {
    font-size: 18px;
  }
  .check {
    margin: 0;
  }
  .event_date_start,
  .expire_date_start {
    width: 130px;
    margin: 0 5px 0 0;
  }
  .event_date_end,
  .expire_date_end {
    width: 130px;
    margin: 0 0 0 5px;
  }
  .event_form_description h1 {
    font-size: 1.1rem;
  }
  .wpcf7c-elm-step2 {
    font-size: 1.1rem;
    text-align: left;
  }
  input[type="button"].wpcf7c-elm-step2,
  input[type="submit"].wpcf7c-elm-step2 {
    text-align: center;
  }
  .confirmation_button input:first-of-type {
    margin-bottom: 14px;
  }
  /* イベント情報
	----------------------------------------------------------*/
  .event_search_wrap section {
    padding: 20px 10px;
  }
  .event_search_wrap form {
    float: none;
    width: 100%;
  }
  .event_search_wrap div {
    float: none;
    width: 100%;
    margin-top: 15px;
  }
  .event_search_wrap .search {
    width: 100%;
  }
  .search_check li {
    margin: 0 10px 10px 0;
  }
  .event_list .event_img {
    float: none;
    width: 100%;
    height: auto;
  }
  .event_list_left,
  .event_list_right {
    width: 100%;
    float: none;
    padding: 12px 0 0 0;
  }
  #art-box .list_date,
  .event_list_right .list_date {
    margin-top: 6px;
    font-size: 0.8rem;
  }
  .event_when_sp {
    width: auto;
    margin: 0 10px;
  }
  .event_when_sp select {
    border-radius: 5px;
    padding: 12px;
    font-size: 1.1rem;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 20px;
    background: url(../images/common/select_allow_pink.svg) no-repeat right 10px
      center;
    background-size: 20px auto;
  }
  .single-contents-text .post-attr-box.two .post-attr-content {
    margin-left: 0;
    padding-left: 0;
    border-left: none;
  }
  .single-contents-text .post-attr-box .post-attr-content {
    margin: 0 0 14px 0 !important;
    line-height: 1;
  }
  .single-contents-text .post-attr-title {
    font-weight: bold;
  }
  /*ページネーション*/
  #pagination {
    padding: 25px 0 0;
  }
  #pagination span,
  #pagination a {
    margin: 0 8px 5px 0;
    line-height: 3;
  }
  /* KCICについて
	----------------------------------------------------------*/
  .link_page_button.about_access_link {
    margin-top: 0px;
  }
  /* 蔵書一覧
	----------------------------------------------------------*/
  .library-box {
    margin: 0;
    padding: 0;
  }
  /* 伝統芸能マップ
	----------------------------------------------------------*/
  .font_l .map-title {
    letter-spacing: 0;
  }
}

@media only screen and (max-width: 320px) {
  .event_menu li span {
    font-size: 0.9rem;
  }
  .event_box .event_header p {
    font-size: 0.8rem;
  }
  /* 奉納行事
	-------------------------------------*/
  .font_l .calendar-event-month {
    font-size: 1.4em;
  }
}

/*2022年リニューアル修正*/
/* トップページ
-------------------------------------*/
/* 言語切り替えボタン*/
.language-button {
  width: 116px;
  border-radius: 13px;
  background: #f4f3f3;
  border: none;
  cursor: pointer;
  font-size: 12px;
}
.language-button:lang(vi),
.language-button:lang(en),
.language-button:lang(ko),
.language-button:lang(zh-TW),
.language-button:lang(zh-CN) {
  display: none;
}
.language-switch-sp:lang(vi),
.language-switch-sp:lang(en),
.language-switch-sp:lang(ko),
.language-switch-sp:lang(zh-TW),
.language-switch-sp:lang(zh-CN) {
  display: none;
}
.language {
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: space-between;
}
.language-button .icon {
  position: relative;
  width: 22px;
  display: block;
  height: 100%;
}
.language-button .icon:before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 11px;
  height: 11px;
  background: url(../images/common/earth-icon.svg) no-repeat;
  background-size: contain;
}
.language-button .arrow {
  position: relative;
  width: 23px;
  display: block;
  background-color: #e6e6e6;
  height: 100%;
  border-radius: 0 13px 13px 0;
}
.language-button .arrow:after {
  content: "";
  position: absolute;
  width: 7px;
  height: 4px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: url(../images/common/language-arrow.svg) no-repeat;
  background-size: contain;
}
.language-button {
  position: relative;
}
.language-button ul {
  display: none;
  position: absolute;
  width: 116px;
  z-index: 100;
  top: 32px;
  left: 0;
  background-color: #f4f3f3;
  border: solid 1px #e6e6e6;
  padding: 0;
}
.language-button:hover ul {
  display: block;
}
.language-button ul li {
  display: block;
  border-bottom: dotted 1px #000;
}
.language-button ul li:last-child {
  border-bottom: none;
}
.language-button ul li a {
  display: block;
  padding: 5px 10px;
  font-size: 14px;
  height: 100%;
}
/* SNS・メルマガセクション*/
.about_box {
  width: 100%;
  display: flex;
  text-align: center;
}
.about_box-item {
  padding-top: 30px;
  padding-bottom: 30px;
  width: 50%;
}
.about_box h2 {
  margin: 0 auto 35px;
  max-width: 250px;
}
.about_box h2 img {
  width: 100%;
}
.about_box p {
  text-align: center;
}
.about_box .text {
  width: 340px;
  margin: 0 auto 35px;
}
.about_box .subtext {
  color: #e6378d;
  font-weight: bold;
  margin-bottom: 10px;
}
.about_img {
  display: inline-block;
  width: 45%;
}
.sns-box {
  border-right: 1px dashed #e6e6e6;
}
.sns_icon_box {
  margin: 20px 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
.sns_icon_box li {
  display: inline-block;
  width: 35px;
  margin: 0 16px;
}
.sns_icon_box li a:hover {
  opacity: 0.75;
}
.sns_icon_box li img {
  width: 100%;
  height: auto;
  height: 35px;
}
.about_link_layer {
  margin: 30px 0 0 0;
  text-align: center;
}
.about .mail-box-link {
  display: inline-block;
}
.about .mail-box-link .mail-box-button {
  padding: 18px 18px 18px 54px;
  position: relative;
  background: #e6378d;
  color: #fff;
  display: block;
  border: none;
  width: 340px;
  font-size: 16px;
  font-weight: bold;
  border-radius: 50px;
}
.about .mail-box-link .mail-box-button:hover {
  text-decoration: none;
  background: #000;
}
.about .mail-box-link .mail-box-button:after {
  content: "";
  position: absolute;
  width: 19px;
  height: 18px;
  background: url(../images/top/top-mail-icon.svg) no-repeat;
  background-size: contain;
  left: calc(50% - 60px);
  top: 50%;
  transform: translate(-50%,-50%);
}
@media screen and (max-width: 767px) {
  .about_box {
    display: block;
    padding-top: 25px;
  }
  .about_box-item {
    width: 100%;
  }
  .about_box h2 {
    margin: 0 auto 16px;
  }
  .about_box .text {
    width: 95%;
    margin: 0 auto 25px;
    max-width: 500px;
  }
  .sns-box {
    border-right: none;
  }
  .about .mail-box-link {
    max-width: 340px;
    width: 90%;
  }
  .about .mail-box-link .mail-box-button {
    padding: 12px 12px 12px 54px;
    width: 100%;
    font-size: 14px;
  }
  .about .mail-box-link .mail-box-button:after {
  left: calc(50% - 50px);
  }
}
/* ページ下部のバナー */
.other_banner .other_banner_slider {
  display: flex;
  flex-wrap: wrap;
  gap: 1.6666%;
}
.other_banner .other_banner_slider li {
  width: 15%;
}
.other_banner .other_banner_slider .other_banner_long {
  width: 48%;
  margin-top: 20px;
}

.other_banner .other_banner_slider li a img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 980px) {
  .other_banner .other_banner_slider {
    gap: 2.6666%;
  }
  .other_banner .other_banner_slider li {
    width: 23%;
  }
}
@media screen and (max-width: 767px) {
  .other_banner .other_banner_slider {
    gap: 3.5%;
  }
  .other_banner .other_banner_slider li {
    width: 31%;
  }
  .other_banner .other_banner_slider .other_banner_long {
    width: 100%;
  }
}
@media screen and (max-width: 539px) {
  .other_banner .other_banner_slider {
    gap: 4%;
  }
  .other_banner .other_banner_slider li {
    width: 48%;
  }
}

/* 伝統芸能団体
-------------------------------------*/
.map-list {
  display: flex;
  flex-wrap: wrap;
}
.map-list-item {
  display: flex;
  width: 50%;
  align-items: center;
}
.map-list-item-left {
  width: 38%;
  display: flex;
  align-items: center;
}
.map-list-item-right {
  width: 62%;
}
.tam-group {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .map-list {
    display: block;
  }
  .map-list-item {
    width: 100%;
    display: block;
    margin-top: 0.5em;
    margin-bottom: 0.5em;
  }
  .map-list-item-left,
  .map-list-item-right {
    width: 100%;
  }
  .tam-group {
    margin-left: 0;
  }
}
#mapp0_poi_list .map-list {
  display: block;
}
/* 伝統芸能カレンダー
-------------------------------------*/
.calendar-event-month-inner {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 50px;
}
.calender-event-month-items {
  display: flex;
  flex-wrap: wrap;
  width: 50%;
}
.calendar-event-group {
  display: flex;
  width: 100%;
}
.calendar-event-name {
  width: 43%;
}
.calendar-event-link {
  width: 57%;
  padding-left: 0.5rem;
}
.calendar-event-link.fix-margin {
  margin-left: 43%;
}
@media screen and (max-width: 767px) {
  .calendar-event-month-inner {
    display: block;
  }
  .calender-event-month-items {
    display: block;
    width: 100%;
  }
  .calendar-event-group {
    margin-top: 1.5em;
    margin-bottom: 1.5em;
    display: block;
  }
  .calendar-event-name,
  .calendar-event-link {
    width: 100%;
  }
  .calendar-event-link {
    padding-left: 0;
  }
  .calendar-event-link.fix-margin {
    margin-left: 0;
  }
}
/* 伝統芸能団体のタブ切り替え
-------------------------------------*/
.c-tab {
  max-width: 980px;
  margin: 36px auto 0;
  border-bottom: 2px solid #e6378d;
}
.c-tab__list {
  width: 100%;
  display: flex;
}
.c-tab__list--traditional {
  max-width: 740px;
}
.c-tab li {
  width: 33.33333%;
  margin-right: 3px;
  flex: 1;
  order: -1;
  font-size: 21px;
  cursor: pointer;
  text-align: center;
  white-space: normal;
  border-radius: 15px 15px 0 0;
  border: 2px solid #e6378d;
  border-bottom: none;
}
.c-tab li a {
  display: block;
  font-weight: bold;
  padding: 15px 3px;
}
.c-tab li:hover {
  background-color: #e6378d;
}
.c-tab li:hover a {
  color: #fff;
  text-decoration: none;
}

.c-tab li.active {
  background-color: #e6378d;
}
.c-tab li.active a {
  color: #fff;
  font-weight: bold;
}
.sub_page_head.traditional-sub_page_head #title-box {
  padding: 50px 0 30px;
}

@media only screen and (max-width: 979px) {
  .c-tab {
    margin: 20px 0 0;
  }
  .c-tab li {
    font-size: 13px;
  }
  .c-tab li:first-of-type {
    margin-left: 3px;
  }
  .sub_page_head.traditional-sub_page_head #title-box {
    padding: 30px 0 15px;
  }
}
/* MailPoet3プラグイン
-------------------------------------*/
.mailpoet_form {
  margin-top: 25px;
}
input[type="submit"].mailpoet_submit {
  padding: 18px;
  background: #e62686;
  border: 1px solid #e62686;
  color: #fff;
  font-weight: bold;
  font-size: 1.1rem;
}
#art-box h2.mailpoet-heading,
#art-box .mailpoet_form_html input,
#art-box .mailpoet_form_iframe input {
  font-family: Futura, "Century Gothic", "Helvetica Neue", Arial, "游ゴシック",
    YuGothic, Futura, "ヒラギノ角ゴ Pro W3", Osaka, "Hiragino Kaku Gothic Pro",
    メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
#mailpoet_form_1 .mailpoet_text,
#mailpoet_form_1 .mailpoet_textarea {
  height: 38px;
  font-size: 14px;
}
#art-box h2.mailpoet-heading {
  margin-bottom: 0.6em;
  font-size: 16px;
}
.post-7958 #mailpoet_form_1 form.mailpoet_form {
  padding-left: 0;
}
/* 多言語対応スタイル修正
-------------------------------------*/
/* header */
.header_sub_menu:lang(en),
.header_sub_menu:lang(vi) {
  font-size: 10px;
}
.header_event_button a:lang(en),
.header_event_button a:lang(zh-CN),
.header_event_button a:lang(zh-TW),
.header_event_button a:lang(vi),
.header_event_button a:lang(ko) {
  display: table-cell;
}
.header_event_button a:lang(zh-CN),
.header_event_button a:lang(zh-TW),
.header_event_button a:lang(ko) {
  padding-top: 8px;
  padding-bottom: 7px;
}
.header_event_button a:lang(en) {
  padding-top: 9px;
  padding-bottom: 5px;
  font-size: 10px;
  white-space: nowrap;
}
.header_event_button a:lang(vi) {
  padding-top: 8px;
  padding-bottom: 4px;
  font-size: 11px;
}
@media only screen and (max-width: 979px) {
  #menu #header-sp-nav-btn-text:lang(vi) {
    font-size: 10px;
    text-align: center;
  }
}
.font_size_switch:lang(vi) {
  padding-top: 8px;
  padding-bottom: 0;
}
.font_size_switch select:lang(en),
.font_size_switch select:lang(vi) {
  width: 64px;
}

.event_box .event_header p font font:lang(vi) {
  width: 102px;
  display: inline-block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.event_box p:lang(en),
.event_box p:lang(ko) {
  overflow: hidden;
}

/* お問い合わせページ */
.translated-ltr:lang(en) .confirmation_button input,
.translated-ltr:lang(vi) .confirmation_button input {
  min-width: 230px;
  width: inherit;
}
/* 奉納行事ページ */
.calendar-event-month-sub:lang(en),
.calendar-event-month-sub:lang(zh-CN),
.calendar-event-month-sub:lang(zh-TW),
.calendar-event-month-sub:lang(vi),
.calendar-event-month-sub:lang(ko) {
  display: none;
}
/* 伝統芸能マップ・アートナビ */
#mapp0_poi_list .map-title:lang(en),
#mapp0_poi_list .map-title:lang(vi),
#mapp0_poi_list .map-title:lang(ko) {
  letter-spacing: 0.2em;
}
/*TODOmain-slide-titleもう使われていない場合index.phpから削除する*/
.main-slide-title {
  display: none;
}
/* 投稿イベントのシングルページ */
.single-contents-text .post-attr-box .post-attr-title:lang(en),
.single-contents-text .post-attr-box .post-attr-title:lang(vi) {
  letter-spacing: 0;
  padding-right: 1em;
  width: 135px;
}
.single-contents-text .post-attr-box .post-attr-content:lang(en),
.single-contents-text .post-attr-box .post-attr-content:lang(vi) {
  letter-spacing: 0;
  margin-left: 145px;
  width: auto;
}
#art-box .single-contents-text .post-attr-box .post-attr-title:lang(en),
#art-box .single-contents-text .post-attr-box .post-attr-title:lang(vi) {
  padding-right: 1em;
}

/*伝統芸能マップとアートナビのスマホの時のinputの調整*/
@media only screen and (max-width: 732px) {
  .map.kan .kan-input {
    display: block;
  }
  .kan-input {
    display: block;
  }
  .map-poi-index-input {
    margin-top: 0;
    margin-right: 0.5rem;
  }
  .kan-ebook {
    margin-top: 0.6em;
    display: block;
  }
  .kan-print {
    margin-top: 0.8em;
  }
}
@media only screen and (min-width: 733px) {
  .map.kan .kan-input {
    display: none;
  }
  .kan-input {
    display: none;
  }
}

/* 2023年改修ここから */
/* トップページ */
section.p-top-event {
  padding-top: 80px;
  padding-bottom: 80px;
  max-width: 100%;
  background-color: #f2f2f2;
  background-image: repeating-linear-gradient(
    -45deg,
    #fff,
    #fff 5px,
    transparent 0,
    transparent 6px
  );
}
.p-top-event__container {
  max-width: 980px;
  margin-right: auto;
  margin-left: auto;
}
.p-top-event__event-box {
  background-color: #fff;
  border: 1px solid #e6e6e6;
  border-radius: 5px;
}
/* トップページ　開催中イベント */
.p-top-event-today-box {
  display: flex;
  justify-content: center;
}
.event_date_box {
  display: flex;
  width: 100%;
  justify-content: space-between;
}
.event_box p.event_date_title {
  color: #000;
  font-weight: bold;
  float: unset;
  font-size: 12px;
  width: auto;
  white-space: nowrap;
}
.event_box p.event_date--holding {
  float: unset;
  width: auto;
}
.p-top-event-today__item:first-of-type {
  border-left: solid 1px #e6e6e6;
}
/* トップページ　イベント一覧　分野別カテゴリー */
.p-top-event__field-list {
  max-width: 690px;
  margin: 0 auto;
  display: flex;
  gap: 6px;
  justify-content: center;
  flex-wrap: wrap;
}
.p-top-event__field-item {
  border: 2px solid #000;
  border-radius: 40px;
  width: calc((100% / 4) - 6px);
  background: #fff;
}
.p-top-event__field-link {
  font-size: 14px;
  font-weight: bold;
  color: #000;
  line-height: 40px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 5px;
}
.p-top-event__field-icon {
  width: 20px;
  height: 20px;
  margin-right: 5px;
}
.p-top-event__field-icon--others {
  display: none;
}
.p-top-event__field-icon img {
  width: 20px;
  height: 20px;
}

/* トップページ　イベント情報募集 */
.page_top .p-top-info {
  border-bottom: 1px solid #e6e6e6;
}

/* トップページ　カゴシマ・アーティスト・ライブラリー */

.p-top-artist {
  max-width: 980px;
  margin: 0 auto;
}
.p-top-artist__coming-soon-text {
  font-weight: bold;
  font-size: 35px;
  color: #e6378d;
  text-align: center;
}
.p-top-artist__main-text {
  text-align: center;
}

/* イベント一覧ページ */

.event_search_wrap div {
  float: inherit;
  width: 100%;
}
.event_search_wrap form {
  float: inherit;
  width: 100%;
  position: relative;
}
.event_search_wrap form input[type="submit"] {
  width: 120px;
  height: 48px;
  background-color: #e6378d;
  color: #fff;
  font-weight: bold;
  position: absolute;
  top: 1px;
  right: 1px;
  border: none;
  padding: 0;
  border-radius: 0;
  -webkit-appearance: none;
}
.event_search_wrap form input[type="submit"]:hover {
  background-color: #000;
  padding: 0;
}
.event_search_wrap .search {
  width: 100%;
  height: 50px;
  border: #b0b0b0 solid 1px;
  border-radius: 2px;
  background: #fff;
  -webkit-appearance: none;
}
.event_search-list {
  background: #fff;
  padding: 10px 15px 5px;
  border-radius: 5px;
}
.event_list_category {
  display: flex;
  align-items: center;
  position: relative;
}
.event_list_category--top {
  flex-flow: column;
  align-items: baseline;
}
.event_list_genre {
  display: flex;
  align-items: center;
  flex-flow: wrap;
}
.event_box .event_header .event_list_genre_item {
  display: flex;
  align-items: center;
  font-weight: bold;
  color: #e6378d;
  margin-right: 7px;
}
.event_list_genre_item {
  display: flex;
  align-items: center;
  font-weight: bold;
  color: #e6378d;
  margin-right: 7px;
}
.event_list_genre_item--top {
  font-size: 10px;
  white-space: nowrap;
  margin-bottom: 5px;
}
.event_list_genre_icon {
  width: 26px;
  margin-right: 3px;
}
.event_list_field {
  background-color: #fff0f5;
  border-radius: 2px;
  padding: 3px 5px;
  display: inline-flex;
  flex-wrap: wrap;
  font-size: 10px;
  font-weight: bold;
  color: #e6378d;
}
.event_box .event_header .event_list_field_item {
  font-weight: bold;
  margin: 0;
}
.event_list_field_item::after {
  content: "／";
}
.event_list_field_item:last-of-type:after {
  content: "";
}
.event_list_date {
  position: absolute;
  top: 0;
  right: 0;
  color: #999;
}

/* イベント詳細ページ */
.event_list_category--detail {
  position: relative;
}
.event_list_field--detail {
  display: flex;
  align-items: center;
  position: absolute;
  top: 0;
  right: 0;
}
.p-event-single__title-box {
  padding: 45px 0 30px 4px;
}
.p-event-single__title {
  margin: 0 34px 0 0;
  border-right: none;
  line-height: 1.4;
  height: auto;
  color: #e6378d;
  font-size: 1.92rem;
  font-weight: bold;
  letter-spacing: 0.14em;
}
.p-event-single__day {
  display: inline-block;
  background-color: #fff0f5;
  padding: 4px 10px;
  color: #e6378d;
  font-size: 15px;
  font-weight: bold;
  border-radius: 2px;
  line-height: 1;
  margin-top: 10px;
}

/* アーティスト紹介　ABOUT */
.p-artist-about {
  padding-top: 50px;
}
.p-artist-about h4 {
  color: #e6378d;
  font-size: 25px;
  font-weight: bold;
  margin-bottom: 50px;
}
/*アーティスト紹介　一覧*/
.p-artist-list {
  padding-top: 30px;
}
/*アーティスト紹介　スペース一覧*/
#mapp0_poi_list .map-list--shop {
  display: flex;
  gap: 10px 20px;
}
#mapp0_poi_list .map-item--shop {
  width: calc((100% - 60px) / 4);
}
/*アーティスト紹介　スペース紹介*/
.c-detail__sub-content {
  padding: 14px 12px 6px 12px;
  background: #efefef;
  display: flex;
  flex-flow: wrap;
}
.c-detail__sub-content .title {
  width: 15%;
  border-right: 1px solid #6b6c6e;
  letter-spacing: 0.2em;
  padding-right: 15px;
  line-height: 1.85;
  text-align: right;
  vertical-align: middle;
  margin-bottom: 5px;
}
.c-detail__sub-content .content {
  width: 85%;
  line-height: 1.8;
  vertical-align: middle;
  letter-spacing: 0.2em;
  padding-left: 15px;
}
/* アーティスト紹介　よくある質問 */
.p-artist-faq {
  padding: 30px 0 0;
}
.p-artist-faq__item-title {
  position: relative;
  padding-left: 60px;
  border-bottom: 1px dashed #525252;
  padding-top: 25px;
  padding-bottom: 25px;
  font-weight: bold;
  font-size: 16px;
  display: block;
}
.p-artist-faq__item-icon {
  width: 40px;
  height: 40px;
  line-height: 40px;
  border-radius: 50%;
  margin-right: 20px;
  font-size: 20px;
  font-weight: bold;
  font-family: 'Roboto',arial,sans-serif;
  text-align: center;
  position: absolute;
  left: 4px;
}
.p-artist-faq__item-icon--title {
  background: #e6378d;
  color: #fff;
  top: 50%;
  transform: translate(0, -50%);
}
.p-artist-faq__item-icon--content {
  background: #fdebf4;
  color: #e6378d;
  top: 20px;
}
.p-artist-faq__item-title::-webkit-details-marker {
  display: none;
}
.p-artist-faq__item-title::before {
  content: "";
  width: 30px;
  height: 5px;
  position: absolute;
  background: #e6378d;
  border-radius: 10px;
  right: 20px;
  top: 50%;
  transform: translate(0, -50%);
}
.p-artist-faq__item-title::after {
  content: "";
  width: 30px;
  height: 5px;
  position: absolute;
  background: #e6378d;
  border-radius: 10px;
  right: 20px;
  top: 50%;
  transform: translate(0, -50%) rotate(90deg);
  transition: all ease 0.5s;
}
.p-artist-faq__item[open] .p-artist-faq__item-title::after {
  transform: translate(0, -50%) rotate(180deg);
}
.p-artist-faq__item-content {
  position: relative;
  padding-left: 60px;
  padding-top: 25px;
  padding-bottom: 25px;
  border-bottom: 1px dashed #525252;
}

/* イベント投稿フォーム */
.form_check_button span.wpcf7-list-item {
  margin: 0;
  position: relative;
}
.form_check_button .wpcf7-list-item-label {
  position: relative;
  float: left;
  padding: 5px 12px 5px 30px;
  margin: 0 10px 5px 0;
  color: #fff;
  font-weight: bold;
  background-color: #666;
  border-radius: 5px;
  cursor: pointer;
  font-weight: normal;
  font-size: 14px;
}
.form_check_button .wpcf7-list-item-label::before {
  content: "";
  height: 13px;
  width: 13px;
  top: 9px;
  left: 12px;
  position: absolute;
  border: solid 1px #fff;
}
.form_check_button input[type="checkbox"] {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.form_check_button input[type="checkbox"]:checked ~ span.wpcf7-list-item-label {
  background-color: #e6378d;
}
.form_check_button input[type="checkbox"]:checked ~ span.wpcf7-list-item-label::after {
    content: "";
    position: absolute;
    top: 13px;
    left: 18px;
    width: 5px;
    height: 13px;
    margin: -8px 0 0 0;
    border-bottom: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(45deg);
    transform-origin: 50% 50% 0;
    transform-origin: 50% 50% 0;
}

/* コンタクトフォーム */
input[type=submit]:disabled {
  opacity: 0.5;
}

/* component */

.c-container {
  max-width: 980px;
}

.c-title {
  max-width: 300px;
  margin-right: auto;
  margin-left: auto;
}
.c-title--artist {
  max-width: 616px;
}
.c-title img {
  width: 100%;
  height: auto;
}
.c-title-sub {
  font-size: 24px;
  font-weight: bold;
  color: #e62686;
}
.c-title-sub--center {
  text-align: center;
}
.c-text-center {
  text-align: center;
}

.c-font--roboto {
  font-family: 'Roboto',arial,sans-serif;
}

/* アーティストリスト */

.c-list-artist__list {
  display: flex;
  gap: 30px;
  flex-flow: wrap;
}
.c-list-artist__item {
  width: calc((100% / 4) - 23px);
}
.c-list-artist__item:hover .c-list-artist__item-img {
  opacity: 0.8;
}
.c-list-artist__item:hover .c-list-artist__item-name {
  text-decoration: underline;
}
.c-list-artist__item-link:hover {
  text-decoration: none;
}
.c-list-artist__item-img {
  height: 220px;
  border: 1px solid #e6e6e6;
  margin-bottom: 15px;
  transition: all ease 0.5s;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
.c-list-artist__item-genre span {
  font-size: 12px;
  font-weight: bold;
  color: #e6378d;
}
.c-list-artist__item-genre span::after {
  content: " /";
}
.c-list-artist__item-genre span:last-of-type::after {
  content: "";
}
.c-list-artist__item-name {
  font-size: 17px;
  font-weight: bold;
  color: #000;
}

/* 詳細ページ */
.c-detail {
  border: 1px solid #acacac;
  padding: 50px;
}
.c-detail__title-box {
  border-bottom: 1px dashed #acacac;
  padding-bottom: 50px;
  margin-bottom: 50px;
  display: flex;
  justify-content: space-between;
}
.c-detail__genre-list span {
  font-size: 14px;
  font-weight: bold;
  color: #e6378d;
  margin-bottom: 5px;
}
.c-detail__genre-list span::after {
  content: " /";
}
.c-detail__genre-list span:last-of-type::after {
  content: "";
}
.c-detail__name {
  font-size: 25px;
  font-weight: bold;
}
.c-detail__shop-name {
  font-size: 25px;
  font-weight: bold;
}
.c-detail__artist-name {
  font-weight: bold;
  font-size: 18px;
}
.c-detail__sns-list {
  display: flex;
  justify-content: flex-end;
}
.c-detail__sns-item {
  margin-left: 5px;
  width: 30px;
  height: 30px;
  background-color: #e6378d;
  border-radius: 50%;
  position: relative;
}
.c-detail__sns-item img {
  width: 16px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.c-detail__main-img img {
  width: 100%;
  max-height: 550px;
  object-fit: contain;
}
.c-detail__main-text {
  font-size: 14px;
}
.c-detail__img-list {
  display: flex;
  justify-content: center;
  gap: 0 27px;
}
.c-detail__img-item {
  width: calc((100% / 4) - 20px);
  height: 200px;
  border: 1px solid #e6e6e6;
  transition: all ease 0.5s;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.c-detail__sub-title {
  font-size: 20px;
  font-weight: bold;
  color: #e6378d;
  padding-left: 14px;
  position: relative;
}
.c-detail__sub-title::before {
  content: "";
  width: 5px;
  height: 26px;
  background-color: #e6378d;
  position: absolute;
  left: 0;
  top: 3px;
}
.c-detail__event-list {
  background-color: #f5f5f5;
  padding: 30px;
}
.c-detail__event-item {
  margin-bottom: 10px;
}
.c-detail__event-date {
  display: inline-block;
  color: #878787;
  margin-right: 10px;
}
.c-detail__event-link {
  color: #000;
  text-decoration: underline;
}
.c-detail__event-item:last-of-type {
  margin-bottom: 0;
}
.c-detail__shop-list {
  display: flex;
  flex-flow: wrap;
  gap: 20px;
}
.c-detail__shop-item {
  width: calc((100% / 2) - 20px);
  border: 1px solid #F5F5F5;
}
.c-detail__shop-item:hover .c-detail__shop-img{
  opacity: 0.8;
}
.c-detail__shop-item:hover .c-detail__shop-link::after{
  transform: translate(4px,-50%) rotate(45deg);
}
.c-detail__shop-link {
  display: flex;
  align-items: center;
  padding: 10px;
  position: relative;
}
.c-detail__shop-link:hover{
  text-decoration: none;
}
.c-detail__shop-link::after {
  content: "";
  width: 10px;
	height: 10px;
	border-top: 2px solid #e6378d;
	border-right: 2px solid #e6378d;
  position: absolute;
  top: 50%;
  right: 14px;
	transform: translate(0,-50%) rotate(45deg);
  transition: all ease 0.5s;
}
.c-detail__shop-img {
  width: 90px;
  height: 90px;
  transition: all ease 0.5s;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.c-detail__shop-content {
  width: calc(100% - 90px);
  padding-left: 15px;
  padding-right: 20px;
}
.c-detail__shop-title {
  font-size: 15px;
  font-weight: bold;
  margin-bottom: 3px;
  color: #000;
  text-decoration: underline;
}
.c-detail__shop-address {
  font-size: 12px;
  font-weight: bold;
  color: #878787;
  line-height: 1.5;
}
.c-detail__artist-list {
  display: flex;
  flex-flow: wrap;
  gap: 20px;
}
.c-detail__artist-item {
  width: calc((100% / 5) - 20px);
}
.c-detail__artist-item:hover .c-detail__artist-img{
  opacity: 0.8;
}
.c-detail__artist-link:hover {
  text-decoration: none;
}
.c-detail__artist-img {
  height: 160px;
  border: 1px solid #e6e6e6;
  transition: all ease 0.5s;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  margin-bottom: 10px;
}
.c-detail__artist-genre span {
  font-size: 12px;
  font-weight: bold;
  color: #e6378d;
  line-height: 1;
}
.c-detail__artist-genre  span::after {
  content: " /";
}
.c-detail__artist-genre  span:last-of-type::after {
  content: "";
}
.c-detail__artist-name {
  font-size: 15px;
  font-weight: bold;
  color: #000;
  text-decoration: none;
}
.c-border {
  width: 100%;
  border-bottom: 1px dashed #acacac;
}

/* utility */
.u-mgb-xs {
  margin-bottom: 1.5rem;
}
.u-mgb-s {
  margin-bottom: 2rem;
}
.u-mgb-m {
  margin-bottom: 3rem;
}
.u-mgb-l {
  margin-bottom: 4rem;
}
.u-mgb-xl {
  margin-bottom: 5rem;
}

.u-mgt-xs {
  margin-top: 1.5rem;
}
.u-mgt-s {
  margin-top: 2rem;
}
.u-mgt-m {
  margin-top: 3rem;
}
.u-mgt-l {
  margin-top: 4rem;
}
.u-mgt-xl {
  margin-top: 5rem;
}

.u-display-sp {
  display: none;
}
.u-display-inline {
  display: inline-block;
}

@media only screen and (max-width: 767px) {
  /* トップページ */
  section.p-top-event {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .page_top .p-top-artist {
    padding-bottom: 0;
  }
  .p-top-event__field-list {
    max-width: 500px;
    gap: 10px;
  }
  .p-top-event__field-item {
    width: calc((100% / 2) - 10px);
  }

  /* トップページ　開催中イベント */
  .p-top-event-today-box {
    flex-flow: wrap;
    justify-content: flex-start;
  }
  .p-top-event-today__item:first-of-type {
  border-left: none;
}
  /* トップページ　新着イベント */
  .event_header {
    flex-flow: column;
  }
  .p-top-event__event-box {
    background-color: unset;
    border: none;
    border-radius: 0;
  }
  /* トップページ　カゴシマ・アーティスト・ライブラリー */
  .p-top-artist__coming-soon-text {
    font-size: 20px;
  }

  /* イベント一覧 */
  .event_search_wrap form input[type="submit"] {
    width: 65px;
  }
  .event_search_wrap form input[type="submit"]:hover {
    background-color: #e6378d;
    padding: 0;
  }
  .event_list_category {
    flex-flow: column;
    align-items: baseline;
  }
  .event_list_genre {
    margin-bottom: 5px;
  }
  .event_search-list {
    padding: 10px 10px 5px;
  }

  /* イベント詳細 */
  .p-event-single__title {
    font-size: 1.3rem;
    letter-spacing: 0.05em;
  }
  .p-event-single__day {
    padding: 2px 8px;
    font-size: 12px;
  }
  .event_list_field--detail {
    position: relative;
  }

  /* アーティスト紹介　ABOUT */
  .p-artist-about {
    padding: 30px 10px 0;
  }
  .p-artist-about h4 {
    font-size: 15px;
    margin-bottom: 30px;
  }
  /* アーティスト紹介　よくある質問 */
  .p-artist-faq {
    padding: 10px 10px 0;
  }
  .p-artist-faq__item-title {
    font-size: 15px;
    padding-left: 45px;
    padding-top: 20px;
    padding-bottom: 20px;
    padding: 20px 45px;
  }
  .p-artist-faq__item-title::before {
    width: 20px;
    height: 3px;
    right: 10px;
  }
  .p-artist-faq__item-title::after {
    width: 20px;
    height: 3px;
    right: 10px;
  }
  .p-artist-faq__item-icon {
    width: 30px;
    height: 30px;
    line-height: 30px;
    font-size: 15px;
    left: 2px;
  }
  .p-artist-faq__item-icon--content {
    top: 15px;
  }
  .p-artist-faq__item-content {
    padding-left: 45px;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  /* component */

  .c-title--artist {
    max-width: 300px;
  }

  /*アーティスト紹介　スペース紹介*/
  .c-detail__sub-content {
    flex-flow: column;
  }
  .c-detail__sub-content .title {
    width: 100%;
    padding-right: 0;
    text-align: left;
    margin-bottom: 5px;
    border-right: none;
    font-weight: bold;
  }
  .c-detail__sub-content .content {
    width: 100%;
    padding-left: 0;
    font-size: 13px;
    line-height: 1.5;
    margin-bottom: 8px;
    padding-bottom: 8px;
    border-bottom: 1px solid #ccc;
  }
  .c-detail__sub-content .content:last-of-type {
    border-bottom: none;
  }
  .c-detail__artist-list {
    gap: 10px;
  }
  .c-detail__artist-item {
    width: calc((100% / 2) - 10px);
  }
  .c-detail__artist-img {
    height: 0;
    padding-top: 100%;
    margin-bottom: 5px;
  }
  .c-detail__artist-genre {
    line-height: 1;
  }
  .c-detail__artist-genre span {
    font-size: 10px;
  }
  .c-detail__artist-name {
    font-size: 13px;
  }
  .c-detail__shop-list {
    gap: 0;
  }
  .c-detail__shop-item {
    width: 100%;
    margin-bottom: 8px;
  }
  .c-detail__shop-item:hover .c-detail__shop-img{
    opacity: 1;
  }
  .c-detail__shop-item:hover .c-detail__shop-link::after{
    transform: translate(0,-50%) rotate(45deg);
  }
  .c-detail__shop-link {
    padding: 8px;
  }
  .c-detail__shop-img {
    height: 50px;
    width: 50px;
  }
  .c-detail__shop-content {
    width: calc(100% - 50px);
    padding-left: 10px;
  }
  .c-detail__shop-title {
    font-size: 13px;
  }
  .c-detail__shop-address {
    display: none;
  }

  /* アーティストリスト */
  .c-list-artist__list {
    gap: 15px 10px;
  }
  .c-list-artist__item {
    width: calc(50% - 5px);
  }
  .c-list-artist__item-img {
    height: 0;
    padding-top: 100%;
    margin-bottom: 5px;
  }
  .c-list-artist__item-genre {
    line-height: 1;
  }
  .c-list-artist__item-genre span {
    font-size: 10px;
  }
  .c-list-artist__item-name {
    font-size: 14px;
  }

  /* 詳細ページ */
  .c-detail {
    padding: 30px 15px;
  }
  .c-detail__title-box {
    padding-bottom: 20px;
    margin-bottom: 30px;
  }
  .c-detail__genre-list span {
    font-size: 12px;
  }
  .c-detail__name {
    font-size: 20px;
  }
  .c-detail__sns-item {
    width: 25px;
    height: 25px;
    margin-left: 3px;
  }
  .c-detail__sns-item img {
    width: 15px;
  }
  .c-detail__img-list {
    flex-flow: wrap;
    gap: 8px;
  }
  .c-detail__img-item {
    height: 0;
    width: calc((100% / 4) - 8px);
    padding-top: 21%;
  }
  .c-detail__event-list {
    padding: 15px;
  }
  .c-detail__event-date {
    font-size: 12px;
    line-height: 1.2;
    display: block;
  }
  .c-detail__sub-title {
    font-size: 20px;
  }

  /* utility */
  .u-mgb-xs {
    margin-bottom: 10px;
  }
  .u-mgb-s {
    margin-bottom: 10px;
  }
  .u-mgb-m {
    margin-bottom: 20px;
  }
  .u-mgb-l {
    margin-bottom: 30px;
  }
  .u-mgb-xl {
    margin-bottom: 40px;
  }

  .u-mgt-xs {
    margin-top: 10px;
  }
  .u-mgt-s {
    margin-top: 10px;
  }
  .u-mgt-m {
    margin-top: 20px;
  }
  .u-mgt-l {
    margin-top: 30px;
  }
  .u-mgt-xl {
    margin-top: 40px;
  }

  .u-display-sp {
    display: block;
  }
  .u-display-pc {
    display: none;
  }
}

/* Contact form 7デフォルトのロードアイコンを非表示 */
div.wpcf7 .ajax-loader {
  display: none !important;
}
.wpcf7-spinner {
  display: none!important;
}
.wpcf7-mail-sent-ok {
  display:none !important;
}