@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Tenor+Sans&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif:wght@400;600;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@200..900&display=swap");
.tenor-sans-regular {
  font-family: "Tenor Sans", sans-serif;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  font-style: normal;
}

/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

html {
  line-height: 1; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

body {
  margin: 0;
}

main {
  display: block;
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

abbr[title] {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
}

button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
  cursor: default;
}

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

option {
  padding: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

[type=number] {
  -moz-appearance: textfield;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable]:focus {
  outline: auto;
}

table {
  border-color: inherit;
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

/**
 * ラベルをブロック要素にする
 * input, select, textareaのlabel要素をブロック要素にします。
 */
:where(label):has(+ :where(textarea, input, select)) {
  display: block;
}

/**
 * textareaのブロックサイズを大きくする
 */
:where(textarea:not([rows])) {
  min-block-size: 6em;
}

/**
 * フォーム要素のフォントスタイルを継承する
 * button, input, select, textareaのfont-familyとfont-sizeは、ページの他の部分と同じにします。
 */
:where(button, input, select, textarea) {
  font-family: inherit;
  font-size: inherit;
}

/**
 * 検索入力のスタイルを正規化する
 * macOSおよびiOSの検索入力の角丸を削除し、背景色を正規化します。
 */
:where([type=search]) {
  -webkit-appearance: textfield;
}

/* iOS only */
@supports (-webkit-touch-callout: none) {
  :where([type=search]) {
    border: 1px solid -apple-system-secondary-label;
    background-color: canvas;
  }
}
/**
 * 表のスタイルを改善する
 * デフォルトのスタイル設定では表が見づらいため、paddingと折り返し境界線を追加します。
 */
:where(table) {
  border-collapse: collapse;
  border: 1px solid;
}

:where(th, td) {
  border: 1px solid;
  padding: 0.25em 0.5em;
}

html {
  font-size: 62.5%;
}

body {
  font-family: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Roboto, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 1.6rem;
  color: #333;
  font-weight: 400;
  margin: 0;
  padding: 0;
}
body.is-fixed {
  overflow: hidden;
}

html[lang=en] body main {
  font-family: "Noto Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

html[lang=zh-Hans] body main {
  font-family: "Noto Sans SC", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

button,
input,
optgroup,
select,
textarea {
  border: 1px solid;
}

button,
[type=button],
[type=reset],
[type=submit] {
  border: 1px solid;
}

img {
  max-width: 100%;
  width: 100%;
  height: auto;
  display: inline-block;
}

a {
  color: #6800a6;
  text-decoration: underline;
}
@media (any-hover: hover) {
  a:hover {
    opacity: 0.8;
    transition: all 0.3s;
  }
}

/* Utilities: display / layout helpers */
.u-hidden {
  display: none !important;
}

.u-inline {
  display: inline !important;
}

.u-block {
  display: block !important;
}

.u-flex {
  display: flex !important;
}

.u-grid {
  display: grid !important;
}

.u-flex-center {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.u-w-100 {
  width: 100% !important;
}

.u-h-100 {
  height: 100% !important;
}

.u-block-tab-lg {
  display: none !important;
}

.u-block-tab-sm {
  display: none !important;
}

.u-inline-tab-sm {
  display: inline !important;
}

.u-flex-tab-sm {
  display: flex !important;
}

.u-grid-tab-sm {
  display: grid !important;
}

@media (max-width: 1079.98px) {
  .u-hidden-tab-lg {
    display: none !important;
  }
  .u-block-tab-lg {
    display: block !important;
  }
}
@media (max-width: 767.98px) {
  .u-hidden-tab-sm {
    display: none !important;
  }
  .u-block-tab-sm {
    display: block !important;
  }
}
/* Utilities: spacing (margin/padding) */
.u-m-0 {
  margin: 0 !important;
}

.u-mt-0 {
  margin-top: 0 !important;
}

.u-mr-0 {
  margin-right: 0 !important;
}

.u-mb-0 {
  margin-bottom: 0 !important;
}

.u-ml-0 {
  margin-left: 0 !important;
}

.u-mb-8 {
  margin-bottom: 8px !important;
}

.u-mb-12 {
  margin-bottom: 12px !important;
}

.u-mb-16 {
  margin-bottom: 16px !important;
}

.u-mb-20 {
  margin-bottom: 20px !important;
}

.u-mb-24 {
  margin-bottom: 24px !important;
}

.u-mb-32 {
  margin-bottom: 32px !important;
}

.u-mb-40 {
  margin-bottom: 40px !important;
}

.u-mb-48 {
  margin-bottom: 48px !important;
}

.u-mb-56 {
  margin-bottom: 56px !important;
}

.u-mb-64 {
  margin-bottom: 64px !important;
}

.u-mt-8 {
  margin-top: 8px !important;
}

.u-mt-12 {
  margin-top: 12px !important;
}

.u-mt-16 {
  margin-top: 16px !important;
}

.u-mt-20 {
  margin-top: 20px !important;
}

.u-mt-24 {
  margin-top: 24px !important;
}

.u-mt-32 {
  margin-top: 32px !important;
}

.u-mt-40 {
  margin-top: 40px !important;
}

.u-mt-48 {
  margin-top: 48px !important;
}

.u-mt-56 {
  margin-top: 56px !important;
}

.u-mt-64 {
  margin-top: 64px !important;
}

.u-p-0 {
  padding: 0 !important;
}

.u-pt-0 {
  padding-top: 0 !important;
}

.u-pr-0 {
  padding-right: 0 !important;
}

.u-pb-0 {
  padding-bottom: 0 !important;
}

.u-pl-0 {
  padding-left: 0 !important;
}

.u-pb-8 {
  padding-bottom: 8px !important;
}

.u-pb-12 {
  padding-bottom: 12px !important;
}

.u-pb-16 {
  padding-bottom: 16px !important;
}

.u-pb-20 {
  padding-bottom: 20px !important;
}

.u-pb-24 {
  padding-bottom: 24px !important;
}

.u-pb-32 {
  padding-bottom: 32px !important;
}

.u-pb-40 {
  padding-bottom: 40px !important;
}

.u-pb-48 {
  padding-bottom: 48px !important;
}

.u-pb-56 {
  padding-bottom: 56px !important;
}

.u-pb-64 {
  padding-bottom: 64px !important;
}

.u-pt-8 {
  padding-top: 8px !important;
}

.u-pt-12 {
  padding-top: 12px !important;
}

.u-pt-16 {
  padding-top: 16px !important;
}

.u-pt-20 {
  padding-top: 20px !important;
}

.u-pt-24 {
  padding-top: 24px !important;
}

.u-pt-32 {
  padding-top: 32px !important;
}

.u-pt-40 {
  padding-top: 40px !important;
}

.u-pt-48 {
  padding-top: 48px !important;
}

.u-pt-56 {
  padding-top: 56px !important;
}

.u-pt-64 {
  padding-top: 64px !important;
}

.u-p-8 {
  padding: 8px !important;
}

.u-p-16 {
  padding: 16px !important;
}

.u-p-24 {
  padding: 24px !important;
}

.u-p-32 {
  padding: 32px !important;
}

/* Utilities: text / alignment / size */
.u-text-left {
  text-align: left !important;
}

.u-text-center {
  text-align: center !important;
}

.u-text-right {
  text-align: right !important;
}

.u-text-small {
  font-size: 0.875rem !important;
}

.u-text-base {
  font-size: 1rem !important;
}

.u-text-large {
  font-size: 1.125rem !important;
}

.u-text-muted {
  color: var(--c-muted) !important;
}

.u-fw-bold {
  font-weight: 700 !important;
}

.u-color-primary {
  color: #6800a6 !important;
}

/* Utilities: a11y — visually hidden but accessible */
.u-visually-hidden {
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  border: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}

/* width */
.w-10 {
  width: 10% !important;
}

.w-15 {
  width: 15% !important;
}

.w-20 {
  width: 20% !important;
}

.w-25 {
  width: 25% !important;
}

.w-30 {
  width: 30% !important;
}

.w-35 {
  width: 35% !important;
}

.w-40 {
  width: 40% !important;
}

.w-45 {
  width: 45% !important;
}

.w-50 {
  width: 50% !important;
}

.w-60 {
  width: 60% !important;
}

.w-70 {
  width: 70% !important;
}

.w-80 {
  width: 80% !important;
}

.w-90 {
  width: 90% !important;
}

.w-100 {
  width: 100% !important;
}

body.is-fixed {
  overflow: hidden;
}

body.admin-bar .l-header {
  top: 32px;
}
body.admin-bar .l-header__toggle {
  top: 50px;
}
body.admin-bar .l-header__menu {
  top: 102px;
}

@media (max-width: 782px) {
  #wpadminbar {
    position: fixed;
    inset: 0;
  }
  body.admin-bar .l-header {
    top: 46px;
  }
  body.admin-bar .l-header__toggle {
    top: 62px;
  }
  body.admin-bar .l-header__menu {
    top: 115px;
  }
}
.l-header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background: #fff;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  z-index: 100;
}
.l-header a {
  text-decoration: none;
  color: #333;
}
.l-header #header-inner {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  gap: clamp(16px, 3vw, 32px);
  padding-right: 0;
  align-items: center;
}
@media (max-width: 1190px) {
  .l-header #header-inner {
    gap: 15px;
  }
}
.l-header__logo {
  flex: 0 0 auto;
  margin: 0;
  max-width: clamp(140px, 16vw, 230px);
  margin-left: 16px;
}
@media (max-width: 1190px) {
  .l-header__logo {
    max-width: clamp(170px, 12vw, 230px);
  }
}
.l-header__logo img {
  width: 100%;
  height: auto;
  display: block;
}
.l-header__menu {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 15px;
}
@media (max-width: 1190px) {
  .l-header__menu {
    gap: 5px;
  }
}
.l-header__cta li {
  height: 50%;
}
@media (max-width: 1079.98px) {
  .l-header__cta li {
    height: 100%;
  }
}
.l-header__cta .c-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 100%;
  padding: 10px;
  padding-left: 30px;
  padding-right: 5px;
  font-weight: 500;
  font-size: 1.3rem;
  line-height: 1.2;
  border: 1px solid transparent;
  transition: filter 0.25s ease;
  background: #a800a7;
  color: #fff !important;
  text-align: center;
  text-decoration: none;
}
@media (max-width: 1190px) {
  .l-header__cta .c-cta {
    width: 105px;
    font-size: 1.2rem;
    padding-left: 25px;
  }
}
@media (any-hover: hover) {
  .l-header__cta .c-cta:hover {
    filter: brightness(0.95);
  }
}
.l-header__cta .c-cta--primary {
  background: #6800a6;
  position: relative;
}
.l-header__cta .c-cta--primary::before {
  content: "";
  width: 20px;
  height: 20px;
  display: block;
  background-image: url(/wordpress/wp-content/themes/musashino-music/assets/img/common/i-siryou.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 10px;
}
@media (max-width: 1190px) {
  .l-header__cta .c-cta--primary::before {
    width: 16px;
    height: 16px;
    left: 8px;
  }
}
.l-header__cta .c-cta--secondary {
  position: relative;
}
.l-header__cta .c-cta--secondary::before {
  content: "";
  width: 20px;
  height: 20px;
  display: block;
  background-image: url(/wordpress/wp-content/themes/musashino-music/assets/img/common/i-web.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 10px;
}
@media (max-width: 1190px) {
  .l-header__cta .c-cta--secondary::before {
    width: 16px;
    height: 16px;
    left: 8px;
  }
}

.l-header__toggle {
  display: none;
}

.l-nav {
  padding: 10px 15px 10px 0;
  padding-right: 0;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}
.l-nav__bar {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 16px;
  align-items: center;
}
@media (max-width: 1190px) {
  .l-nav__bar {
    gap: 12px;
  }
}
.l-nav__purpose {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 14px;
  font-size: 1.2rem;
}
.l-nav ul[aria-label=公式SNS] {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 8px;
}
.l-nav ul[aria-label=公式SNS] a {
  display: block;
  width: 24px;
  height: 24px;
}
@media (max-width: 1190px) {
  .l-nav ul[aria-label=公式SNS] a {
    width: 20px;
    height: 20px;
  }
}
.l-nav {
  /* 言語 */
}
.l-nav__lang {
  line-height: 1.5;
  font-size: 1.5rem;
}
@media (max-width: 1190px) {
  .l-nav__lang {
    font-size: 1.2rem;
  }
}
.l-nav__lang::after {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-style: solid;
  border-color: #333;
  border-width: 2px 2px 0 0;
  vertical-align: middle;
  transform: rotate(135deg);
}
.l-nav__lang select {
  border: none;
}
.l-nav {
  /* 検索（丸い入力） */
}
.l-nav__search form {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  align-items: center;
  gap: 4px;
  position: relative;
}
.l-nav__search .c-search__input,
.l-nav__search input {
  width: clamp(100px, 18vw, 140px);
  padding: 2px 5px 2px;
  border: 1px solid;
  border-radius: 999px;
  outline: none;
  font-size: 1.2rem;
}
.l-nav__search .c-search__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  transition: opacity 0.25s ease;
  position: absolute;
  right: 10px;
}
.l-nav__search .c-search__button img {
  width: 16px;
  height: 16px;
  display: block;
}
@media (any-hover: hover) {
  .l-nav__search .c-search__button:hover {
    opacity: 0.7;
  }
}
.l-nav ul[aria-label=グローバルナビゲーション] {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  padding-block: 5px;
}
.l-nav ul[aria-label=グローバルナビゲーション] li {
  position: relative;
  padding-inline: 16px;
}
.l-nav ul[aria-label=グローバルナビゲーション] li:first-child {
  padding-left: 0px;
}
.l-nav ul[aria-label=グローバルナビゲーション] li:last-child {
  padding-right: 0px;
}
.l-nav ul[aria-label=グローバルナビゲーション] li + li a::before {
  content: "";
  position: absolute;
  width: 1px;
  height: 13px;
  top: 3px;
  left: 0;
  background-color: #cccccc;
}
.l-nav ul[aria-label=グローバルナビゲーション] li a {
  font-weight: bold;
}
.l-nav__submenu {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: nowrap;
  font-size: 1.3rem;
}
.l-nav__submenu li {
  position: relative;
  padding-inline: 10px;
}
.l-nav__submenu li:first-child {
  padding-left: 0px;
}
.l-nav__submenu li:last-child {
  padding-right: 0px;
}
.l-nav__submenu li + li a::before {
  content: "";
  position: absolute;
  width: 1px;
  height: 13px;
  top: 1px;
  left: 0;
  background-color: #cccccc;
}

/* =========================================
   SP header（tab-lg 以下）
   -----------------------------------------
   - ヘッダーを1行バー＋全画面ドロワーに
   - ハンバーガーで .l-header__menu を開閉
========================================= */
@media (max-width: 1079.98px) {
  .l-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background-color: #fff;
    height: 70px;
  }
  .l-header #header-inner {
    height: 100%;
  }
  .l-header__logo {
    max-width: 200px;
    width: 100%;
  }
  .l-header {
    /* ナビ本体（ドロワー） */
  }
  .l-header__menu {
    position: fixed;
    top: 70px;
    left: 0;
    width: 100%;
    height: calc(100% - 70px);
    background-color: #fff;
    display: none;
    flex-direction: column;
    overflow-y: auto;
  }
  .l-header__menu.is-open {
    display: flex;
  }
  .l-header nav {
    order: 2;
  }
  .l-header .l-nav__bar {
    order: 3;
    padding: 20px 15px;
  }
  .l-header {
    /* CTAを縦並びの大きなボタンに */
  }
  .l-header__cta {
    order: 1;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 8px;
    padding: 20px 15px;
  }
  .l-header__cta li {
    width: 100%;
    height: 100%;
  }
  .l-header__cta .c-cta {
    display: block;
    width: 100%;
    padding: 5px 16px;
    min-height: 50px;
    text-align: center;
    font-weight: bold;
    font-size: 1.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .l-header__cta .c-cta--secondary {
    background: #a800a7;
    color: #fff;
  }
  .l-header__cta .c-cta--secondary::before {
    transform: translateY(0);
    position: static;
    margin-right: 10px;
  }
  .l-header__cta .c-cta:not(.c-cta--secondary) {
    background-color: #6800a6;
    color: #6800a6;
    border: 1px solid #6800a6;
  }
  .l-header__cta .c-cta:not(.c-cta--secondary)::before {
    transform: translateY(0);
    position: static;
    margin-right: 10px;
  }
  /* ハンバーガーボタン */
  .l-header__toggle {
    position: fixed;
    top: 18px;
    right: 16px;
    z-index: 30;
    width: 32px;
    height: 32px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    cursor: pointer;
  }
  .l-header__toggle span {
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background-color: #333;
    transition: transform 0.25s ease, opacity 0.25s ease;
  }
  .l-header__toggle.open span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }
  .l-header__toggle.open span:nth-child(2) {
    opacity: 0;
  }
  .l-header__toggle.open span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }
  /* ナビゲーションを縦方向レイアウトに */
  .l-nav {
    padding: 0;
    gap: 0;
    align-items: stretch;
  }
  .l-nav__bar {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 24px;
  }
  .l-nav__purpose {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 0;
    font-size: 1.6rem;
    font-weight: 500;
  }
  .l-nav__purpose a::before {
    content: "";
    width: 15px;
    margin-right: 10px;
    vertical-align: middle;
    display: inline-block;
    height: 3px;
    background-color: #6800a6;
  }
  .l-nav__purpose a {
    display: block;
    padding: 10px 4px;
  }
  .l-nav__lang {
    position: relative;
  }
  .l-nav__lang select {
    border: 1px solid #333;
    padding: 10px;
    width: 100%;
  }
  .l-nav__lang::after {
    position: absolute;
    right: 15px;
    width: 12px;
    height: 12px;
    top: 50%;
    transform: translateY(-65%) rotate(135deg);
  }
  .l-nav__search form {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    align-items: center;
    gap: 8px;
  }
  .l-nav__search .c-search__input,
  .l-nav__search input {
    border: 1px solid #333;
    padding: 10px;
    width: 100%;
    border-radius: 4px;
  }
  .l-nav__search .c-search__button {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
  }
  .l-nav__search .c-search__button img {
    width: 20px;
    height: 20px;
    display: block;
  }
  .l-nav ul[aria-label=公式SNS] {
    justify-content: center;
    gap: 15px;
    width: 100%;
  }
  .l-nav ul[aria-label=公式SNS] a {
    width: 32px;
    height: 32px;
  }
  .l-nav ul[aria-label=公式SNS] {
    margin-bottom: 40px;
  }
  .l-nav ul[aria-label=グローバルナビゲーション] {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 0;
    padding-block: 0;
    margin-top: 8px;
  }
  .l-nav ul[aria-label=グローバルナビゲーション] li {
    padding-inline: 0;
    border-bottom: 1px solid #CBCBCB;
  }
  .l-nav ul[aria-label=グローバルナビゲーション] li + li a::before {
    content: none;
  }
  .l-nav ul[aria-label=グローバルナビゲーション] li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 15px;
    width: 100%;
  }
  .l-nav ul[aria-label=グローバルナビゲーション] li a::after {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-style: solid;
    border-color: #333;
    border-width: 2px 2px 0 0;
    vertical-align: middle;
    transform: rotate(45deg);
    border-color: #6800a6;
  }
  .l-nav__submenu {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 0px;
    margin-top: 0px;
  }
  .l-nav__submenu li + li a::before {
    content: none;
  }
  .l-nav__submenu li {
    padding: 0;
    border-bottom: 1px solid #CBCBCB;
  }
  .l-nav__submenu a {
    padding: 20px 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 1.6rem;
    font-weight: bold;
    width: 100%;
    position: relative;
  }
  .l-nav__submenu a::after {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-style: solid;
    border-color: #333;
    border-width: 2px 2px 0 0;
    vertical-align: middle;
    transform: rotate(45deg);
    border-color: #6800a6;
  }
}
.l-footer {
  background: #060606;
  color: rgba(255, 255, 255, 0.9);
  font-size: 1.4rem;
  line-height: 1.7;
  padding: clamp(32px, 4vw, 56px) clamp(16px, 4vw, 24px) clamp(20px, 4vw, 32px);
}
@media (max-width: 767.98px) {
  .l-footer {
    padding: 40px 20px;
  }
}
.l-footer a {
  color: inherit;
  text-decoration: none;
}
@media (any-hover: hover) {
  .l-footer a:hover {
    color: #c9b3ff;
  }
}
.l-footer__main {
  max-width: 1180px;
  margin: 0 auto clamp(24px, 4vw, 40px);
  display: flex;
  justify-content: space-between;
  gap: clamp(24px, 4vw, 48px);
}
@media (max-width: 1079.98px) {
  .l-footer__main {
    justify-items: center;
    text-align: center;
    flex-direction: column;
  }
}
.l-footer__brand {
  display: grid;
  gap: 16px;
}
.l-footer__logo img {
  max-width: 220px;
  height: auto;
  filter: brightness(1);
}
.l-footer__address {
  margin: 0;
  font-style: normal;
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
}
.l-footer__nav {
  display: flex;
  gap: 15px 30px;
  font-size: 1.3rem;
}
@media (max-width: 12000px) {
  .l-footer__nav {
    font-size: 1.2rem;
  }
}
@media (max-width: 1079.98px) {
  .l-footer__nav {
    flex-direction: column;
    font-size: 1.4rem;
  }
}
.l-footer__column {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (max-width: 1079.98px) {
  .l-footer__column {
    text-align: center;
  }
}
@media (max-width: 767.98px) {
  .l-footer__column {
    text-align: left;
  }
}
.l-footer__bottom {
  max-width: 1180px;
  margin: 0 auto;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  padding-top: clamp(12px, 2vw, 18px);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.65);
}
@media (max-width: 1079.98px) {
  .l-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}
