/* 色変数の定義 */
:root {
    --color-cardinal-red: #B1221A;
    --color-light-cardinal-red: #db382f;
    --color-dark-cardinal-red: #8f1b15;
    --color-white: #FFFFFF;
    --color-light-gray: #F5F5F5;
    --color-charcoal-gray: #333333;
    --color-medium-gray: #999999;
    --color-pale-beige: #F7EFE2;
    /* 連絡先管理用の色変数 */
    --color-table-border: #ddd;
    --gray-color: #F5F5F5;
    /* 偶数行に使用する薄い赤 */
    --color-even-row: #FCE8E8;
    /* 送付履歴の名前表示用のより暗い緑色 */
    --color-deep-green: #003300;
    /* 資料選択用の明るい緑色 */
    --color-select-green: #28a745;
    --footer-height: 70px;
    --header-height: 45px;
    /* ガラス質感用の共通スタイル変数 */
    --glass-bg-strong: linear-gradient(135deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.18));
    --glass-bg-soft: linear-gradient(135deg, rgba(255, 245, 245, 0.7), rgba(255, 255, 255, 0.16));
    --glass-border: 1px solid rgba(255, 255, 255, 0.45);
    --glass-border-strong: 1px solid rgba(255, 255, 255, 0.55);
    --glass-shadow-strong: 0 20px 40px rgba(30, 30, 60, 0.2);
    --glass-shadow-soft: 0 14px 32px rgba(51, 51, 79, 0.18);
    --glass-blur-amount: 18px;
}

body {
    font-family: Arial, sans-serif;
    margin: 0;
    width: 100%;
    height: auto;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    box-sizing: border-box;
}

/* トップ画面はヘッダーを含めて全画面表示させる */
body.home-page {
    width: 100%;
    height: auto;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    box-sizing: border-box;
}

/* 3D背景用キャンバス */
#backgroundCanvas {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    filter: blur(4px);
    opacity: 0.6;
    pointer-events: none;
    /* 背景の薄いグラデーション */
    background: linear-gradient(to bottom, #ffffff, #ff9090dc);
}

/* ナビゲーションバー */
.top-nav {
    position: fixed;
    display: flex;
    justify-content: space-between;
    align-items: center;
    /* グラデーション */
    background-image: linear-gradient(120deg, rgba(177, 34, 26, 0.88), rgba(143, 27, 21, 0.68));
    color: var(--color-white);
    padding: 3px 0px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.25);
    box-shadow: 0 18px 32px rgba(95, 20, 16, 0.35);
    backdrop-filter: blur(14px) saturate(150%);
    -webkit-backdrop-filter: blur(14px) saturate(150%);
    width: 100%;
    z-index: 1000;
    left: 0;
    top: 0;
}
.logo-area {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: var(--color-white);
}
.logo {
    /* 320x100 のロゴ画像に合わせた比率 */
    height: 30px;
    width: auto;
    padding-left: 5px;
}
.app-name {
    font-size: 1.2rem;
    font-weight: bold;
}
.header-title {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    font-size: 1.5rem;
    /* ヘッダータイトルは薄いグレーで統一 */
    color: var(--color-light-gray);
}
.user-area {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-right: 5px;
}
.company-name {
    font-weight: bold;
}
.logout {
    cursor: pointer;
}

/* ダッシュボード用パネル */
.dashboard {
    /* メニューパネルを縦方向に並べる */
    display: flex;
    flex-direction: column;
    gap: 2rem;
    padding: 0 5px;
    /* margin-top: 1.5rem; */
    justify-content: center;
    align-items: center;
}

/* 管理設定ダッシュボードのヘッダー・フッター分の余白を確保 */
.admin-dashboard {
    padding: var(--header-height) 5px var(--footer-height);
    margin-top: 0;
    gap: 1rem;
}

/* 統計/フォローアップエリアを左右に配置 */
.dashboard-top {
    display: flex;
    justify-content: center;
    align-items: stretch; /* 両ダッシュボードの高さを揃える */
    gap: 1rem;
    width: 100%;
    margin-top: 5px;
    margin-bottom: 10px;
}

/* 統計ダッシュボード */
.stats-dashboard {
    width: 50%;
    max-width: none;
    padding: 0.6rem;
    border-radius: 20px;
    border: var(--glass-border);
    background: var(--glass-bg-strong);
    box-shadow: var(--glass-shadow-strong);
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}

body.home-page .stats-dashboard,
body.home-page .followup-dashboard {
    flex: 1 1 320px;
    min-width: 280px;
    width: auto;
}

@supports (backdrop-filter: blur(1px)) {
    .stats-dashboard {
        backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        -webkit-backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        background: linear-gradient(130deg, rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.14));
    }
}

/* 統計カードを横並びで表示 */
.stats-cards {
    display: flex;
    justify-content: space-around;
    gap: 1rem;
    flex-wrap: wrap;
    /* margin-bottom: 1rem; */
}

/* 各統計カード */
.stat-card {
    flex: 1;
    min-width: 150px;
    border-radius: 18px;
    padding: 0.75rem 0.75rem 1rem;
    text-align: center;
    border: var(--glass-border);
    background: var(--glass-bg-soft);
    box-shadow: var(--glass-shadow-soft);
    position: relative;
    overflow: hidden;
}

@supports (backdrop-filter: blur(1px)) {
    .stat-card {
        backdrop-filter: blur(var(--glass-blur-amount)) saturate(160%);
        -webkit-backdrop-filter: blur(var(--glass-blur-amount)) saturate(160%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.12));
    }
}

/* 統計カードのタイトルを強調表示 */
.stat-card__title {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin: -0.5rem -0.5rem 0.75rem;
    padding: 0.55rem 0.5rem;
    background: linear-gradient(135deg, var(--color-cardinal-red) 0%, #d64c45 100%);
    color: var(--color-white);
    border-radius: 4px 4px 0 0;
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.08em;
}

/* 統計カードのタイトルアイコン */
.stat-card__title-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.2);
    font-size: 0.95rem;
}

/* 統計カードのタイトルテキスト */
.stat-card__title-text {
    font-size: 0.9rem;
}

/* カード内の数値 */
.stat-card .value {
    font-size: 1.5rem;
    color: var(--color-cardinal-red);
}

/* フォローアップリスト表示 */
.followup-dashboard {
    width: 50%;
    max-width: none;
    padding: 0.6rem;
    border-radius: 20px;
    border: var(--glass-border);
    background: var(--glass-bg-strong);
    box-shadow: var(--glass-shadow-strong);
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}

@supports (backdrop-filter: blur(1px)) {
    .followup-dashboard {
        backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        -webkit-backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        background: linear-gradient(130deg, rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.14));
    }
}
.followup-dashboard h3 {
    margin-top: 0;
    text-align: center;
}
.followup-lists {
    display: flex;
    gap: 1rem;
}
.followup-section {
    flex: 1;
    /* リストが長い場合にスクロール表示 */
    max-height: 235px;
    display: flex;
    flex-direction: column;
}
.followup-section ul {
    list-style: none;
    /* ホバー時の浮き上がりで上端が切れないよう余白を確保 */
    padding: 0.2rem 0 0.4rem;
    margin: 0;
    /* リスト部分のみスクロールさせる */
    overflow-y: auto;
    flex: 1;
    scrollbar-width: none;
}
.followup-section ul::-webkit-scrollbar {
    width: 6px;
}
.followup-section ul::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.2);
    border-radius: 3px;
}
.followup-title {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0.4rem 0 0.6rem;
    position: sticky;
    top: 0;
    z-index: 1;
    padding: 0.45rem 0.7rem;
    border-radius: 4px;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #ffffff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.18);
}

/* 未閲覧タイトルのビジュアル強調 */
.followup-title--unviewed {
    background: linear-gradient(135deg, var(--color-cardinal-red) 0%, #d64c45 100%);
}

/* 閲覧済みアクションなしタイトルのビジュアル強調 */
.followup-title--noaction {
    background: linear-gradient(135deg, #62666c 0%, #8f969e 100%);
}

/* 未閲覧・閲覧済みアイコン色 */
.icon-unviewed {
    /* 閲覧済みアクションなしと色を入れ替え */
    color: var(--color-medium-gray);
}

.icon-noaction {
    /* 未閲覧アイコンと色を入れ替え */
    color: var(--color-cardinal-red);
}
.followup-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: linear-gradient(140deg, rgba(255, 245, 245, 0.75), rgba(255, 255, 255, 0.24));
    border: var(--glass-border);
    border-radius: 16px;
    padding: 0.55rem 0.75rem;
    margin-bottom: 0.4rem;
    font-size: 0.6rem; /* フォントサイズを小さく */
    cursor: pointer;
    position: relative;
    transition: transform 0.28s ease, background 0.28s ease;
    overflow: visible;
    z-index: 0;
}

.followup-item::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -18px;
    transform: translate3d(-50%, 0, 0);
    width: calc(100% - 34px);
    max-width: 320px;
    height: 30px;
    background: radial-gradient(ellipse at center, rgba(38, 26, 26, 0.26) 0%, rgba(38, 26, 26, 0.14) 48%, transparent 72%);
    border-radius: 50%;
    filter: blur(8px);
    opacity: 0.76;
    transition: opacity 0.28s ease, transform 0.28s ease, filter 0.28s ease;
    pointer-events: none;
    z-index: -1;
}

