@charset "UTF-8";
/* ------------------------
  カレンダーページ リセット
------------------------ */
body main #calendar html,
body main #calendar body {
  height: 100%;
}
body main #calendar ul,
body main #calendar ol,
body main #calendar p {
  margin: 0;
  padding: 0;
  list-style: none;
}
body main #calendar pre,
body main #calendar textarea {
  overflow: auto;
}
body main #calendar template {
  display: none;
}
body main #calendar details,
body main #calendar main,
body main #calendar summary {
  display: block;
}
body main #calendar input[type=number] {
  width: auto;
}
body main #calendar input[type=search] {
  -webkit-appearance: textfield;
}
body main #calendar input[type=search]::-webkit-search-cancel-button,
body main #calendar input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}
body main #calendar progress {
  display: inline-block;
}
body main #calendar small {
  font-size: 75%;
}
body main #calendar sub,
body main #calendar sup {
  position: relative;
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
}
body main #calendar sup {
  top: -0.5em;
}
body main #calendar sub {
  bottom: -0.25em;
}
body main #calendar textarea {
  resize: vertical;
}
body main #calendar audio,
body main #calendar canvas,
body main #calendar iframe,
body main #calendar img,
body main #calendar svg,
body main #calendar video {
  vertical-align: middle;
}
body main #calendar audio:not([controls]) {
  display: none;
}
body main #calendar img {
  border: 0;
  max-width: 100%;
  height: auto;
}
body main #calendar button,
body main #calendar input,
body main #calendar select,
body main #calendar textarea {
  min-height: 1.5em;
  color: inherit;
  font-family: inherit;
  font-weight: inherit;
  font-style: inherit;
}
body main #calendar button {
  overflow: visible;
}
body main #calendar button,
body main #calendar select {
  text-transform: none;
}
body main #calendar input {
  line-height: normal;
}
body main #calendar button,
body main #calendar html input[type=button],
body main #calendar input[type=reset],
body main #calendar input[type=submit] {
  border-style: none;
  cursor: pointer;
  background-color: transparent;

  -webkit-appearance: button;
}
body main #calendar button[disabled],
body main #calendar html input[disabled] {
  cursor: default;
}
body main #calendar button::-moz-focus-inner,
body main #calendar input::-moz-focus-inner {
  padding: 0;
  border: 0;
}
body main #calendar code,
body main #calendar kbd,
body main #calendar pre,
body main #calendar samp {
  font-family: monospace;
}
body main #calendar ol,
body main #calendar ul {
  list-style: none;
}
body main #calendar select {
     -moz-appearance: none;
  -webkit-appearance: none;
}
body main #calendar table {
  border-spacing: 0;
  border-collapse: collapse;
}
body main #calendar fieldset {
  border: 0;
}

/* ------------------------
  カレンダーページ Base Settings
------------------------ */
html {
  font-size: inherit;
}

@media screen and (max-width: 1540px) {
  main .breadcrumb {
    padding-inline: 6.25vw;
  }
}
@media (max-width: 767.98px) {
  main .breadcrumb {
    margin-inline: 0;
    padding-inline: 20px;
  }
}
main .container {
  padding-inline: 0;
}
@media (max-width: 767.98px) {
  main .container {
    margin-inline: 0;
    padding-inline: 0;
  }
}
@media (max-width: 767.98px) {
  main .contents__sub {
    margin-inline: 0;
    padding-inline: 0;
  }
}
@media (max-width: 767.98px) {
  main .archiveRefer {
    margin-inline: 0;
  }
}
main .view_timer.grayout {
  display: none;
}
@media screen and (max-width: 1540px) {
  main .bge-ckeditor {
    padding-inline: 6.25vw;
  }
}
@media (max-width: 767.98px) {
  main .bge-ckeditor {
    padding-inline: 20px;
  }
}