.l-footer__legal {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
}
@media (max-width: 1079.98px) {
  .l-footer__legal {
    flex-direction: column;
    order: 1;
  }
}
.l-footer__legal li {
  white-space: nowrap;
}
.l-footer__legal a {
  color: inherit;
  font-size: 12px;
}
@media (max-width: 1079.98px) {
  .l-footer__copy {
    order: 2;
    text-align: center;
    width: 100%;
  }
}

#page-top {
  position: fixed;
  bottom: 15px;
  right: 15px;
  width: 40px;
  height: 40px;
  background-color: #fff;
  border: 1px solid #6800a6;
  border-radius: 50%;
  z-index: 30;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}
@media (max-width: 767.98px) {
  #page-top {
    bottom: 75px;
  }
}
@media (any-hover: hover) {
  #page-top:hover {
    transition: all 0.3s;
    opacity: 0.8;
  }
}
#page-top a {
  display: block;
  margin-top: 6px;
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  border-style: solid;
  border-color: #6800a6;
  border-width: 2px 2px 0 0;
  vertical-align: middle;
  transform: rotate(-45deg);
}

.l-main {
  padding-top: 100px;
}

.l-section {
  padding: 80px 20px;
}
@media (max-width: 1079.98px) {
  .l-section {
    padding: 60px 20px;
  }
}