/* ホバー演出を無効化し、常時同じ質感で表示 */
@supports (backdrop-filter: blur(1px)) {
    .followup-item {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(160%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(160%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0.16));
    }
}

.followup-item .fu-days {
    color: var(--color-cardinal-red);
    font-weight: bold;
    display: flex;
    align-items: center;
    gap: 0.2rem;
}

/* フォローアップ内の文字配置 */
.followup-item .fu-main {
    display: flex;
    flex-direction: column;
}

.followup-item .fu-name {
    display: flex;
    gap: 0.2rem;
}

.followup-item .fu-company {
    color: var(--color-charcoal-gray);
}

.followup-item .fu-doc {
    color: var(--color-medium-gray);
}

/* 折れ線グラフ表示エリア */
.chart-container {
    width: 100%;
    height: 150px; /* グラフの高さを縮小 */
    position: relative;
    margin-top: 0.5rem;
    background: var(--glass-bg-soft); /* 資料リストと同じ背景色 */
    border-radius: 18px;
    padding: 0.75rem;
    border: var(--glass-border);
    box-shadow: var(--glass-shadow-soft);
    box-sizing: border-box;
}

@supports (backdrop-filter: blur(1px)) {
    .chart-container {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(150%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(150%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.54), rgba(255, 255, 255, 0.12));
    }
}

/* 資料名リスト */
.doc-list {
    /* width: 100%; */
    background: linear-gradient(140deg, rgba(255, 255, 255, 0.54), rgba(255, 255, 255, 0.12));
    border-radius: 16px;
    padding: 0.5rem;
    list-style: none;
    height: 60px; /* 常に3件分の高さを確保 */
    overflow-y: auto;
    /* スクロールバーを極細に */
    scrollbar-width: thin;
    margin: 0.5rem 0;
    font-size: 0.8rem; /* リストの文字サイズを縮小 */
    border: var(--glass-border);
    box-shadow: var(--glass-shadow-soft);
}

@supports (backdrop-filter: blur(1px)) {
    .doc-list {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(140%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(140%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0.1));
    }
}

/* 資料名リストのスクロールバーを一番細くする */
.doc-list::-webkit-scrollbar {
    width: 3px;
}

.doc-list::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.2);
    border-radius: 2px;
}
.doc-list li {
    display: flex;
    justify-content: space-between;
    align-items: center; /* 縦位置を揃える */
    border-bottom: 1px solid var(--color-table-border);
    height: 20px; /* 項目の高さを固定 */
    line-height: 20px; /* テキストを中央に配置 */
    padding: 0; /* 余白をなくし高さを揃える */
    gap: 0.3rem; /* 左右項目の間隔を確保 */
}
.doc-list li span:first-child {
    flex: 1;
    overflow: hidden; /* はみ出しを隠す */
    text-overflow: ellipsis; /* 長い資料名は省略表示 */
    white-space: nowrap;
}
.doc-list li span:last-child {
    flex-shrink: 0; /* 送付数は縮まない */
}

/* 今月送付資料がない場合のメッセージ */
.doc-list li.empty {
    justify-content: center;
    border-bottom: none;
    height: 100%; /* 空の場合も高さを保持 */
    line-height: 60px; /* メッセージを中央に表示 */
}

/* 全社レポート用スタイル */
.company-report {
    display: flex;
    flex-direction: column; /* 縦並びで1列にする */
    box-sizing: border-box; /* パディング分も含めてレイアウトを調整 */
    padding: var(--header-height) 0 var(--footer-height); /* ヘッダー・フッター分のみ余白を確保 */
}
.report-user {
    background: var(--glass-bg-strong);
    padding: 0.6rem; /* 余白を縮小 */
    border-radius: 20px;
    border: var(--glass-border);
    box-shadow: var(--glass-shadow-strong);
    width: calc(100% - 1rem); /* 左右マージン分を差し引いてはみ出しを防ぐ */
    box-sizing: border-box; /* パディングを含めて幅を計算 */
    font-size: 0.9rem; /* 全体の文字サイズを調整 */
    margin: 0.5rem; /* 上下左右にゆとりを持たせる */
}

@supports (backdrop-filter: blur(1px)) {
    .report-user {
        backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        -webkit-backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.14));
    }
}
.report-user__title {
    margin: 0 0 0.1rem 0;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: nowrap;
    text-align: left;
    padding: 0.35rem 0.8rem;
    background: linear-gradient(135deg, var(--color-cardinal-red) 0%, #d64c45 100%);
    border-radius: 999px;
    color: var(--color-white);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    box-shadow: 0 2px 6px rgba(177, 34, 26, 0.18);
}

.report-user__title-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.25);
    line-height: 1;
}

.report-user__title-icon i {
    font-size: 1.05rem;
    line-height: 1;
}

/* レポートカード内の3カラム配置 */
.report-columns {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap; /* 画面幅に合わせて折り返す */
    align-items: stretch;
}

/* 月次・週次レポート共通ブロック */
.report-block {
    flex: 1 1 320px; /* グラフエリアは一定幅を確保しつつ可変 */
    min-width: 260px;
    display: flex;
    flex-direction: column;
}

/* 集計情報表示 */
.summary-stats {
    flex: 1 1 220px;
    min-width: 220px;
    max-width: 100%;
    background: var(--glass-bg-soft);
    border-radius: 18px;
    padding: 0.75rem;
    border: var(--glass-border);
    box-shadow: var(--glass-shadow-soft);
    display: flex;
    flex-direction: column;
    justify-content: center;
    font-size: 1rem;
    margin-top: 0.5rem; /* 資料リストと上部位置を合わせる */
}

@supports (backdrop-filter: blur(1px)) {
    .summary-stats {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(150%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(150%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.54), rgba(255, 255, 255, 0.12));
    }
}

.summary-stats p {
    margin: 0.2rem 0;
}

/* 月次・週次・日次ごとの余白を確保 */
.summary-stats .stat-group {
    margin-bottom: 0.5rem;
}

.summary-stats .stat-group:last-child {
    margin-bottom: 0;
}

/* 集計グループのタイトル */
.summary-stats .group-title {
    font-weight: bold;
    display: flex;
    align-items: center;
    gap: 0.2rem;
    margin-bottom: 0.2rem;
}

.summary-stats .stat-value {
    color: var(--color-cardinal-red);
    font-weight: bold;
}

/* 送付数と返答率を横並びに表示 */
.summary-stats .rate-row {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap; /* 狭い画面では折り返して表示 */
}

@media (max-width: 960px) {
    .report-block,
    .summary-stats {
        flex: 1 1 100%;
        min-width: 100%;
    }

    .summary-stats {
        margin-top: 0.5rem;
    }
}

/* 段ごとの行スタイル */
.menu-row {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    /* 画面幅が狭い場合に折り返す */
    flex-wrap: wrap;
}

body.home-page .menu-row {
    width: 100%;
}

body.home-page .menu-row .panel {
    width: auto;
    flex: 1 1 clamp(170px, 21vw, 230px);
    max-width: 250px;
}

body.home-page .menu-row .panel-compact {
    width: auto;
    /* panel よりも伸びないよう flex-grow を無効化し、タブレット横向きでも差を出す */
    flex: 0 1 clamp(95px, 14vw, 140px);
    max-width: 150px;
}
.panel {
    /* デフォルトテーマ（カーディナルレッド系） */
    --panel-bg-start: rgba(177, 34, 26, 0.78);
    --panel-bg-end: rgba(143, 27, 21, 0.65);
    --panel-text-color: var(--color-white);
    --panel-hover-text-color: var(--color-white);
    --panel-shadow-rest: 0 12px 28px rgba(95, 20, 16, 0.32);
    --panel-shadow-hover: 0 18px 36px rgba(95, 20, 16, 0.38);
    --panel-lift: translateY(-4px) scale(1.02);
    --panel-glow-color: rgba(255, 255, 255, 0.4);
    --panel-glow-radius: 75%;
    --panel-glow-scale: 0.82;
    --panel-glow-scale-hover: 1.02;
    border: var(--glass-border-strong);
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    /* パネルのサイズを統一しつつ縦幅を縮小 */
    width: 200px;
    height: 170px;
    text-decoration: none;
    cursor: pointer;
    position: relative;
    /* 内側ハイライトを保ちながら右上バッジが切れないように overflow は指定しない */
    /* アニメーションのための下地 */
    background-image: linear-gradient(135deg, rgb(205 11 0 / 72%), rgba(143, 27, 21, 0.48));
    background-size: 200% 200%;
    background-position: 0% 50%;
    color: var(--panel-text-color);
    box-shadow: var(--panel-shadow-rest);
    transition: transform 0.45s cubic-bezier(0.19, 1, 0.22, 1),
        box-shadow 0.45s cubic-bezier(0.19, 1, 0.22, 1),
        background-position 0.45s ease,
        color 0.3s ease;
    overflow: visible;
    /* ホバー演出は撤廃し、静的に表示 */
}

