/* calendar_style.css */

/* :root 変数（色・寸法など共通化できる部分を集約）*/
:root {
    /* 全体レイアウト */
    --cal-border-color: #d0eaff;
    --cal-shadow: 0 0 6px rgba(0, 0, 0, 0.08);

    /* ヘッダ */
    --cal-header-color: #2a3f5f;

    /* ナビボタン */
    --cal-nav-bg: #e0f0ff;
    --cal-nav-border: #fff;
    --cal-nav-bg-hover: #cde7ff;
    --cal-nav-color: #2a4d77;

    /* 曜日行 */
    --cal-week-bg: #eef6ff;
    --cal-week-border: #bcd5f0;

    /* セル */
    --cal-cell-border: #dbe7f6;
    --cal-cell-hover: #fff9d6;

    /* 当月外 */
    --cal-other-bg: #f0f0f0;
    --cal-other-text: #aaaaaa;

    /* 祝日 */
    --cal-holiday-bg: #ffeef0;
    --cal-holiday-text: #d02030;

    /* 月曜（トグルON） */
    --cal-mon-bg: #ffffe5;
    --cal-mon-text: #c07000;

    /* 土曜・日曜 */
    --cal-sat-text: #8bb7dd;
    --cal-sun-text: #d02020;
    --cal-sat-bg: #e5ffff;
    /* --cal-sun-bg: #d0a0a0; */
    /* 祝日と同じにする */

    /* 今日 */
    --cal-today-border: #ff944a;

    /* ミニカレンダー */
    --cal-mini-bg: #f8fbff;
    --cal-mini-border: #d8e7f7;
    --cal-mini-cell-border: #e2efff;
    --cal-mini-other-bg: #f1f1f1;
    --cal-mini-other-text: #b5b5b5;
    --cal-mini-holiday-bg: #ffeaea;
    --cal-mini-holiday-text: #e03030;
}

/* ============================================================
   カレンダー全体の枠
   ============================================================ */
.cal-wrapper {
    width: 100%;
    max-width: 900px;
    margin: 0 auto;
    padding: 12px;
    background: #ffffff;
    border-radius: 10px;
    border: 2px solid var(--cal-border-color);
    box-shadow: var(--cal-shadow);
}

/* ============================================================
   カレンダータイトル（YYYY年 MM月）
   ============================================================ */
.cal-header {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 12px;
}

.cal-header-text {
    font-size: 1.8rem;
    font-weight: bold;
    color: var(--cal-header-color);
    margin: 0 10px;
}

/* ============================================================
   移動ボタン（前月 / 次月）
   ============================================================ */
.cal-nav-btn {
    background: var(--cal-nav-bg);
    border: 1px solid var(--cal-nav-border);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 0.9rem;
    cursor: pointer;
    color: var(--cal-nav-color);
    transition: background 0.2s;
}

.cal-nav-btn:hover {
    background: var(--cal-nav-bg-hover);
}

/* トグル部分（祝日背景ON/OFF、週開始位置）*/
.cal-toggles {
    display: flex;
    gap: 14px;
    justify-content: center;
    margin-bottom: 14px;
}


.cal-toggle-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.9rem;
    color: var(--cal-header-color);
}

.cal-toggle-item2 {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 10pt;
    color: var(--cal-header-color);
}

.cal-toggle-checkbox {
    transform: scale(1.3);
}

/* ============================================================
   カレンダー本体テーブル（6×7）
   ============================================================ */
.cal-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

.cal-table th {
    text-align: center;
    padding: 6px 0;
    background: var(--cal-week-bg);
    color: var(--cal-header-color);
    border-bottom: 2px solid var(--cal-week-border);
}

.cal-table td {
    height: 70px;
    text-align: left;
    vertical-align: top;
    padding: 4px;
    border: 1px solid var(--cal-cell-border);
    font-size: 1rem;
    font-weight: bold;
    transition: background 0.15s;
    position: relative;
}

/* ============================================================
   当月外（日付が灰色）
   ============================================================ */
.cal-other-month {
    background: var(--cal-other-bg) !important;
    color: var(--cal-other-text) !important;
}

/* ============================================================
   祝日背景（トグル ON のとき）
   ============================================================ */
.cal-holiday-bg {
    background: var(--cal-holiday-bg) !important;
    color: var(--cal-holiday-text) !important;
    font-weight: bold;
}

/* ============================================================
   月曜だけ色変化（トグルON）
   ============================================================ */
.cal-mon {
    background: var(--cal-mon-bg) !important;
    color: var(--cal-mon-text) !important;
    font-weight: bold;
}

/* ============================================================
   土曜／日曜
   ============================================================ */
.cal-sat {
    color: var(--cal-sat-text) !important;
    background: var(--cal-sat-bg) !important;
}

.cal-sun {
    color: var(--cal-sun-text) !important;
    background: var(--cal-holiday-bg) !important;
}

/* ============================================================
   今日の日付（強調）
   ============================================================ */