#calendar {
  /* === テキスト強調色_END === */
  background-color: #fff;
  word-break: normal;
  color: #000;
  font-family: "Noto Sans JP", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  line-height: 1.5;
  /* === 月ごとの色指定_START === */

  --orbis-calendar-theme-bg-color-darker: #c4928a;
  --orbis-calendar-theme-bg-color-default: #dfc3bf;
  --orbis-calendar-theme-bg-color-lighter: #f1e7e5;
  /* === 月ごとの色指定_END === */
  /* === テキスト強調色_START === */
  --orbis-calendar-theme-bg-color-emphasis: #eb5145;
  --orbis-calendar-theme-bg-color-emphasis-thin: #ef857d;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  overflow-wrap: anywhere;
  line-break: strict;
  text-spacing-trim: trim-start;
}
#calendar p {
  font-weight: 400;
}
#calendar a {
  text-decoration: underline;
  color: #000;
}
#calendar a:visited {
  color: #000;
}
#calendar a:hover {
  text-decoration: none;
  color: #000;
}
#calendar a:active {
  text-decoration: none;
  color: #000;
}
#calendar a[href^="tel:"]:hover {
  color: #000;
}
@media (min-width: 768px) {
  #calendar a[href^="tel:"] {
    cursor: text;
    text-decoration: none;
  }
}

@media (min-width: 768px) {
  .l-page#calendar .l-page__container {
    display: grid;
    width: 100%;
    background-color: #f2f4f5;
  }
}
@media screen and (min-width: 768px) and (min-width: 1440px) {
  .l-page#calendar .l-page__container {
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }
}
.l-page#calendar .l-page__credit {
  font-size: 0.875rem;
  font-weight: 400;

  padding-block: 1.25rem;
}
@media screen and (max-width: 1540px) {
  .l-page#calendar .l-page__credit {
    padding-inline: 6.25vw;
  }
}
@media (max-width: 767.98px) {
  .l-page#calendar .l-page__credit {
    padding-inline: 20px;
  }
}
.l-page#calendar .l-page__mainArea {
  overflow-x: clip;
  position: relative;
  width: 100%;
  background-color: #fff;

  padding-block: 1.4375rem 0;
}
@media (min-width: 768px) {
  .l-page#calendar .l-page__mainArea {
    width: 410px;
    box-shadow: 0 0.25rem 0.5rem color-mix(in srgb, #000, transparent 91%);

    justify-self: center;
    padding-block: 1.875rem 7.5rem;
  }
}
.l-page#calendar .l-page__mainArea::before {
  content: "";
  display: block;
  position: absolute;
  bottom: -0.625rem;
  left: 0;
  width: 100%;
  height: 0.625rem;
  background-color: #fff;
}
.l-page#calendar .l-cont__inner {
  padding-inline: 1.21875rem;
}
@media (min-width: 768px) {
  .l-page#calendar .l-cont__inner {
    padding-inline: 1.625rem;
  }
}
.l-page#calendar .l-section {
  position: relative;
  z-index: 1;

  --_section-space: 5rem;
  padding-block: 2.5rem var(--_section-space);
}
.l-page#calendar .l-section::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  border-radius: 3rem;
  background-color: #fff;
  pointer-events: none;

  inset: 0 0 calc(-1 * var(--_section-space)) 0;
}
.l-page#calendar .l-section.l-section--noSpace {
  -webkit-margin-after: 5rem;
          margin-block-end: 5rem;
}
.l-page#calendar .l-section.l-section--noSpace::before {
  inset: 0;
}
.l-page#calendar .l-section.l-section--bgDarker::before {
  background-color: var(--orbis-calendar-theme-bg-color-darker);
}
.l-page#calendar .l-section.l-section--bgDefault::before {
  background-color: var(--orbis-calendar-theme-bg-color-default);
}
.l-page#calendar .l-section.l-section--bgLighter::before {
  background-color: var(--orbis-calendar-theme-bg-color-lighter);
}