@supports (backdrop-filter: blur(1px)) {
    .panel {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(170%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(170%);
        background-image: linear-gradient(135deg, rgb(205 11 0 / 72%), rgba(143, 27, 21, 0.48));
    }
    .panel-compact {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(155%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(155%);
        background-image: linear-gradient(140deg, rgba(255, 255, 255, 0.9), rgba(246, 246, 246, 0.46));
    }
}
.panel-compact {
    /* 利用頻度の低いパネルを控えめに見せるためのサイズと配色 */
    width: 110px;
    height: 96px; /* 縦幅をわずかに伸ばして視認性を確保 */
    --panel-bg-start: rgba(255, 255, 255, 0.95);
    --panel-bg-end: rgba(246, 246, 246, 0.55);
    --panel-text-color: var(--color-charcoal-gray);
    --panel-hover-text-color: var(--color-charcoal-gray);
    --panel-shadow-rest: 0 10px 25px rgba(120, 107, 96, 0.26);
    --panel-shadow-hover: 0 18px 36px rgba(120, 107, 96, 0.32);
    --panel-lift: translateY(-3px) scale(1.03);
    --panel-glow-color: rgba(255, 255, 255, 0.32);
    --panel-glow-radius: 70%;
    --panel-glow-scale: 0.88;
}
.panel-icon {
    font-size: 2.7rem; /* パネルアイコンをさらに縮小 */
    margin-bottom: 0.5rem;
    color: var(--color-white);
    /* 発光 */
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.8);
}
.panel-compact .panel-icon {
    /* 控えめパネルのアイコンをさらに縮小し差別化を強調 */
    font-size: 2rem;
    color: var(--color-cardinal-red);
    text-shadow: none;
}
.panel-compact .panel-title {
    /* 控えめパネルのタイトルサイズを微調整 */
    font-size: 0.8rem;
}
.panel-title {
    font-size: 1.0rem;
    font-weight: bold;
}

/* 資料ライブラリページ */
.library {
    box-sizing: border-box;
    padding: var(--header-height) 1.5rem var(--footer-height);
    display: flex;
    flex-direction: column;
    justify-content: center; /* 画面中央に配置 */
    align-items: center;
    gap: 1.5rem;
    width: min(1200px, 100%);
    margin: 0 auto;
    min-height: calc(100vh - var(--header-height)); /* ヘッダー分の高さを引く */
}

@media (max-height: 860px) {
    .library {
        /* margin: 35px auto 70px; */
        padding: var(--header-height) 1rem var(--footer-height);
        min-height: calc(100vh - var(--header-height) - 35px);
    }
}
.search-bar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}
.search-bar input {
    width: 280px; /* タブレットで入力しやすい幅 */
    padding: 0.75rem;
    font-size: 1.1rem;
    border-radius: 4px;
    border: 1px solid var(--color-medium-gray); /* ボーダー色を統一 */
}
.search-bar select {
    padding: 0.75rem;
    font-size: 1.1rem;
    border-radius: 4px;
    border: 1px solid var(--color-medium-gray);
}
.search-bar input,
.search-bar select,
.search-bar .search-btn,
.search-bar .clear-btn {
    height: 3rem;
    box-sizing: border-box;
}
.search-bar .search-btn,
.search-bar .clear-btn {
    display: flex;
    align-items: center;
    justify-content: center;
}
.search-btn {
    /* メニューパネルと同じグラデーションを適用 */
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.8rem 0.9rem;
    font-size: 1.1rem;
    cursor: pointer;
}
.search-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}

/* 検索クリアボタン */
.clear-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-medium-gray), var(--color-charcoal-gray));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.8rem 0.9rem;
    font-size: 1.1rem;
    cursor: pointer;
}
.clear-btn:hover {
    opacity: 0.8;
    background-image: linear-gradient(to bottom right,
        var(--color-medium-gray), var(--color-charcoal-gray));
}

/* CSVエクスポートボタン */
.export-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    /* フォントを少し大きく */
    font-size: 1.1rem;
    cursor: pointer;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 1rem;
}
.export-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}

/* 履歴画面アクションエリア */
.history-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    /* margin-bottom: 0.5rem; */
}

/* 履歴画面内検索バー調整 */
.history-actions .search-bar {
    margin-bottom: 0;
}

/* カテゴリマスタ画面アクションエリア */
.category-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.category-actions .search-bar {
    margin-bottom: 0;
    align-items: stretch;
}

#doc-master-category {
    flex: 1 1 18rem;
    width: 100%;
    max-width: 18rem;
}

#doc-register-category-main,
#doc-register-category-middle,
#doc-register-category-small,
#doc-edit-category-main,
#doc-edit-category-middle,
#doc-edit-category-small {
    flex: initial;
    width: 100%;
    max-width: none;
}


/* 新規登録ボタン */
.new-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    /* フォントを少し大きく */
    font-size: 1.1rem;
    height: 3rem;
    box-sizing: border-box;
    padding: 0.4rem 0.8rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
}
.new-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}

/* チャットボタン */
.chat-btn {
    border: none;
    border-radius: 4px;
    padding: 0.5rem 0.7rem;
    cursor: pointer;
    position: relative;
}
.chat-btn i {
    font-size: 1rem;
}
.chat-btn.active {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
}
.chat-btn.inactive {
    background-color: var(--color-light-gray);
    color: var(--color-medium-gray);
    cursor: not-allowed;
}
.chat-btn:disabled {
    pointer-events: none;
}
.chat-btn.active:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}

/* 編集ボタン */
.edit-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.5rem 0.7rem;
    cursor: pointer;
}
.edit-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}

/* 一覧テーブル用削除ボタン */
.delete-btn-sm {
    background-image: linear-gradient(to bottom right,
        var(--color-medium-gray), var(--color-charcoal-gray));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.5rem 0.7rem;
    cursor: pointer;
}
.delete-btn-sm:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-medium-gray), var(--color-charcoal-gray));
    opacity: 0.8;
}

/* パンくずリスト */
.breadcrumb {
    margin-bottom: 0.5rem;
    font-size: 1rem;
    color: var(--color-charcoal-gray);
    display: flex;
    justify-content: center; /* 画面中央寄せ */
    align-items: center; /* 矢印を垂直中央に揃える */
}
/* パンくずリストの各要素 */
.breadcrumb-item {
    cursor: pointer;
    color: var(--color-charcoal-gray);
    text-decoration: none;
}
.breadcrumb-separator {
    margin: 0 0.3rem; /* カテゴリ名との間隔 */
    color: var(--color-medium-gray); /* 少し暗めのグレー */
    vertical-align: middle; /* 文字中心を揃える */
}
.breadcrumb-item:hover {
    text-decoration: underline;
}
/* -------------------- フッター -------------------- */
/* ホームボタンと戻るボタンをまとめて配置 */
.footer {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 70px;
    display: flex;
    justify-content: center; /* 戻るボタンを中央に配置 */
    align-items: center; /* ボタンを上下中央揃え */
    z-index: 1000;
}

/* フッター内ボタン共通 */
.footer .home-button,
.footer .back-button,
.footer .send-button {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    width: 70px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    cursor: pointer;
}

/* ホームボタンは左端に固定し右角を丸くする */
.footer .home-button {
    position: absolute;
    left: 0;
    border-radius: 0 23px 23px 0;
}

/* 戻るボタンは円形に */
.footer .back-button {
    border-radius: 50%;
}

/* 送付ボタンは右端に固定し左角を丸くする */
.footer .send-button {
    position: absolute;
    right: 0;
    border-radius: 23px 0 0 23px;
}

.footer .home-button.hidden,
.footer .back-button.hidden {
    display: none;
}

/* ホバー時の色変化 */
.footer .home-button:hover,
.footer .back-button:hover,
.footer .send-button:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red));
}

/* 送付数表示 */
/* 送付ボタンのバッジ */
.send-badge {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    /* 選択バッジと同じ緑色を使用 */
    background-color: var(--color-select-green);
    color: var(--color-white);
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
}

/* チャット未読バッジ（資料選択バッジと同じスタイル） */
/* チャット未読バッジ */
.chat-badge {
    position: absolute;
    width: 24px; /* チャットボタン用は小さめに調整 */
    height: 24px;
    border-radius: 50%;
    background-color: var(--color-select-green);
    color: var(--color-white);
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
}

