:root {
    --bg-color: white;
    --text-color: black;
    --fc-today-bg-color: white;
    --saturday-text-color: black;
    --sunday-text-color: black;
    --holiday-text-color: black;
    --saturday-bg-color: #f0f0ff;
    --sunday-bg-color: #fff0f0;
    --holiday-bg-color: #fff0f0;
}

/* カレンダー */
#calendar.fc {
    max-width: 220px;
    margin: 0 auto;
}

/* カレンダー上部ツールバー */
#calendar.fc .fc-toolbar.fc-header-toolbar {
    margin-bottom: 2px;
}

/* 年月タイトル */
#calendar.fc .fc-toolbar-title {
    font-size: 1.1em;
}

/* 日イベント(非表示) */
#calendar.fc .fc-daygrid-body-natural .fc-daygrid-day-events {
    display: none;
}

/* テキストのアンダーバー(非表示) */
#calendar.fc .fc-scrollgrid-sync-inner a,
#calendar.fc .fc-daygrid-day-top a {
    text-decoration: none;
}

/* 日付テキスト */
#calendar.fc .fc-daygrid-day-top {
    display: flex;
    justify-content: center;
}

/* 日付カーソル(矢印固定) */
#calendar.fc .fc-daygrid-day {
    cursor: default;
}

/* 土曜日(背景色) */
#calendar.fc .fc-day.fc-day-sat {
    background-color: var(--saturday-bg-color);
}

/* 土曜日(文字色) */
#calendar.fc .fc-day.fc-day-sat a {
    --text-color: var(--saturday-text-color);
}

/* 日曜日(背景色) */
#calendar.fc .fc-day.fc-day-sun {
    background-color: var(--sunday-bg-color);
}

/* 日曜日(文字色) */
#calendar.fc .fc-day.fc-day-sun a {
    --text-color: var(--sunday-text-color);
}

/* 祝日(背景色) */
#calendar.fc .fc-day.holiday {
    background-color: var(--holiday-bg-color);
}

/* 祝日(文字色) */
#calendar.fc .fc-day.holiday a {
    --text-color: var(--holiday-text-color);
}

/* 文字色 */
#calendar.fc .fc-day a {
    color: var(--text-color);
}

/* 休業日に斜線追加 */
/*
div#calendar.fc .fc-day:has(.classification_1):before {
    display: block;
    content: "";
    border: 0;
    border-top: solid 1px #000000;
    width: 44px;
    height: 0;
    transform: rotate(-49deg);
    transform-origin: 35px 17px;
}
@media (min-width:768px) and (max-width:1279px) {
    div#calendar.fc .fc-day:has(.classification_1):before {
        width: 40px;
        transform: rotate(-55deg);
        transform-origin: 31px 17px;
    }
}
*/

/* 背景色 */
#calendar.fc .fc-daygrid-day:has(.fc-event) {
    background-color: var(--bg-color);
}

/* 最終行(翌月の日付のみの週) */
#calendar.fc table.fc-scrollgrid-sync-table tr:has(td.fc-day-sun.fc-day-disabled ~ td.fc-day-sat.fc-day-disabled),
#calendar.fc table.fc-scrollgrid-sync-table tr:has(td.fc-day-sun.fc-day-other ~ td.fc-day-sat.fc-day-other) {
    display: none;
}

/* カレンダー説明 */
#calendar-description {
    max-width: 220px;
    margin: 0 auto;
    margin-top: 0.3em;
}

/* カレンダー説明(文字) */
#calendar-description div:before {
    content: '';
    display: inline-block;
    width: 30px;
    height: 0.8em;
    margin-right: 0.5em;
    background-color: var(--bg-color);
}

/* ツールチップ */
/* オーバーフローの解除 */
#calendar.fc .fc-scroller-harness {
    overflow: visible;
}

/* 表示位置を修正 */
#calendar.fc .fc-daygrid-day-number {
    z-index: auto;
}

/* ツールチップ全体設定 */
#calendar.fc .fc-daygrid-day:has(.fc-event) .fc-daygrid-day-number::before,
#calendar.fc .fc-daygrid-day:has(.fc-event) .fc-daygrid-day-number::after {
    position: absolute;
    display: none;
}

/* 吹き出しのひげ部分 */
#calendar.fc .fc-daygrid-day:has(.fc-event) .fc-daygrid-day-number::before {
    content: "";
    border: 8px solid transparent;
    border-bottom-color: #000;
    top: 16px;
}

/* 吹き出しの本体 */
#calendar.fc .fc-daygrid-day:has(.fc-event) .fc-daygrid-day-number::after {
    content: attr(data-title);
    padding: 4px 7px;
    background: #000;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    color: #fff;
    top: 31px;
    left: 0;
    z-index: 5;
    min-width: 30px;
    white-space: pre;
}

/* マウスホバーしたときの設定 */
#calendar.fc .fc-daygrid-day:has(.fc-event) .fc-daygrid-day-number:hover::before,
#calendar.fc .fc-daygrid-day:has(.fc-event) .fc-daygrid-day-number:hover::after {
    display: block;
}