/*
* calendar-common.css
*
*/
/* --------------------------------
  カレンダーページ共通
-------------------------------- */
@-webkit-keyframes modalShow {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes modalShow {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes modalClose {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes modalClose {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.c-modal {
  display: none;
  position: fixed;
  z-index: 1030;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  color: #000;
  font-family: "Noto Sans JP", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;

  --_modal-block-space: 5vh;
}
@media (min-width: 768px) {
  .c-modal {
    --_modal-block-space: 2.8125rem;
  }
}
.c-modal.is-open {
  display: block;
}
.c-modal[aria-hidden=true] {
  -webkit-animation: modalClose 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
          animation: modalClose 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.c-modal[aria-hidden=false] {
  -webkit-animation: modalShow 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
          animation: modalShow 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.c-modal .c-timeTag {
  display: inline-flex;
  align-items: center;
  margin: 0.5rem auto 0;
  padding: 0.25rem 1rem 0.3125rem;
  border: solid 0.0625rem #e6e6e6;
  border-radius: 999px;
  min-height: 1.4375rem;
  background-color: #fff;

  --_gap-date: 1rem;
  gap: var(--_gap-date);
}
.c-modal .c-timeTag__date {
  display: flex;
  position: relative;
  font-size: 1rem;
  font-weight: 400;

  gap: 0.25rem;
}
.c-modal .c-timeTag__date > time {
  font-weight: 600;
}
.c-modal .c-timeTag__date + .c-timeTag__date::before {
  content: "~";
  display: block;
  position: absolute;
  top: 50%;
  left: calc(-1 * var(--_gap-date) / 2);

  translate: -50% -50%;
}
.c-modal .c-btn {
  text-align: center;
}
.c-modal .c-btn > a,
.c-modal .c-btn > button {
  display: inline-grid;
  position: relative;
  border-radius: 999px;
  min-width: 10.8125rem;
  min-height: 3.75rem;
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  background-color: #000;
  text-decoration: none;
  color: #fff;
  font-size: 1rem;
  font-weight: 600;

  place-content: center;
  padding-inline: 3.125rem 4.0625rem;
}
.c-modal .c-btn > a[download] .c-btnIcon::before,
.c-modal .c-btn > button[download] .c-btnIcon::before {
  width: 0.875rem;
  height: 1.125rem;

  -webkit-mask-image: url(/contents/feature/images/calendar/icon_download.svg);

          mask-image: url(/contents/feature/images/calendar/icon_download.svg);
}
@media (hover: hover) and (pointer: fine) {
  .c-modal .c-btn > a:where(:-webkit-any-link, :enabled, summary):hover, .c-modal .c-btn > button:where(:-webkit-any-link, :enabled, summary):hover {
    opacity: 1;
    -webkit-transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
  .c-modal .c-btn > a:where(:-moz-any-link, :enabled, summary):hover, .c-modal .c-btn > button:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 1;
    -moz-transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
  .c-modal .c-btn > a:where(:any-link, :enabled, summary):hover,
  .c-modal .c-btn > button:where(:any-link, :enabled, summary):hover {
    opacity: 1;
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
}
@media (hover: none) and (any-pointer: coarse) {
  .c-modal .c-btn > a.is-touched,
  .c-modal .c-btn > button.is-touched {
    opacity: 1;
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
}
.c-modal .c-btn.grayout {
  display: block !important;
}
.c-modal .c-btn.grayout > a,
.c-modal .c-btn.grayout > button {
  cursor: not-allowed;
  background-color: #aaa;
  pointer-events: none;
  color: color-mix(in srgb, #fff 70%, transparent 30%);
}
.c-modal .c-btn.grayout > a .c-btnIcon,
.c-modal .c-btn.grayout > button .c-btnIcon {
  opacity: 0.8;
}
.c-modal .c-btn__remarks {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 0.75rem;
}
.c-modal .c-btn__remarks.c-btn__remarks--emphasis {
  color: var(--orbis-calendar-theme-bg-color-emphasis);
}
.c-modal .c-btn__remarksText {
  display: block;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  text-align: center;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.4;
}
.c-modal .c-btn__remarksIcon {
  display: block;
  position: relative;
  width: 0.5625rem;
  height: 1.0625rem;
}
.c-modal .c-btn__remarksIcon::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 999px;
  width: 1.2022115039rem;
  height: 0.0625rem;
  background-color: currentColor;

  translate: -50% -50%;
}
.c-modal .c-btn__remarksIcon.c-btn__remarksIcon--before {
  -webkit-margin-end: 0.5rem;
          margin-inline-end: 0.5rem;
}
.c-modal .c-btn__remarksIcon.c-btn__remarksIcon--before::before {
  rotate: 56deg;
}
.c-modal .c-btn__remarksIcon.c-btn__remarksIcon--after {
  -webkit-margin-start: 0.5rem;
          margin-inline-start: 0.5rem;
}
.c-modal .c-btn__remarksIcon.c-btn__remarksIcon--after::before {
  rotate: -56deg;
}
.c-modal .c-btnIcon {
  display: inline-grid;
  position: absolute;
  top: 50%;
  right: 1rem;
  border: solid 0.0625rem currentColor;
  border-radius: 50%;
  width: var(--_icon-size);
  height: var(--_icon-size);

  --_icon-size: 1.75rem;
  translate: 0 -50%;
}
.c-modal .c-btnIcon::before {
  content: "";
  display: grid;
  margin: auto;
  width: 0.9375rem;
  height: 0.5625rem;
  background-color: currentColor;

  grid-area: 1/-1;
  place-content: center;
  -webkit-mask-image: url(/contents/feature/images/calendar/icon_arrow_d.svg);
          mask-image: url(/contents/feature/images/calendar/icon_arrow_d.svg);
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
}
.c-modal .c-link > a {
  position: relative;
  text-align: left;
  font-size: 1rem;
  font-weight: 600;

  gap: 0.25rem;
}
.c-modal .c-link > a::after {
  content: "";
  display: inline-block;
  position: relative;
  margin-left: 0.25rem;
  width: 1.75rem;
  height: 1.75rem;
  background-image: url(/contents/feature/images/calendar/icon_link.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% auto;

  translate: 0 0.5rem;
}
.c-modal .c-link > a[target=_blank]::after {
  background-image: url(/contents/feature/images/calendar/icon_link_blank.svg);
}
.c-modal .c-link.c-link--center {
  text-align: center;
}
.c-modal .c-modal__overlay {
  display: block;
  width: 100%;
  height: 100%;
  background-color: color-mix(in srgb, #000 60%, transparent 40%);
}
.c-modal .c-modal__container {
  display: block;
  overflow: hidden auto;
  padding: var(--_modal-block-space) 1.25rem;
  width: calc(100% - 2.5rem);
  height: 100%;
  max-height: calc(100% - var(--_modal-block-space) * 2);
  text-align: center;
}
@media (min-width: 768px) {
  .c-modal .c-modal__container {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--_modal-block-space) 1.625rem;
    width: calc(100% - 3.25rem);
  }
}
.c-modal .c-modal__containerInner {
  align-self: center;
  height: -webkit-max-content;
  height: -moz-max-content;
  height: max-content;

  margin-block: 0.625rem 3.125rem;
}
.c-modal .c-modal__cont {
  align-self: center;
  position: relative;
  padding: 2rem 0;
  border-radius: 2rem;
  width: 100%;
  max-width: 28rem;
  background-color: #fff;
}
.c-modal .c-modal__cont .os-scrollbar {
  --os-size: 7px;
  --os-handle-border-radius: 999px;
  --os-track-border-radius: 999px;
  --os-handle-bg-hover: $calendar-color-btn;
  --os-handle-bg-active: $calendar-color-btn;
  --os-track-bg-hover: $calendar-bg-gray-02;
  --os-track-bg-active: $calendar-bg-gray-02;
}
.c-modal .c-modal__cont .os-scrollbar.os-scrollbar-vertical {
  -webkit-margin-end: 1rem;
          margin-inline-end: 1rem;
}
.c-modal .c-modal__cont .os-scrollbar.os-scrollbar-horizontal {
  display: none;
}
.c-modal .c-modal__cont .os-scrollbar-track {
  border-radius: 999px;
  background-color: #d9d9d9;
}
.c-modal .c-modal__cont .os-scrollbar-handle {
  max-height: 150px;
  background-color: #2a2b2c;
}
.c-modal .c-modal__title {
  margin: 0;
  text-align: center;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.4;
}
.c-modal .c-modal__header {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin-bottom: 0.75rem;

  padding-inline: 2rem;
}
.c-modal .c-modal__timeTag {
  padding: 0.0625rem 1rem 0.125rem;
}
.c-modal .c-modal__contInner {
  overflow-y: auto;
  max-height: 57.14vh;

  margin-inline: 0.25rem;
  padding-inline: 2rem;
}
@media (min-width: 768px) {
  .c-modal .c-modal__contInner {
    max-height: 26rem;
  }
}
.c-modal .c-modal__contBody {
  margin-top: 0.75rem;
  text-align: left;
}
.c-modal .c-modal__btn {
  margin-top: 1rem;
  min-width: 11.25rem;
}
.c-modal .c-modal__btn > a,
.c-modal .c-modal__btn > button {
  min-width: calc(11.25rem - 1.875rem * 2);
  min-height: 2.375rem;
  font-size: 0.875rem;
  font-weight: 600;

  padding-inline: 1.875rem 2.1875rem;
}
.c-modal .c-modal__btn .c-btnIcon {
  right: 0.5625rem;

  --_icon-size: 1.125rem;
}
.c-modal .c-modal__btn .c-btnIcon::before {
  width: 0.5625rem;
  height: 0.375rem;
}
.c-modal .c-modal__img {
  overflow: hidden;
  border-radius: 1.5rem;
}
.c-modal .c-modal__img img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
.c-modal .c-modal__text {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.6;
}
.c-modal .c-modal__text + .c-modal__text {
  margin-top: 0.5em;
}
.c-modal .c-modal__closeBtn {
  display: grid;
  position: absolute;
  bottom: calc(-0.75rem - var(--_icon-size));
  left: 50%;
  border: solid 0.0625rem #e6e6e6;
  border-radius: 50%;
  width: var(--_icon-size);
  height: var(--_icon-size);
  cursor: pointer;
  background-color: #fff;

  --_icon-size: 2.875rem;
  place-content: center;
  translate: -50% 0;
}
.c-modal .c-modal__closeBtn::before,
.c-modal .c-modal__closeBtn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 999px;
  width: 1.4375rem;
  height: 0.125rem;
  background-color: #000;

  translate: -50% -50%;
}
.c-modal .c-modal__closeBtn::before {
  rotate: 45deg;
}
.c-modal .c-modal__closeBtn::after {
  rotate: -45deg;
}
@media (hover: hover) and (pointer: fine) {
  .c-modal .c-modal__closeBtn:where(:-webkit-any-link, :enabled, summary):hover {
    background-color: color-mix(in srgb, #000 10%, #fff 90%);
  }
  .c-modal .c-modal__closeBtn:where(:-moz-any-link, :enabled, summary):hover {
    background-color: color-mix(in srgb, #000 10%, #fff 90%);
  }
  .c-modal .c-modal__closeBtn:where(:any-link, :enabled, summary):hover {
    background-color: color-mix(in srgb, #000 10%, #fff 90%);
  }
}
@media (hover: none) and (any-pointer: coarse) {
  .c-modal .c-modal__closeBtn.is-touched {
    background-color: color-mix(in srgb, #000 10%, #fff 90%);
  }
}

.l-page#calendar {
  /* --- カレンダーページ共通ここから --- */
}
.l-page#calendar .c-icon {
  display: grid;
  position: relative;
  border-radius: 50%;
  width: var(--_icon-size);
  height: var(--_icon-size);
  background-color: var(--_color);

  --_icon-size: 1.75rem;
  --_color: #fff;
  --_path-color: #000;
  place-content: center;
}
.l-page#calendar .c-heading {
  display: flex;
  align-items: center;
  flex-direction: column-reverse;

  gap: 0.625rem;
}
.l-page#calendar .c-heading__text {
  font-size: 1rem;
  font-weight: 500;
}
.l-page#calendar .c-heading__textEn {
  font-family: optima-lt-pro, sans-serif;
  font-size: 3rem;
  font-weight: 400;
  line-height: 1.3;
}
.l-page#calendar .c-heading__textEn::before,
.l-page#calendar .c-heading__textEn::after {
  content: "";
  display: block;

  inline-size: 0;
  block-size: 1px;
}
.l-page#calendar .c-heading__textEn::before {
  -webkit-margin-after: calc((1 - 1.3) * 0.5em);
          margin-block-end: calc((1 - 1.3) * 0.5em);
}
.l-page#calendar .c-heading__textEn::after {
  -webkit-margin-before: calc((1 - 1.3) * 0.5em);
          margin-block-start: calc((1 - 1.3) * 0.5em);
}
.l-page#calendar .c-headingLv3 {
  text-align: center;
  font-size: 1.5rem;
  font-size: 500;
  line-height: 1.4;
}
.l-page#calendar .c-headingLv3__remarks {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 0.75rem;
}
.l-page#calendar .c-headingLv3__remarksText {
  display: block;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  text-align: center;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.4;
}
.l-page#calendar .c-headingLv3__remarksIcon {
  display: block;
  position: relative;
  width: 0.5625rem;
  height: 1.0625rem;
}
.l-page#calendar .c-headingLv3__remarksIcon::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 999px;
  width: 1.2022115039rem;
  height: 0.0625rem;
  background-color: currentColor;

  translate: -50% -50%;
}
.l-page#calendar .c-headingLv3__remarksIcon.c-headingLv3__remarksIcon--before {
  -webkit-margin-end: 0.5rem;
          margin-inline-end: 0.5rem;
}
.l-page#calendar .c-headingLv3__remarksIcon.c-headingLv3__remarksIcon--before::before {
  rotate: 56deg;
}
.l-page#calendar .c-headingLv3__remarksIcon.c-headingLv3__remarksIcon--after {
  -webkit-margin-start: 0.5rem;
          margin-inline-start: 0.5rem;
}
.l-page#calendar .c-headingLv3__remarksIcon.c-headingLv3__remarksIcon--after::before {
  rotate: -56deg;
}
.l-page#calendar .c-headingLv5 {
  text-align: center;
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.4;
}
.l-page#calendar .c-timeTag {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 1rem 0.3125rem;
  border: solid 0.0625rem #e6e6e6;
  border-radius: 999px;
  min-height: 1.625rem;
  background-color: #fff;

  --_gap-date: 1rem;
  gap: var(--_gap-date);
}
.l-page#calendar .c-timeTag__date {
  display: flex;
  position: relative;
  font-size: 1rem;
  font-weight: 400;

  gap: 0.25rem;
}
.l-page#calendar .c-timeTag__date > time {
  font-weight: 600;
}
.l-page#calendar .c-timeTag__date + .c-timeTag__date::before {
  content: "~";
  display: block;
  position: absolute;
  top: 50%;
  left: calc(-1 * var(--_gap-date) / 2);

  translate: -50% -50%;
}
.l-page#calendar .c-btn {
  text-align: center;
}
.l-page#calendar .c-btn > a,
.l-page#calendar .c-btn > button {
  display: inline-grid;
  position: relative;
  border-radius: 999px;
  min-width: 10.8125rem;
  min-height: 3.75rem;
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  background-color: #000;
  text-decoration: none;
  color: #fff;
  font-size: 1rem;
  font-weight: 600;

  place-content: center;
  padding-inline: 3.125rem 4.0625rem;
}
.l-page#calendar .c-btn > a[download] .c-btnIcon::before,
.l-page#calendar .c-btn > button[download] .c-btnIcon::before {
  width: 0.875rem;
  height: 1.125rem;

  -webkit-mask-image: url(/contents/feature/images/calendar/icon_download.svg);

          mask-image: url(/contents/feature/images/calendar/icon_download.svg);
}
@media (hover: hover) and (pointer: fine) {
  .l-page#calendar .c-btn > a:where(:-webkit-any-link, :enabled, summary):hover, .l-page#calendar .c-btn > button:where(:-webkit-any-link, :enabled, summary):hover {
    opacity: 1;
    -webkit-transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
  .l-page#calendar .c-btn > a:where(:-moz-any-link, :enabled, summary):hover, .l-page#calendar .c-btn > button:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 1;
    -moz-transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
  .l-page#calendar .c-btn > a:where(:any-link, :enabled, summary):hover,
  .l-page#calendar .c-btn > button:where(:any-link, :enabled, summary):hover {
    opacity: 1;
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
}
@media (hover: none) and (any-pointer: coarse) {
  .l-page#calendar .c-btn > a.is-touched,
  .l-page#calendar .c-btn > button.is-touched {
    opacity: 1;
    transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
    background-color: #646464;
  }
}
.l-page#calendar .c-btn.grayout {
  display: block !important;
}
.l-page#calendar .c-btn.grayout > a,
.l-page#calendar .c-btn.grayout > button {
  cursor: not-allowed;
  background-color: #aaa;
  pointer-events: none;
  color: color-mix(in srgb, #fff 70%, transparent 30%);
}
.l-page#calendar .c-btn.grayout > a .c-btnIcon,
.l-page#calendar .c-btn.grayout > button .c-btnIcon {
  opacity: 0.8;
}
.l-page#calendar .c-btn__remarks {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 0.75rem;
}
.l-page#calendar .c-btn__remarks.c-btn__remarks--emphasis {
  color: var(--orbis-calendar-theme-bg-color-emphasis);
}
.l-page#calendar .c-btn__remarksText {
  display: block;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  text-align: center;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.4;
}
.l-page#calendar .c-btn__remarksIcon {
  display: block;
  position: relative;
  width: 0.5625rem;
  height: 1.0625rem;
}
.l-page#calendar .c-btn__remarksIcon::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 999px;
  width: 1.2022115039rem;
  height: 0.0625rem;
  background-color: currentColor;

  translate: -50% -50%;
}
.l-page#calendar .c-btn__remarksIcon.c-btn__remarksIcon--before {
  -webkit-margin-end: 0.5rem;
          margin-inline-end: 0.5rem;
}
.l-page#calendar .c-btn__remarksIcon.c-btn__remarksIcon--before::before {
  rotate: 56deg;
}
.l-page#calendar .c-btn__remarksIcon.c-btn__remarksIcon--after {
  -webkit-margin-start: 0.5rem;
          margin-inline-start: 0.5rem;
}
.l-page#calendar .c-btn__remarksIcon.c-btn__remarksIcon--after::before {
  rotate: -56deg;
}
.l-page#calendar .c-btnIcon {
  display: inline-grid;
  position: absolute;
  top: 50%;
  right: 1rem;
  border: solid 0.0625rem currentColor;
  border-radius: 50%;
  width: var(--_icon-size);
  height: var(--_icon-size);

  --_icon-size: 1.75rem;
  translate: 0 -50%;
}
.l-page#calendar .c-btnIcon::before {
  content: "";
  display: grid;
  margin: auto;
  width: 0.9375rem;
  height: 0.5625rem;
  background-color: currentColor;

  grid-area: 1/-1;
  place-content: center;
  -webkit-mask-image: url(/contents/feature/images/calendar/icon_arrow_d.svg);
          mask-image: url(/contents/feature/images/calendar/icon_arrow_d.svg);
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: 100% auto;
          mask-size: 100% auto;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
}
.l-page#calendar .c-link > a {
  position: relative;
  text-align: left;
  font-size: 1rem;
  font-weight: 600;

  gap: 0.25rem;
}
.l-page#calendar .c-link > a::after {
  content: "";
  display: inline-block;
  position: relative;
  margin-left: 0.25rem;
  width: 1.75rem;
  height: 1.75rem;
  background-image: url(/contents/feature/images/calendar/icon_link.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% auto;

  translate: 0 0.5rem;
}
.l-page#calendar .c-link > a[target=_blank]::after {
  background-image: url(/contents/feature/images/calendar/icon_link_blank.svg);
}
.l-page#calendar .c-link.c-link--center {
  text-align: center;
}
.l-page#calendar .c-accordion {
  overflow: hidden;
}
.l-page#calendar .c-accordion:not(:last-of-type) {
  border-bottom: solid 0.0625rem #aaa;
}
.l-page#calendar .c-accordion:first-of-type {
  border-bottom: solid 0.0625rem #aaa;
}
.l-page#calendar .c-accordion .c-link > a::after {
  width: 1.375rem;
  height: 1.375rem;

  translate: 0 0.25rem;
}
.l-page#calendar .c-accordionBtn {
  display: grid;
  align-items: center;
  position: relative;
  width: 100%;
  cursor: pointer;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  text-align: left;

  --_icon-size: 0.5rem;
  --_icon-margin: 0.625rem;
  grid-template: ". icon"/1fr calc(var(--_icon-size) + var(--_icon-margin) * 2);
  gap: 0 0.5rem;
  padding-block: 1rem;
}
@media (hover: hover) and (pointer: fine) {
  .l-page#calendar .c-accordionBtn:where(:-webkit-any-link, :enabled, summary):hover {
    opacity: 0.65;
    -webkit-transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  .l-page#calendar .c-accordionBtn:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.65;
    -moz-transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
    transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  .l-page#calendar .c-accordionBtn:where(:any-link, :enabled, summary):hover {
    opacity: 0.65;
    transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}