/* パネル右上に少しはみ出す位置 */
.panel .chat-badge {
    width: 36px; /* パネル用は大きめに表示 */
    height: 36px;
    top: -8px;
    right: -8px;
    font-size: 1rem;
    z-index: 2; /* ホバー時のハイライトより前面に配置しバッジが被らないようにする */
}

/* チャットボタン上のバッジ位置 */
.chat-btn .chat-badge {
    top: -8px;
    right: -8px;
}

/* 撮影ボタン */
/* 撮影ボタンのスタイル */
#capture-button {
    /* 画面下部中央に固定（戻るボタンと重ならないよう配置） */
    position: fixed;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: 5px solid var(--color-white); /* 白いふち */
    border-radius: 50%;
    width: 100px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    cursor: pointer;
}
#capture-button:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red));
}
.category-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
}
.document-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center; /* 中央寄せ */
    gap: 1rem;
}
.document-item.drag-placeholder {
    opacity: 0.4;
    pointer-events: none;
}
.drag-ghost {
    position: fixed;
    z-index: 1000;
    pointer-events: none;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.3);
    border-radius: 4px;
    opacity: 0.95;
}
.drop-indicator {
    width: 4px;
    background-color: var(--color-cardinal-red);
    border-radius: 4px;
    pointer-events: none;
    align-self: stretch;
}
.document-item {
    position: relative;
    border-radius: 18px;
    padding: 1.1rem;
    box-sizing: border-box;
    flex: 0 0 240px;
    max-width: 240px;
    /* PDFプレビューがカードからはみ出さないように余白を確保 */
    border: var(--glass-border);
    background: var(--glass-bg-strong);
    box-shadow: var(--glass-shadow-soft);
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* ホバーアニメーションの滑らかさを調整 */
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
}

@supports (backdrop-filter: blur(1px)) {
    .document-item {
        backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        -webkit-backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.14));
    }
}

/* 資料ホバー時の拡大アニメーション */
@media (hover: hover) and (pointer: fine) {
    .document-item:hover {
        transform: scale(1.03);
        box-shadow: 0 26px 42px rgba(95, 20, 16, 0.28);
    }
}

/* 選択状態の背景 */
.document-item.selected {
    background: linear-gradient(135deg, rgba(104, 234, 46, 0.45), rgba(255, 255, 255, 0.2));
    border-color: rgba(104, 234, 46, 0.5);
}

/* 選択用丸アイコン */
.select-circle {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 2px solid var(--color-medium-gray);
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-white);
    color: var(--color-medium-gray);
    font-weight: bold;
    font-size: 0.8rem;
}

/* 選択時の丸アイコン */
.document-item.selected .select-circle {
    background-color: var(--color-select-green);
    border-color: var(--color-select-green);
    color: var(--color-white);
}


.pdf-canvas {
    width: 200px;
    max-width: 100%;
    aspect-ratio: 200 / 141; /* 既定サイズの縦横比を維持 */
    height: auto;
    border: 1px solid var(--color-light-gray);
    border-radius: 4px;
    object-fit: contain;
    display: block;
    margin: 0 auto; /* カード中央に配置 */
}

.doc-icon {
    width: 200px;
    height: 141px;
    border: 1px solid var(--color-light-gray);
    border-radius: 4px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 4rem;
    color: var(--color-dark-cardinal-red);
}

/* Office ドキュメントアイコンのカラー指定 */
.doc-icon .fa-file-word {
    color: #2B579A; /* Word のブランドカラー */
}

.doc-icon .fa-file-excel {
    color: #217346; /* Excel のブランドカラー */
}

.doc-icon .fa-file-powerpoint {
    color: #D24726; /* PowerPoint のブランドカラー */
}

.document-title {
    font-size: 0.8rem;
    margin-top: 0.5rem;
    word-break: break-all;
}

/* 資料ダウンロードボタン */
.document-download-button {
    margin-top: 0.75rem;
    padding: 0.4rem 0.75rem;
    width: 100%;
    border: none;
    border-radius: 20px;
    background-image: linear-gradient(135deg, var(--color-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.document-download-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* 資料が無い場合のメッセージ */
.no-document {
    width: 100%;
    text-align: center;
    color: var(--color-medium-gray);
    font-size: 1rem;
}

/* カテゴリアイテム */
.category-item {
    position: relative;
}

.category-panel {
    flex: 0 1 clamp(240px, 32%, 330px);
    width: clamp(240px, 32%, 330px);
    max-width: 330px;
    min-width: 240px;
    height: 120px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 0.75rem;
    text-align: left;
    text-decoration: none;
    padding: 0.5rem 0.75rem;
    color: var(--color-white);
    border-radius: 18px;
    border: var(--glass-border-strong);
    background-image: linear-gradient(135deg, rgb(205 11 0 / 72%), rgba(143, 27, 21, 0.48));
    box-shadow: 0 12px 28px rgba(95, 20, 16, 0.32);
    position: relative;
    overflow: hidden;
}

@supports (backdrop-filter: blur(1px)) {
    .category-panel {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(160%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 4px)) saturate(160%);
        background-image: linear-gradient(135deg, rgb(205 11 0 / 72%), rgba(143, 27, 21, 0.48));
    }
}

/* カテゴリアイコン */
.category-img {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border-radius: 4px;
}

/* テキスト部分 */
.category-text {
    display: flex;
    flex-direction: column;
}

@media (min-width: 960px) {
    .category-list {
        justify-content: center;
    }

    .category-panel {
        flex: 0 1 calc((90% - 2rem) / 3);
        max-width: calc((90% - 2rem) / 3);
        width: calc((90% - 2rem) / 3);
    }
}

.category-title {
    font-size: 1.1rem;
    font-weight: bold;
}

.category-desc {
    font-size: 0.8rem;
    margin-top: 0.25rem;
    color: rgba(255, 255, 255, 0.72);
    overflow: hidden;
    display: -webkit-box; /* 複数行対応 */
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3; /* 3行を超える場合に省略 */
}

/* ホバー時の効果 */


/* 非表示制御 */
.hidden {
    display: none;
}


/* 資料登録ページ */
.register {
    /* ヘッダー・フッターに隠れないように余白を確保 */
    padding: var(--header-height) 1rem var(--footer-height);
    display: flex;
    flex-direction: column;
    align-items: center; /* 中央寄せ */
    justify-content: center; /* 画面中央に配置 */
    box-sizing: border-box; /* パディングを含めて高さを計算 */
    min-height: calc(100vh - var(--header-height) - var(--footer-height));
}
.page-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.8rem;
    color: var(--color-light-cardinal-red);
    margin-bottom: 1rem;
}
.register-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-width: 600px; /* タブレットを考慮してやや広め */
    width: 100%;
}
.form-group {
    display: flex;
    flex-direction: column;
}
.register-form input,
.register-form select,
.register-form textarea {
    padding: 0.75rem; /* タブレットでもタップしやすい */
    font-size: 1rem;
    border: 1px solid var(--color-medium-gray);
    border-radius: 4px;
    overflow-y: hidden; /* 自動リサイズのためスクロール非表示 */
    resize: none; /* 手動リサイズは無効化 */
}

/* SMTP情報の端末内保存を説明する注意文 */
.register-form__note {
    font-size: 0.9rem;
    color: var(--color-dark-gray);
    line-height: 1.6;
    background-color: rgba(177, 34, 26, 0.05);
    border-left: 4px solid var(--color-light-cardinal-red);
    padding: 0.75rem 1rem;
    border-radius: 4px;
    margin: 0 0 0.75rem;
}

/* SMTP情報入力欄をまとめて囲む枠 */
.register-form__smtp-section {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid rgba(177, 34, 26, 0.25);
    border-radius: 8px;
    background-color: rgba(177, 34, 26, 0.04);
}

/* SMTP入力欄を操作不可にした際の視覚的な無効状態 */
.register-form__smtp-section--disabled {
    opacity: 0.55;
}

.register-form__smtp-section--disabled input {
    pointer-events: none;
}

/* SMTPパスワードラベルの文字サイズを調整し、折り返しを防止 */
.register-form__smtp-section label[for="smtp-pass"],
.register-form__smtp-section label[for="edit-smtp-pass"] {
    font-size: 0.85rem;
    white-space: nowrap;
}

/* ユーザー署名欄の高さとスクロール挙動を調整 */
#user-signature {
    min-height: 12rem;
    overflow-y: auto;
    resize: vertical;
}

/* メールテンプレ本文入力欄の高さを確保し、長文でもスクロール可能にする */
#mail-template-body {
    min-height: 11rem;
    overflow-y: auto;
    resize: vertical;
}

/* メール送信フォーム */
.mail-form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    width: 100%;
}
.mail-form input,
.mail-form select,
.mail-form textarea {
    padding: 0.5rem;
    font-size: 1rem;
    border: 1px solid var(--color-medium-gray);
    border-radius: 4px;
}