.l-container {
  max-width: 1000px;
  margin: 0 auto;
  width: 100%;
}

.top .l-container {
  max-width: 1100px;
}

@media (max-width: 1079.98px) {
  .l-main {
    padding-top: 70px;
  }
}
.c-post-section .p-archive__heading.wp-block-heading {
  margin-top: 60px !important;
}

.p-archive__empty {
  margin-bottom: 60px;
}
@media (max-width: 1079.98px) {
  .p-archive__item {
    border-bottom: 1px solid #CBCBCB;
  }
}
.p-archive__row, .p-archive__link {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 1.5rem 0;
  text-decoration: none;
  color: inherit;
}
.p-archive__row--s, .p-archive__link--s {
  background-color: #6800a6;
}
.p-archive__date {
  color: #333;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  display: block;
  flex-shrink: 0;
  font-feature-settings: "palt";
  font-size: 1.4rem;
}
.p-archive__title {
  -webkit-text-decoration: underline transparent;
          text-decoration: underline transparent;
  line-height: 1.4;
  font-size: 1.4rem;
  font-feature-settings: "palt";
}
.p-archive__row:hover .p-archive__title, .p-archive__row:focus-visible .p-archive__title, .p-archive__link:hover .p-archive__title, .p-archive__link:focus-visible .p-archive__title {
  text-decoration-color: currentColor;
}
@media (max-width: 767.98px) {
  .p-archive__row, .p-archive__link {
    flex-wrap: wrap;
    gap: 10px 20px;
  }
  .p-archive__date {
    font-size: 1.2rem;
  }
  .p-archive__title {
    line-height: 1.4;
    font-size: 1.3rem;
    width: 100%;
  }
}
.p-archive__more {
  text-align: center;
  margin-top: 40px;
}
.p-archive__more a {
  padding: 15px 20px;
  color: #fff;
}
.p-archive__more--single {
  padding-bottom: 40px;
  padding-top: 20px;
}
.p-archive__more--single a {
  padding: 8px 20px;
  font-weight: bold;
  background: #6800a6;
  text-align: center;
  text-decoration: none;
  display: inline-block;
}
@media (max-width: 767.98px) {
  .p-archive__more a {
    font-size: 1.5rem;
  }
}