.cal-today {
    border: 2px solid var(--cal-today-border) !important;
    box-shadow: inset 0 0 6px rgba(255, 140, 70, 0.4);
}

/* ============================================================
   ホバー（視認性UP）
   ============================================================ */
.cal-table td:hover:not(.cal-other-month),
.cal-holiday-bg:hover:not(.cal-other-month),
.cal-sat:hover:not(.cal-other-month),
.cal-sun:hover:not(.cal-other-month),
.cal-mon:hover:not(.cal-other-month) {
    background: var(--cal-cell-hover) !important;
}

/* ============================================================
   ミニカレンダー（前後月表示）
   ============================================================ */
.cal-mini-wrapper {
    margin-top: 4px;
    padding: 4px 4px;
    /* ←左右の余白を削減 */
    background: var(--cal-mini-bg);
    border-radius: 6px;
    border: 1px solid var(--cal-mini-border);
    width: 115px;
    /* ←※数字2桁＋セル7列がピッタリになる黄金値 */

}

.cal-mini-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

.cal-mini-table td {
    width: 14px;
    /* ←2桁数字が入る最小幅 */
    padding: 1px 0;
    /* ←上下左右の余白削減 */
    text-align: center;
    border: 1px solid var(--cal-mini-cell-border);
    font-size: 8.5pt;
    /* ←コンパクト化 */
}

/* 当月外（灰） */
.cal-mini-other {
    background: var(--cal-mini-other-bg);
    color: var(--cal-mini-other-text);
}

/* 祝日（薄赤） */
.cal-mini-holiday {
    background: var(--cal-mini-holiday-bg);
    color: var(--cal-mini-holiday-text);
}

.holidayname {
    font-size: 7pt;
    padding: 0;
}

.plusbtn {
    font-size: 9pt;
    font-weight: normal;
    background: aqua;
    border-width: 2px;
    border-radius: 10px;
    padding-top: 2px;
    padding-bottom: 2px;
    padding-left: 5px;
    padding-right: 5px;
    color: #0077cc;
    position: absolute;
    top: 2px;
    right: 4px;
    /* pointer-events: none; */
    /* hover干渉防止 */
}

.btnpluscommit {
    font-size: 9pt;
    font-weight: normal;
    background: lightgreen;
    border-width: 2px;
    border-radius: 10px;
    color: #0077cc;
}

.plus-floating {
    position: absolute;
    background: #ffffff;
    border: 1px solid #aaa;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    padding: 6px 8px;
    display: flex;
    gap: 8px;
    z-index: 9999;
    transition: opacity 0.2s;
}

.plus-floating.hidden {
    display: none;
    opacity: 0;
}

.plus-option {
    font-size: 9pt;
    font-weight: normal;
    background: aqua;
    border-width: 2px;
    border-radius: 10px;
    padding-top: 2px;
    padding-bottom: 2px;
    padding-left: 5px;
    padding-right: 5px;
    color: #0077cc;
}

.plus-option:hover {
    background: #dceeff;
}

/* 祝日上のSや+マークを見やすく */
.cal-holiday-bg .plusbtn {
    color: #cc0033;
}

.cal-holiday-name {
    font-size: 10px;
    color: #d33;
    margin-top: -2px;
}

/* ============================================================
   上部ナビゲーション3分割レイアウト
   ============================================================ */
.cal-header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    margin-bottom: 10px;
}

/* 左の「前月」・右の「翌月」 */
.cal-side-box {
    width: 80px;
    /* 必要に応じて調整 */
    text-align: center;
    font-size: 1rem;
    padding: 8px 0;
}

/* 中央は自動で広がる */
.cal-center-box {
    flex: 1;
}

.url-anim {
    padding: 0 10px;
    background-image: linear-gradient(to right,
            rgba(0, 0, 0, 0) 50%,
            var(--hover-color, #333333) 50%);
    background-position: 0 0;
    background-size: 200% auto;
    transition: .3s;
    text-decoration: none;
}

.url-anim:hover {
    background-position: -100% 0;
    color: #fff !important;
}

.cal-shift-mark {
    color: black;
    font-size: 12px;
    margin-left: 4px;
    padding: 1px 3px;
    border: 1px solid #aaa;
    border-radius: 4px;
    cursor: pointer;
    background: #f3f3f3;
}

.cal-shift-mark:hover {
    background: #e0e0ff;
}

#plus-floating {
    position: absolute;
    /* JS が left/top を動的セット */
    z-index: 9999;
    /* 最前面 */
    background: #fff;
    border: 1px solid #ccc;
    padding: 6px;
    border-radius: 6px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

#plus-floating.hidden {
    display: none;
}

/* ============================================================
   スマホレイアウト
   ============================================================ */
@media (max-width: 480px) {
    .cal-header-text {
        font-size: 1.3rem;
    }

    .cal-nav-btn {
        padding: 4px 8px;
        font-size: 0.8rem;
    }

    .cal-table td {
        height: 50px;
        font-size: 0.9rem;
    }
}