/* 必須項目を示す赤いアスタリスク */
.required-mark {
    color: var(--color-cardinal-red);
    margin-right: 0.25rem;
}

/* タグ選択 UI */
.tag-selector {
    position: relative;
}

.tag-input {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    min-height: 2.5rem;
    padding: 0.5rem;
    border: 1px solid var(--color-medium-gray);
    border-radius: 4px;
    cursor: pointer;
    width: 100%;
    box-sizing: border-box;
}

.selected-tag {
    background-color: var(--color-light-gray);
    border-radius: 3px;
    padding: 0.25rem 0.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.remove-tag {
    cursor: pointer;
}

.tag-list {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    width: 100%;
    max-height: 200px;
    overflow-y: auto;
    background-color: var(--color-white);
    border: 1px solid var(--color-medium-gray);
    border-radius: 4px;
    z-index: 1000;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    list-style: none;
    padding: 0;
    margin: 0;
}

.tag-list li {
    padding: 0.5rem;
    cursor: pointer;
}

.tag-list li:hover {
    background-color: var(--color-light-gray);
}
.register-submit-btn {
    /* メニューパネルと同じグラデーションを適用 */
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.5rem 1rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center; /* アイコンと文字を中央揃え */
    font-size: 1.1rem; /* タブレットでも押しやすい文字サイズ */
    gap: 0.3rem;
    width: 8rem; /* 幅をやや短く */
    align-self: center; /* 中央寄せ */
}
.register-submit-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}

/* 削除ボタン */
.delete-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-medium-gray), var(--color-charcoal-gray));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.5rem 1rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    gap: 0.3rem;
    width: 8rem;
    align-self: center;
}
.delete-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-medium-gray), var(--color-charcoal-gray));
    opacity: 0.8;
}

/* 編集画面ボタン配置 */
.button-row {
    display: flex;
    justify-content: space-between;
    width: 100%;
    margin-top: 1rem; /* 入力欄との間隔を広げる */
    margin-bottom: 1.5rem; /* フッターの戻るボタンと重ならないよう余白を追加 */
}

/* ボタンを中央に配置する場合に使用 */
.button-row.center {
    justify-content: center;
}

/* 連絡先管理ページ */
.contact {
    /* ヘッダーとフッターの重なりを防ぐ */
    padding: var(--header-height) 1rem var(--footer-height);
}

/* 送付先選択用レイアウト */
.send-container {
    display: flex;
    gap: 1rem;
}
.send-left {
    width: 50%;
}
.send-right {
    width: 50%;
    padding: 1rem;
    padding-bottom: 3rem;
    background: var(--glass-bg-strong);
    border-radius: 10px;
    border: var(--glass-border);
    box-shadow: var(--glass-shadow-strong);
    /* リストをスクロールさせるため縦方向レイアウト */
    display: flex;
    flex-direction: column;
}

@supports (backdrop-filter: blur(1px)) {
    .send-right {
        backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        -webkit-backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        background: linear-gradient(130deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0.14));
    }
}
.selected-list {
    list-style: none;
    padding: 0;
    /* 枠内でスクロール可能にする */
    flex-grow: 1;
    overflow-y: auto;
    scrollbar-width: thin;
    margin: 0;
    border-radius: 10px;
    border: var(--glass-border);
    background: linear-gradient(140deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0.12));
    box-shadow: var(--glass-shadow-soft);
}
.selected-list li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.28);
    padding: 0.3rem 0;
}

@supports (backdrop-filter: blur(1px)) {
    .selected-list {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0.1));
    }
}
.selected-doc-list {
    list-style: none;
    padding: 0;
    max-height: 30vh;
    overflow-y: auto;
    border-radius: 10px;
    border: var(--glass-border);
    background: linear-gradient(140deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0.12));
    box-shadow: var(--glass-shadow-soft);
    scrollbar-width: thin;
    margin: 0;
}
.selected-doc-list li {
    padding: 0.3rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}

@supports (backdrop-filter: blur(1px)) {
    .selected-doc-list {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.48), rgba(255, 255, 255, 0.1));
    }
}
.selected-doc-list input[type="checkbox"] {
    width: 1.2rem;
    height: 1.2rem;
    margin-right: 0.3rem;
}
.selected-doc-list li:last-child {
    border-bottom: none;
}
.no-selected {
    text-align: center;
    color: var(--color-charcoal-gray);
    margin-top: 0;
    margin-bottom: 0.5rem;
}
.contact-send-btn {
    width: 100%;
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    /* 確認ボタンはやや大きめの文字サイズで表示 */
    font-size: 1.2rem;
    border: none;
    border-radius: 4px;
    padding: 0.5rem;
    cursor: pointer;
}
.contact-send-btn:disabled {
    background-image: none; /* グラデーションを無効化 */
    background-color: #cccaca; /* より薄いグレーの背景に調整 */
    color: var(--color-medium-gray); /* 背景より濃いグレーの文字色 */
    cursor: not-allowed;
    pointer-events: none;
}
.contact-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1rem;
}
.contact-table th,
.contact-table td {
    border: 1px solid var(--color-table-border);
    padding: 0.5rem;
    /* 送付履歴テーブルと同じフォントサイズに調整 */
    font-size: 0.9rem;
}
.contact-table th:first-child,
.contact-table td:first-child {
    text-align: center;
    width: 40px;
    vertical-align: middle;
}
.contact-table input[type="checkbox"] {
    width: 1.2rem;
    height: 1.2rem;
}
.contact-table th {
    /* パネルと同じグラデーションカラー */
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    cursor: default;
}

/* ソート可能なヘッダー */
.contact-table th.sortable {
    cursor: pointer;
}

/* ソートアイコン */
.sort-icon {
    margin-left: 0.4rem;
}
.contact-table tbody tr:nth-child(odd) {
    background-color: var(--color-white);
}
.contact-table tbody tr:nth-child(even) {
    background-color: var(--color-even-row);
}

/* タグ表示用 */
.contact-table .selected-tag {
    margin-right: 0.3rem;
    margin-bottom: 0.3rem;
    background-color: var(--color-light-cardinal-red);
    color: var(--color-white);
    font-size: 13px;
}
.doc-master-table .selected-tag {
    margin-right: 0.3rem;
    margin-bottom: 0.3rem;
    background-color: var(--color-light-cardinal-red);
    color: var(--color-white);
    font-size: 13px;
}
.history-table .selected-tag {
    /* margin-right: 0.3rem; */
    background-color: var(--color-light-cardinal-red);
    color: var(--color-white);
    font-size: 10px;
}
.contact-table td.edit-cell {
    text-align: center;
}

/* ステータス表示用 */
.history-table .status-tag {
    margin-right: 0.3rem;
    padding: 3px;
    border-radius: 3px;
    font-size: 13px;
    /* 中央寄せ表示用 */
    display: inline-block;
    text-align: center;
}

/* 返答有のステータス */
.history-table .status-answered {
    background-color: var(--color-light-cardinal-red);
    color: var(--color-white);
}

/* 未回答のステータス */
.history-table .status-pending {
    background-color: var(--color-medium-gray);
    color: var(--color-white);
}

/* ステータス列を中央揃え */
.history-table td.status-cell {
    text-align: center;
}

/* チャット列を中央揃え */
.history-table td.chat-cell {
    text-align: center;
}

/* 送付履歴ページ */
.history {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box; /* パディングを含めて高さを計算 */
    padding: calc(var(--header-height) + 1.5rem) 1.5rem calc(var(--footer-height) + 2rem); /* ヘッダー・フッターと重ならないように調整 */
    min-height: calc(100vh - var(--header-height)); /* ヘッダー分の高さを引いた最低高さ */
}
.history-table {
    width: 100%;
    border-collapse: collapse;
    /* margin-top: 1rem; */
}
.history-table th,
.history-table td {
    border: 1px solid var(--color-table-border);
    padding: 0.5rem;
    /* 高解像度端末での閲覧を考慮してフォントをやや小さめに */
    font-size: 0.9rem;
}
.history-table .id-column {
    display: none;
}
.history-table th {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    cursor: default;
}
.history-table th.sortable {
    cursor: pointer;
}
.history-table tbody tr:nth-child(odd) {
    background-color: var(--color-white);
}
.history-table tbody tr:nth-child(even) {
    background-color: var(--color-even-row);
}

/* 送付先より小さめの資料名フォント */
.history-table .doc-name {
    font-size: 0.8rem;
    color: var(--color-charcoal-gray);
}

/* 削除済み資料表示用スタイル */
.deleted-document-label {
    color: #999;
    font-style: italic;
}

.chat-deleted-notice {
    margin: 0.5rem 0;
    color: #999;
    font-size: 0.9rem;
}

/* 会社名表示 */
.history-table .company-name {
    font-weight: bold;
    color: var(--color-charcoal-gray);
}