.p-archive__information, .p-archive__calendar {
  margin-top: 80px;
}
@media (max-width: 1079.98px) {
  .p-archive__information, .p-archive__calendar {
    margin-top: 40px;
  }
}

.p-archive__tabs.p-archive__tabs--event {
  margin-top: 40px;
  margin-bottom: 20px;
}

.p-archive__result-head {
  margin-top: 60px;
}

.p-archive__more--s {
  margin-top: 20px;
  margin-bottom: 60px;
}

.p-archive__more-link--s {
  background-color: #6800a6;
  padding: 10px 20px !important;
  text-decoration: none;
  display: inline-block;
}

.post-type-archive-concert .p-archive__information {
  margin-top: 0;
}

.top .p-archive {
  padding-bottom: 0px;
}
.top .p-archive .l-container {
  padding-bottom: 80px;
  border-bottom: 1px dashed #CBCBCB;
}
.top .p-archive + .p-events {
  padding-bottom: 0px;
}
.top .p-archive + .p-events .l-container {
  padding-bottom: 80px;
  border-bottom: 1px dashed #CBCBCB;
}

.p-archive__tabs {
  margin-bottom: 40px;
}

.p-news-single__title {
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.4;
  font-feature-settings: "palt";
  margin-bottom: 40px;
}
.p-news-single__meta {
  margin-bottom: 30px;
}