@media (hover: none) and (any-pointer: coarse) {
  .l-page#calendar .c-accordionBtn.is-touched {
    opacity: 0.65;
    transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}
.l-page#calendar .c-accordionBtn[aria-expanded=true] .c-accordionIcon::after {
  transition: rotate 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);

  rotate: 0deg;
}
.l-page#calendar .c-accordionBtn__text {
  display: flex;
  flex-direction: column;
  font-size: 1rem;
}
.l-page#calendar .c-accordionBtn__text .c-accordionBtn__textSm {
  font-size: 0.875rem;
  font-weight: 400;
}
.l-page#calendar .c-accordionIcon {
  --_icon-size: 1.75rem;
}
.l-page#calendar .c-accordionIcon::before,
.l-page#calendar .c-accordionIcon::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  border-radius: 999px;
  width: 0.875rem;
  height: 0.125rem;
  background-color: #000;

  translate: -50% -50%;
}
.l-page#calendar .c-accordionIcon::after {
  transition: rotate 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);

  rotate: 90deg;
}
.l-page#calendar .c-accordionPanel {
  display: grid;
  transition: grid-template-rows 0.36s cubic-bezier(0.39, 0.575, 0.565, 1);

  grid-template-rows: 0fr;
  will-change: grid-template-rows;
}
.l-page#calendar .c-accordionPanel[aria-hidden=false] {
  transition: grid-template-rows 0.46s cubic-bezier(0.39, 0.575, 0.565, 1);

  grid-template-rows: 1fr;
}
.l-page#calendar .c-accordionPanel__inner {
  overflow: hidden;
}
.l-page#calendar .c-accordionPanel__inner > *:last-child {
  margin-bottom: 1.375rem;
}

/* --- カレンダーページ共通ここまで --- */