/* 送付先氏名表示 */
.history-table .recipient-name {
    color: var(--color-deep-green);
}

/* ページネーション */
.pagination {
    margin-top: 0.5rem;
    display: flex;
    justify-content: center;
    gap: 0.5rem;
}

.pagination button {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.6rem 1rem;
    font-size: 1.2rem;
    cursor: pointer;
}

/* 現在ページ/総ページ表示 */
.pagination .page-info {
    display: flex;
    align-items: center;
    font-size: 1.3rem;
    color: var(--color-dark-cardinal-red);
    padding: 0 0.5rem;
}

.pagination button:hover:not(:disabled) {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}

.pagination button.active {
    background-image: linear-gradient(to bottom right,
        var(--color-dark-cardinal-red), var(--color-cardinal-red));
}

.pagination button:disabled {
    opacity: 0.5;
    cursor: default;
}

/* 名刺登録ページ */
.card-register {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    /* ヘッダー分の高さを引いて中央に配置 */
    min-height: calc(85vh - 70px);
}
.select-area {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 0;
}
.file-area,
.camera-area {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

/* カメラスキャン画面の余白調整 */
.camera-area {
    /* ヘッダーとvideoの間に適度な余白を確保 */
    justify-content: flex-start;
    gap: 0.5rem;
    padding: 0.5rem 0 0;
    min-height: calc(90vh - 70px - 0.5rem);
}
.drop-zone {
    width: 70%;
    height: 370px;
    border: 2px dashed var(--color-light-cardinal-red);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-light-gray);
    color: var(--color-charcoal-gray);
    text-align: center;
}
.drop-zone.dragover {
    border-color: var(--color-cardinal-red);
    background-color: var(--color-pale-beige);
}
#video {
    /* 画面サイズに応じて可変 */
    width: 90%;
    height: 450px;
    max-height: calc(90vh - 120px - 0.5rem); /* ヘッダーとボタンに加え上余白を除外 */
    background: #000;
    object-fit: cover;
}

/* 資料閲覧ページ */
.viewer {
    padding: 0;
    height: calc(95vh - 70px);
    position: relative;
}
.doc-frame {
    width: 100%;
    height: 100%;
    border: none;
    display: block;
}

/* ビューアモーダル */
.viewer-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.8);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 1000;
}
.viewer-modal.open {
    display: flex;
}
.viewer-frame {
    width: 100%;
    height: 100%;
    border: none;
}
.pdf-viewer {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 1rem;
    overflow-y: auto;
    background-color: var(--color-white);
    flex: 1 1 auto;
}
.pdf-page-canvas {
    width: 100%;
    height: auto;
    display: block;
    margin: 0 auto 1.5rem;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    background-color: var(--color-white);
}
.pdf-viewer-message {
    text-align: center;
    color: var(--color-charcoal-gray);
    font-size: 1rem;
    padding-top: 2rem;
}
.modal-close {
    position: absolute;
    top: 60px;
    right: 10px;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 50%;
    background-color: var(--color-cardinal-red);
    color: var(--color-white);
    font-size: 1.5rem;
    cursor: pointer;
    z-index: 1001;
}

/* マスタ共通モーダル */
body.modal-open {
    overflow: hidden;
}

.category-register-modal,
.tag-modal,
.mail-template-modal,
.chat-template-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.45);
    /* 背景をぼかしてモーダル表示時の視認性を向上 */
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    z-index: 1200;
}

.category-register-modal.open,
.tag-modal.open,
.mail-template-modal.open,
.chat-template-modal.open {
    display: flex;
}

.category-register-modal__content,
.tag-modal__content,
.mail-template-modal__content,
.chat-template-modal__content {
    background-color: var(--color-white);
    border-radius: 5px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
    width: min(600px, calc(100vw - 2rem));
    max-height: min(82vh, 600px);
    overflow-y: auto;
    padding: 1rem 1.75rem 1.75rem;
    position: relative;
    display: flex;
    flex-direction: column;
}

.category-register-modal__title,
.tag-modal__title,
.mail-template-modal__title,
.chat-template-modal__title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 1.25rem;
    color: var(--color-light-cardinal-red);
    margin: 0 2.5rem 1.25rem 0;
}

.category-register-modal__close,
.tag-modal__close,
.mail-template-modal__close,
.chat-template-modal__close {
    position: absolute;
    top: 0.9rem;
    right: 1rem;
    width: 2.5rem;
    height: 2.5rem;
    border: none;
    border-radius: 50%;
    background-color: var(--color-cardinal-red);
    color: var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.category-register-modal__close:hover,
.tag-modal__close:hover,
.mail-template-modal__close:hover,
.chat-template-modal__close:hover {
    opacity: 0.85;
}

@media (max-width: 600px) {
    .category-register-modal__content,
    .tag-modal__content,
    .mail-template-modal__content,
    .chat-template-modal__content {
        width: calc(100vw - 1.5rem);
        padding: 0.85rem 1.25rem 1.5rem;
        max-height: min(90vh, 560px);
    }
    .category-register-modal__title,
    .tag-modal__title,
    .mail-template-modal__title,
    .chat-template-modal__title {
        font-size: 1.15rem;
        margin-right: 2rem;
    }
}

/* マスタ共通モーダル内のタイポグラフィと余白を微調整 */
.category-register-modal__content .register-form,
.tag-modal__content .register-form,
.mail-template-modal__content .register-form,
.chat-template-modal__content .register-form {
    gap: 0.75rem;
}

.category-register-modal__content .form-group,
.tag-modal__content .form-group,
.mail-template-modal__content .form-group,
.chat-template-modal__content .form-group {
    flex-direction: row;
    align-items: center;
    gap: 0.75rem;
}

.category-register-modal__content .form-group--image {
    align-items: flex-start;
}

.form-group__image-field {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex: 1;
}

.form-group__image-preview {
    display: none;
    max-width: 200px;
    border-radius: 4px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12);
}

.form-group__image-preview-wrapper {
    display: none;
    flex-direction: column;
    gap: 0.25rem;
}

.form-group__image-caption {
    font-size: 0.75rem;
    color: #666666;
}

.category-register-modal__content .form-group label,
.tag-modal__content .form-group label,
.mail-template-modal__content .form-group label,
.chat-template-modal__content .form-group label {
    font-size: 0.9rem;
    margin-bottom: 0;
    min-width: 6.5rem;
    max-width: 6.5rem;
    flex-shrink: 0;
}

.category-register-modal__content .form-group input,
.category-register-modal__content .form-group select,
.category-register-modal__content .form-group textarea,
.tag-modal__content .form-group input,
.tag-modal__content .form-group select,
.tag-modal__content .form-group textarea,
.mail-template-modal__content .form-group input,
.mail-template-modal__content .form-group select,
.mail-template-modal__content .form-group textarea,
.chat-template-modal__content .form-group input,
.chat-template-modal__content .form-group select,
.chat-template-modal__content .form-group textarea {
    flex: 1;
}

.category-register-modal__content .form-group--order-inline label,
.tag-modal__content .form-group--order-inline label,
.mail-template-modal__content .form-group--order-inline label,
.chat-template-modal__content .form-group--order-inline label {
    white-space: nowrap;
}

.category-register-modal__content .register-form input,
.category-register-modal__content .register-form select,
.category-register-modal__content .register-form textarea,
.tag-modal__content .register-form input,
.tag-modal__content .register-form select,
.tag-modal__content .register-form textarea,
.mail-template-modal__content .register-form input,
.mail-template-modal__content .register-form select,
.mail-template-modal__content .register-form textarea,
.chat-template-modal__content .register-form input,
.chat-template-modal__content .register-form select,
.chat-template-modal__content .register-form textarea {
    font-size: 0.9rem;
    padding: 0.65rem 0.7rem;
}

.category-register-modal__content .register-form select,
.tag-modal__content .register-form select,
.mail-template-modal__content .register-form select,
.chat-template-modal__content .register-form select {
    min-height: 2.5rem;
}

.category-register-modal__content .register-form textarea,
.tag-modal__content .register-form textarea,
.mail-template-modal__content .register-form textarea,
.chat-template-modal__content .register-form textarea {
    min-height: 4rem;
}

/* SweetAlert2がモーダルより前面に表示されるようにz-indexを調整 */
.swal2-container {
    z-index: 1400 !important;
}

.category-register-modal__content .register-submit-btn,
.tag-modal__content .register-submit-btn,
.mail-template-modal__content .register-submit-btn,
.chat-template-modal__content .register-submit-btn {
    font-size: 0.95rem;
    padding: 0.55rem 1.4rem;
    min-width: 7rem;
}

/* チャットページ */
.chat {
    padding: var(--header-height) 1rem var(--footer-height);
}