.c-top-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  padding: 0.8em 1.4em;
  font-family: "Tenor Sans", serif;
  font-size: 2rem;
  max-width: 280px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
.c-top-button::after {
  content: "";
  width: 20px;
  display: block;
  height: 10px;
  background-image: url(/wordpress/wp-content/themes/musashino-music/assets/img/top/i-top-arrow-w.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 14px;
}
.c-top-button--grad {
  background: linear-gradient(90deg, #a800a7, #6800a6);
  color: #fff;
}
.c-top-button--grad:hover {
  filter: brightness(1.05);
}
.c-top-button--grad {
  box-shadow: 0 0px 10px rgba(51, 0, 180, 0.262745098), 0 0px 12px rgba(51, 0, 180, 0.262745098);
}
.c-top-button {
  /* サイズ（必要なら） */
}
.c-top-button--sm {
  padding: 0.45em 1.1em;
  font-size: 0.95em;
}
.c-top-button--lg {
  padding: 0.8em 1.8em;
  font-size: 1.05em;
}

.calendar-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  padding: 0.8em 1em;
  font-size: 1.4rem;
  max-width: 280px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  color: #333;
  border: 1px solid #CBCBCB;
}
.calendar-button::before {
  content: "";
  width: 20px;
  height: 20px;
  margin-right: 10px;
  display: inline-block;
  background-image: url(/wordpress/wp-content/themes/musashino-music/assets/img/top/i-calendar.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* ベース */
.c-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-feature-settings: "palt";
  gap: 0.35em;
  padding: 0.1em 0.6em;
  min-width: 150px;
  border: 1px solid #CBCBCB;
  font-size: 1.3rem;
  line-height: 1.6;
  color: #6800a6;
  background: #fff;
  text-decoration: none;
  white-space: nowrap;
}
@media (max-width: 1079.98px) {
  .c-category {
    font-size: 1.2rem;
    min-width: 100px;
  }
}

/* カテゴリ別 */
.c-category--info {
  border-color: #6800a6;
  color: #6800a6;
}

.c-category--admissions {
  border-color: #1e5bd8;
  color: #1e5bd8;
}

.c-category--admissions-event {
  border-color: #39bff2;
  color: #39bff2;
}

.c-category--event {
  border-color: #f28c28;
  color: #f28c28;
}

.c-category--info-competition {
  border-color: #c9a227;
  color: #c9a227;
}

.c-category--media {
  border-color: #2e9d57;
  color: #2e9d57;
}

.c-category--info-students {
  border-color: #1aa6a6;
  color: #1aa6a6;
}

.c-category--info-alumni {
  border-color: #111111;
  color: #111111;
}

.c-category--default {
  border-color: #CBCBCB;
  color: #6800a6;
}

.post-type-archive-exam-event .c-category {
  min-width: 170px;
}

.c-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
}
.c-tabs__btn {
  display: inline-block;
  padding: 6px 14px;
  text-decoration: none;
  color: #333;
  background-color: #fff;
  border: 1px solid #CBCBCB;
  border-radius: 4px;
  transition: all 0.2s;
  font-size: 1.4rem;
  line-height: 1.5;
  cursor: pointer;
  font-family: inherit;
}
.c-tabs__btn[type=button], .c-tabs__btn:not([href]) {
  border: 1px solid #CBCBCB;
}
.c-tabs__btn:hover, .c-tabs__btn:focus-visible {
  background-color: #f4f4f4;
  border-color: #6800a6;
  color: #6800a6;
}
.c-tabs__btn.is-active {
  background-color: #6800a6;
  border-color: #6800a6;
  color: #fff;
}
.c-tabs__btn.is-active:hover, .c-tabs__btn.is-active:focus-visible {
  background-color: #a800a7;
  border-color: #a800a7;
}
@media (max-width: 767.98px) {
  .c-tabs {
    gap: 6px;
  }
  .c-tabs__btn {
    padding: 6px 16px;
    font-size: 1.3rem;
  }
}

.p-archive__important + .p-archive__header {
  margin-top: 40px;
}
.p-archive__important + .p-archive__tabs {
  margin-top: 40px;
}
@media (max-width: 767.98px) {
  .p-archive__important + .p-archive__tabs {
    margin-top: 20px;
  }
}
.p-archive__important__head {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
  gap: 12px;
  color: #6800a6;
  position: relative;
}
@media (max-width: 767.98px) {
  .p-archive__important__head {
    flex-direction: column;
    align-items: flex-start;
  }
}
.p-archive__important__label {
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
  padding-right: 24px;
  position: relative;
  padding-left: 36px;
}
.p-archive__important__label::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: url("/wordpress/wp-content/themes/musashino-music/assets/img/common/i-important.svg") no-repeat center/contain;
  flex-shrink: 0;
}
.p-archive__important__item {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: nowrap;
  gap: 12px;
  position: relative;
  padding-left: 24px;
}
@media (max-width: 767.98px) {
  .p-archive__important__item {
    padding-left: 0px;
  }
}
.p-archive__important__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 100%;
  background-color: #6800a6;
}
@media (max-width: 767.98px) {
  .p-archive__important__item::before {
    content: none;
  }
}
.p-archive__important__link {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
  gap: 8px;
  text-decoration: none;
  color: #6800a6;
  transition: opacity 0.2s;
}
@media (max-width: 767.98px) {
  .p-archive__important__link {
    flex-direction: column;
    align-items: flex-start;
    font-size: 1.4rem;
    line-height: 1.4;
  }
}
.p-archive__important__link:hover, .p-archive__important__link:focus-visible {
  opacity: 0.8;
}
.p-archive__important__date {
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.top .p-archive__important {
  padding-top: 100px;
}
@media (min-width: 1500px) {
  .top .p-archive__important {
    max-width: 1600px;
    width: 100%;
    margin: 0 auto;
  }
}
@media (max-width: 1079.98px) {
  .top .p-archive__important {
    padding-top: 70px;
  }
}
.top .p-archive__important__head {
  margin: 20px;
}
.top .p-archive__important + .p-mv {
  padding-top: 0px;
}

/* ----------------------------------------
 * SP固定メニュー（スマホのみ）
 * ------------------------------------- */
.c-sp-fix {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 80;
  /* iPhone等のセーフエリア対応 */
  padding-bottom: env(safe-area-inset-bottom);
  /* 背景（必要に応じて調整） */
  background: #6800a6;
  box-shadow: 0 -6px 18px rgba(0, 0, 0, 0.18);
  /* スマホだけ表示 */
}
@media (min-width: 1080px) {
  .c-sp-fix {
    display: none;
  }
}
.c-sp-fix__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin: 0;
  padding: 0;
  list-style: none;
}
.c-sp-fix__item {
  margin: 0;
  /* 区切り線 */
}
.c-sp-fix__item:not(:last-child) {
  border-right: 1px solid rgba(255, 255, 255, 0.35);
}
.c-sp-fix__item:nth-child(2), .c-sp-fix__item:nth-child(4) {
  background: #a800a7;
}
.c-sp-fix__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-feature-settings: "palt";
  min-height: 54px;
  padding: 3px 2px;
  color: #fff;
  text-decoration: none;
  text-align: center;
  font-size: 12px;
  line-height: 1.1;
  -webkit-tap-highlight-color: rgba(255, 255, 255, 0.2);
}
.c-sp-fix__link:focus-visible {
  outline: 3px solid rgba(255, 255, 255, 0.65);
  outline-offset: -3px;
}
.c-sp-fix__link {
  /* アイコン */
}
.c-sp-fix__link::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  margin-bottom: 4px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.c-sp-fix__link {
  /* 文字が長い場合の保険 */
}
@media (max-width: 360px) {
  .c-sp-fix__link {
    font-size: 11px;
  }
}
.c-sp-fix {
  /* ----------------------------------------
   * アイコン
   * ------------------------------------- */
}
.c-sp-fix__link--req::before {
  background-image: url("/wordpress/wp-content/themes/musashino-music/assets/img/common/i-bottom-1.svg");
}
.c-sp-fix__link--web::before {
  background-image: url("/wordpress/wp-content/themes/musashino-music/assets/img/common/i-bottom-2.svg");
}
.c-sp-fix__link--acc::before {
  background-image: url("/wordpress/wp-content/themes/musashino-music/assets/img/common/i-bottom-3.svg");
}
.c-sp-fix__link--con::before {
  background-image: url("/wordpress/wp-content/themes/musashino-music/assets/img/common/i-bottom-4.svg");
}

/* ----------------------------------------
 * 固定メニューで本文が隠れないようにする
 * - 全ページで表示する想定のため body に下余白を付与
 * - トップだけにしたいなら body.home 等で限定してOK
 * ------------------------------------- */
@media (max-width: 767px) {
  body {
    padding-bottom: calc(76px + env(safe-area-inset-bottom));
  }
}/*# sourceMappingURL=style.css.map */