/* ==================================================
   図書室関連ページ共通デザイン
   読み込み対象：library-letter / newbook
   JavaScript・画像・外部通信なし
   ================================================== */
/* 図書室関連ページで使用する共通色 */
:root {
    --library-blue: #1f5fae;
    --library-blue-dark: #174b8a;
    --library-blue-light: #edf5ff;
    --library-border: #d7e3f1;
    --library-text: #26384d;
    --library-muted: #62758b;
}

.library-page {
    --library-blue: #1f5fae;
    --library-blue-dark: #174b8a;
    --library-blue-light: #edf5ff;
    --library-border: #d7e3f1;
    --library-text: #26384d;
    --library-muted: #62758b;

    width: 100%;
    color: var(--library-text);
    font-size: 16px;
    line-height: 1.85;
}

.library-page,
.library-page * {
    box-sizing: border-box;
}


/* ==================================================
   ページ上部の説明
   ================================================== */

.library-page-intro {
    margin: 0 0 24px !important;
    padding: 22px 26px !important;

    background: var(--library-blue-light);
    border: 1px solid var(--library-border);
    border-left: 6px solid var(--library-blue);
    border-radius: 10px;
}

.library-page-intro-label {
    margin: 0 0 5px !important;

    color: var(--library-blue);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.16em;
}

.library-page-intro-text {
    margin: 0 !important;

    color: var(--library-text);
    font-size: 17px;
    font-weight: 500;
}

/* ==================================================
   ページ内メニュー
   ================================================== */

.library-jump-label {
    margin: 0 0 12px !important;

    color: var(--library-blue-dark);
    font-size: 17px;
}

.library-jump-buttons {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;

    margin: 0 0 44px !important;
}

.library-jump-buttons .wp-block-button {
    width: 100% !important;
    margin: 0 !important;
}

.library-jump-buttons .wp-block-button__link {
    display: flex !important;
    align-items: center;
    justify-content: center;

    width: 100% !important;
    min-height: 58px;
    padding: 12px 16px !important;

    color: var(--library-blue-dark) !important;
    background: #ffffff !important;

    border: 2px solid var(--library-blue) !important;
    border-radius: 8px !important;

    font-size: 16px !important;
    font-weight: 700 !important;
    text-align: center;
    text-decoration: none !important;
}

.library-jump-buttons .wp-block-button__link:hover,
.library-jump-buttons .wp-block-button__link:focus {
    color: #ffffff !important;
    background: var(--library-blue) !important;
}

/* ==================================================
   大見出し
   ================================================== */

.library-section-heading {
    margin: 48px 0 20px !important;
    padding: 12px 16px !important;

    color: #ffffff !important;
    background: var(--library-blue) !important;

    border: 0 !important;
    border-radius: 8px !important;

    font-size: 24px !important;
    line-height: 1.5 !important;

    scroll-margin-top: 120px;
}

/* ==================================================
   共通カード
   ================================================== */

.library-card {
    margin-top: 0 !important;
    margin-bottom: 18px !important;
    padding: 24px 26px !important;

    background: #ffffff;
    border: 1px solid var(--library-border);
    border-radius: 10px;
}

.library-card h3 {
    margin: 0 0 14px !important;
    padding: 0 0 9px !important;

    color: var(--library-blue-dark) !important;
    background: transparent !important;

    border: 0 !important;
    border-bottom: 2px solid var(--library-border) !important;

    font-size: 20px !important;
    line-height: 1.5 !important;
}

.library-card p {
    margin-top: 0 !important;
    margin-bottom: 13px !important;
}

.library-card p:last-child {
    margin-bottom: 0 !important;
}

.library-card ul {
    margin: 6px 0 0 !important;
    padding-left: 1.5em !important;
}

.library-card li + li {
    margin-top: 5px;
}

/* ==================================================
   開室時間・休室日
   ================================================== */

.library-summary-columns {
    gap: 18px !important;
    margin-bottom: 0 !important;
}

.library-summary-columns > .wp-block-column {
    margin-bottom: 0 !important;
}

.library-summary-card {
    height: 100%;
}

.library-emphasis {
    color: var(--library-blue-dark);
    font-size: 18px;
}

/* ==================================================
   図書館カレンダー
   ================================================== */

.library-calendar-card {
    background: var(--library-blue-light);
}

.library-calendar-card .wp-block-buttons {
    margin-top: 18px !important;
}

.library-external-button .wp-block-button__link {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;

    padding: 12px 22px !important;

    color: #ffffff !important;
    background: var(--library-blue) !important;

    border: 2px solid var(--library-blue) !important;
    border-radius: 999px !important;

    font-weight: 700 !important;
    text-decoration: none !important;
}