/* 資料名リンク表示エリア */
.chat-doc-link {
    /* text-align: center; */
    margin-bottom: 0.5rem;
}
.chat-doc-link a {
    color: var(--color-cardinal-red);
    text-decoration: underline;
}
.chat-messages {
    height: calc(95vh - 360px);
    overflow-y: auto;
    border: 1px solid var(--color-table-border);
    background-color: #f5f5f5d9;
    padding: 0.5rem;
}
.chat-input-area {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.5rem;
    align-items: stretch; /* 添付ボタンと送信ボタンをテキストエリアの高さに揃える */
}
/* テキストエリアとファイル名表示用ラッパー */
.chat-textarea-wrapper {
    position: relative;
    flex: 1;
}
/* 選択したファイル名と削除アイコンをテキストエリア内の右上に表示 */
.chat-file-info {
    position: absolute;
    top: 0.2rem;
    right: 0.5rem;
    display: none;
    align-items: center;
}

/* ファイル名表示 */
.chat-file-name {
    color: #008000;
    font-size: 0.8rem;
}

/* 添付削除用アイコン */
.chat-file-remove {
    margin-left: 0.3rem;
    color: #B1221A;
    font-size: 0.8rem;
    cursor: pointer;
}
.chat-template-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-top: 0.5rem;
}
/* 顧客回答ボタン */
.chat-template-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.3rem 0.6rem; /* 通常の高さを確保 */
    cursor: pointer;
}
.chat-template-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}
/* 送付内容確認画面ではコンパクトなボタンを使用 */
.template-preview .chat-template-btn {
    padding: 0.2rem 0.5rem;
    line-height: 1.2;
}
.chat-input {
    width: 100%;
    padding: 0.5rem;
    box-sizing: border-box; /* 余白込みで幅を計算しボタンと重ならないようにする */
    height: 4.5rem; /* 高さ固定 */
    overflow-y: auto; /* 内容が多い場合はスクロール */
    resize: none; /* 手動リサイズは無効化 */
    -ms-overflow-style: none; /* IE でのスクロールバー非表示 */
    scrollbar-width: none; /* Firefox でのスクロールバー非表示 */
}
/* 添付ファイル名表示と重ならないよう上部に余白を追加 */
.chat-input.has-file {
    padding-top: 1.5rem;
}
/* Chrome 等でのスクロールバー非表示 */
.chat-input::-webkit-scrollbar {
    display: none;
}
.chat-send-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0 1rem; /* 左右の余白のみ確保してアイコン位置を中央に保つ */
    cursor: pointer;
    display: flex; /* アイコンを中央に配置 */
    align-items: center;
    justify-content: center;
    height: 4.5rem; /* テキストエリアと同じ高さに統一 */
    flex-shrink: 0; /* ボタン幅が潰れないよう固定 */
}
.chat-send-btn i {
    font-size: 1.25rem; /* アイコンを少し大きく */
}
.chat-attach-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0 1rem; /* 左右の余白のみ設定して高さを固定 */
    cursor: pointer;
    display: flex; /* アイコンを中央に表示 */
    align-items: center;
    justify-content: center;
    height: 4.5rem; /* テキスト入力欄と高さを合わせる */
    flex-shrink: 0; /* 画面幅が狭い場合でも幅を維持 */
}
.chat-attach-btn i {
    font-size: 1.25rem;
}
.chat-send-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}
.chat-send-btn:disabled {
    background-image: none;
    background-color: #cccaca;
    color: var(--color-medium-gray);
    cursor: not-allowed;
    pointer-events: none;
}
.my-message {
    text-align: right;
    margin-bottom: 0.3rem;
}
.their-message {
    text-align: left;
    margin-bottom: 0.3rem;
}

/* メッセージ本文 */
.message-text {
    display: inline-block;
    padding: 0.2rem 0.4rem;
    /* 改行を表示するために必要 */
    white-space: pre-wrap;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0.3));
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.6);
    box-shadow: 0 8px 18px rgba(51, 51, 79, 0.18);
    text-align: left;
}

@supports (backdrop-filter: blur(1px)) {
    .message-text {
        backdrop-filter: blur(12px) saturate(140%);
        -webkit-backdrop-filter: blur(12px) saturate(140%);
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.75), rgba(255, 255, 255, 0.22));
    }
}
.message-file {
    color: var(--color-cardinal-red);
    text-decoration: underline;
}

/* 送信日時 */
.message-time {
    font-size: 0.7rem;
    color: var(--color-medium-gray);
    display: block;
    margin-bottom: 0.1rem;
}

/* ログインページ */
.login-container {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    min-height: 95vh;
}
/* ログインフォームを囲む白いボックス */
.login-box {
    background: var(--glass-bg-strong);
    width: 90%;
    max-width: 480px;
    padding: 0.5rem;
    border-radius: 24px;
    border: var(--glass-border);
    box-shadow: var(--glass-shadow-strong);
    display: flex;
    flex-direction: column;
    align-items: center;
}

@supports (backdrop-filter: blur(1px)) {
    .login-box {
        backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        -webkit-backdrop-filter: blur(var(--glass-blur-amount)) saturate(150%);
        background: linear-gradient(140deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.14));
    }
}
/* ログインページで使用するロゴ */
.login-page-logo {
    width: 250px;
    height: auto;
}
.login-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
    max-width: 400px;
}
.login-form input {
    padding: 0.75rem;
    font-size: 1rem;
    border: 1px solid var(--color-medium-gray);
    border-radius: 4px;
}
.login-submit-btn {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.5rem 1rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 15px; /* フォントサイズをやや大きく */
    height: 50px; /* 縦幅を広げる */
    width: 8rem; /* ボタン幅を短く */
    align-self: center; /* 中央寄せ */
}
.login-submit-btn:hover {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-cardinal-red));
}
.login-message {
    text-align: center;
    margin-top: 0.5rem;
}


/* 資料カテゴリマスタページ */
.category-master {
    /* ヘッダーとフッターの重なりを防ぐ */
    padding: var(--header-height) 1rem var(--footer-height);
}
.category-master-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1rem;
}
.category-master-table th,
.category-master-table td {
    border: 1px solid var(--color-table-border);
    padding: 0.5rem;
    font-size: 0.9rem;
}
.category-master-table th {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    cursor: default;
}
.category-master-table tbody tr:nth-child(odd) {
    background-color: var(--color-white);
}
.category-master-table tbody tr:nth-child(even) {
    background-color: var(--color-even-row);
}
.category-master-table td.edit-cell {
    text-align: center;
}

/* タグマスタページ */
.tag-master {
    /* ヘッダーとフッターの重なりを防ぐため上下のみ高さ分を確保 */
    padding: var(--header-height) 1rem var(--footer-height);
}
.tag-master-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1rem;
}
.tag-master-table th,
.tag-master-table td {
    border: 1px solid var(--color-table-border);
    padding: 0.5rem;
    font-size: 0.9rem;
}
.tag-master-table th {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    cursor: default;
}
.tag-master-table tbody tr:nth-child(odd) {
    background-color: var(--color-white);
}
.tag-master-table tbody tr:nth-child(even) {
    background-color: var(--color-even-row);
}
.tag-master-table td.edit-cell {
    text-align: center;
}
/* 表示順とタグ名の列幅調整 */
.tag-master-table th:nth-child(2),
.tag-master-table td:nth-child(2) {
    width: 80px; /* 表示順をやや狭く */
}
.tag-master-table th:nth-child(4),
.tag-master-table td:nth-child(4) {
    width: 200px; /* タグ名を広めに */
}

/* 資料マスタの列幅調整 */
.doc-master-table th:nth-child(2),
.doc-master-table td:nth-child(2) {
    width: 300px; /* タイトルを広めに */
}
.doc-master-table th:nth-child(3),
.doc-master-table td:nth-child(3) {
    width: 100px; /* ファイル種別をやや狭く */
}

/* 管理者権限ページ */
.admin-authority {
    /* ヘッダーとフッターが重ならないよう上下のみ高さ分を確保 */
    padding: var(--header-height) 1rem var(--footer-height);
}
.admin-authority-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1rem;
}
.admin-authority-table th,
.admin-authority-table td {
    border: 1px solid var(--color-table-border);
    padding: 0.5rem;
    font-size: 0.9rem;
}
.admin-authority-table th {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    cursor: default;
}
.admin-authority-table tbody tr:nth-child(odd) {
    background-color: var(--color-white);
}
.admin-authority-table tbody tr:nth-child(even) {
    background-color: var(--color-even-row);
}
.admin-authority-table td.edit-cell {
    text-align: center;
}

/* 環境変数テーブル */
#env-table th,
#env-table td {
    width: 45%;
}
#env-table th:last-child,
#env-table td:last-child {
    width: 10%;
    text-align: center;
}

/* 送付内容確認ページ */
.confirm {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
    padding: var(--header-height, 45px) 1rem var(--footer-height, 70px);
}
.confirm-left,
.confirm-right {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.confirm-section {
    margin-bottom: 1rem;
    display: flex;
    flex-direction: column;
}
/* 送付内容確認画面では余白をgapで調整 */
.confirm .confirm-section {
    margin-bottom: 0;
}
.confirm-right {
    align-self: flex-start;
}

/* 右カラム内のボタンは自然な位置で配置し、幅いっぱいに表示 */
.confirm-right .contact-send-btn {
    width: 100%;
}

/* 送付先一覧エリアは残り高さに合わせてスクロール */
.send-right .confirm-section:nth-of-type(2) {
    flex-grow: 1;
    min-height: 0;
}

/* 資料・送付先の見出し余白調整 */
.confirm-section h2 {
    margin: 0;
    margin-bottom: 0.5rem;
    font-size: 1.1rem;
}
.confirm-count {
    font-size: 1rem;
    color: #a42923;
}
.confirm-contact-list,
.contact-list {
    list-style: none;
    padding: 0;
    margin: 0;
    border: var(--glass-border);
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0.16));
    max-height: 19vh;
    overflow-y: auto;
    scrollbar-width: thin;
}
.confirm-contact-list li {
    padding: 0.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.28);
}
.confirm-contact-list li:last-child {
    border-bottom: none;
}

@supports (backdrop-filter: blur(1px)) {
    .confirm-contact-list,
    .contact-list {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.52), rgba(255, 255, 255, 0.12));
    }
}

/* 顧客回答内容選択エリア */
.confirm-template-row {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-bottom: 0.5rem;
}

.confirm-template-row select {
    padding: 0.5rem;
    font-size: 1rem;
    border: 1px solid var(--color-medium-gray);
    border-radius: 4px;
}

/* 顧客回答ボタン表示領域 */
.template-preview {
    border: var(--glass-border);
    border-radius: 10px;
    padding: 0.6rem; /* 余白を縮小 */
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0.18));
    min-height: 2.5rem; /* ボタンが詰まり過ぎない最低高さ */
    overflow-y: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

@supports (backdrop-filter: blur(1px)) {
    .template-preview {
        backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        -webkit-backdrop-filter: blur(calc(var(--glass-blur-amount) - 6px)) saturate(150%);
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.12));
    }
}

/* 左カラム内のスクロール領域制御 */
.confirm-left .confirm-section {
    flex: 1 1 auto;
    min-height: 0;
}
#no-docs {
    margin: 0 0 0.5rem;
}
/* 送付確認画面の資料表示 */
.confirm-doc-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    scrollbar-width: thin;
    align-items: flex-start; /* カードを縦方向に引き伸ばさない */
    align-content: flex-start; /* 余白ができても上詰めで表示 */
}

/* 送付内容確認画面の資料アイコンサイズ調整 */
.confirm .document-item {
    flex: 0 0 150px;
    padding: 0.5rem;
    height: 230px; /* カード高さを固定 */
    display: flex;
    flex-direction: column;
    align-items: center;
}
.confirm .pdf-canvas,
.confirm .doc-icon {
    width: 150px;
    height: 106px;
}
.confirm .document-title {
    flex: 1 1 auto;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.confirm .document-download-button {
    margin-top: auto;
    width: 100%;
}
.confirm .doc-icon {
    font-size: 3rem;
}
.confirm .select-circle {
    width: 20px;
    height: 20px;
    font-size: 0.7rem;
}

/* 送付内容確認画面では戻るボタンを画面下に配置 */
.confirm .back-button {
    position: static;
    left: auto;
    bottom: auto;
    transform: none;
    margin: 1rem auto 0;
    display: flex;
}

@media (max-width: 1024px) {
    .confirm {
        flex-direction: column;
    }
    .confirm-left,
    .confirm-right {
        max-width: 100%;
    }
}

/* 登録・編集画面では戻るボタンをフォーム下に配置 */
.register .back-button {
    position: static;
    left: auto;
    bottom: auto;
    transform: none;
    margin: 1rem auto 0;
    display: flex;
}

/* ビューアページ */
.viewer-page {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    padding: 0;
    position: relative;
}
.viewer-page .viewer-frame {
    flex: 1;
    width: 100%;
}
.viewer-page.missing {
    justify-content: center;
    align-items: center;
    background-color: var(--color-light-gray);
    padding: 2rem;
    text-align: center;
}
.viewer-missing[hidden] {
    display: none !important;
}

.viewer-missing {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    max-width: 420px;
    margin: 0 auto;
    padding: 1.5rem;
    border-radius: 8px;
    background-color: var(--color-white);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    color: var(--color-charcoal-gray);
}
.viewer-missing-title {
    font-size: 1.2rem;
    font-weight: bold;
    margin: 0;
    color: var(--color-cardinal-red);
}
.viewer-missing-text {
    margin: 0;
    line-height: 1.6;
}
.viewer-missing-contact[hidden] {
    display: none !important;
}
.viewer-missing-contact {
    text-align: left;
    border-top: 1px solid var(--color-light-gray);
    padding-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.viewer-missing-contact-title {
    font-weight: bold;
    margin: 0;
    color: var(--color-charcoal-gray);
}
.viewer-missing-detail-list {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.viewer-missing-detail-row {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 0.5rem;
    align-items: start;
}
.viewer-missing-detail-row dt {
    font-weight: bold;
    color: var(--color-cardinal-red);
}
.viewer-missing-detail-row dd {
    margin: 0;
    word-break: break-word;
}
.doc-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem;
}
.download-btn {
    /* ダウンロードボタンは視認性を高めるため緑色で表示 */
    background-color: #28a745;
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.4rem 0.8rem;
    text-decoration: none;
}
.download-btn:hover {
    opacity: 0.8;
}

/* 非 PDF 時はヘッダーを画面中央に表示 */
.viewer-page.non-pdf .doc-header {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}

/* 定型文案内とボタンをまとめるコンテナ */
.response-section {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding-bottom: 0.5rem;
}

/* 定型文の案内文 */
.response-note {
    text-align: center;
    margin: 0;
    color: var(--color-select-green);
}

/* レスポンスボタンはページ下部に配置 */
.response-buttons {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
}
.response-buttons button {
    background-image: linear-gradient(to bottom right,
        var(--color-light-cardinal-red), var(--color-dark-cardinal-red));
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    padding: 0.4rem 0.8rem;
    cursor: pointer;
}
.response-buttons button:disabled {
    background-image: none;
    background-color: var(--color-medium-gray);
    color: var(--color-white);
    cursor: not-allowed;
    opacity: 0.7;
}
.response-buttons button:hover {
    opacity: 0.8;
}

/* 回答をやり直すボタン */
.response-reset-btn {
    background-color: var(--color-white);
    color: var(--color-dark-cardinal-red);
    border: 1px solid var(--color-dark-cardinal-red);
    border-radius: 4px;
    padding: 0.35rem 0.9rem;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.response-reset-btn:hover {
    background-color: var(--color-dark-cardinal-red);
    color: var(--color-white);
}

/* 画面の縦幅が小さいデバイス向けのトップ画面圧縮 */
@media (max-height: 860px) {
    body.home-page .dashboard {
        gap: 1.5rem;
        margin: 35px 5px 70px 5px;
    }
    body.home-page .panel {
        height: 150px;
    }
    body.home-page .panel-compact {
        height: 80px;
    }
    /* body.home-page .panel-icon {
        font-size: 2.3rem;
    } */
}

/* 画面高さが820px以下の場合の調整 */
@media (max-height: 820px) {
    .followup-section {
        max-height: 235px; /* 画面が低い場合はフォローアップリストも縮小 */
    }
}

/* 画面高さが820px以下の資料登録ページの調整 */
@media (max-height: 820px) {
    /* .register {
        padding: 0.5rem;
    } */
    .register-form {
        gap: 0.5rem;
    }
    .register-form input,
    .register-form select,
    .register-form textarea {
        padding: 0.5rem;
    }
    .register-submit-btn {
        padding: 0.4rem 0.8rem;
    }
}

/* 画面高さが820px以下の送付履歴ページの調整 */
@media (max-height: 820px) {
    .history {
        padding: calc(var(--header-height) + 0.5rem) 0.5rem calc(var(--footer-height) + 1rem);
    }
    .history-table th,
    .history-table td {
        padding: 0.25rem;
        font-size: 0.8rem;
    }
    .pagination button {
        padding: 0.4rem 0.8rem;
    }
}

@media (max-height: 720px) {
    body.home-page .stats-dashboard,
    body.home-page .followup-dashboard {
        padding: 0.45rem;
    }
    body.home-page .stat-card {
        padding: 0.55rem;
    }
    body.home-page .stat-card .value {
        font-size: 1.3rem;
    }
    body.home-page .followup-section {
        max-height: 200px;
    }
    body.home-page .menu-row {
        gap: 1rem;
    }
    body.home-page .panel {
        height: 132px;
    }
    body.home-page .panel-compact {
        height: 80px;
    }
}