.library-external-button .wp-block-button__link:hover,
.library-external-button .wp-block-button__link:focus {
    background: var(--library-blue-dark) !important;
}

/* ==================================================
   利用案内
   ================================================== */

.library-info-card {
    border-left: 6px solid var(--library-blue);
    scroll-margin-top: 120px;
}

.library-info-card a {
    color: var(--library-blue-dark) !important;
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.library-area-list {
    padding: 13px 16px !important;

    color: var(--library-blue-dark);
    background: var(--library-blue-light);
    border-radius: 7px;

    font-weight: 700;
}

.library-subheading {
    margin: 20px 0 10px !important;
    padding: 8px 13px !important;

    color: var(--library-blue-dark) !important;
    background: var(--library-blue-light) !important;

    border: 0 !important;
    border-radius: 6px !important;

    font-size: 17px !important;
    line-height: 1.5 !important;
}

.library-note {
    color: var(--library-muted);
    font-size: 14px;
}

.library-note-important {
    padding: 12px 15px !important;

    color: #70420f;
    background: #fff7e8;
    border: 1px solid #efd4a5;
    border-radius: 7px;
}

/* ==================================================
   スマートフォン
   ================================================== */

@media (max-width: 768px) {
   
    .library-page {
        font-size: 15px;
        line-height: 1.8;
    }

    .library-page-intro {
        padding: 18px !important;
    }

    .library-page-intro-text {
        font-size: 15px;
    }

    .library-jump-buttons {
        grid-template-columns: 1fr !important;
        gap: 9px !important;
        margin-bottom: 36px !important;
    }

    .library-jump-buttons .wp-block-button__link {
        min-height: 50px;
    }

    .library-section-heading {
        margin-top: 38px !important;
        padding: 11px 14px !important;
        font-size: 21px !important;
    }

    .library-summary-columns {
        display: block !important;
    }

    .library-summary-columns > .wp-block-column {
        margin-bottom: 14px !important;
    }

    .library-card {
        padding: 20px 18px !important;
    }

    .library-card h3 {
        font-size: 18px !important;
    }

    .library-emphasis {
        font-size: 16px;
    }

    .library-external-button,
    .library-external-button .wp-block-button__link {
        width: 100% !important;
    }
}

/* ==================================================
   新しく購入した本
   月・分類・書籍一覧
   ================================================== */

.newbook-month {
    margin: 30px 0 48px !important;
    padding: 26px !important;

    background: #ffffff;
    border: 1px solid var(--library-border);
    border-radius: 12px;
}

/* 月の見出し */
.newbook-month-heading {
    margin: 0 0 24px !important;
    padding: 13px 18px !important;

    color: #ffffff !important;
    background: var(--library-blue) !important;

    border: 0 !important;
    border-radius: 8px !important;

    font-size: 24px !important;
    line-height: 1.4 !important;

    scroll-margin-top: 120px;
}

/* 大人の本・子どもの本 */
.newbook-category-heading {
    margin: 30px 0 12px !important;
    padding: 9px 14px !important;

    color: var(--library-blue-dark) !important;
    background: var(--library-blue-light) !important;

    border: 0 !important;
    border-left: 5px solid var(--library-blue) !important;
    border-radius: 6px !important;

    font-size: 18px !important;
    line-height: 1.5 !important;
}

.newbook-month-heading + .newbook-category-heading {
    margin-top: 0 !important;
}

/* Flexible Tableの外枠 */
.newbook-month figure.wp-block-flexible-table-block-table {
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 22px !important;
    overflow: hidden;

    border-radius: 8px;
}

/* 書籍一覧表 */
.newbook-month figure.wp-block-flexible-table-block-table table {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;

    border-collapse: collapse !important;
    table-layout: fixed !important;

    background: #ffffff;
}

.newbook-month figure.wp-block-flexible-table-block-table td {
    padding: 11px 14px !important;

    color: var(--library-text) !important;
    background: #ffffff !important;
    border: 1px solid var(--library-border) !important;

    font-size: 15px !important;
    line-height: 1.65 !important;
    text-align: left !important;
    vertical-align: top !important;
    overflow-wrap: anywhere;
}

/* 書名 */
.newbook-month figure.wp-block-flexible-table-block-table td:first-child {
    width: 68% !important;
    font-weight: 600;
}

/* 著者名 */
.newbook-month figure.wp-block-flexible-table-block-table td:last-child {
    width: 32% !important;

    color: var(--library-blue-dark) !important;
    background: #f6faff !important;

    font-weight: 600;
}

/* 表の行を見分けやすくする */
.newbook-month figure.wp-block-flexible-table-block-table tr:nth-child(even) td:first-child {
    background: #fbfdff !important;
}

/* スマートフォン */
@media (max-width: 768px) {
    .newbook-month {
        margin-bottom: 36px !important;
        padding: 18px 14px !important;
    }

    .newbook-month-heading {
        margin-bottom: 20px !important;
        padding: 11px 14px !important;
        font-size: 21px !important;
    }

    .newbook-category-heading {
        margin-top: 24px !important;
        padding: 8px 11px !important;
        font-size: 16px !important;
    }

    .newbook-month figure.wp-block-flexible-table-block-table td {
        padding: 9px 8px !important;
        font-size: 13px !important;
        line-height: 1.55 !important;
    }

    .newbook-month figure.wp-block-flexible-table-block-table td:first-child {
        width: 65% !important;
    }

    .newbook-month figure.wp-block-flexible-table-block-table td:last-child {
        width: 35% !important;
    }
}

/* ==================================================
   新しく購入した本：年度・月メニュー
   ================================================== */

.newbook-intro {
    margin: 0 0 24px !important;
    padding: 18px 22px !important;

    color: var(--library-text);
    background: var(--library-blue-light);
    border-left: 5px solid var(--library-blue);
    border-radius: 8px;

    font-size: 16px;
    line-height: 1.8;
}

.newbook-year-heading {
    margin: 34px 0 18px !important;
    padding: 14px 18px !important;

    color: #ffffff !important;
    background: var(--library-blue-dark) !important;

    border: 0 !important;
    border-radius: 9px !important;

    font-size: 26px !important;
    line-height: 1.4 !important;

    scroll-margin-top: 120px;
}

.newbook-month-nav {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 10px !important;

    margin: 0 0 18px !important;
}

.newbook-month-nav .wp-block-button {
    width: 100% !important;
    margin: 0 !important;
}

.newbook-month-nav .wp-block-button__link {
    position: relative;

    display: flex !important;
    align-items: center;
    justify-content: center;

    width: 100% !important;
    min-height: 58px;
    padding: 13px 16px !important;

    color: #174b8a !important;
    background: #ffffff !important;
    background-image: none !important;

    border: 1px solid #c9dff4 !important;
    border-left: 5px solid #1f5fae !important;
    border-radius: 10px !important;

    box-shadow: 0 4px 12px rgba(31, 95, 174, 0.08);

    font-size: 16px !important;
    font-weight: 700 !important;
    text-decoration: none !important;

    transition:
        transform 0.2s ease,
        box-shadow 0.2s ease,
        background-color 0.2s ease;
}

.newbook-month-nav .wp-block-button__link:hover,
.newbook-month-nav .wp-block-button__link:focus {
    color: #174b8a !important;
    background: #eef8ff !important;
    border-color: #8ed1fc !important;
    border-left-color: #1f5fae !important;

    box-shadow: 0 7px 18px rgba(31, 95, 174, 0.14);
    transform: translateY(-2px);
}

.newbook-month-nav .wp-block-button__link:hover,
.newbook-month-nav .wp-block-button__link:focus {
    color: #ffffff !important;
    background: #1f5fae !important;
    border-color: #1f5fae !important;
}

.newbook-library-link {
    margin: 0 0 34px !important;
}

.newbook-library-link .wp-block-button__link {
    padding: 11px 22px !important;

    color: #ffffff !important;
    background: var(--library-blue) !important;

    border: 2px solid var(--library-blue) !important;
    border-radius: 999px !important;

    font-weight: 700 !important;
    text-decoration: none !important;
}

.newbook-library-link .wp-block-button__link:hover,
.newbook-library-link .wp-block-button__link:focus {
    background: var(--library-blue-dark) !important;
}

@media (max-width: 768px) {
    .newbook-intro {
        padding: 16px !important;
        font-size: 15px;
    }

    .newbook-year-heading {
        margin-top: 28px !important;
        padding: 12px 15px !important;
        font-size: 22px !important;
    }

    .newbook-month-nav {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
    }

    .newbook-month-nav .wp-block-button__link {
        min-height: 44px;
        padding: 8px 6px !important;
        font-size: 14px !important;
    }

    .newbook-library-link,
    .newbook-library-link .wp-block-button__link {
        width: 100% !important;
    }
}



.wp-block-buttons.newbook-month-nav .wp-block-button__link:hover,
.wp-block-buttons.newbook-month-nav .wp-block-button__link:focus,
.newbook-month-nav.wp-block-button .wp-block-button__link:hover,
.newbook-month-nav.wp-block-button .wp-block-button__link:focus,
.wp-block-button.newbook-month-nav .wp-block-button__link:hover,
.wp-block-button.newbook-month-nav .wp-block-button__link:focus {
    color: #ffffff !important;
    background-color: #1f5fae !important;
    border-color: #1f5fae !important;
}